Телесистемы
 Разработка, производство и продажа радиоэлектронной аппаратуры
На главную   | Карта сайта | Пишите нам | В избранное
Требуется программист в Зеленограде
- обработка данных с датчиков; ColdFire; 40 тыс.
e-mail:jobsmp@pochta.ru

Телесистемы | Электроника | Конференция «Микроконтроллеры и их применение»

Если правильно понял, то вот так(+)

Отправлено Quasy 03 октября 2008 г. 11:42
В ответ на: FLOAT->INT отправлено <font color=gray>Anton_2</font> 03 октября 2008 г. 00:18


typedef union
{
union uu_type
{
struct xx_type
{
long a1:24; // 3-х байтовое
char a2; // + 1 байт
}xx;
long a;
}uu;
float b;
}s_param;
s_param my;
// Для удобства доступа к полям:
#define USER_FLOAT_24 my.uu.xx.a1
#define LONG_32 my.uu.a
#define FLOAT_32 my.b
C_task main( void )
{
//..........................
// программа работает с USER_FLOAT_24. Это на самом деле
// целое, наложенное на адреса float. Для 32-битовой
// float-математики мы ее приспособим с помощью сдвига.
USER_FLOAT_24 = 0x43839f;
//..........................
// Надо получить 2632. Начинаю.
// Сначала для нормальной работы 3-х байтовое float
// перевожу в нормальный 4-х байтовый формат
// с помощью сдвига в сторону старшего байта
LONG_32 = (USER_FLOAT_24 << 8); // получится 0x43839f00
printf("Float_24 = %f\n",FLOAT_32); // проверка:263.242197 OK!
FLOAT_32 = FLOAT_32 * 10.0; // 262.2 переводим в 2632
printf("%f\n",FLOAT_32); // проверка: 2632.421970. OK!
// Осталось взять целую часть.
// Вариант1. Целое получаю просто отбросом дробной части...
//LONG_32 = (long)(my.b);

// Вариант2. Можно не просто отбрасыванием дробной части, а
// даже и округлить, если надо...
LONG_32 = (long)(FLOAT_32<0.0)?(FLOAT_32-0.5):(FLOAT_32+0.5);

// Что там получилось?
printf("%d\n",LONG_32); // проверка: 2632. OK!
}


Составить ответ | Вернуться на конференцию

Ответы


Отправка ответа
Имя*: 
Пароль: 
E-mail: 
Тема*:

Сообщение:

Ссылка на URL: 
URL изображения: 

если вы незарегистрированный на форуме пользователь, то
для успешного добавления сообщения заполните поле, как указано ниже:
введите число 56:

Перейти к списку ответов | Конференция | Раздел "Электроника" | Главная страница | Карта сайта

Rambler's Top100 Рейтинг@Mail.ru
 
Web telesys.ru