Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 07.03.2010, 08:45
Axmed0207 Axmed0207 вне форума
Прохожий
 
Регистрация: 01.03.2010
Сообщения: 4
Репутация: 10
По умолчанию Не работают функции округления

Пожалуйста, помогите разобратся в следующей проблеме:

В библиотеке имеется функция, которая при вызове должна возвращать число типа Single вида 1,2345 (с четыремя разрядами после запятой).
Это число генерируется внутри функции рандомизатором, затем преобразуется по определенному алгоритму, в результате получается, например, такое число:
0,381500005722046
далее, оно должно округлятся до 4-ёх разрядов после запятой с помощью соотвтетствующей функции, и возвращаться в кач-ве результата:
Код:
n:=RoundTo(n,-4);
Result:=n;
Проблема в том, что на выходе получается неокругленное число с кучей разрядов.
Пробывал использовать вместо RoundTo функцию FormatFloat - результат одинаковый
Ответить с цитированием
  #2  
Старый 07.03.2010, 09:01
Аватар для W1ndow
W1ndow W1ndow вне форума
Новичок
 
Регистрация: 15.09.2009
Адрес: Березники
Сообщения: 61
Репутация: 16
По умолчанию

Тебе надо использовать тип функции где больше количество знаков, используй Real или Extended
Ответить с цитированием
  #3  
Старый 07.03.2010, 09:55
Axmed0207 Axmed0207 вне форума
Прохожий
 
Регистрация: 01.03.2010
Сообщения: 4
Репутация: 10
По умолчанию

Спасибо за совет, но он не помог.
Single,Double,Extended... Все это вещественные числа, отличаются только размером.
Функция RoundTo должна работать со всеми этими типами.
Ответить с цитированием
  #4  
Старый 09.03.2010, 03:54
AlexSku AlexSku вне форума
Специалист
 
Регистрация: 07.05.2007
Адрес: Москва
Сообщения: 884
Репутация: 21699
По умолчанию

Дробное число хранится в двоичном виде. Поэтому если это не степень двойки (напр., 0,25 = 1/4 = (2)^-2), то при преобразовании к десятичному виду всегда будет куча разрядов (нули или девятки и в конце что-нибудь), как ни округляй перед этим. Округление имеет смысл, если есть преобразование в строку (для вывода), например:
Код:
procedure TForm1.Button1Click(Sender: TObject);
var
  x: Single;
begin
  x:= StrToFloatDef(Edit1.Text, 0);
  Edit1.Text:= Format('%.4f', [x]);
end;
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

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

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 21:12.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter