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


Ищущий истину
******

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

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


что за квадратичная апроксимация ?
Первый раз о такой слышу, перерыл сейчас 2 учебника по вычислительной математике, нигде нет такого!
Это я к тому,что дайте хоть информацию по методу. (может он по другому еще как то называется ? )
Вообще минимум как вычисляется ? берется производная, и смотрится где она меняет знак с "-" на "+"...
А вот производную на сетке можно апроксимировать используя саму сеточную функцию.
Там в формуле как раз квадрат есть, может имеется ввиду выч. минимум через апроксимацию производной на сетке ?
(при этом сетка производной будет смещенна относительно основной сетки на пол шага, а величина шага задает точность.)


--------------------
Помогая друг другу, мы справимся с любыми трудностями!
"Не опускать крылья!" (С)
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #3


Гость






Олег, если программа на С++ здесь недопустима - скрой сообщение... smile.gif
http://infobez.net.ru/cpp/alg/quadapprox.php
 К началу страницы 
+ Ответить 
сообщение
Сообщение #4


Ищущий истину
******

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

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


Ах вот оно что.... полиномиальное приближение! good.gif
Я то думал...
Вобщем это задача квадратичной интрерполяции! (именно так она в книгах значиться)!
тогда вопрос решен smile.gif


--------------------
Помогая друг другу, мы справимся с любыми трудностями!
"Не опускать крылья!" (С)
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #5


Новичок
*

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

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


Этот метод еще называется-метод Пауэлла

Ссылочку не дадите?????
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #6


Гость






Я же привел ссылку в своем предыдущем посте...
 К началу страницы 
+ Ответить 
сообщение
Сообщение #7


Новичок
*

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

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


Volvo, вот такая херь появляется:


Цитата
DriveHost предлагает услуги хостинга сайтов, регистрации доменов, а также некоторые дополнительные услуги. Мы создали для Вас сервис, сочетающий удобство и легкость, качество и скорость, надежность и функциональность.



Хостинг от $0.67
99,7% UpTime
PHP, MySQL, Perl, CGI
FrontPage, Cron, WAP
Бесплатные домены
Dual Xeon 3.0, 2 GB RAM
Неограниченный трафик
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #8


Гость






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

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


Новичок
*

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

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


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


Гость






Цитата(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

 





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