Функция написана с учетом определенного диапазона входных данных.Если ожидание этих входных данных не выполнено, выдается предупреждение:
#include <stdio.h>
#define COUNT_OF(x) (sizeof(x)/sizeof(0[(x)]))
void computeGold( float* reference, float* idata, const unsigned int len)
{
double total_sum = 0;
unsigned int i;
reference[0] = 0;
for( i = 1; i < len; ++i)
{
total_sum += idata[i-1];
reference[i] = idata[i-1] + reference[i-1];
}
// Here it should be okay to use != because we have integer values
// in a range where float can be exactly represented
if (total_sum != reference[i-1])
printf("Warning: exceeding single-precision accuracy. Scan will be inaccurate.\n");
}
//(C) Nvidia Corp
float data[] = {
1.0,
2.0,
3.0,
4.0,
5.0
};
float data2[] = {
123456.0,
999999.0,
999999.0,
999999.0,
999999.0,
999999.0,
999999.0,
999999.0,
999999.0,
999999.0,
999999.0,
999999.0,
999999.0,
999999.0,
999999.0,
999999.0,
999999.0,
999999.0,
123456.0
};
float ref[COUNT_OF(data2)] = {0.0};
int main()
{
computeGold( ref, data, COUNT_OF(data));
computeGold( ref, data2, COUNT_OF(data2));
return 0;
}