qSin() дает неправильные значения греха?

У меня есть код:

for(int i = 0; i < 314; i++){
    float nextSine = aSin(i/5);
    qDebug() << "i: "<<QString::number(i)<<" sin(i/5) = nextSine: "<<nextSine;
}

И вот пример результатов, которые я получаю:

i:  "303"  sin(i/5) = nextSine:  -0.304811
i:  "304"  sin(i/5) = nextSine:  -0.304811
i:  "305"  sin(i/5) = nextSine:  -0.966118
i:  "306"  sin(i/5) = nextSine:  -0.966118

Иногда это правильно, но иногда неправильно, например, когда i==303

2 ответа

Решение

Вы, вероятно, хотите привести в плавающее состояние перед запуском функции:

float nextSine = aSin((float)i/5.0);

У вас есть эти проблемы, продолжающиеся здесь:

1) Вы пытаетесь разделить целое число на 5, что может привести к потере точности, если целое число не делится на 5. Например, 313/5=62, а не 62,6 в вашем случае, но это только один из примеров. Решение состоит в том, чтобы использовать float явно.

2) У вас есть ненужная переменная nextSine. Вы можете просто устранить это здесь.

3) В вашем коде есть синтаксическая ошибка, так как вы имели в виду **q**Sin, а не aSin.

4) Удостоверьтесь, что вы выполняете свою функцию как можно более эффективно.

5) Вы пытаетесь использовать явное пространство для печати, но qDebug уже управляет этим для вас, так что в итоге вы получите два вместо намеченного.

Итак, вот что я бы лично написал:

for (int i = 0; i < 314; ++i)
     qDebug() << "i:" <<QString::number(i)
              << " sin(i/5) = nextSine:" << qSin(static_cast<float>(i)/5);

или же

for (int i = 0; i < 314; ++i)
     qDebug() << "i:" <<QString::number(i)
              << " sin(i/5.0) = nextSine:" << qSin(i/5.0);

или же

for (float f = 0; f < 314.0; f+=1.0)
     qDebug() << "i:" <<QString::number(f, 'f')
              << " sin(f/5) = nextSine:" << qSin(f/5);
Другие вопросы по тегам