2014 dxdy logo

Научный форум dxdy

Математика, Физика, Computer Science, Machine Learning, LaTeX, Механика и Техника, Химия,
Биология и Медицина, Экономика и Финансовая Математика, Гуманитарные науки


Правила форума


Посмотреть правила форума



Начать новую тему Ответить на тему На страницу 1, 2, 3, 4  След.
 
 Как на компьютере вычисляются корни и др мат. функции?
Сообщение24.08.2020, 02:57 


01/03/20
46
Как на компьютере вычисляются корни, показательная функция, логарифмы, тригонометрические функции? В учебниках по вычислительной математике есть разные способы, в том числе ряд Тейлора, итерационные методы. Но из учебников не понятно, какие алгоритмы приводятся для иллюстрации теории, а какие реально используются на практике.

 Профиль  
                  
 
 Re: Как на компьютере вычисляются корни и др мат. функции?
Сообщение24.08.2020, 07:52 
Заслуженный участник
Аватара пользователя


11/03/08
9904
Москва
Здесь кое-что можно найти
http://libarch.nmu.org.ua/handle/Genofo ... tribute=ru
http://www.toroid.ru/ivanovVV.html
Но вообще при выборе метода надо учитывать архитектуру конкретной ЭВМ.

 Профиль  
                  
 
 Re: Как на компьютере вычисляются корни и др мат. функции?
Сообщение24.08.2020, 08:42 


20/01/12
198
IvanX в сообщении #1480468 писал(а):
Как на компьютере вычисляются корни, тригонометрические функции?

CORDIC

 Профиль  
                  
 
 Re: Как на компьютере вычисляются корни и др мат. функции?
Сообщение24.08.2020, 13:02 


01/03/20
46
В приведенных книгах много методов, без примеров, не понятно, что именно выбрать :roll:
Попробую уточнить вопрос. Хочу написать программку на C++, которая вычисляет квадратный корень данного числа $x$ с заданной точностью $\varepsilon$. Какой именно алгоритм использовать?

 Профиль  
                  
 
 Re: Как на компьютере вычисляются корни и др мат. функции?
Сообщение24.08.2020, 13:07 
Заслуженный участник
Аватара пользователя


11/03/08
9904
Москва
Если просто действительные числа - алгоритм Герона. Для каких-то других числовых систем, а также для очень больших целых - надо что-то иное, но что? Надо уточнить, что считаем.

 Профиль  
                  
 
 Re: Как на компьютере вычисляются корни и др мат. функции?
Сообщение24.08.2020, 13:20 


01/03/20
46
Евгений Машеров в сообщении #1480516 писал(а):
Если просто действительные числа - алгоритм Герона.
Как по заданной погрешности $\varepsilon$ узнать кол-во итераций? Есть какая-то формула для оценки погрешности?
У меня получилось доказать сходимость последовательности Герона только для $a>1$. Доказал, что эта последовательность ограничена снизу и не убывает. Как доказать при $0<a<1$?

Евгений Машеров в сообщении #1480516 писал(а):
Надо уточнить, что считаем.
Для чисел double. Пусть я хочу написать свою функцию sqrt для C++. И желательно осмысленно, оптимально, с минимальным числом итераций по заданной погрешности.

 Профиль  
                  
 
 Re: Как на компьютере вычисляются корни и др мат. функции?
Сообщение24.08.2020, 13:30 


23/04/17
305
Россия
IvanX в сообщении #1480468 писал(а):
Как на компьютере вычисляются корни

Например, так это делается на ассемблере: http://ww1.microchip.com/downloads/en/AppNotes/00544d.pdf

 Профиль  
                  
 
 Re: Как на компьютере вычисляются корни и др мат. функции?
Сообщение24.08.2020, 14:24 


14/01/11
3040
IvanX в сообщении #1480518 писал(а):
Как по заданной погрешности $\varepsilon$ узнать кол-во итераций? Есть какая-то формула для оценки погрешности?

Этими вопросами занимается вычислительная математика. Берите учебник и изучайте. В частности, итерационная формула Герона для нахождения квадратного корня - это не что иное, как применение метода Ньютона к уравнению $x^2-a=0$, а сходимость метода Ньютона давно исследована и описана.

 Профиль  
                  
 
 Re: Как на компьютере вычисляются корни и др мат. функции?
Сообщение24.08.2020, 14:49 


05/09/16
12064
IvanX в сообщении #1480468 писал(а):
Как на компьютере вычисляются корни,

