Как я могу оптимизировать производительность рекурсивного алгоритма для решения сложной комбинаторной задачи с помощью мемоизации и многопроцессорной обработки в Python?»
Я работаю над комбинаторной задачей, над которой мне нужно генерировать все возможные конфигурации заданных входных данных и вычислять результат на основе определенных ограничений. Вот краткое описание того, что я делаю:
Я использую рекурсивную функцию для генерации конфигураций.
Чтобы улучшить эффективности, я реализовал мемоизацию с помощью functools.lru_cache Python.
Однако размер входных данных значительно увеличился, и теперь вычисление решения занимает слишком много времени.
Я хочу изучить возможность использования многопроцессорных возможностей Python для распараллеливания вычислений. все еще используя мемоизацию. Однако я столкнулся со следующими проблемами:
lru_cache не является потокобезопасным или процессобезопасным.
Когда я разделил работу между несколькими процессы, кэш мемоизации не является общим между ними, что приводит к повторным вычислениям в разных процессах.
Управление общим состоянием для мемоизации между процессами является сложным и подвержено состояниям гонки.
Есть ли способ эффективно объединить многопроцессорность с общим кешем запоминания в Python? Если нет, то какие альтернативные подходы я могу использовать для оптимизации этого рекурсивного комбинаторного алгоритма?
Ограничения:
Размер входных данных может быть очень большим (например, сотни элементов).
Решение должно быть масштабируемым для использования на многоядерных машинах.
Дерево рекурсии имеет перекрывающиеся подзадачи, что делает запоминание необходимым для эффективности.
Я хочу, чтобы этот вопрос быть решена, и я ожидаю на него соответствующего ответа
Подробнее здесь: https://stackoverflow.com/questions/792 ... -to-python
Относится к Python [закрыто] ⇐ Python
Программы на Python
1731960337
Anonymous
Как я могу оптимизировать производительность рекурсивного алгоритма для решения сложной комбинаторной задачи с помощью мемоизации и многопроцессорной обработки в Python?»
Я работаю над комбинаторной задачей, над которой мне нужно генерировать все возможные конфигурации заданных входных данных и вычислять результат на основе определенных ограничений. Вот краткое описание того, что я делаю:
Я использую рекурсивную функцию для генерации конфигураций.
Чтобы улучшить эффективности, я реализовал мемоизацию с помощью functools.lru_cache Python.
Однако размер входных данных значительно увеличился, и теперь вычисление решения занимает слишком много времени.
Я хочу изучить возможность использования многопроцессорных возможностей Python для распараллеливания вычислений. все еще используя мемоизацию. Однако я столкнулся со следующими проблемами:
lru_cache не является потокобезопасным или процессобезопасным.
Когда я разделил работу между несколькими процессы, кэш мемоизации не является общим между ними, что приводит к повторным вычислениям в разных процессах.
Управление общим состоянием для мемоизации между процессами является сложным и подвержено состояниям гонки.
Есть ли способ эффективно объединить многопроцессорность с общим кешем запоминания в Python? Если нет, то какие альтернативные подходы я могу использовать для оптимизации этого рекурсивного комбинаторного алгоритма?
Ограничения:
Размер входных данных может быть очень большим (например, сотни элементов).
Решение должно быть масштабируемым для использования на многоядерных машинах.
Дерево рекурсии имеет перекрывающиеся подзадачи, что делает запоминание необходимым для эффективности.
Я хочу, чтобы этот вопрос быть решена, и я ожидаю на него соответствующего ответа
Подробнее здесь: [url]https://stackoverflow.com/questions/79201157/related-to-python[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия