Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
61 / 186 / 31
Регистрация: 14.02.2013
Сообщений: 1,695

Формат представления чисел с плавающей запятой

09.06.2023, 22:00. Показов 709. Ответов 13
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Передаю число с плавающей запятой через COM на МК 0,0043 но в итоге получаю на самом МК число 1979120896,0.

Целы числа передаются как надо без проблем как отрицательные так и положительные НО почему происходит затык с числами с плавающей запятой?
Догадываюсь что форматы представлений чисел с плавающей запятой у компиляторов разные.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
09.06.2023, 22:00
Ответы с готовыми решениями:

Сравнение чисел с плавающей запятой с точностью
Добрый день. Стоит задача сравнить частное двух чисел с числом Pi. Но максимальное значение которому равно частное в диапазоне от 0-100000...

Хранение чисел с плавающей запятой в памяти
Здравствуйте. Скорее, вопрос не по теме, просто не знаю, куда задать вопрос. Вопрос связан с хранение чисел с плавающей запятой. Ответьте...

Перевод двоичных чисел в формат плавающей запятой в нормальной форме одинарной точности
Доброе время суток,объясните как переводить числа двоичной системы в формат плавающей запятой в нормальной форму одинарной точности.Пытался...

13
Эксперт JavaЭксперт по электроникеЭксперт .NET
 Аватар для wizard41
3403 / 2725 / 574
Регистрация: 04.09.2018
Сообщений: 8,560
Записей в блоге: 3
09.06.2023, 22:13
Цитата Сообщение от VladimirU Посмотреть сообщение
НО почему происходит затык с числами с плавающей запятой?
Потому что надо сперва понимать как передаются сообщения вообще. У дробного числа есть мантисса и экспонента, а COM порт передает посылки побайтово. Принимающая сторона должна их корректно распознать и сцепить.
0
61 / 186 / 31
Регистрация: 14.02.2013
Сообщений: 1,695
09.06.2023, 22:25  [ТС]
wizard41, конвертировал в HEX и сравнивал числа совершенно разные.
0
Эксперт JavaЭксперт по электроникеЭксперт .NET
 Аватар для wizard41
3403 / 2725 / 574
Регистрация: 04.09.2018
Сообщений: 8,560
Записей в блоге: 3
09.06.2023, 22:29
VladimirU, прокрути в голове еще раза три то, что я сказал.
0
61 / 186 / 31
Регистрация: 14.02.2013
Сообщений: 1,695
09.06.2023, 22:31  [ТС]
Отправляю вот таким способом
C++
1
_serialPort.Write(BitConverter.GetBytes(0.0043), 0, 4);
на стороне МК получаю вот такое HEX 0X75F6FD22 но если это формат IEEE 754 то на стороне МК я должен увидеть вот такое число 0X3B8CE704
0
Эксперт JavaЭксперт по электроникеЭксперт .NET
 Аватар для wizard41
3403 / 2725 / 574
Регистрация: 04.09.2018
Сообщений: 8,560
Записей в блоге: 3
09.06.2023, 22:34
VladimirU, ну все правильно. А С++ тут при чем?
Цитата Сообщение от VladimirU Посмотреть сообщение
то на стороне МК я должен увидеть
А кто его знает, как на стороне МК организовано считывание?
0
Эксперт .NET
 Аватар для Rius
13112 / 7673 / 1674
Регистрация: 25.05.2015
Сообщений: 23,390
Записей в блоге: 14
09.06.2023, 22:41
Лучший ответ Сообщение было отмечено VladimirU как решение

Решение

VladimirU,
Можно передать число как строку и на той стороне распарсить строку обратно в число.
Либо передавать в виде массива байтов. И опять же потом собирать.

Добавлено через 2 минуты
на стороне МК получаю вот такое HEX 0X75F6FD22
Суффикса f нету, поэтому там байты не от float, а от double.
Вы посмотреть данные отправляемого массива до отправки никак не догадались?

Добавлено через 3 минуты
0.0043 == 0x3F719CE075F6FD22
1
61 / 186 / 31
Регистрация: 14.02.2013
Сообщений: 1,695
09.06.2023, 22:51  [ТС]
Rius, всё спасибо понял я лишь отправлял часть мантисы.

Добавлено через 6 минут
Решил просто
C++
1
_serialPort.Write(BitConverter.GetBytes((float)0.0043), 0, 4);
0
Эксперт .NET
 Аватар для Rius
13112 / 7673 / 1674
Регистрация: 25.05.2015
Сообщений: 23,390
Записей в блоге: 14
09.06.2023, 22:52
C#
1
0.0043f
Вот так решается.
0
61 / 186 / 31
Регистрация: 14.02.2013
Сообщений: 1,695
09.06.2023, 23:14  [ТС]
На стороне МК что бы HEX преобразовать в float по IEEE нужно воспользоваться союзом union. Я так понимаю это не стандарт языка Си, а способность компилятора.
0
Эксперт .NET
 Аватар для Rius
13112 / 7673 / 1674
Регистрация: 25.05.2015
Сообщений: 23,390
Записей в блоге: 14
10.06.2023, 06:56
На стороне МК нет hex. Там есть байты.

Не только union.

Почему битовые операции нельзя применять к переменной с плавающей точкой?
Как получить из двух byte один int?
0
61 / 186 / 31
Регистрация: 14.02.2013
Сообщений: 1,695
10.06.2023, 21:27  [ТС]
Rius, Почему битовые операции нельзя применять к переменной с плавающей точкой?

Потому что переменные с плавающей точкой формируются по IEEE 754 это не прямой бинарный счёт целых чисел. Даже читать не стал.
0
 Аватар для roach1967
983 / 463 / 233
Регистрация: 27.06.2014
Сообщений: 1,033
13.06.2023, 01:46
VladimirU, отправляйте число в текстовом виде, а на стороне МК обратно преобразовывайте.
P.S. С STM32 делал так - отправляемое значение (по логике работы программы) не превышало 2100. Поэтому умножал необходимое значение на 1000000 и целую часть числа в виде int32_t отправлял в контроллер, где уже обратно делил на 1000000. Таким образом передавал с точность 6-ть знаков после запятой
0
61 / 186 / 31
Регистрация: 14.02.2013
Сообщений: 1,695
13.06.2023, 08:18  [ТС]
roach1967, уже решил без форматирования в текст. Все проще.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
13.06.2023, 08:18
Помогаю со студенческими работами здесь

Представления числа с плавающей запятой в двоичном коде
Есть программа при вводе данных к примеру: 740,94 выводит значение: 740,940002441406. Мне сказали что число меняется из-за...

Преобразовать целое число в формат с плавающей запятой
С помощью какой команды (или набором команд) сопроцессора можно представить обычное число как число с плавающей точкой например просто...

Особенности представления чисел с плавающей точкой
$n = 5.148\0.198; print $n; // =26 print floor($n); // =25 PHP бист швайсэ!!! З.Ы. php 5.3.3 - 5.3.10

Нормализация чисел с плавающей запятой
Здравствуйте. Пишу макросы для автоматической проверки лабораторных работ. Столкнулась с проблемой: не могу реализовать перевод чисел в...

Сравнение чисел с плавающей запятой
Сравнение чисел с плавающей запятой. В этой теме я попробую "просто" объяснить новичкам в программировании что есть тип double...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru