Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
1 / 1 / 1
Регистрация: 07.09.2014
Сообщений: 88
1

Метод Ньютона, программа ничего не выводит

30.11.2015, 23:14. Просмотров 812. Ответов 1
Метки нет (Все метки)

Здравствуйте. У меня стоит задача нахождение минимум функции методом Ньютона с дроблением шага:
Вот моя программа:
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
82
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
 
namespace lr6
{
    class Program
    {
 
        public static double f(double x1, double x2)
        {
            return Math.Sqrt(Math.Pow(x1, 2) + Math.Pow(x2, 2) + 1) + 0.5 * x1 - 0.5 * x2;
        }
 
        public static double dx1(double x1, double x2)
        {
            return x1 / (Math.Sqrt(Math.Pow(x1, 2) + Math.Pow(x2, 2))+0.5);
            
        }
 
        public static double dx2(double x1, double x2)
        {
            return x2 / (Math.Sqrt(Math.Pow(x1, 2) + Math.Pow(x2, 2)) - 0.5);
            
        }
 
        public static double dx1x1(double x1, double x2)
        {
            return (-1 * (x1 * x1) / Math.Pow((x1 * x1 + x2 * x2 + 1), 3 / 2)) + 1 / (Math.Pow((x1 * x1 + x2 * x2 + 1), 1 / 2));
           
        }
 
        public static double dx1x2(double x1, double x2)
        {
            return -((x1) * x2) / (Math.Pow((x1 * x1 + x2 * x2 + 1), 3 / 2)); 
            
        }
 
        public static double dx2x2(double x1, double x2)
        {
            return (-1 * (x2 * x2) / Math.Pow((x1 * x1 + x2 * x2 + 1), 3 / 2)) + 1 / (Math.Pow((x1 * x1 + x2 * x2 + 1), 1 / 2));
        }
 
        static void Main(string[] args)
        {
 
            double x1 = 1, x2 = 1;
            double p1 = 0, p2 = 0;
            double alpha = 0.5, eps = 0.25, beta = 0.5, delta = 0.001;
            int k = 0;
 
            double a11, a12, a21, a22;
            double gr1, gr2;
 
            while (Math.Abs(dx1(x1, x2)) > delta && Math.Abs(dx2(x1, x2)) > delta)
            {
                a11 = dx1x1(x1, x2); a12 = dx1x2(x1, x2); a21 = dx1x2(x1, x2); a22 = dx2x2(x1, x2);
                gr1 = -dx1(x1, x2); gr2 = -dx2(x1, x2);
                p1 = (a22 * gr1 - a12 * gr2) / (a11 * a22 - a12 * a21);
                p2 = (a11 * gr2 - a21 * gr1) / (a11 * a22 - a12 * a21);
 
                if (f(x1 + alpha * p1, x2 + alpha * p2) - f(x1, x2) <= eps * alpha * (p1 * dx1(x1, x2) + p2 * dx2(x1, x2)))
                {
                    k++;
                }
                else
                {
                    alpha *= beta;
                    continue;
                }
                x1 += alpha * p1;
                x2 += alpha * p2;
            }
            Console.WriteLine("x1=" + x1);
            Console.WriteLine("x2=" + x2);
            Console.WriteLine("f=" + f(x1, x2));
            Console.WriteLine("k=" + k);
            Console.ReadKey();
        }
    }
}
программа ничего в консоль не выводит , помогите плиз найти ошибку. Спасибо
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
30.11.2015, 23:14
Ответы с готовыми решениями:

Метод Ньютона-Рафсона. Программа не выводит значения
Написал программу(как смог) для решения системы нелинейных уравнений методом ньютона-рафсона....

Метод ничего не выводит
Написала вот такой код, вроде все правильно. метод PrintMatrix должен выводить мне матрицы. но не...

Программа ничего не выводит
При компиляции ничего не выводит #include &lt;stdio.h&gt; #include &lt;math.h&gt; #include &lt;conio.h&gt;...

Программа не выводит ничего
Собственно начал изучать NASM но у меня не выводится в этой программе ничего global _start ...

1
153 / 153 / 56
Регистрация: 20.12.2011
Сообщений: 1,614
01.12.2015, 08:17 2
Jonny123, у вас зацикливается программа.
посмотрите на ваш цикл while
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
01.12.2015, 08:17

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Программа ничего не выводит
program p1; var s: string; n, i: byte; begin readln (s); readln (n); for i:=1 to length(s) do...

Программа ничего не выводит
Здравствуйте, помогите, пожалуйста. Программа компилируется нормально, ошибок компилятор не выдает....

Программа запускается, но ничего не выводит
Пишу в CodeBlocks. Задание: Дан массив из 18 вещественных чисел, все элементы которого различны....

Программа ничего не выводит на экран
#include &lt;stdio.h&gt; int N,M; int a; int KP,KV; int o,oN,t; int i,j; void next(int x){ ...

почему программа ничего не выводит
Здравствуйте, 1 день на Java я. Вопрос, почему ничего не выводит данная программа? Помогите...

Программа компилируется, но ничего не выводит
program L6; Var s,st,s1,s2:string; k,ss:byte; function poss(r:byte;sa:string;var...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.