Інформація про навчальний заклад

ВУЗ:
Національний університет Львівська політехніка
Інститут:
Не вказано
Факультет:
Не вказано
Кафедра:
АСУ

Інформація про роботу

Рік:
2024
Тип роботи:
Лабораторна робота
Предмет:
Чисельні методи

Частина тексту файла (без зображень, графіків і формул):

МІНІСТЕРСТВО ОСВІТИ І НАУКИ, МОЛОДІ ТА СПОРТУ УКРАЇНИ НАЦІОНАЛЬНИЙ УНІВЕРСИТЕТ „ЛЬВІВСЬКА ПОЛІТЕХНІКА” Кафедра АСУ Звіт Лабораторна робота № 6 Розв’язування системи нелінійних алгебраїчних рівнянь методом простої ітерації (методом Ньютона) з дисципліни: «Чисельні методи» Варіант №9 Мета роботи: вивчити і засвоїти метод Ньютона. Порядок роботи 1) Попереднє опрацювання теоретичного матеріалу. 2) Отримання допуску до виконання лабораторної роботи. 3) Опрацювання типового навчального завдання (прикладів). 4) Створення проекту для виконання індивідуального завдання. 5) Оформити звіт для захисту лабораторної роботи за зразком: назва роботи; мета роботи; короткі теоретичні відомості; алгоритм розв’язування задачі; тексти відповідних модулів проекту; аналіз отриманих результатів та висновки. 6) Захист лабораторної роботи. Завдання Використовуючи метод простої ітерації, розв’язати з точністю ε = 10 такі нелінійні системи рівнянь. Початкове наближення знайти графічно.  Код програми #include <iostream> #include <locale> #include <math.h> using namespace std; double m_jak[2][2], m_rez[2], v_delta[2], cos(...); void SetJ (double x, double y) { m_jak[0][0]=(-1)*x+1; m_jak[0][1]=1; m_jak[1][0]=2; m_jak[1][1]=1-0.5*y*y; } void SetR (double x, double y) { m_rez[0]=-(cos(0.4*y+x*x)+x*x+y*y-1.6); m_rez[1]=-(1.5*x*x-2*y*y-1); } void GetD () { double det=1.0/(m_jak[0][0]*m_jak[1][1]-m_jak[1][0]*m_jak[0][1]); double buf; buf=m_jak[0][0]; m_jak[0][0]=m_jak[1][1]*det; m_jak[1][1]=buf*det; m_jak[1][0]=(-m_jak[1][0])*det; m_jak[0][1]=(-m_jak[0][1])*det; v_delta[0]=(m_rez[0])*m_jak[0][0]+(m_rez[1])*m_jak[0][1]; v_delta[1]=(m_rez[0])*m_jak[1][0]+(m_rez[1])*m_jak[1][1]; } void main () { double x=1, y=4; setlocale (LC_ALL,""); cout<<"Розв’язування системи нелiнiйних алгебраїчних рiвнянь методом простої iтерацiї (методом Ньютона):"<<endl; for (int i=1; i<8; i++){ SetJ (x, y); SetR (x, y); GetD (); x+=v_delta[0]; y+=v_delta[1]; cout.precision(20); cout<<"Iтерацiя "<<i<<endl; cout<<"x="<<x<<" y="<<y<<endl; cout.precision(6); cout<<"Значення функцiй у цих точках: F1(x, y)="<<m_rez[0]<<" F2(x, y)="<<m_rez[1]<<endl; } cin.get(); } Приклад виконання програми  Висновок: на даній роботі була створена програма для обчислення системи нелінійних рівнянь методом простої ітерації (методом Нютона). Програма обчислювала розвязок для зазначеної у завданні системи рівнянь. При виконанні програми, для досягнення розвязку, було здійснено 7 ітерацій. Початкове положення невідомих і при першій ітерації було обране таке: х=-34,15089, у=-10,5431, значення функцій для цих невідомих: F1(х , у)=-14,5431, F2(х , у)=31,5. Як зображено на скріншоті виконання програми при другій ітерації невідомі набули таких значень: х=-71,2308, у=16,05981, значення функцій для цих невідомих: F1(х, у)=1276,79, F2(х, у)=-1526,11. Після семи операцій було отримано такий кінцевий результат: х=-2743,4552556 у=331,934249 (точне значення зображено на скріншоті виконання програми), а значення функцій у цих точках наближені до нуля. Оскільки для обчислення даної системи слід здійснити всього 7 ітерацій, то єдине обмеження у точності обчислення становить апаратна і програмна частина. Для розв’язання більш складних систем кількість ітерацій може бути надзвичайно великою, тому слід задавати точність обчислення таких систем.  Абсолютна похибка: сos(0,4у+х2)+х2+у2-1,6=-1,76367 1,88267-1,7637=0,11897 1,5х2-2у2-1=2,311 2,6753-2,311=0,3643 Відносна похибка: 0,11897/1,88267*100%=6,3% 0,3643/2,6753*100%=13,6%
Антиботан аватар за замовчуванням

06.12.2015 15:12-

Коментарі

Ви не можете залишити коментар. Для цього, будь ласка, увійдіть або зареєструйтесь.

Ділись своїми роботами та отримуй миттєві бонуси!

Маєш корисні навчальні матеріали, які припадають пилом на твоєму комп'ютері? Розрахункові, лабораторні, практичні чи контрольні роботи — завантажуй їх прямо зараз і одразу отримуй бали на свій рахунок! Заархівуй всі файли в один .zip (до 100 МБ) або завантажуй кожен файл окремо. Внесок у спільноту – це легкий спосіб допомогти іншим та отримати додаткові можливості на сайті. Твої старі роботи можуть приносити тобі нові нагороди!
Нічого не вибрано
0%

Оголошення від адміністратора

Антиботан аватар за замовчуванням

Подякувати Студентському архіву довільною сумою

Admin

26.02.2023 12:38

Дякуємо, що користуєтесь нашим архівом!