2014 dxdy logo

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

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




Начать новую тему Ответить на тему На страницу Пред.  1, 2, 3
 
 Re: Итальянка
Сообщение05.10.2023, 21:56 


05/09/16
12203
lel0lel в сообщении #1612606 писал(а):
в котором каждый бит это три умножения. Его можно переписать, что умножений будет два ( меньше для рекурсий второго порядка не получить)

Там ведь даже не умножения, а возведения в квадрат, а это должно быть быстрее чем просто умножение.
lel0lel в сообщении #1612606 писал(а):
Поздравляю)
Примерно в полтора раза быстрее.

Вольфрам, как я слышал, небыстрый. pari/gp тоже интерпретатор, но вот на подобные вычиcления немного лучше заточен, вот и всё.
lel0lel в сообщении #1612606 писал(а):
Очень может быть, и, кстати, похоже на правду, так как это объясняет различие в полтора раза.
Не не, в программах на pari/gp что я запускал не используется встроенная функция вычисления Фибоначчи, она такие большие числа не умеет.
Использовалось два кода, подсказанный ув. maxal, через производящую функцию, по модулю
fibomod_2(n,m)=lift(polcoef(lift(Mod(x,(x^2-x-1)*Mod(1,10^m))^n),1,x))
и возведением "производящей матрицы" в степень, тоже по модулю:
fibomod_1(n,m)=lift(((Mod([1,1;1,0],10^m))^(n-1))[1,1])

Обе берут на вход n - номер числа Фибоначчи, m - сколько последних цифр вернуть в качестве результата (ведущие нули опускаются).
С кодом fibomod_2(), использующим производящую функцию, надо быть осторожным: переменная x не должна использоваться до этого кода, или надо выполнить команду kill(x) если использовалась.

P.S. Ну а вообще, сермяжная правда конечно в том, что числа Фибоначчи (и вообще ЛРП, но Фибоначчи в особенности) и всё про них украдено задолго до нас. :mrgreen: Но сейчас вычисления такого объема , как например предложили вы (стомиллионнозначные числа по тысячезначному модулю), стало доступно на гаджетах (я пользуюсь андроид планшетом, и он по скорости примерно такой же как мой ноутбук) лёжа на диване, и позволяет легко удовлетворить праздный интерес.

 Профиль  
                  
 
 Re: Итальянка
Сообщение05.10.2023, 23:02 
Заслуженный участник


20/04/10
1909
wrest в сообщении #1612618 писал(а):
lel0lel в сообщении #1612606 писал(а):
в котором каждый бит это три умножения. Его можно переписать, что умножений будет два ( меньше для рекурсий второго порядка не получить)
Там ведь даже не умножения, а возведения в квадрат, а это должно быть быстрее чем просто умножение.

Про три умножения -- это я про алгоритм, который использовался при расчёте выше мной. Он легко переписывается под два умножения, правда именно умножения, поэтому, как вы верно заметили два squaring в алгоритме gmp всё равно будут немного быстрее, скорее всего.
wrest в сообщении #1612618 писал(а):
Вольфрам, как я слышал, небыстрый. pari/gp тоже интерпретатор, но вот на подобные вычиcления немного лучше заточен, вот и всё.
Да, это влияет, но не сильно, на таких объемах основное -- это количество больших умножений, если его сделать минимальным, то ни интерпретатор, ни железо -- не главное.
wrest в сообщении #1612618 писал(а):
Не не, в программах на pari/gp что я запускал не используется встроенная функция вычисления Фибоначчи, она такие большие числа не умеет.

Это понятно, я вам отправлял код maxal, там, при вычислении $x^n \bmod Cp(x)$, используется только возведение в квадрат полиномов по полиномиальному модулю (алгоритм Fiduccia), тем не менее это почти тоже, что некоторое количество умножений по модулю. Поэтому я и сказал, что так или иначе, в pari для умножения двух линейных полиномов по модулю полинома второго порядка реализация эквивалентна двум большим умножениям. Отсюда и различие 3/2. Про другие коды сказать не берусь, так как pari не использую, но, с большой вероятностью, это те же два умножения (быть может squaring).
wrest в сообщении #1612618 писал(а):
всё про них украдено задолго до нас
Это вы зря, полно открытых проблем. Машины считают быстро, это ваша правда. Посчитаю пожалуй "пентаначчи") давно ничего не считал, так, ради интереса: $f_0=f_1=f_2=f_3=0, f_4=1, f_{k+5}=f_{k+4}+f_{k+3}+f_{k+2}+f_{k+1}+f_{k}$. Задача таже. Расчётное время полёта 2 часа 26 минут :D, но я пожалуй спать

 Профиль  
                  
 
 Re: Итальянка
Сообщение06.10.2023, 01:47 
Заслуженный участник


