我正在将方程转换为 C++。这对于运行标准偏差是否正确。
this->runningStandardDeviation = (this->sumOfProcessedSquaredSamples - sumSquaredDividedBySampleCount) / (sampleCount - 1);
这是完整的功能:
void BM_Functions::standardDeviationForRunningSamples (float samples [], int sampleCount)
{
    // update the running process samples count
    this->totalSamplesProcessed += sampleCount;
    // get the mean of the samples
    double mean = meanForSamples(samples, sampleCount);
    // sum the deviations
   // sum the squared deviations
   for (int i = 0; i < sampleCount; i++)
   {
        // update the deviation sum of processed samples
        double deviation = samples[i] - mean;
        this->sumOfProcessedSamples += deviation;
        // update the squared deviations sum
        double deviationSquared = deviation * deviation;
        this->sumOfProcessedSquaredSamples += deviationSquared;
    }
    // get the sum squared
    double sumSquared = this->sumOfProcessedSamples * this->sumOfProcessedSamples;
    // get the sum/N
    double sumSquaredDividedBySampleCount = sumSquared / this->totalSamplesProcessed;
    this->runningStandardDeviation = sqrt((this->sumOfProcessedSquaredSamples -     sumSquaredDividedBySampleCount) / (sampleCount - 1));
}