Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/40: Рейтинг темы: голосов - 40, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 23.12.2010
Сообщений: 10

Алгоритм Свена и метод дихотомии для двумерного случая

12.06.2013, 07:10. Показов 8338. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день. Прошу помочь с переделкой алгоритма Свена для двумерного случая.
Дихотомию уже переделала, осталось только Свена.

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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
 static double f(double[] x)
        {
            return Math.Pow(x[0] - 4, 2) + Math.Pow(x[1] - 5, 2);
        }
 
        static double f(double x1, double x2)
        {
            return Math.Pow(x1 - 4, 2) + Math.Pow(x2 - 5, 2);
        }
public static double Bisect(double[] x, double[] S)
        {
            double a = -1, b = 1;
            Svenns(x, Solution.E, ref a, ref b);
            double delta = E / 30;
            double na = 0, nb = 0;
            do
            {
                na = ((a + b) / 2) - delta;
                nb = ((a + b) / 2) + delta;
 
                if (f(x[0] + na * S[0], x[1] + na * S[1]) < f(x[0] + nb * S[0], x[1] + nb * S[1]))
                { b = nb; }
                else
                { a = na; }
            }
            while (Math.Abs(b - a) > E);
 
            return (a + b) / 2.0;
        }
 
public static void Svenns(double x0, double t, ref double l, ref double r)
        {
            double delta = 0, x = 0, xn = 0;
            int k = 0;
 
            if (f(x0 - t) >= f(x0) && f(x0 + t) >= f(x0))
            {
                l = f(x0 - t); r = f(x0 + t);
            }
            else if (f(x0) >= f(x0 - t) && f(x0) >= f(x0 + t))
            {
                Console.WriteLine("Случайным образом будет выбрана другая точка.");
                Random rnd = new Random();
                x0 = rnd.Next(-100, 100);
            }
            else
            {
                if (f(x0 - t) >= f(x0) && f(x0) >= f(x0 + t))
                {
                    delta = t;
                    l = x0;
                    x = x0 + t;
                    k = 1;
                }
 
                if (f(x0) >= f(x0 - t) && f(x0 + t) >= f(x0))
                {
                    delta = -t;
                    r = x0;
                    x = x0 - t;
                    k = 1;
                }
 
                xnext = x + Math.Pow(2, k) * delta;
                while (f(xnext) < f(x))
                {
                    xnext = x + Math.Pow(2, k) * delta;
                    if (f(xnext) < f(x) && delta == t)
                    {
                        l = x;
                        r = xnext;
                    }
                    if (f(xnext) < f(x) && delta == -t)
                    {
                        r = x;
                        l = xnext;
                    }
                    k++;
                }
            }
        }
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
12.06.2013, 07:10
Ответы с готовыми решениями:

Уравнение Лапласа для двумерного случая
Я слабо понимаю, что это вообще такое, но нужно написать код и забыть. Вот здесь я нашёл решение нужным мне способом: ...

Сделать рассчет для двумерного случая.
Здравствуйте! Подскажите пожалуйста как будет выглядеть код, если х будет не вектором, а матрицей? А sqrt(ex)*randn - не числом, а...

Метод деления отрезка пополам для решения нелинейных уравнений (метод дихотомии)
Здравствуйте. Помогите пожалуйста дописать программу. Вот что вымучал, но на сдаче завалили, типо нет вывода корней, не рассмотрены...

7
Master of Orion
Эксперт .NET
 Аватар для Psilon
6102 / 4958 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
12.06.2013, 08:07
Анют- А, неправильно делаете. В т.ч. дихотомию. Работать будет правильно только для сепарабельных функций.
1
0 / 0 / 0
Регистрация: 23.12.2010
Сообщений: 10
12.06.2013, 08:19  [ТС]
А как правильно делать, не подскажете7
0
Master of Orion
Эксперт .NET
 Аватар для Psilon
6102 / 4958 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
12.06.2013, 08:27
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
        public Vector Solve()
        {
            Vector previousIterationY;
            var lambda = new Vector(n);
            do
            {
                previousIterationY = y;                
                for (int j = 0; j < n; j++)
                {
                    var previousStepY = y;
                    int i = j;
                    lambda[j] = Dichotomy(x => LambdaSolve(x, i), y[j]);
                    y += lambda[j] * d[j];
                }
            } while ((y - previousIterationY).Norm >= epsilon);
            return y;
        }
то есть сохраняем Y как константу, после этого решаем по одной координате, полученную координату запихиваем обратно в Y и дальше уже от нее идем (а не от нуля). Делаем это пока норма приращения не будет меньше эпсилон. Это называется метод покоординатного спуска. Если непонятно объяснил найдите в интернете описание.

Добавлено через 1 минуту
Ну или я могу скинуть примерное решение, Это метод розенброка, то есть покоординатный спуск + грам-шмидт, то есть даже больше, чем вам нужно
1
0 / 0 / 0
Регистрация: 23.12.2010
Сообщений: 10
12.06.2013, 08:57  [ТС]
я делала метод п.с., вообще это всё для того, чтобы корректно работали методы штрафных функций и проекции градиента, потому, что (вроде как) у меня ошибка именно с метода дихотомии начинается, перетекает в метод наискорейшего спуска и отсюда в проекцию градиента.
0
Master of Orion
Эксперт .NET
 Аватар для Psilon
6102 / 4958 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
12.06.2013, 09:00
Анют- А, ошибка в том, что сначала по одной координате искать надо, а потом по другой, вы же сразу по обеим пытаетесь, а это неправильно.
1
0 / 0 / 0
Регистрация: 23.12.2010
Сообщений: 10
12.06.2013, 09:11  [ТС]
то есть вот где лябда ищу, использовать покоординатный спуск?

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
public static double fst(double[,] x, double[,] idx)
        {
            double[] S = new double[2];
            double[,] s = (double[,])idx.Clone();
            double[,] xprev = new double[2, 1];
            
            double lambda = 0;
            int k = 0;
            do
            {
                xprev = (double[,])x.Clone();
 
                lambda = Bisect(0, 50, new double[] { x[0, 0], x[1, 0] }, new double[2] { s[0, 0], s[1, 0] });
 
                x[0, 0] = xprev[0, 0] + lambda * s[0, 0];
                x[1, 0] = xprev[1, 0] + lambda * s[1, 0];
                k++;
            }
            while (Matrix.Euclid(grd(x)) >= E);
 
            return lambda;
        }
0
Master of Orion
Эксперт .NET
 Аватар для Psilon
6102 / 4958 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
12.06.2013, 10:51
книжка
стр.293
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.06.2013, 10:51
Помогаю со студенческими работами здесь

Алгоритм Свена и золотого сечения
Функция x^2+5e^(-0.05*x). Найти минимум функции используя алгоритм Свена и метод Ньютона. Прошу помогите.

Алгоритм решения уравнения методом прогонки для 3х многого случая.СРОЧНО!
СРОЧНО!!! Помогите пожалуйста кто сможет))) Дано дифференциальное уравнение, которое описываете распределение радона в пористой среде...

Метод Свена, Тернарный поиск
program lab1v3; {$APPTYPE CONSOLE} uses SysUtils,math; const eps=0.00001; var a,b,x:real; function f(x:real):real; begin ...

Метод дихотомии для минимизации функции
Помогите пожалуйста,не могу понять алгоритм реализации)буду очень благодарна за помощь

Метод дихотомии для двух уравнений
Друзья, помогите доделать программу. Спасибо, тем кто решит. Надо написать метод дихотомии для двух и более уравнений. Вот мой код unit...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru