Блог им. AlexeyPetrushin

Ускорить симуляцию

В симуляциях важна производительность, можно ускорить вычисления за счет болшей памяти а) кеш, это отдельная тема б) приближенной функцией. Где вместо реально и сложной функции используется ее приближение из 100, 1000 или 10000 точек.

count = 1000
ys[i] = fn(x) for x in collect([xmin, xmax], { count })
last_i = count-1

И затем любое значение можно получить как

y = ys[trunc(last_i*(x-xmin))]

Со скоростью 4х операций и хорошей локальностью памяти.

Как вариант можно линейную аппроксимацию, тоже быстро, но это еще быстрее, и точность часто вполне достаточная, ее можно повышать/понижать числом точек.

Языки использующие структуры близкие к железу (C, Nim, и т.п) но часто достаточно JavaScript/Java они также работают достаточно быстро.

П.С. Python/Matlab используют векторизацию и многие типовые операции реализованы эффективно на C, но таки, не всегда удается уложиться именно в эти операции.

324
1 комментарий
Для меня, это как для Вас,  Бис-октадиенил-метил амин.
avatar

Читайте на SMART-LAB:
Фото
📊 Конвертируемые облигации: как формируется доходность
Конвертируемые облигации — это инструмент, который сочетает в себе преимущества долгового и долевого инвестирования. Инвестор получает не...
Фото
Как создать своего торгового робота или приложение благодаря SDK от Xroad
Продвинутым пользователям программы для трейдинга может быть недостаточно базовых конфигураций, интеграции с Excel и роботов на Python....
Новички на Мосбирже: рассказываем о восьми новых криптоиндексах
Московская биржа начинает расчет и публикацию ценовых индексов восьми криптовалют, которые в будущем могут стать основой для запуска...
Фото
ММК: результаты в 2026 году продолжат ухудшаться. Актуализация взгляда на акции компании.
Здравствуйте! Продолжаю серию публикаций с актуализацией взгляда на российские металлургические компании и состояние рыночной конъюнктуры в...

теги блога Alex Craft

....все тэги



UPDONW
Новый дизайн