Как ускорить вычисления23.09.2014, 19:08. Показов 3273. Ответов 17
Метки нет Все метки)
(
Добрый день,
у меня есть алгоритм (имеющий достаточно много вычислений). Его надо прогнать 10^9 раз, но уже на 10^8 раз он считает полтора часа. Подскажите пожалуйста, какими методами я могу ускорить процесс вычисления? P/s: алгоритм так устроен, что следующая итерация зависит от результата предыдущей. Спасибо.
0
|
23.09.2014, 19:08 | |
Ответы с готовыми решениями:
17
Как ускорить программные вычисления? Как ускорить вычисления/дать больше ресурсов скомпилированному приложению в Borland C++ Builder |
23.09.2014, 19:38 [ТС] | |
taras atavin, я понимаю, что абстрактный вопрос. Но алгоритм привести не могу, да и смысл....
Меня интересует, как можно ускорить его? Распаралелить на несколько ПК не вариант, т.к. циклы зависят друг от друга (пока не посчитался первый, нельзя считать второй и т.д.).
0
|
Наблюдатель
![]() 457 / 192 / 33
Регистрация: 01.05.2012
Сообщений: 1,028
|
|
23.09.2014, 20:05 | |
Костяныч, в программировании (в современном это не так актуально, компы мощные, быстродействие - афигенное, памяти - завались, но раньше...) есть такое понятие как оптимизация кода.
т.е. грубо говоря в языке программирования "СуперУсик" (придумал только что) пустой цикл FOR выполняется (для количества циклов = 10 000) медленнее на 1 мили-секунду чем аналогичный цикл WHILE Соответственно вложенный цикл из тех же 10 000 затормозит алгоритм for по сравнению с while на сколько??? Тебе надо заняться оптимизацией кода Я не знаю на каком языке ты писал свою прогу, что она там считает, тем более что ты не торопишься рассказывать об этом. Отсюда мораль. Копай в сторону оптимизации. PS оптимизация это в том числе ликвидация повторных вычислений и действий PS2 в некоторых языках есть возможность засекать время выполнения циклов или вычислений.
1
|
![]() 4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
|
|
24.09.2014, 19:21 | |
Если уж спрашиваешь, то как раз скрывать нет смысла. А если скрываешь, то спрашивать.
Добавлено через 6 минут Да нет, это раньше было не так актуально, пока на процессороёмкие задачи тупо не хватало памяти. Тот же мк хоть забивай в него прогу, от качества пессимизации которой зависела жизнь лучшего хакера планеты, его жены и трёх дочерей, а тормозить он не сможет всё равно, так как в 102-х байтах тормоза просто не помещаются. Спектрум тормозить уже может, но умеренно и достаточно не пессимизировать, чтоб не тормозил. А на современных машинах с гигабайтами одной оперативы проги надо уже специально оптимизировать. Добавлено через 3 минуты Это у спектрума по меркам тогдашней памяти быстродействие было офигенное, эмкахе его вообще можно было на пару порядков уронить и ни кто бы этого даже не заметил, а сейчас ни кто в здравом уме кроме как по экономическим мотивам не откажется нарастить его порядков так на десять. Добавлено через 2 минуты Ну съэкономит он пару миллисеунд в час, так это съедается даже дефицитом точности тактового генератора. Оптимизация должна быть на уровне алгоритма, а изгнание подобных блох - это так, полировка.
0
|
![]() |
|
24.09.2014, 19:23 | |
Из практики.
1. Если в цикле или далее в нескольких выражениях используется одно и тоже выражение/функция/постоянная - определить/вычислить заранее. 2. х*х выполняется быстрее, чем x^2. 3. Если точность вычислений позволяет, то простейшие функции быстрее считать через ряд. 4. Сложные функции мы заранее табулировали и вводили как исходные данные. Промежуточные значения - интер- или экстраполяция. 5. Избегать ссылки на ссылки. Есть и 6-е и 7-е и т.д. Ничего нового я не сказал. Все это есть в учебниках.
1
|
9 / 10 / 2
Регистрация: 18.06.2013
Сообщений: 119
|
|
24.09.2014, 19:38 | |
1. Пиши на асме.
2. используй ПЛИС, т.к. они созданы для решения различных вычислительных задач. 3. Используй математику, т.е попробуй решать задачи проще. Пример - карта Карно. У тебя имеется набор из 20 переменных, и 100 условий выполнения одного действия. Если будешь описывать все 100 условий, то грош тебе цена, а, использую теорему ДеМоргана, ты сокращаешь запись, и за это уже получаешь: 1) изящную запись; 2) минимум кода - уже оптимизация; 3) быстродействие - ещё оптимизировал. Добавлено через 28 секунд Пришли алгоритм. Но чувствую, что у тебя банальный брутфорс
1
|
24.09.2014, 20:28 [ТС] | |
Спасибо, весьма дельные советы! Некоторые уже использовал.
А что быстрее будет 3 if или switch сразу? Добавлено через 1 минуту И где можно почитать (сгусток подходов) часто встречающиеся, так сказать паттерны для оптимизации кода?
0
|
24.09.2014, 20:37 [ТС] | |
Alex Dark, java)
0
|
24.09.2014, 20:47 | |
0
|
24.09.2014, 20:56 | |
0
|
Наблюдатель
![]() 457 / 192 / 33
Регистрация: 01.05.2012
Сообщений: 1,028
|
|
25.09.2014, 21:59 | |
1
|
25.09.2014, 21:59 | ||||||
Помогаю со студенческими работами здесь
18
Ускорить вычисления с double (round и др.) Надо ускорить алгоритм вычисления чисел с не повторяющимися цифрами Как ускорить Как ускорить код? Recordset - Как ускорить? Искать еще темы с ответами Или воспользуйтесь поиском по форуму:
|
|
Новые блоги и статьи
![]() |
||||
Мониторинг с Prometheus в PHP
Jason-Webb 04.04.2025
Prometheus выделяется среди других систем мониторинга своим подходом к сбору и хранению метрик. В отличие от New Relic, который использует агентный подход и отправляет данные во внешнее хранилище,. . .
|
Пакет Context в Golang: Управление потоками и ресурсами
golander 04.04.2025
Работа с горутинами в Go часто напоминает управление непослушными детьми - они разбегаются кто куда, делают что хотят и не всегда завершаются вовремя. К счастью, в Go 1. 7 появился пакет context,. . .
|
Контейнеризация React приложений с Docker
Reangularity 03.04.2025
Контейнеризация позволяет упаковать приложение со всеми его зависимостями в автономный контейнер, который можно запустить на любой платформе с установленным Docker. Это существенно упрощает процессы. . .
|
Свой попап в SwiftUI
mobDevWorks 03.04.2025
SwiftUI, как декларативный фреймворк от Apple, предоставляет множество инструментов для создания пользовательских интерфейсов. В нашем распоряжении есть такие API как alerts, popovers, action sheets. . .
|
Антипаттерны микросервисной архитектуры
ArchitectMsa 03.04.2025
Хорошо спроектированная микросервисная система может выдержать испытание временем, оставаясь гибкой, масштабируемой и устойчивой к большинству проблем. Такая архитектура обладает высоким уровнем. . .
|
std::mutex в C++: Советы и примеры использования
bytestream 03.04.2025
std::mutex - это механизм взаимного исключения, который гарантирует, что критический участок кода выполняется только одним потоком в каждый момент времени. Это простое, но могущественное средство. . .
|
Не удержался от оценки концепции двигателя Стирлинга.
Hrethgir 03.04.2025
Сколько не пытался - она выдавала правильные схемы, причём случайно рисовала горячие области в середине, холодные по краям, трубки с краёв в низ и магнит в соединяющей, но при этой выдавала описание. . .
|
Метод с двумя буферами (или double buffering) или ping-pong buffering
Hrethgir 02.04.2025
Из ответов LM модели.
Метод, который предполагает использование двух массивов для хранения промежуточных результатов сложения векторов, обычно применяется в сценариях, где необходимо минимизировать. . .
|
На любовном киберфронте
Alexander-7 01.04.2025
Недавно на одном малоизвестном сайте знакомств мною заинтересовалась девушка:
«Текст немного странный. Но, судя по адресу почты, иностранка», – подумал я. Поколебавшись пару суток, я ответил ей:. . .
|
Как работает Node.js изнутри
run.dev 29.03.2025
Node. js изменил подход к разработке веб-приложений, позволив использовать JavaScript не только на стороне клиента, но и на сервере. Созданный в 2009 году Райаном Далем, этот открытый,. . .
|