5 / 4 / 1
Регистрация: 14.02.2018
Сообщений: 583
1

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

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

Author24 — интернет-сервис помощи студентам
помогите пожалуйста под мой метод 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
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
11.02.2019, 23:51
Ответы с готовыми решениями:

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

Если оба числа четные, то оба возвестив квадрат
Даны 2 вещественных числа, если они оба четные то оба возвестив квадрат, если нет то к каждому из...

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

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

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

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

Добавлено через 11 часов 30 минут
Помогите кто-нибудь, пожалуйста...
0
66 / 57 / 13
Регистрация: 16.03.2017
Сообщений: 426
13.02.2019, 11:53 4
у вас есть две функции:
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  [ТС] 5
Михаиллллллл, у меня функция вызывается в методе Gold. Но как тогда поступить, если в методе descent_method нужно проверять значение текущее и предыдущее, а также, если смотреть по коду из примера, то там все используется... я очень запуталась, что менять в том методе... если брать как в примере переменную В, то писать, что она = function_optimiz(alpha) ? А потом снова и снова ее вызывать ? Просто в примере вызывается функция, зависящая от ее переменных vars, а у меня альфа, но в дальнейшем у них меняются значения vars
0
66 / 57 / 13
Регистрация: 16.03.2017
Сообщений: 426
13.02.2019, 15:09 6
перед вызовом функции нужно убедиться, что все то что она использует и то, что в нее посылаете, существует.
сделайте проверки заранее
0
5 / 4 / 1
Регистрация: 14.02.2018
Сообщений: 583
13.02.2019, 15:20  [ТС] 7
Михаиллллллл, проверки чего ? Если я в 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 8
Вы в делаете так:
C++ (Qt)
1
alpha = Gold(a,b,eps, alpha);
то ваша альфа правильно считается?
0
5 / 4 / 1
Регистрация: 14.02.2018
Сообщений: 583
13.02.2019, 16:01  [ТС] 9
Михаиллллллл, это неправильно переделано ( я просто уже не знаю как сделать можно.. в функцию нельзя передавать значение альфа, потому что я его не задаю. а нахожу на промежутке, который задаю сама..
0
261 / 111 / 53
Регистрация: 22.01.2017
Сообщений: 448
13.02.2019, 16:07 10
ElKros, лучше напишите задание полностью
0
5 / 4 / 1
Регистрация: 14.02.2018
Сообщений: 583
13.02.2019, 16:14  [ТС] 11
n1b1ru, у меня дана система ОДУ, которую я решила. Задана функция описана как function_optimiz, зависящая от альфа. В нее входят решения системы. Ее нужно минимизировать методом покоординатного спуска. Я сразу решала методом Gold - золотого сечения и правильно находит. Но теперь нужно покоординатный спуск сделать, а у меня не получается..
0
261 / 111 / 53
Регистрация: 22.01.2017
Сообщений: 448
13.02.2019, 16:26 12
ElKros, вот тема с форума: Реализация метода покоординатного спуска
0
5 / 4 / 1
Регистрация: 14.02.2018
Сообщений: 583
13.02.2019, 16:28  [ТС] 13
n1b1ru, это как раз этот пример я взяла, но мне не удается переделать под свою программу..
0
66 / 57 / 13
Регистрация: 16.03.2017
Сообщений: 426
13.02.2019, 16:33 14
еще раз, у вас все упирается в альфу. вы можете ее определить до вызова функции?
0
5 / 4 / 1
Регистрация: 14.02.2018
Сообщений: 583
13.02.2019, 16:34  [ТС] 15
Михаиллллллл, я могу только промежуток указать, на котором буду искать альфа. Ведь конкретное значение я не могу ввести сразу
0
66 / 57 / 13
Регистрация: 16.03.2017
Сообщений: 426
13.02.2019, 16:39 16
ну так найдите альфу и вызывайте функцию. если вам нужно вычислить несколько альф в каких то пределах, то используйте цикл 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 17
ElKros, для конкретного альфа у вас все правильно работает?
Я как понимаю вам надо вызвать функцию в цикле с шагом для интервала альфа?
0
5 / 4 / 1
Регистрация: 14.02.2018
Сообщений: 583
13.02.2019, 16:51  [ТС] 18
n1b1ru, у меня работает, если я задаю промежуток и ищу на нем альфа методом Gold, при каждом новом альфа у меня пересчитывается система и значение функции. То есть просто метод Gold работает

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

Добавлено через 2 минуты
Михаиллллллл, так, у меня промежуток просто сужается к одной точке, если брать метод золотого сечения. И получается одно значение. Но как это привязать к методу спуска...
0
13.02.2019, 16:57
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
13.02.2019, 16:57
Помогаю со студенческими работами здесь

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru