реклама на сайте
подробности

 
 
3 страниц V   1 2 3 >  
Reply to this topicStart new topic
> STM32F429: ошибка преобразования uint32_t в float
Алексей ВМ
сообщение Feb 3 2016, 13:16
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 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
Go to the top of the page
 
+Quote Post
Непомнящий Евген...
сообщение Feb 3 2016, 13:20
Сообщение #2


Знающий
****

Группа: Свой
Сообщений: 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
Go to the top of the page
 
+Quote Post
Алексей ВМ
сообщение Feb 3 2016, 13:27
Сообщение #3


Участник
*

Группа: Участник
Сообщений: 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
Go to the top of the page
 
+Quote Post
Непомнящий Евген...
сообщение Feb 3 2016, 13:29
Сообщение #4


Знающий
****

Группа: Свой
Сообщений: 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);    
}


Вот она и глючит.


Это не она глючит wink.gif
Go to the top of the page
 
+Quote Post
Алексей ВМ
сообщение Feb 3 2016, 13:31
Сообщение #5


Участник
*

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



Цитата(Непомнящий Евгений @ Feb 3 2016, 16:29) *
Это не она глючит wink.gif


ок, не она. А что (кто)?
Go to the top of the page
 
+Quote Post
Непомнящий Евген...
сообщение Feb 3 2016, 13:33
Сообщение #6


Знающий
****

Группа: Свой
Сообщений: 771
Регистрация: 16-07-07
Из: Волгодонск
Пользователь №: 29 153



Цитата(Алексей ВМ @ Feb 3 2016, 16:31) *
ок, не она. А что (кто)?


я ж откуда знаю. У вас проблема в чем? Прочитанное не совпадает с записанным? Или то, что чистая eeprom дает вам NAN?
Go to the top of the page
 
+Quote Post
scifi
сообщение Feb 3 2016, 13:35
Сообщение #7


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Цитата(Алексей ВМ @ Feb 3 2016, 16:27) *
Если еепром чистая, то в буфере будут все 0xFF.

ЕМНИП, float, в котором все байты 0xFF, - это неправильный float. Вот оно и ругается. Не все возможные коды допустимы для float.
Go to the top of the page
 
+Quote Post
Непомнящий Евген...
сообщение Feb 3 2016, 13:39
Сообщение #8


Знающий
****

Группа: Свой
Сообщений: 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
Go to the top of the page
 
+Quote Post
Алексей ВМ
сообщение Feb 3 2016, 13:41
Сообщение #9


Участник
*

Группа: Участник
Сообщений: 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?


Именно. Причем для приведенного выше примера с присвоением в переменной число.
Go to the top of the page
 
+Quote Post
scifi
сообщение Feb 3 2016, 13:42
Сообщение #10


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Цитата(Непомнящий Евгений @ Feb 3 2016, 16:39) *
он не ругается, он говорит, что это NaN - Not a number. Это допустимое значение для float...

Ну ладно, это вопрос интерпретации.
Но исходный вопрос как бы иллюстрирует кашу в голове у вопрошающего.. Там надо начинать с начала. Что хотим сделать? Что не получилось? Почему не получилось? Ну и т.д.
Go to the top of the page
 
+Quote Post
Непомнящий Евген...
сообщение Feb 3 2016, 13:44
Сообщение #11


Знающий
****

Группа: Свой
Сообщений: 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;    
}



Go to the top of the page
 
+Quote Post
scifi
сообщение Feb 3 2016, 13:45
Сообщение #12


Гуру
******

Группа: Свой
Сообщений: 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;

Это же азы. Нельзя же так...
Go to the top of the page
 
+Quote Post
Алексей ВМ
сообщение Feb 3 2016, 13:48
Сообщение #13


Участник
*

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



Цитата(Непомнящий Евгений @ Feb 3 2016, 16:44) *
И что? Это же преобразование чисел по правилам арифметики, а не интерпретация 4-х байт как float


ок, теперь ясно, спасибо.


Цитата(scifi @ Feb 3 2016, 16:45) *
Забавно, что Вас это удивляет.
Это же азы. Нельзя же так...


В переменной "а" не NaN, а число. Пример приведен лишь для этого, впрочем, выше уже все объяснили.
Go to the top of the page
 
+Quote Post
skripach
сообщение Feb 4 2016, 13:28
Сообщение #14


■ ■ ■ ■
*****

Группа: Свой
Сообщений: 1 100
Регистрация: 9-08-06
Пользователь №: 19 443



Цитата(Алексей ВМ @ Feb 3 2016, 16:27) *
Мне надо записать и прочитать float в еепром.

union в помощь. 1111493779.gif


--------------------
Делай что должен и будь что будет.
Go to the top of the page
 
+Quote Post
Непомнящий Евген...
сообщение Feb 4 2016, 13:32
Сообщение #15


Знающий
****

Группа: Свой
Сообщений: 771
Регистрация: 16-07-07
Из: Волгодонск
Пользователь №: 29 153



Цитата(skripach @ Feb 4 2016, 16:28) *
union в помощь. 1111493779.gif


Стесняюсь спросить, а зачем тут union?
Go to the top of the page
 
+Quote Post

3 страниц V   1 2 3 >
Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 18th July 2025 - 18:01
Рейтинг@Mail.ru


Страница сгенерированна за 0.01496 секунд с 7
ELECTRONIX ©2004-2016