• Добро пожаловать на компьютерный форум Tehnari.ru. Здесь разбираемся с проблемами ПК и ноутбуков: Windows, драйверы, «железо», сборка и апгрейд, софт и безопасность. Форум работает много лет, сейчас он переехал на новый движок, но старые темы и аккаунты мы постарались сохранить максимально аккуратно.

    Форум не связан с магазинами и сервисами – мы ничего не продаём и не даём «рекламу под видом совета». Отвечают обычные участники и модераторы, которые следят за порядком и качеством подсказок.

    Если вы у нас впервые, загляните на страницу о форуме и правила – там коротко описано, как задать вопрос так, чтобы быстро получить ответ. Чтобы создавать темы и писать сообщения, сначала зарегистрируйтесь, а затем войдите под своим логином.

    Не знаете, с чего начать? Создайте тему с описанием проблемы – подскажем и при необходимости перенесём её в подходящий раздел.
    Задать вопрос Новые сообщения Как правильно спросить
    Если пришли по старой ссылке со старого Tehnari.ru – вы на нужном месте, просто продолжайте обсуждение.

Определение машинного эпсилон

  • Автор темы Автор темы vitshpit
  • Дата начала Дата начала

vitshpit

Ученик
Регистрация
17 Сен 2015
Сообщения
6
Реакции
0
Баллы
0
Определение машинного эпсилон

Помогите пожалуйста, Нужно определить машинный эпсилон для различных типов данных, и сравнить получения результатов.

У меня есть такой вариант эпсилон:

PROGRAM lab1_eps;
uses crt;
var e,e1:double;

procedure vichisl_eps(e1:double; var e:double);
begin
e:=1;
e1:=2;
while (e1>1) do
begin
e:=e/2;
e1:=1+e;
end;
e:=e*2;
end;

BEGIN
clrscr;
vichisl_eps(e1,e);
writeln;
writeln('Mashinnoe epsilon=',e);
readln;
END.

Как сделать для различных типов данных, и как добавить чтобы выводилось время выполнения для каждого из типов?
 
Как сделать для различных типов данных
Если только по рабоче-крестьянски (показано ниже).
как добавить чтобы выводилось время выполнения для каждого из типов?
Формально ввёл, но это бессмысленно: там "квант" времени - 10 мсек, а цикл даже на моём DOS-эмуляторе гораздо короче. Так что, похоже, никак: времена оказываются нулевыми.
Код:
PROGRAM lab1_eps;
uses CRT, DOS;
var
 e_s,e1_s:single;
 e_r,e1_r:real;
 e_d,e1_d:double;
 e_e,e1_e:extended;
 h,min,sec,sec100:Word;
 Time1,Time2:LongInt;

Begin
 e_s:=1;
 e1_s:=2;
 GetTime(h,min,sec,sec100);
 Time1:=h*360000+min*6000+sec*100+sec100;
 while (e1_s>1) do
  begin
   e_s:=e_s/2;
   e1_s:=1+e_s;
  end;
 e_s:=e_s*2;
 GetTime(h,min,sec,sec100);
 Time2:=h*360000+min*6000+sec*100+sec100;
 Writeln('Single: eps= ',e_s,'   time = ',(Time2-Time1)*10,' ms');
 e_r:=1;
 e1_r:=2;
 GetTime(h,min,sec,sec100);
 Time1:=h*360000+min*6000+sec*100+sec100;
 while (e1_r>1) do
  begin
   e_r:=e_r/2;
   e1_r:=1+e_r;
  end;
 e_r:=e_r*2;
 GetTime(h,min,sec,sec100);
 Time2:=h*360000+min*6000+sec*100+sec100;
 Writeln('Real: eps= ',e_r,'   time = ',(Time2-Time1)*10,' ms');
 e_d:=1;
 e1_d:=2;
 GetTime(h,min,sec,sec100);
 Time1:=h*360000+min*6000+sec*100+sec100;
 while (e1_d>1) do
  begin
   e_d:=e_d/2;
   e1_d:=1+e_d;
  end;
 e_d:=e_d*2;
 GetTime(h,min,sec,sec100);
 Time2:=h*360000+min*6000+sec*100+sec100;
 Writeln('Double: eps= ',e_d,'   time = ',(Time2-Time1)*10,' ms');
 e_e:=1;
 e1_e:=2;
 GetTime(h,min,sec,sec100);
 Time1:=h*360000+min*6000+sec*100+sec100;
 while (e1_e>1) do
  begin
   e_e:=e_e/2;
   e1_e:=1+e_e;
  end;
 e_e:=e_e*2;
 GetTime(h,min,sec,sec100);
 Time2:=h*360000+min*6000+sec*100+sec100;
 Writeln('Extended: eps= ',e_e,'   time = ',(Time2-Time1)*10,' ms');
 Readln
End.
 
Спасибо, большое!
 
Назад
Сверху