Экспертная система Delphi.int.ru

Сообщество программистов
Общение, помощь, обмен опытом

Логин:
Пароль:
Регистрация | Забыли пароль?

Delphi.int.ru Expert

Другие разделы портала

Переход к вопросу:

#   

Статистика за сегодня:  


Лучшие эксперты

Подробнее »



Вопрос # 3 890

/ вопрос закрыт /

Здравствуйте!
В приведенной ниже программе, требуется найти минимум функции с точностью 0.001 методом градиентного спуска...
Пмогите найти ошибку!

Приложение:
  1. function FuncGD (x1, x2: real): real;
  2. begin
  3. Result := Sqr(x2 - Sqr(x1)) + Sqr(1 - x1);
  4. end;
  5.  
  6. function FuncGDx1 (x1, x2: real): real;
  7. begin
  8. Result := 4*x2*x1 + 4*x1*Sqr(x1) + 2*x1 - 2;
  9. end;
  10.  
  11. function FuncGDx2 (x1, x2: real): real;
  12. begin
  13. Result := 2*x2 - 2*Sqr(x1);
  14. end;
  15.  
  16. procedure TMainForm.BitBtnGDRunClick(Sender: TObject);
  17. var
  18. x01, x02, h: real;
  19. x1, x2, l: real;
  20. E: real;
  21. begin
  22.  
  23. x01 := StrToFloat(LabEdGDx01.Text);
  24. x02 := StrToFloat(LabEdGDx02.Text);
  25. h := StrToFloat(LabEdGDh.Text);
  26. E := StrToFloat(LabEdGDAccuracy.Text);
  27.  
  28. l := Sqrt(Sqr(FuncGDx1(x01, x02)) + Sqr(FuncGDx2(x01, x02)));
  29. while l > E do begin
  30. repeat
  31. x1 := x01 - h*(FuncGDx1(x01, x02));
  32. x2 := x02 - h*(FuncGDx2(x01, x02));
  33. h := h/2;
  34. until FuncGD(x1, x2) < FuncGD(x01, x02);
  35. l := Sqr(FuncGDx1(x1, x2)) + Sqr(FuncGDx2(x1, x2));
  36. x01 := x1;
  37. x02 := x2;
  38. end;
  39. EditGDx1.Text := FloatToStr(x1);
  40. EditGDx2.Text := FloatToStr(x2);
  41. EditGDfx1x2.Text := FloatToStr(FuncGD(x1, x2));
  42.  
  43. end;


serox Вопрос закрыт (ответы не принимаются, мини-форум закрыт)

Вопрос задал: serox (статус: Посетитель)
Вопрос отправлен: 16 марта 2010, 02:03
Состояние вопроса: закрыт, ответов: 0.


Мини-форум вопроса

Всего сообщений: 8; последнее сообщение — 17 марта 2010, 10:09; участников в обсуждении: 3.
min@y™

min@y™ (статус: Доктор наук), 16 марта 2010, 08:09 [#1]:

Цитата (serox):

Пмогите найти ошибку!

Какую ошибку искать?
Делаю лабы и курсачи по Delphi и Turbo Pascal. За ПИВО! Пишите в личку, а лучше в аську. А ещё лучше - звоните в скайп!
Егор

Егор (статус: 10-ый класс), 16 марта 2010, 13:01 [#2]:

в чём ошибка?
Опасайтесь багов в приведенном выше коде; я только доказал корректность, но не запускал его.
— Donald E. Knuth.
serox

serox (статус: Посетитель), 16 марта 2010, 23:15 [#3]:

Я так понимаю полуается бесконечный цикл... Т.к. программа виснет на этой процедуре... Видимо ошибка в самом алгоритме...

P.S. Хотя по моему всёправильно... *SCRATCH*
That will be, you and do not learn, if never will try! ^__^
Егор

Егор (статус: 10-ый класс), 17 марта 2010, 06:35 [#4]:

Вот зависающий цикл:
    repeat
      x1 := x01 - h*(FuncGDx1(x01, x02));
      x2 := x02 - h*(FuncGDx2(x01, x02));
      h := h/2;
    until FuncGD(x1, x2) < FuncGD(x01, x02);
Здесь h в конце станет равным нулю, соответственно FuncGD(x1, x2) будет равно FuncGD(x01, x02). Если при этом FuncGD(x1, x2) было больше FuncGD(x01, x02), то выхода из цикла не будет.
Можно, конечно, сделать условие <=, но это глупое условие - слишком высокая точность, на пределе машинной арифметики.
В этом цикле должны меняться переменные x01 и х02. Примерно так:
...
      x1 := x01;  // <---------
      x2 := x02;  // <---------
...
    repeat
      x01 := x1;  // <---------
      x02 := x2;  // <---------
      x1 := x01 - h*(FuncGDx1(x01, x02));
      x2 := x02 - h*(FuncGDx2(x01, x02));
      h := h/2;
    until FuncGD(x1, x2) < FuncGD(x01, x02);
Опасайтесь багов в приведенном выше коде; я только доказал корректность, но не запускал его.
— Donald E. Knuth.
Егор

Егор (статус: 10-ый класс), 17 марта 2010, 06:35 [#5]:

вообще, если программа виснет, нужно пользоваться отладчиком - в данном случае стало бы понятно, почему
Опасайтесь багов в приведенном выше коде; я только доказал корректность, но не запускал его.
— Donald E. Knuth.
serox

serox (статус: Посетитель), 17 марта 2010, 07:19 [#6]:

Я видимо не такой прошаренный...

P.S. А где можно про него почитать? :)
That will be, you and do not learn, if never will try! ^__^
min@y™

min@y™ (статус: Доктор наук), 17 марта 2010, 08:20 [#7]:

Цитата (serox):

Я видимо не такой прошаренный...

Да, без отладчика только хэллоу, ворлд написать можно. Учись пользоваться дебаггером.
Делаю лабы и курсачи по Delphi и Turbo Pascal. За ПИВО! Пишите в личку, а лучше в аську. А ещё лучше - звоните в скайп!
Егор

Егор (статус: 10-ый класс), 17 марта 2010, 10:09 [#8]:

Цитата (serox):

А где можно про него почитать?

гугл в помощь - просто рассказывать долго.
а так - очень удобная штука. плюс к тому - несложная
Опасайтесь багов в приведенном выше коде; я только доказал корректность, но не запускал его.
— Donald E. Knuth.

27 мая 2013, 12:16: Вопрос закрыт (решение принял DNK): Автор потерял интерес к вопросу

Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте.

Версия движка: 2.6+ (26.01.2011)
Текущее время: 22 февраля 2025, 11:50
Выполнено за 0.02 сек.