IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code], либо быть опубликованы на нашем PasteBin в режиме вечного хранения.
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> Метод квадратичной аппроксимации, вычисление минимума функции
сообщение
Сообщение #1


Новичок
*

Группа: Пользователи
Сообщений: 19
Пол: Мужской
Реальное имя: Дмитрий

Репутация: -  0  +


привет всем. Наткнулся на этот сайт и решил попросить помощи.


Составить программу вычисления минимума функции f(x) на интервале [a,b] с точностью 0.001 методом квадратичной аппроксимации

sin 3x-3sinx [0, 3.5]


P.S. Жду помощи
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
сообщение
Сообщение #2


Гость






Тогда через Google-кеш smile.gif
Здесь...

Хотя странно... Еще вчера все открывалось...
 К началу страницы 
+ Ответить 
сообщение
Сообщение #3


Новичок
*

Группа: Пользователи
Сообщений: 19
Пол: Мужской
Реальное имя: Дмитрий

Репутация: -  0  +


Там на С++ написана.....попробую переделать. Спасибо еще раз!!!!
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #4


Гость






Цитата(deymon81 @ 2.03.2006 20:45)
Там на С++ написана...

Вот перевод на Паскаль:
uses crt;

type
func_type = function(x: double): double;

function f(x: double): double;
begin
f := exp(x) - 2*x*x*x;
end;

{ поиск минимума методом квадратичной аппроксимации }
function findMinQuadApprox(xs, h, eps1, eps2: double;
max_step: longint; f: func_type): double;
var
x, f_x: array[0 .. 2] of double;
k: longint;
i_min, i_max: integer;
xn, f_xn, a1, a2: double;

begin
x[0] := xs; x[1] := xs + h;

if f(x[0]) > f(x[1]) then begin
x[2] := xs + 2 * h
end
else begin
x[2] := xs - h
end;

f_x[0] := f(x[0]); f_x[1] := f(x[1]); f_x[2] := f(x[2]);

for k := 0 to pred(max_step) do begin

if f_x[0] < f_x[1] then begin

if f_x[0] < f_x[2] then i_min := 0 else i_min := 2

end
else begin

if f_x[1] < f_x[2] then i_min := 1 else i_min := 2;

end;

a1 := (f_x[1] - f_x[0]) / (x[1] - x[0]);
a2 := 1.0 / (x[2]-x[1])*((f_x[2]-f_x[0]) / (x[2]-x[0])-
(f_x[1]-f_x[0]) / (x[1]-x[0]));
xn := (x[1]+x[0])*0.5-a1/(2*a2);
f_xn := f(xn);

if (abs((xn-x[i_min])/xn) < eps1) and
(abs((f_xn-f_x[i_min])/f_xn) < eps2) then break;

if f_x[0] >= f_x[1] then begin

if f_x[0] > f_x[2] then i_max := 0 else i_max := 2;

end
else begin

if f_x[1] > f_x[2] then i_max := 1 else i_max := 2;

end;

if f_xn < f_x[i_min] then begin
x[i_max] := xn;
f_x[i_max] := f_xn;
end
else begin
x[i_max] := 2*x[i_min]-xn;
f_x[i_max] := f(x[i_max]);
end;
end;

findMinQuadApprox := xn;
end;

var x: double;
begin
clrscr;

x := findMinQuadApprox(10, 0.1, 0.00001, 0.00001, 100, f);
writeln('x = ', x:10:6);
writeln('f(x) = ', f(x):10:6);
readln;
end.
 К началу страницы 
+ Ответить 

Сообщений в этой теме


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 





- Текстовая версия 7.09.2025 4:22
500Gb HDD, 6Gb RAM, 2 Cores, 7 EUR в месяц — такие хостинги правда бывают
Связь с администрацией: bu_gen в домене octagram.name