奈奎斯特频率限制 - 如何仅混合低于Nyqvist极限

时间:2016-03-24 23:21:36

标签: c++ audio signal-processing synthesis

我正在使用getSampleRate()辅助函数来计算奈奎斯特限制并将其分配给临时局部变量。

我现在必须更新将谐波混合在一起的类的部分,以便只有频率低于奈奎斯特极限的谐波包含在混音中。据说getFrequency()会找出它设置的频率,但之后我仍然不确定如何只包括那些频率。也许是if语句。

class SawWave
{
public:
void reset()
{

    for(int i=0; i<MAX_HARMONICS; i++)
    {
        harmonic[i].reset();

    }
}

void setFrequency(float frequency){

    for(int i=0; i < MAX_HARMONICS; i++)
    {
        harmonic[i].setFrequency(frequency * (i + 1));
    }
}

float tick()
{
    float nyquist = getSampleRate() * 0.5;   
    float sum = 0;
    int count;


    for (count = 0; count < MAX_HARMONICS; count++)
    {
        sum += (harmonic[count].tick()) * 1 / (count + 1);
    }
    return sum;
}

protected:

Sine harmonic[MAX_HARMONICS];
};

1 个答案:

答案 0 :(得分:2)

由于您提到您可以使用Sine::getFrequency()访问各个谐波的频率,因此您只需将它们从sum中累积的生成信号中排除:

for (count = 0; count < MAX_HARMONICS; count++)
{
    if (harmonic[count].getFrequency() < nyquist)
    {
        sum += (harmonic[count].tick()) * 1 / (count + 1);
    }
}

请注意,一旦找到一个不小于nyquist的谐波,您也可以停止产生更多谐波,因为您按频率增加的顺序存储谐波:

for (count = 0; count < MAX_HARMONICS; count++)
{
    if (harmonic[count].getFrequency() < nyquist)
    {
        sum += (harmonic[count].tick()) * 1 / (count + 1);
    }
    else
    {
        break;
    }
}