20/04/10
1909
Время в секундах, немного раньше планируемого.
Код:
In[116]:= AbsoluteTiming[AnyOrderRecurrenceModulo[{0, 0, 0, 0, 1}, {1, 1, 1, 1, 1}, 10^10000000, 10^1000]]

Out[116]= {7474.47,
297919434044441427313952240882791859235377456519957485683612326523101343187362485727950513984897408395496
758254206776045600872220478373237452374283441317226722846870348022952014396504076758453612303636532822655
484940428198255664630193251812981357182008672955588092292209205401387170080496741712116822345565753287753
952057689414845743494482987594714257798724183449405530685469958729607189120032090941391938738193571965020
989325826484390252837443091721399860062328139936172039093718733375213438541691651031355203405931173528985
527672468556878197950083643100603759034920127037472513136157172439312821183036734091812810198773052715056
796167537718276046473659449129481680288867987158434436222784729602238558415469784467770705947560236441675
070255456452649997533877319135183367080208234025796307848225760647126584074253677577392179807162815590026
358723966740095321659626251879997346875931238743224948041964358907625571889757090877956684833848932495317
91795297759953095409776391702029485
2042506005648324353}

 Профиль  
                  
 
 Re: Итальянка
Сообщение06.10.2023, 08:36 


05/09/16
12203
lel0lel в сообщении #1612491 писал(а):
Давайте проведём небольшой конкурс железа: посчитаем $F_n\bmod 10^{1000}$ для $n=10^{10^7}$. У меня получилось так (не пользуясь периодичностью)

Если вспомнить про период, то время счета будет 300мс (результат не печатаю, он правильный) :mrgreen:
? fibomod_10m(n,m)=n=n%(15*10^(m-1));lift(((Mod([1,1;1,0],10^m))^(n-1))[1,1])
? fibomod_10m(10^(10^7),1000);
? ##
*** last result computed in 306 ms.
?


-- 06.10.2023, 08:52 --

lel0lel в сообщении #1612623 писал(а):
Посчитаю пожалуй "пентаначчи")

Вот универсальные ванлайнеры для обсуждаемой темы
1. Считаем n-ое k-наччи (подсмотрено в oeis про пентаначчи):
knacci(n, k)=(matrix(k, k, i, j, i==j-1||i==k)^n)[1, k]
Например 20-е пентаначчи:
? knacci(20,5)
%229 = 26784
?


2. Считаем n-ое k-наччи по модулю m
knaccimod(n,k,m)=lift(((Mod(matrix(k, k, i, j, i==j-1||i==k),m))^(n))[1,k])
Например 20-e 5-наччи по модулю 1000:
? knaccimod(20,5,10^3)
%230 = 784
?


-- 06.10.2023, 08:53 --

lel0lel в сообщении #1612633 писал(а):
Время в секундах, немного раньше планируемого.

У меня чуть меньше часа (57 минут).

 Профиль  
                  
 
 Re: Итальянка
Сообщение06.10.2023, 09:41 


05/09/16
12203
Для закрытия обощенного вопроса темы хорошо бы ещё научиться вычислять период k-наччи по модулю (ЛРП же периодические все по модулю, если я правильно понимаю).

 Профиль  
                  
 
 Re: Итальянка
Сообщение06.10.2023, 11:14 


05/09/16
12203
wrest в сообщении #1612650 писал(а):
Для закрытия обощенного вопроса темы хорошо бы ещё научиться вычислять период k-наччи по модулю (ЛРП же периодические все по модулю, если я правильно понимаю).

Можно даже не наименьший (главный), если это сложно, а какой-нибудь.

 Профиль  
                  
 
 Re: Итальянка
Сообщение06.10.2023, 14:52 
Модератор
Аватара пользователя


11/01/06
5710
maxal в сообщении #1559683 писал(а):
Строгое изложение теории можно найти в учебнике
Глухов М. M., Елизаров В. П., Нечаев А. А. Алгебра.
См. глава 25 § 9. Вычисление периода и длины подхода ЛРП над конечным полем

 Профиль  
                  
 
 Re: Итальянка
Сообщение06.10.2023, 15:01 


05/09/16
12203
maxal
Спасибо, я пас: у меня не хватает образования для этой главы этой книги.
Может, lel0lel или Doctor Boom почитают.

 Профиль  
                  
 
 Re: Итальянка
Сообщение06.10.2023, 15:07 
Модератор
Аватара пользователя


11/01/06
5710
Вот здесь есть код для вычисления периода по простому модулю:
post1559671.html#p1559671

 Профиль  
                  
 
 Re: Итальянка
Сообщение06.10.2023, 15:17 


05/09/16
12203
maxal в сообщении #1612699 писал(а):
Вот здесь есть код для вычисления периода по простому модулю:

Да, я видел. Но у нас модуль не простой (пока интересовались последними цифрами десятичной записи, т.е. модулями вида $2^n\cdot 5^n$) и код, ессно, не работает...

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

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



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

Сейчас этот форум просматривают: ИСН


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

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