Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.67/9: Рейтинг темы: голосов - 9, средняя оценка - 4.67
5 / 4 / 1
Регистрация: 14.02.2018
Сообщений: 583

Как соединить оба метода?

11.02.2019, 23:51. Показов 2354. Ответов 64
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
помогите пожалуйста под мой метод Gold и функцию function_optimiz написать метод descent_method ?

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
double function_optimiz(double alpha) {
    double y[N];
    y[0] = 10e-10, y[1] = 0.0, y[2] = 0.0, y[3] = 0.0;
    double t0 = 0.0, max_t = 5.73e-08, h = 1e-10;
    double t = t0;
    double sum = 0;
 
    for(t = t0; t <= max_t; t += h) {
 
        rosenbrock(y, t0, max_t, h, alpha);
        std::cout << t << "\t" << std::setprecision(5) << y[0] << "\t" << y[1] << "\t" << y[2] << "\t" << y[3] << std::endl;
 
        sum += (j_0(y) - j_1(y))*(j_0(y) - j_1(y));
        cout << "sum: " << sum << "\n";
 
    }
    return sum;
}
void Gold(double a, double b, double e, double alpha) {
    long nIter = 1;
 
    double t = (std::sqrt(5) - 1)*0.5;
    double x1 = b - t * (b - a);
    double x2 = a + t * (b - a);
 
    double h1, h2;
 
    while (e <= fabs(b - a)) {
        std::cout << "\t**\t Iteration: " << (nIter++) << " \t **" << std::endl;
        std::cout << std::setprecision(4) << "[ a ; b ]: [ " << a << " ; " << b << " ]\t" << " ALPHA_1: " << x1 << "\tALPHA_2: " << x2 << std::endl;
        h2 = function_optimiz(x2);
        h1 = function_optimiz(x1);
        if (h2 < h1) a = x1;
        else b = x2;
 
        x1 = b - t * (b - a);
        x2 = a + t * (b - a);
 
    }
 
    std::cout << "\t**\t Iteration: " << (nIter++) << " \t **" << std::endl;
    std::cout << std::setprecision(4) << "[ a ; b ]: [ " << a << " ; " << b << " ]\t" << " ALPHA_1: " << x1 << "\tALPHA_2: " << x2 << std::endl;
 
    std::cout << "\n\t**\t Result \t **";
    std::cout << "\nALPHA_min =  " << (alpha = (a + b) / 2);
 
}
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
void descent_method(func_ptr f, double* vars, double eps, int max_steps_count)
{
double B = f(vars), A = 0; // значение целевой функции на текущей и пердидущей итерациях
bool was_counted = false; // был ли определен минимум за максимально допустимое количество итераций
int stpes_ellapsed = 0; // количество итераций, затраченных на поиск минимума (статистическая информация)
double delta = 0.0; // полученная погрешность (статистическая информация)
for(int i = 0; i < max_steps_count; i++){
A = B; // предыдущее значение целевой функции
 
for(int var_index = 0; var_index < var_count; var_index++) // проходим по каждому аргументу целевой функции
vars[var_index] = golden_section(f, vars, var_index, eps, -5000, 5000, max_steps_count); // и находим минимум одномерной функции по этой пе
 
B = f(vars); // текущее значение целевой функции
 
delta = fabs(A - B);
 
if(delta <= eps)
{
stpes_ellapsed = i + 1;
was_counted = true;
break;
}
}
 
std::cout << "Результат поиска минимума функции " << "<тут пишем функцию>" << std::endl;
 
if(!was_counted)
std::cout << "За максимально указанное количество шагов ( " << max_steps_count << " ) минимум не был посчитан." << std::endl;
else {
std::cout << "Количество итераций: " << stpes_ellapsed << std::endl;
std::cout << "Погрешность: " << delta << std::endl;
}
 
std::cout << "Точка: X(";
for(int i = 0; i < var_count; i++){
std::cout << vars[i] << ", ";
 
}
 
std::cout << "\b\b" << ")" << std::endl;
std::cout << "Значение функции f(X): " << std::setprecision(10) << f(vars) << std::endl;
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
11.02.2019, 23:51
Ответы с готовыми решениями:

Как соединить диски,чтобы система видела оба диска
У соседа такая ситуация:750 гб САТА диск стал невидимым для системы и он открутил и положил в полку.Потом покупал другой диск,туда...

Если оба числа четные, то оба возвестив квадрат
Даны 2 вещественных числа, если они оба четные то оба возвестив квадрат, если нет то к каждому из них прибавить 3. uses crt; var...

Как сделать чтоб аргументы метода пользователь вводил с консоли а не в скобках метода во внешнем коде?
доброго времени суток!!! Помогите плиз!!! как сделать чтоб аргументы метода пользователь вводил с консоли а не в скобках метода во...

64
 Аватар для Михаиллллллл
66 / 57 / 13
Регистрация: 16.03.2017
Сообщений: 426
12.02.2019, 17:51
не совсем понятно чего вы хотите.
можете в методе descent_method просто вызвать 2 функции.
напишите подробней, чего вы ждете от descent_method
0
5 / 4 / 1
Регистрация: 14.02.2018
Сообщений: 583
13.02.2019, 10:38  [ТС]
Михаиллллллл, я не могу понять как мне их там вызвать, просто должна фиксироваться одна из координат и методом золотого сечения решаться и затем сравниваться текущее и предыдущее значение функции. Но функцию я должна минимизировать по двум параметрам. Параметр альфа и параметр, в будущем добавлю, M.
Вот и не могу понять как пока что сделать для одного параметра альфа, для которого метод золотого сечения работает верно.

Добавлено через 2 часа 57 минут
Михаиллллллл, может вы сможете мне помочь переписать под мою функцию и метод ?

Добавлено через 11 часов 30 минут
Помогите кто-нибудь, пожалуйста...
0
 Аватар для Михаиллллллл
66 / 57 / 13
Регистрация: 16.03.2017
Сообщений: 426
13.02.2019, 11:53
у вас есть две функции:
double function_optimiz(double alpha)
void Gold(double a, double b, double e, double alpha)
Их можно вызывать где угодно следующим образом:
C++ (Qt)
1
2
function_optimiz(23.54);
Gold(325.2, 564.5, 22, 23.54);
вместо цифр ставьте ваши переменные
0
5 / 4 / 1
Регистрация: 14.02.2018
Сообщений: 583
13.02.2019, 12:20  [ТС]
Михаиллллллл, у меня функция вызывается в методе Gold. Но как тогда поступить, если в методе descent_method нужно проверять значение текущее и предыдущее, а также, если смотреть по коду из примера, то там все используется... я очень запуталась, что менять в том методе... если брать как в примере переменную В, то писать, что она = function_optimiz(alpha) ? А потом снова и снова ее вызывать ? Просто в примере вызывается функция, зависящая от ее переменных vars, а у меня альфа, но в дальнейшем у них меняются значения vars
0
 Аватар для Михаиллллллл
66 / 57 / 13
Регистрация: 16.03.2017
Сообщений: 426
13.02.2019, 15:09
перед вызовом функции нужно убедиться, что все то что она использует и то, что в нее посылаете, существует.
сделайте проверки заранее
0
5 / 4 / 1
Регистрация: 14.02.2018
Сообщений: 583
13.02.2019, 15:20  [ТС]
Михаиллллллл, проверки чего ? Если я в main вызываю функцию Gold, то все верно считает

Добавлено через 8 минут
Михаиллллллл, можно делать вот так ?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
void descent_method(double y[N], double alpha, double eps, int max_steps_count)
{
double B = function_optimiz(alpha), A = 0; 
bool was_counted = false; 
int stpes_ellapsed = 0; 
double delta = 0.0; 
for(int i = 0; i < max_steps_count; i++){
A = B; 
 
for(int var_index = 0; var_index < var_count; var_index++)
alpha = Gold(a,b,eps, alpha); 
 
B = function_optimiz(alpha); 
delta = fabs(A - B);
if(delta <= eps)
{
stpes_ellapsed = i + 1;
was_counted = true;
break;
}
}
Добавлено через 1 минуту
Михаиллллллл, просто я делаю минимизацию по параметру альфа, а в моем варианте, как я поменяла, то что-то совсем не то получается..
0
 Аватар для Михаиллллллл
66 / 57 / 13
Регистрация: 16.03.2017
Сообщений: 426
13.02.2019, 15:41
Вы в делаете так:
C++ (Qt)
1
alpha = Gold(a,b,eps, alpha);
то ваша альфа правильно считается?
0
5 / 4 / 1
Регистрация: 14.02.2018
Сообщений: 583
13.02.2019, 16:01  [ТС]
Михаиллллллл, это неправильно переделано ( я просто уже не знаю как сделать можно.. в функцию нельзя передавать значение альфа, потому что я его не задаю. а нахожу на промежутке, который задаю сама..
0
261 / 111 / 53
Регистрация: 22.01.2017
Сообщений: 448
13.02.2019, 16:07
ElKros, лучше напишите задание полностью
0
5 / 4 / 1
Регистрация: 14.02.2018
Сообщений: 583
13.02.2019, 16:14  [ТС]
n1b1ru, у меня дана система ОДУ, которую я решила. Задана функция описана как function_optimiz, зависящая от альфа. В нее входят решения системы. Ее нужно минимизировать методом покоординатного спуска. Я сразу решала методом Gold - золотого сечения и правильно находит. Но теперь нужно покоординатный спуск сделать, а у меня не получается..
0
261 / 111 / 53
Регистрация: 22.01.2017
Сообщений: 448
13.02.2019, 16:26
ElKros, вот тема с форума: Реализация метода покоординатного спуска
0
5 / 4 / 1
Регистрация: 14.02.2018
Сообщений: 583
13.02.2019, 16:28  [ТС]
n1b1ru, это как раз этот пример я взяла, но мне не удается переделать под свою программу..
0
 Аватар для Михаиллллллл
66 / 57 / 13
Регистрация: 16.03.2017
Сообщений: 426
13.02.2019, 16:33
еще раз, у вас все упирается в альфу. вы можете ее определить до вызова функции?
0
5 / 4 / 1
Регистрация: 14.02.2018
Сообщений: 583
13.02.2019, 16:34  [ТС]
Михаиллллллл, я могу только промежуток указать, на котором буду искать альфа. Ведь конкретное значение я не могу ввести сразу
0
 Аватар для Михаиллллллл
66 / 57 / 13
Регистрация: 16.03.2017
Сообщений: 426
13.02.2019, 16:39
ну так найдите альфу и вызывайте функцию. если вам нужно вычислить несколько альф в каких то пределах, то используйте цикл for
C++ (Qt)
1
2
3
4
5
 (double alfa=35; alfa < 7896; alfa++)
{
alpha = Gold(a,b,eps, alpha);
 
}
0
261 / 111 / 53
Регистрация: 22.01.2017
Сообщений: 448
13.02.2019, 16:42
ElKros, для конкретного альфа у вас все правильно работает?
Я как понимаю вам надо вызвать функцию в цикле с шагом для интервала альфа?
0
5 / 4 / 1
Регистрация: 14.02.2018
Сообщений: 583
13.02.2019, 16:51  [ТС]
n1b1ru, у меня работает, если я задаю промежуток и ищу на нем альфа методом Gold, при каждом новом альфа у меня пересчитывается система и значение функции. То есть просто метод Gold работает

Добавлено через 2 минуты
Михаиллллллл, мне нужно найти такое альфа, при котором значение функции будет минимальным.
0
 Аватар для Михаиллллллл
66 / 57 / 13
Регистрация: 16.03.2017
Сообщений: 426
13.02.2019, 16:52
ну тогда найдите на всех промежутках ваши альфы, запишите их в вектор и уже эти данные вносите в функции
0
5 / 4 / 1
Регистрация: 14.02.2018
Сообщений: 583
13.02.2019, 16:57  [ТС]
Михаиллллллл, как можно переписать код из примера ?

Добавлено через 2 минуты
Михаиллллллл, так, у меня промежуток просто сужается к одной точке, если брать метод золотого сечения. И получается одно значение. Но как это привязать к методу спуска...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
13.02.2019, 16:57
Помогаю со студенческими работами здесь

Передача метода в метод, метода как параметр
Здравствуйте друзья. Есть значит некоторый фрейм: public class Window extends JFrame implements ActionListener { ... (1) ......

Заданы два целых числа. Определить являются ли они оба четными или оба нечетными или какое из них четное, а какое нечетное.
помогите пожалуйста составить программу и блок-схему в Pascal. Заданы два целых числа. Определить являются ли они оба четными или оба...

Полиморфизм: вызов метода базового класса, переопределенного метода и нового метода
В базовом классе метод помечен как virtual. Насколько я понял из книги: override означает, что метод не утрачивает связи с базовым...

как при наведении на 1 из 2х элементов менялись оба (как объединить классы в css)
Есть 2 элемента, нужно чтобы при наведении на любой из них менялись оба код &lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; ...

Как удалить дубликаты (оба)
Добрый день! Прошу подсказать, как удалить дублирующиеся электронные адреса в Exel. Суть в том, что они должны удаляться оба,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru