Программная реализация решения алгебраического уравнения методом Бернулли

Решение алгебраических и трансцендентных уравнений в физике, механике, технике, естествознании. Построение некоторой последовательности чисел для вычисления по методу Бернулли. Удобность метода для вычисления на компьютере, повторение операции накопления.

Рубрика Программирование, компьютеры и кибернетика
Вид курсовая работа
Язык русский
Дата добавления 13.09.2017
Размер файла 384,4 K

Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже

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

Размещено на http://www.allbest.ru/

Министерство образования и науки РФ

ФГБОУ ВПО «Удмуртский государственный университет»

Математический факультет

Кафедра вычислительной механики

Курсовая работа на тему:

«Программная реализация решения алгебраического уравнения методом Бернулли»

Научный руководитель:

Камидуллина Т.В.

Студент группы ОБ-010800-31

Копысов Е.С.

Ижевск 2015г

Содержание

Введение

Обозначения

Постановка задачи

Структура данных

Алгоритм

Заключение

Литература

Приложение

Введение

Вычислительная техника наших дней представляет собой мощные средства для фактического выполнения счетной работы. Благодаря этому во многих случаях стало возможным отказаться от приближенной трактовки прикладных вопросов и перейти к решению задач в точной постановке. Решение уравнений - алгебраических или трансцендентных - представляет собой одну из существенных задач прикладного анализа, потребность в которой возникает в многочисленных и самых разнообразных разделах физики, механики, техники и естествознания в широком смысле этого слова. Курсовая работа посвящена одному из методов решения алгебраических уравнений - методу Бернулли.

Обозначения

coeffs - массив коэффициентов

с - массив коэффицентов (по Вержбницкому В.М. c[i])

i - счетчик цикла

coeffs.length - длина массива coeffs

u - массив коэффицентов (по Вержбницкому В.М. u[i])

k, i, j - счетчики циклов

g - корень (по первому условию)

gg - корень (по второму условию)

n - число коэфициентов

answer - строка для ввода с консоли

arrcoeffs - строчный массив коэффицентов

arrcoeffs.length - длина массива

ex - исключение типа NumberFormatException

ex - исключение типа NumberFormatException

ex - исключение типа Exception

lim - предел рандомизации

rnd - объект типа Random

root - корень

Постановка задачи

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

Вычисления по методу Бернулли сводятся в основном к построению некоторой последовательности чисел , для построения которой выбираются вначале некоторые, вообще говоря, произвольные значения . После этого значения вычисляются с помощью рекуррентной формулы:

,

Далее по виду последовательности определяется вид наибольшего (наименьшего) по модулю корня и значение этого корня.

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

После того как найден второй по модулю корень, аналогично находятся третий и последующие корни.

Пусть погрешность округления во всех вычислениях постоянна и равна . Тогда относительная погрешность первого корня равна

, где .

Потеря точности для последующих корней может быть значительно больше.

Таким образом, метод Бернулли обладает очень простой вычислительной схемой. Основные вычисления сводятся к повторению операции накопления, что делает метод удобным для вычисления на ЭВМ. Кроме того, корни в методе Бернулли определяются не все сразу, а один или несколько наибольших (наименьших) по модулю корней, что приводит к потере точности для остальных корней.

Структура данных

Входные данные: double[] coeffs, int n

Выходные данные: double g1

Промежуточные данные:

Double - вещественный объектный тип

int - целочисленный примитивный тип

double - вещественный примитивный тип

String - строковый тип

NumberFormatException - тип исключения

NullPointerException - тип исключения

NumberFormatException - тип исключения

Exception - тип исключения

Random - тип Random

k, i, j - примитивный целочисленный тип

lim - примитивный целочисленный тип

root - вещественный объектный тип

ex - примитивный целочисленный тип

coeffs.length- примитивный целочисленный тип

с ,u,n - примитивный целочисленный тип

arrcoeffs - примитивный целочисленный тип

Алгоритм

Заключение

Данный отчет был подготовлен в течение нескольких дней. Все досконально изучив и наладив, проверив программу, результаты работы меня удволетворили. бернулли уравнение последовательность алгебраический

Литература

1. Вержбицкий В.М. - Основы численных методов. Учебник для вузов. Высш. школа - 2002г.

2. Латыпова Н.В. «Методические указания и рекомендации по вычислительной практике» УдГу, Ижевск,2004г

3. Ким И.Г, Латыпова Н.В., Моторина О.Л. «Численные методы ч.2» УдГу, Ижевск,2013г

4. Ким И.Г, Латыпова Н.В.«Численные методы ч.1» УдГу, Ижевск,2012г

Приложение

Код программы

package Program;

import java.util.Random;

import java.util.Scanner;

public class Program {

public static Double bernoullisMethod(Double[] coeffs) { //метод Бернули

int n = coeffs.length - 1; //инициализация переменной размера массива для коэфф-в c[i]

double[] c = new double[n]; // создание экземпляра массива

for (int i = 1; i < coeffs.length; i++) // в цикле -

c[i - 1] = (-1) * coeffs[i] / coeffs[0]; // - подсчет c[i] коэфф-в

double[] u = new double[n * 2]; // создание экземпляра массива для u[i] коэфф-в

for (int i = 0; i < n - 1; i++)

u[i] = 0; // инициализация элементов до n по начальным условиям

for (int k = 1; k <= n; k++) { // в цикле для каждого u[n+k] элемента

u[n - 1] = k; // присвоение значения по условию

for (int j = 1; j <= n; j++) // вложенный цикл (сумма u[n+k])

u[(n + k) - 1] = c[j - 1] * u[(n + k - j) - 1]; // подсчет u[n+k-j] коэфф-в

}

double g = u[n + n - 2] / u[n + n - 3]; // подсчет корня по первому условию

double gg = u[n + n - 1] / u[n + n - 3]; // подсчет корня по второму условию

return Math.max(g, gg); // вывод максимального корня

}

public static void main(String[] args) {

while (true) {

int n; //число коэфициентов

Double[] coeffs; //массив коэффициентов

try { //попытка выполнить дальнейший код

// инициализация коэффициентов

System.out.print("введите число коэфициентов полинома n = "); // вывод в консоль

n = new Scanner(System.in).nextInt(); //ввод числа n с консоли

//исключение простых уравнений, где n < 3

if (n < 3) {

System.out.println("задайте n больше ");

continue;

}

coeffs = new Double[n]; //создание массива коэфф-в

System.out.println("введете коэффиценты c[i] сами? да/нет"); // вывод в консоль

String answer; //переменная ответа

answer = new Scanner(System.in).nextLine(); //ввод ответа с консоли

if (answer.equals("да")) { //проверка ответ. если "да", то происходит ввод значения коэфф-в вручную

System.out.println("вводите коэффициенты в одну строку, отделяя пробелами"); // вывод в консоль

String[] arrcoeffs = new Scanner(System.in).nextLine().split("\\s+"); //инициализация массива коэфф-в (строки)

if (n == arrcoeffs.length) { //проверка равенства n и длины массива

try { //попытка выполнить дальнейший код

for (int i = 0; i < n; i++) { //для каждого коэфф-та -

coeffs[i] = Double.parseDouble(arrcoeffs[i]); // - его конвертация из строки в вещественное число

}

} catch (NumberFormatException ex) { //перехватывание исключения NumberFormatException

System.out.println("ошибка ввода: "

+ ex.getMessage() + "\n повторите ввод"); //вывод в консоль

continue;

} catch (NullPointerException ex) { //перехватывание исключения NullPointerException

System.out.println("ошибка ввода: "

+ ex.getMessage() + "\n повторите ввод"); //вывод в консоль

continue;

} catch (Exception ex) { //перехватывание общего исключения (ошибки)

System.out.println("один из коэф-тов не является числом "); //вывод в консоль

continue;

}

} else { //когда n не совпадает с размерностью массива

System.out.println("количество к-в не соответствует "

+ "введенному n\n повторите ввод"); // вывод в консоль

continue;

}

} else { //если ответ не "да", коэфф-ты задаются рандомно

int lim = 20; //предел рандомизации

System.out.println("выбраны случайные целые коэффициэнты "

+ "из интервала [" + (-1) * lim + "," + lim + "]"); // вывод в консоль

Random rnd = new Random(); //создание экземпляра класса Random

for (int i = 0; i < n; i++) { // задание произвольных коэфф-в в цикле -

coeffs[i] = (double) rnd.nextInt(lim + 1) - lim; // - значения берутся из интервала [-lim;lim]

System.out.format("%.2f ", coeffs[i]); // последовательный вывод в консоль

}

}

// подсчет корней

double root = bernoullisMethod(coeffs); //применение метода Бернули

System.out.println("\nметодом Бернули посчитан один из максимальных "

+ "корней \ng1 = " + root

+ "\n хотите посчитать новые (или выйти)? да/нет"); //вывод в консоль

// условие невыхода

answer = new Scanner(System.in).nextLine(); // ввод ответа с консоли

if (answer.equals("да")) // проверка ответа. если "да", то программа начинается сначала

continue;

else

return; //иначе происходит выход

} catch (Exception ex) { // перехватывание общего исключения

System.err.println(ex); //вывод исключения через поток err

System.out.println("повторите ввод"); // вывод в коноль

continue;

}

}

}

}

Пример программы:

Размещено на Allbest.ru

...

Подобные документы

  • Описание алгоритма создания программы для решения алгебраических или трансцендентных уравнений с помощью численного метода Бернулли. Нахождение значений корней алгебраического уравнения с заданными параметрами точности. Листинг программы на языке java.

    контрольная работа [206,0 K], добавлен 19.06.2015

  • Численные методы решения задач. Решение алгебраических и трансцендентных уравнений. Уточнение корня по методу половинного деления. Решение систем линейных уравнений методом итераций. Методы решения дифференциальных уравнений. Решение транспортной задачи.

    курсовая работа [149,7 K], добавлен 16.11.2008

  • Понятие определителя матрицы, математические и алгоритмические основы его расчета, функциональные модели, блок-схемы и программная реализация. Сущность метода Гаусса для решения систем линейных алгебраических уравнений и вычисления определителя матрицы.

    контрольная работа [455,2 K], добавлен 18.01.2010

  • Математический алгоритм вычисления корней нелинейного уравнения и его решение методом касательных. Особенности программной реализации решения таких уравнений. Процедура подготовки и решения задачи на ЭВМ, характеристика алгоритма и структуры программы.

    курсовая работа [96,6 K], добавлен 02.06.2012

  • Решение систем алгебраических линейных уравнений методом Крамера. Сущность метода прогонки. Программная реализация метода: блок-схема алгоритма, листинг программы. Проверка применимости данного способа решения для конкретной системы линейных уравнений.

    курсовая работа [581,0 K], добавлен 15.06.2013

  • Итерационные методы решения нелинейных уравнений, системы линейных алгебраических уравнений (СЛАУ). Решение нелинейных уравнений методом интерполирования. Программная реализация итерационных методов решения СЛАУ. Практическое применение метода Эйлера.

    курсовая работа [1,6 M], добавлен 20.01.2010

  • Модифицированный метод Ньютона при заданных начальных условиях, где задаётся погрешность вычисления. Вычисления корня уравнения при помощи программы. Построения графика зависимости приближений двух координат, при котором задаются промежутки и константы.

    реферат [14,1 K], добавлен 29.01.2009

  • Алгоритм решения систем линейных уравнений методом Гаусса, его этапы. Система уравнений для определения коэффициентов сплайна, представляющая собой частный случай систем линейных алгебраических уравнений. Программная реализация, тестовый пример.

    курсовая работа [431,8 K], добавлен 15.06.2013

  • Основные леммы и теоремы для решения линейных интегральных уравнений методом итераций. Применение информационных технологий для вычисления функции, построение алгоритма для определения уравнения по ядру и отрезку интегрирования и правой части уравнения.

    курсовая работа [213,7 K], добавлен 27.11.2010

  • Системы линейных алгебраических уравнений. Код программы для решения систем линейных алгебраических уравнений. Математические и алгоритмические основы решения задачи методом Гаусса. Программная реализация решения. Алгоритмы запоминания коэффициентов.

    лабораторная работа [23,5 K], добавлен 23.09.2014

  • Применение итерационных методов численного решения системы линейных алгебраических уравнений при вычислении на ЭВМ. Математические и алгоритмические основы решения задачи, метод Гаусса. Функциональные модели и блок-схемы, программная реализация решения.

    курсовая работа [527,5 K], добавлен 25.01.2010

  • Поиск корня алгебраического уравнения. Формирование графических объектов на основе "Диаграмма Microsoft Graph". Системы линейных алгебраических уравнений. Алгоритм формирования и копирования матриц для вычисления определителей, вектора решения СЛАУ X.

    контрольная работа [991,1 K], добавлен 11.05.2009

  • Приведение системы линейных алгебраических уравнений к треугольному виду прямым ходом метода Гаусса. Применение обратного хода метода вращений. Создание алгоритма, блок-схемы и кода программы. Тестовый пример решения уравнения и его проверка в MathCad.

    лабораторная работа [164,3 K], добавлен 02.10.2013

  • Решение уравнения методом половинного деления. Программа в Matlab для уравнения (x-2)cos(x)=1. Решение нелинейных уравнений методом Ньютона. Интерполяция заданной функции. Решение системы линейных алгебраических и обыкновенных дифференциальных уравнений.

    курсовая работа [1,4 M], добавлен 15.08.2012

  • Автоматизация решения системы уравнения методом Гаусса (классического метода решения системы линейных алгебраических уравнений, остоящего в постепенном понижении порядка системы и исключении неизвестных) и решения уравнения методами хорд и Ньютона.

    курсовая работа [578,2 K], добавлен 10.02.2011

  • Системы линейных алгебраических уравнений. Матричный метод решения систем линейных уравнений. Решение задачи математическим методом. Блок-схема алгоритма и листинг программы. Расчет трудоемкости разработки программы. Расчет себестоимости и цены программы.

    дипломная работа [144,8 K], добавлен 25.04.2012

  • Методы решения нелинейных уравнений: прямые и итерационные. Методы решения трансцендентных, алгебраических уравнений. Метод деления отрезка пополам, Ньютона, простой итерации. Поиск корня уравнения методом простой итерации с помощью электронных таблиц.

    контрольная работа [2,4 M], добавлен 16.12.2011

  • Сравнительный анализ итерационных методов решения нелинейных алгебраических и трансцендентных уравнений. Простейший алгоритм отделения корней нелинейных уравнений. Метод половинного деления. Геометрический смысл метода Ньютона. Метод простой итерации.

    реферат [95,0 K], добавлен 06.03.2011

  • Сущность матричного метода. Разработка программы решения системы уравнений линейных алгебраических уравнений методом решения через обратную матрицу на языке программирования Delphi. Представление блок-схемы и графического интерфейса программного продукта.

    курсовая работа [1,0 M], добавлен 27.09.2014

  • Математические и алгоритмические основы решения задачи. Функциональные модели и блок-схемы решения задачи. Программная реализация решения задачи. ЛИСП-реализация вычисления неэлементарных функций. Вычисления гамма функции для положительных неизвестных х.

    курсовая работа [621,2 K], добавлен 18.01.2010

Работы в архивах красиво оформлены согласно требованиям ВУЗов и содержат рисунки, диаграммы, формулы и т.д.
PPT, PPTX и PDF-файлы представлены только в архивах.
Рекомендуем скачать работу.