Отливать поплавок в Int с постоянными результатами по платформам/компиляторам/Аркам ЦПC++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 Отливать поплавок в Int с постоянными результатами по платформам/компиляторам/Аркам ЦП

Сообщение Anonymous »

Я написал программу, чтобы сделать некоторую катуляцию с плаванием и поддать результат Int; Когда я отправляю задание в кластер несколько раз, я получил другой результат, даже когда я предоставил те же параметры; < /p>
// compiled with gcc8.3, centos
float* x = ....;
float* y = ....;
// simply use [+ * - /] to caculate cos simlilarity
float similarity = cos_similiarity(x, y, dim);
similarity = similarity * 100;
int result = std::round(similarity);

< /code>
Я отбрасываю поплавок (диапазон 0 - 1) в int (с множителем 100); Иногда я получаю нестабильный результат, например, 50 и 49; Я предполагаю, что поплавок представил результат функции cos_sim, может быть, 49.50 ... 01 и 49.499 ... 9 При запуске на разных машинах, так что круглую функцию подходит к разным int;
, и у меня есть следующее вопрос: < /p>

[*] Я предполагаю, верно? Тот же двоичный (код ASM) может иметь разные результаты математики, работающие на разных версиях Machines/Platers/Libc ..?
Если да, то как сделать мой результат согласованным? Br /> < /ol>

Подробнее здесь: https://stackoverflow.com/questions/794 ... -cpu-archs
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C++»