Вот так: http://cs.uccs.edu/~cs591/bufferOverflo ... 4/e_sqrt.c

 Профиль  
                  
 
 Re: Как на компьютере вычисляются корни и др мат. функции?
Сообщение24.08.2020, 14:53 
Заслуженный участник
Аватара пользователя


21/11/12
1968
Санкт-Петербург
Евгений Машеров в сообщении #1480516 писал(а):
... а также для очень больших целых - надо что-то иное

Важно еще в какой форме должен быть выражен результат. В простых дробях квадратный радикал из натурального $m$ может вычисляться так: $\dfrac{p_{n+1}}{q_{n+1}}=\dfrac{2p_n^2-1}{2p_nq_n}$, где $\dfrac{p_1}{q_1}$ — первое (или некоторое) решение ур. Пелля. Быстрее вряд ли что найдется. Пример: $\sqrt{2}=\dfrac{3}{2},\dfrac{17}{12},\dfrac{577}{408},\dfrac{665857}{470832},...$ уже $12$ дес. знаков.

 Профиль  
                  
 
 Re: Как на компьютере вычисляются корни и др мат. функции?
Сообщение24.08.2020, 17:55 
Заслуженный участник


16/02/13
4195
Владивосток
IvanX в сообщении #1480515 писал(а):
Какой именно алгоритм использовать?
Как вы думаете, писали бы толстенные книжки по вычислительным методам, если б существовал Самый Наилучший Алгоритм?
Andrey A в сообщении #1480529 писал(а):
В простых дробях
Чем ещё хорош подобный метод — очень просто вычисляется погрешность. Поскольку имеет место быть сходящийся ряд побольше-поменьше. А напоследок можно не постесняться да разделить, дабы получить десятичную дробь.

 Профиль  
                  
 
 Re: Как на компьютере вычисляются корни и др мат. функции?
Сообщение24.08.2020, 18:25 
Заслуженный участник
Аватара пользователя


21/11/12
1968
Санкт-Петербург
iifat в сообщении #1480544 писал(а):
... не постесняться да разделить

Можно. Если разовые затраты, к которым нужно отнести и решение Пелля, не сопоставимы с общими — прямой смысл. С рациональным $m$ это работает не хуже, тот же период, а вот для радикалов степени $>2$ периода нет. Но если нужна именно простая дробь, есть другие способы помучиться.

 Профиль  
                  
 
 Re: Как на компьютере вычисляются корни и др мат. функции?
Сообщение24.08.2020, 18:43 
Заслуженный участник
Аватара пользователя


01/08/06
3131
Уфа
Забавную вещь обнаружил: если число, не меньшее 1, записанное в стандартном формате IEEE-754 одинарной или двойной точности, побитово сдвинуть вправо, то получится неплохое начальное приближение для квадратного корня из этого числа.
Интересно, это так задумано, или случайно получилось?
UPD: К сожалению, не работает, см. коммент ниже.

 Профиль  
                  
 
 Re: Как на компьютере вычисляются корни и др мат. функции?
Сообщение24.08.2020, 18:54 
Заслуженный участник
Аватара пользователя


15/10/08
12519
worm2 в сообщении #1480558 писал(а):
Интересно, это так задумано, или случайно получилось?
Случайно ли получилось, что $x/2$ - хорошее начальное приближение для $\sqrt x $? Наверное, это больше зависит не от стандарта, а от алгоритма.

 Профиль  
                  
 
 Re: Как на компьютере вычисляются корни и др мат. функции?
Сообщение24.08.2020, 19:03 
Заслуженный участник
Аватара пользователя


01/08/06
3131
Уфа
Там не $x/2$ получается, а $\sqrt{1+x} \approx 1+x/2$ при $x < 1$, т.е. прямо по Тэйлору.

P.S. А нет, дьявол, не получается! Экспонента-то в этом формате сдвинута на 127 (для Single, для Double — на 1023), так что так просто не сработает. А так красиво было! экспонента тоже на два бы делилась, а нечётная давала бы подходящую прибавку в мантиссу :-(

-- Пн авг 24, 2020 21:17:40 --

Видимо, похожий хак применяется в алгоритме "Fast inverse square root".

 Профиль  
                  
Показать сообщения за:  Поле сортировки  
Начать новую тему Ответить на тему  [ Сообщений: 48 ]  На страницу 1, 2, 3, 4  След.

Модераторы: Модераторы Математики, Супермодераторы



Кто сейчас на конференции

Сейчас этот форум просматривают: Bing [bot]


Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете добавлять вложения

Найти:
Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group