Форум программистов, компьютерный форум, киберфорум
Теория программирования
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/15: Рейтинг темы: голосов - 15, средняя оценка - 4.80
20 / 20 / 4
Регистрация: 31.10.2010
Сообщений: 1,240
Записей в блоге: 2

Как ускорить вычисления

23.09.2014, 19:08. Показов 3273. Ответов 17
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Добрый день,
у меня есть алгоритм (имеющий достаточно много вычислений). Его надо прогнать 10^9 раз, но уже на 10^8 раз он считает полтора часа.
Подскажите пожалуйста, какими методами я могу ускорить процесс вычисления?
P/s: алгоритм так устроен, что следующая итерация зависит от результата предыдущей.
Спасибо.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
23.09.2014, 19:08
Ответы с готовыми решениями:

Как ускорить вычисления
Добрый вечер. Прошу помочь с решением следующей задачи. В моей проге базовый модуль производит вычисления на процессоре i5 -2400 за 11,5...

Как ускорить программные вычисления?
Паскаль использует только 1% памяти при сложных мат.вычислениях,и порой,это занимает часы. Можно ли как-то дать больше памяти паскалю,чтобы...

Как ускорить вычисления/дать больше ресурсов скомпилированному приложению в Borland C++ Builder
Уважаемые форумчане, В своей научной работе еще давно начал использовать Borland C++ Builder 6. Дело в том, что понадобилось выполнить...

17
 Аватар для taras atavin
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
23.09.2014, 19:10
Телепаты водятся на другом форуме.
0
20 / 20 / 4
Регистрация: 31.10.2010
Сообщений: 1,240
Записей в блоге: 2
23.09.2014, 19:38  [ТС]
taras atavin, я понимаю, что абстрактный вопрос. Но алгоритм привести не могу, да и смысл....
Меня интересует, как можно ускорить его? Распаралелить на несколько ПК не вариант, т.к. циклы зависят друг от друга (пока не посчитался первый, нельзя считать второй и т.д.).
0
Наблюдатель
 Аватар для Alex Dark
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
 Аватар для taras atavin
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
24.09.2014, 19:21
Цитата Сообщение от Костяныч Посмотреть сообщение
taras atavin, я понимаю, что абстрактный вопрос. Но алгоритм привести не могу, да и смысл....
Если уж спрашиваешь, то как раз скрывать нет смысла. А если скрываешь, то спрашивать.

Добавлено через 6 минут
Цитата Сообщение от Alex Dark Посмотреть сообщение
Костяныч, в программировании (в современном это не так актуально, компы мощные, быстродействие - афигенное, памяти - завались, но раньше...)
Да нет, это раньше было не так актуально, пока на процессороёмкие задачи тупо не хватало памяти. Тот же мк хоть забивай в него прогу, от качества пессимизации которой зависела жизнь лучшего хакера планеты, его жены и трёх дочерей, а тормозить он не сможет всё равно, так как в 102-х байтах тормоза просто не помещаются. Спектрум тормозить уже может, но умеренно и достаточно не пессимизировать, чтоб не тормозил. А на современных машинах с гигабайтами одной оперативы проги надо уже специально оптимизировать.

Добавлено через 3 минуты
Цитата Сообщение от Alex Dark Посмотреть сообщение
(в современном это не так актуально, компы мощные, быстродействие - афигенное, памяти - завались, но раньше...)
Это у спектрума по меркам тогдашней памяти быстродействие было офигенное, эмкахе его вообще можно было на пару порядков уронить и ни кто бы этого даже не заметил, а сейчас ни кто в здравом уме кроме как по экономическим мотивам не откажется нарастить его порядков так на десять.

Добавлено через 2 минуты
Цитата Сообщение от Alex Dark Посмотреть сообщение
т.е. грубо говоря в языке программирования "СуперУсик" (придумал только что) пустой цикл FOR выполняется (для количества циклов = 10 000) медленнее на 1 мили-секунду чем аналогичный цикл WHILE
Соответственно вложенный цикл из тех же 10 000 затормозит алгоритм for по сравнению с while на сколько???
Тебе надо заняться оптимизацией кода
Я не знаю на каком языке ты писал свою прогу, что она там считает, тем более что ты не торопишься рассказывать об этом.
Ну съэкономит он пару миллисеунд в час, так это съедается даже дефицитом точности тактового генератора. Оптимизация должна быть на уровне алгоритма, а изгнание подобных блох - это так, полировка.
0
 Аватар для OldFedor
