Показать сообщение отдельно
  #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. Пожалуйста, помогите дописать алгоритм так чтобы не возникало неопределенности
Ответить с цитированием