|
STM32F429: ошибка преобразования uint32_t в float |
|
|
|
Feb 3 2016, 13:16
|
Участник

Группа: Участник
Сообщений: 69
Регистрация: 23-10-08
Пользователь №: 41 128

|
Добрый день,
STM32F429, Keil 5.16a
Возникла проблема при преобразовании uint32_t в float:
float * value; uint32_t val = 0xFFFFFFFF;
*value = *(float*)&val;
В результате в *value -1.#QNAN. Что я делаю не так?
В тоже время float a = 0xFFFFFFFF; приводит к значениюю 4.2949673e+009 в переменной а.
Алексей.
Сообщение отредактировал Алексей ВМ - Feb 3 2016, 13:17
|
|
|
|
|
Feb 3 2016, 13:20
|
Знающий
   
Группа: Свой
Сообщений: 771
Регистрация: 16-07-07
Из: Волгодонск
Пользователь №: 29 153

|
Это смотря чего вы хотите добиться. Преобразование чисел делается так Код float * value; uint32_t val = 0xFFFFFFFF;
*value = val; Вы же берете sizeof(float) байт по адресу &val и копируете их по адресу value. ЗЫ На всякий случай - 4-байтный float число 0xffffffff точно сохранить не сможет, точность будет примерно 7 знаков ~4.2949672*10^9
|
|
|
|
|
Feb 3 2016, 13:27
|
Участник

Группа: Участник
Сообщений: 69
Регистрация: 23-10-08
Пользователь №: 41 128

|
Цитата(Непомнящий Евгений @ Feb 3 2016, 16:20)  Это смотря чего вы хотите добиться. Преобразование чисел делается так Код float * value; uint32_t val = 0xFFFFFFFF;
*value = val; Вы же берете sizeof(float) байт по адресу &val и копируете их по адресу value Мне надо записать и прочитать float в еепром. Есть функция uint8_t EEPROM_Read(uint32_t Addr, uint8_t * buf, uint32_t count); которая читает в uint8_t буфер байты. Если еепром чистая, то в буфере будут все 0xFF. Функция, которая читает float, выглядит так Код uint8_t EEPROM_read_float(uint32_t Addr, float * value) { uint32_t val; uint8_t ret; ret = EEPROM_Read(Addr, (uint8_t*)&val, 4); *value = *(float*)&val;
return ret; } Вот она и глючит.
Сообщение отредактировал Алексей ВМ - Feb 3 2016, 13:29
|
|
|
|
|
Feb 3 2016, 13:29
|
Знающий
   
Группа: Свой
Сообщений: 771
Регистрация: 16-07-07
Из: Волгодонск
Пользователь №: 29 153

|
Цитата(Алексей ВМ @ Feb 3 2016, 16:27)  Код uint8_t EEPROM_read_float(uint32_t Addr, float * value) { return EEPROM_Read(Addr, (uint8_t*)&value, 4); } Вот она и глючит. Это не она глючит
|
|
|
|
|
Feb 3 2016, 13:31
|
Участник

Группа: Участник
Сообщений: 69
Регистрация: 23-10-08
Пользователь №: 41 128

|
Цитата(Непомнящий Евгений @ Feb 3 2016, 16:29)  Это не она глючит  ок, не она. А что (кто)?
|
|
|
|
|
Feb 3 2016, 13:39
|
Знающий
   
Группа: Свой
Сообщений: 771
Регистрация: 16-07-07
Из: Волгодонск
Пользователь №: 29 153

|
Цитата(scifi @ Feb 3 2016, 16:35)  ЕМНИП, float, в котором все байты 0xFF, - это неправильный float. Вот оно и ругается. Не все возможные коды допустимы для float. он не ругается, он говорит, что это NaN - Not a number. Это допустимое значение для float... Вот тут можно поклацать и посмотреть http://www.h-schmidt.net/FloatConverter/IEEE754.html
|
|
|
|
|
Feb 3 2016, 13:41
|
Участник

Группа: Участник
Сообщений: 69
Регистрация: 23-10-08
Пользователь №: 41 128

|
Цитата(scifi @ Feb 3 2016, 16:35)  ЕМНИП, float, в котором все байты 0xFF, - это неправильный float. Вот оно и ругается. Не все возможные коды допустимы для float. float a = 0xFFFFFFFF; приводит к значению 4.2949673e+009 в переменной а. Цитата(Непомнящий Евгений @ Feb 3 2016, 16:33)  У вас проблема в чем? Или то, что чистая eeprom дает вам NAN? Именно. Причем для приведенного выше примера с присвоением в переменной число.
|
|
|
|
|
Feb 3 2016, 13:44
|
Знающий
   
Группа: Свой
Сообщений: 771
Регистрация: 16-07-07
Из: Волгодонск
Пользователь №: 29 153

|
Цитата(Алексей ВМ @ Feb 3 2016, 16:41)  float a = 0xFFFFFFFF; приводит к значению 4.2949673e+009 в переменной а. И что? Это же преобразование чисел по правилам арифметики, а не интерпретация 4-х байт как float Цитата Именно. Причем для приведенного выше примера с присвоением в переменной число. Код uint8_t EEPROM_read_float(uint32_t Addr, float * value) { ret = EEPROM_Read(Addr, (uint8_t*)&value, 4); if (*value != *value) // NaN != NaN *value = 0; // или что вы хотите по умолчанию? return ret; }
|
|
|
|
|
Feb 3 2016, 13:45
|
Гуру
     
Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136

|
Цитата(Алексей ВМ @ Feb 3 2016, 16:41)  float a = 0xFFFFFFFF; приводит к значению 4.2949673e+009 в переменной а. Забавно, что Вас это удивляет. Попробуйте понять, почему a и b будут иметь разные значения: Код float a = 0xFFFFFFFF; const int i = 0xFFFFFFFF; float b = *(float*)&i; Это же азы. Нельзя же так...
|
|
|
|
|
Feb 3 2016, 13:48
|
Участник

Группа: Участник
Сообщений: 69
Регистрация: 23-10-08
Пользователь №: 41 128

|
Цитата(Непомнящий Евгений @ Feb 3 2016, 16:44)  И что? Это же преобразование чисел по правилам арифметики, а не интерпретация 4-х байт как float ок, теперь ясно, спасибо. Цитата(scifi @ Feb 3 2016, 16:45)  Забавно, что Вас это удивляет. Это же азы. Нельзя же так... В переменной "а" не NaN, а число. Пример приведен лишь для этого, впрочем, выше уже все объяснили.
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|