// see Hv_quadSynth_AudioLib.Parameter for definitions
    public float GetFloatParameter(Hv_quadSynth_AudioLib.Parameter param)
    {
        switch (param)
        {
        case Parameter.Freqcutoff: return(freqCutoff);

        case Parameter.Gain: return(gain);

        case Parameter.Oscnote: return(oscNote);

        case Parameter.Ringmodfreq: return(ringModFreq);

        case Parameter.Ringmodmultiplier: return(ringModMultiplier);

        case Parameter.Sawmult: return(sawMult);

        case Parameter.Sawoffset: return(sawOffset);

        case Parameter.Sinmult: return(sinMult);

        case Parameter.Sinoffset: return(sinOffset);

        case Parameter.Sqrmult: return(sqrMult);

        case Parameter.Sqroffset: return(sqrOffset);

        case Parameter.Trimult: return(triMult);

        case Parameter.Trioffset: return(triOffset);

        default: return(0.0f);
        }
    }
    public void SetFloatParameter(Hv_quadSynth_AudioLib.Parameter param, float x)
    {
        switch (param)
        {
        case Parameter.Freqcutoff: {
            x          = Mathf.Clamp(x, 0.0f, 20000.0f);
            freqCutoff = x;
            break;
        }

        case Parameter.Gain: {
            x    = Mathf.Clamp(x, 0.0f, 1.0f);
            gain = x;
            break;
        }

        case Parameter.Oscnote: {
            x       = Mathf.Clamp(x, 0.0f, 127.0f);
            oscNote = x;
            break;
        }

        case Parameter.Ringmodfreq: {
            x           = Mathf.Clamp(x, 0.0f, 20000.0f);
            ringModFreq = x;
            break;
        }

        case Parameter.Ringmodmultiplier: {
            x = Mathf.Clamp(x, 0.0f, 1.0f);
            ringModMultiplier = x;
            break;
        }

        case Parameter.Sawmult: {
            x       = Mathf.Clamp(x, 0.0f, 1.0f);
            sawMult = x;
            break;
        }

        case Parameter.Sawoffset: {
            x         = Mathf.Clamp(x, -24.0f, 24.0f);
            sawOffset = x;
            break;
        }

        case Parameter.Sinmult: {
            x       = Mathf.Clamp(x, 0.0f, 1.0f);
            sinMult = x;
            break;
        }

        case Parameter.Sinoffset: {
            x         = Mathf.Clamp(x, -24.0f, 24.0f);
            sinOffset = x;
            break;
        }

        case Parameter.Sqrmult: {
            x       = Mathf.Clamp(x, 0.0f, 1.0f);
            sqrMult = x;
            break;
        }

        case Parameter.Sqroffset: {
            x         = Mathf.Clamp(x, -24.0f, 24.0f);
            sqrOffset = x;
            break;
        }

        case Parameter.Trimult: {
            x       = Mathf.Clamp(x, 0.0f, 1.0f);
            triMult = x;
            break;
        }

        case Parameter.Trioffset: {
            x         = Mathf.Clamp(x, -24.0f, 24.0f);
            triOffset = x;
            break;
        }

        default: return;
        }
        if (IsInstantiated())
        {
            _context.SendFloatToReceiver((uint)param, x);
        }
    }