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

Delphi Sources



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

 
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 03.07.2012, 09:29
ZolotukhinDen ZolotukhinDen вне форума
Прохожий
 
Регистрация: 03.07.2012
Сообщения: 5
Репутация: 10
По умолчанию Помогите избавиться от NaN

Необходимо смоделировать случайную потерю электроном при соударении с атомом. Случайная потеря энергии моделируется функцией:
Код:
Function EL(i:Integer):Real; 
  begin
    Randomize;
    gamma:=roundto((random),-3); //псевдослучайное число
    En:=0;
     for i:=0 to 20000 do
        begin
          En:=Ep*(1+i/20); // приращение энергии от 1 эВ с шагом i/20
          if (Gx(En)=gamma) then EL:=(En/Ep); // Gx(En) - это функция задающая вероятность величины потери энергии (до 3 знака)
        end;
   end;

Энергия которая осталась у электрона после потери считается так:

Function Energy(j:Integer):Extended;
    begin
    if j=1 then Energy:=E/Ep;
    if (j>1) then Energy:=Abs(Energy(j-1)-EL(j));
    end;
Админ: Пользуемся тегами при оформлении кода!
Проблема: если среди значений En не нашлось с точностью до 3 знака равного gamma, то программа вылетает, сообщая что Energy(j) = NaN. Пожалуйста, помогите дописать алгоритм так чтобы не возникало неопределенности

Последний раз редактировалось Admin, 03.07.2012 в 09:57.
Ответить с цитированием
 


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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