7485 / 4149 / 474
Регистрация: 25.08.2012
Сообщений: 11,530
Записей в блоге: 11
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
 Аватар для taras atavin
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
24.09.2014, 19:40
Цитата Сообщение от OldFedor Посмотреть сообщение
2. х*х выполняется быстрее, чем x^2.
Во-первых ксорка не заменяется умножением. А во-вторых медленнее как раз арифметика.
0
 Аватар для OldFedor
7485 / 4149 / 474
Регистрация: 25.08.2012
Сообщений: 11,530
Записей в блоге: 11
24.09.2014, 20:25
Известный факт, taras atavin, умножение выполняется значительно быстрее возведения в целочисленную степень.
0
20 / 20 / 4
Регистрация: 31.10.2010
Сообщений: 1,240
Записей в блоге: 2
24.09.2014, 20:28  [ТС]
Спасибо, весьма дельные советы! Некоторые уже использовал.
А что быстрее будет 3 if или switch сразу?

Добавлено через 1 минуту
И где можно почитать (сгусток подходов) часто встречающиеся, так сказать паттерны для оптимизации кода?
0
Наблюдатель
 Аватар для Alex Dark
457 / 192 / 33
Регистрация: 01.05.2012
Сообщений: 1,028
24.09.2014, 20:29
Ты-б хоть язык программирования озвучил то.
Иль это то же тайна как и алгоритм?
0
20 / 20 / 4
Регистрация: 31.10.2010
Сообщений: 1,240
Записей в блоге: 2
24.09.2014, 20:37  [ТС]
Alex Dark, java)
0
 Аватар для taras atavin
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
24.09.2014, 20:43
Цитата Сообщение от OldFedor Посмотреть сообщение
Известный факт, taras atavin, умножение выполняется значительно быстрее возведения в целочисленную степень.
То есть имелся в виду бейсик? Тогда согласен.
0
24.09.2014, 20:47

Не по теме:

Цитата Сообщение от taras atavin Посмотреть сообщение
То есть имелся в виду бейсик?
И Фортран тоже.

0
 Аватар для taras atavin
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
24.09.2014, 20:54
А что, на фортране есть оператор возведения в степень и он выглядит также?
0
24.09.2014, 20:56

Не по теме:

Цитата Сообщение от taras atavin Посмотреть сообщение
А что, на фортране есть оператор возведения в степень
** _

0
 Аватар для taras atavin
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
25.09.2014, 15:49
Раскритиковал правильно, но ни слова не сказал по теме (пусть она и вилами на воде писана), кроме последней фразы об алгоритме.
Так темы то по сути нет.
0
Наблюдатель
 Аватар для Alex Dark
457 / 192 / 33
Регистрация: 01.05.2012
Сообщений: 1,028
25.09.2014, 21:59
Цитата Сообщение от taras atavin Посмотреть сообщение
Так темы то по сути нет.
пусть она и вилами на воде писана
а это разве не то-же самое.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
25.09.2014, 21:59
Помогаю со студенческими работами здесь

Ускорить вычисления с double (round и др.)
Здравствуйте, я пишу небольшую DLL на C++, но при большом объёме входных данных, она очень сильно загружает процессор, вероятно из-за...

Надо ускорить алгоритм вычисления чисел с не повторяющимися цифрами
Помогите ускорить алгоритм. Надо определить все числа с не повторяющимися цифрами от 0 до 9876543210. У меня время просчета занимает очень...

Как ускорить
Задача Рассмотрим последовательность целых чисел длины N. По ней с шагом 1 двигается “окно” длины K, то есть сначала в “окне” видно...

Как ускорить код?
var subs = Database.Subscription; var ss = !subType ? subs.Where(s => !s.SubscriptionType) :...

Recordset - Как ускорить?
Добрый вечер! Товарищи, очень нужна помощь в понимании процесса выгрузки данных из БД Oracle в Excel через Recordset. Поясню, с...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
18
Ответ Создать тему
Новые блоги и статьи
Мониторинг с 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 году Райаном Далем, этот открытый,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер