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