Моделирование труднорешаемых задач — различия между версиями
Материал из DISCOPAL
StasFomin (обсуждение | вклад) |
StasFomin (обсуждение | вклад) (→Как с этим работаем .) |
||
(не показаны 33 промежуточные версии этого же участника) | |||
Строка 1: | Строка 1: | ||
<noinclude><slideshow style="ispras" headingmark="." scaled=1 /></noinclude> | <noinclude><slideshow style="ispras" headingmark="." scaled=1 /></noinclude> | ||
+ | |||
+ | ;Обязательно посмотрите: | ||
+ | {{vimeoembed|820808618|800|450}} | ||
+ | {{vimeoembed|887817907|800|450}} | ||
+ | {{vimeoembed|887825798|800|450}} | ||
+ | |||
+ | Цели: для осеннего курса 2023, где собрались скорее заинтересованные практикой, чем сложностью задач, можно | ||
+ | * Сделать одну задачу целиком (визуализация, постановка в ЦЛП и сведение от 3SAT) | ||
+ | * Или пару задач «поверхностно» — постановка + визуализация (это легкая часть), без части про сведение от 3SAT и тестирования (это может быть очень головоломно). | ||
+ | * Можно сделать и больше, такой же блок, может заменить решение задачи из [[Моделирование бизнес-задач]], если те почему-то не понравились. | ||
+ | * Может можно будет даже сделать и меньше, если будет сделано качественно (красивая визуализация, или сложная задача и т.п) — т.е. не надо гнать количество, лучше сделать хорошо и красиво. | ||
+ | * Разумеется, можно использовать все, что найдете в интернете (код, статьи, книги), или подскажут нейросети (но они обычно подсказывают неверно). | ||
+ | |||
==== Проблема текущих подходов. ==== | ==== Проблема текущих подходов. ==== | ||
Строка 10: | Строка 23: | ||
* множество книг, слайдов, [https://www.youtube.com/results?search_query=NP+complete+proof видео] и т.п. — но все как правило перепев «ГД», на досках или [https://www.youtube.com/watch?v=ctwX--JEzSA&t=9s одноразовых веселых видео]. | * множество книг, слайдов, [https://www.youtube.com/results?search_query=NP+complete+proof видео] и т.п. — но все как правило перепев «ГД», на досках или [https://www.youtube.com/watch?v=ctwX--JEzSA&t=9s одноразовых веселых видео]. | ||
** но не «живые модели»! | ** но не «живые модели»! | ||
− | |||
==== Результат . ==== | ==== Результат . ==== | ||
− | |||
* Нет навыков проверяемых доказательств | * Нет навыков проверяемых доказательств | ||
* Не получаются ''навыки'' работы с труднорешаемыми задачами. | * Не получаются ''навыки'' работы с труднорешаемыми задачами. | ||
** Мучать «эвристики» и «нейросети» не приходя в сознание. | ** Мучать «эвристики» и «нейросети» не приходя в сознание. | ||
+ | *** «Какая у вас задача» — ну мы тут «GAN» сети пробовали, вот теперь трансформеры… — Задача то какая? | ||
− | ==== | + | ==== Что делать?. ==== |
− | + | <div style="font-size:50%; background:#ffffdd>[https://ru.wikibooks.org/wiki/%D0%9C%D0%B5%D1%82%D0%BE%D0%B4%D1%8B_%D0%9A%D1%80%D0%B8%D1%81%D1%82%D0%BE%D0%B1%D0%B0%D0%BB%D1%8F_%D0%A5%D1%83%D0%BD%D1%82%D1%8B … — Это же проблема Бен Бецалеля. Калиостро же доказал, что она не имеет решения.… — Мы сами знаем, что она не имеет решения, … Мы хотим знать, как её решать. ©]</div> | |
− | + | ||
− | + | ||
− | + | ||
+ | * Научится формализованно формулировать | ||
+ | ** ЦЛП | ||
+ | ** 3SAT | ||
+ | * Использовать решатели | ||
+ | ** ЦЛП (cbc, coin, SCIP, CPLEX, GUROBI, COPT, MIPT…) | ||
+ | ** SAT (см. SAT-Races [http://sat-race-2019.ciirc.cvut.cz/]). | ||
− | * | + | === Тогда можно . === |
− | ** | + | * Часто решить задачу для реальных данных сходу |
+ | ** Или покрутить постановку чтобы задача решалась (релаксация бизнес-ограничений). | ||
+ | * Начать тестировать | ||
+ | ** Алгоритмы полиномиальные в среднем | ||
+ | ** Приближенные алгоритмы с гарантией точности | ||
+ | ** Вероятностные алгоритмы | ||
+ | ** Эвристики | ||
+ | * Доказать труднорешаемость | ||
+ | ** Конструктивное сведение кодом, тестирование | ||
+ | ** Потом статья с объяснением. | ||
− | + | === Конструктивные алгоритмические доказательства . === | |
− | + | ||
+ | <noinclude> | ||
+ | ==== Задача о раскраске в 4 цвета . ==== | ||
+ | <slides split="-----" width="800"> | ||
+ | [[File:Моделирование труднорешаемых задач_2023-04-25_09-45-17_image0.png]] | ||
+ | ----- | ||
+ | [[File:Моделирование труднорешаемых задач_2023-04-25_09-48-32_image0.png]] | ||
+ | ----- | ||
+ | [[File:Моделирование труднорешаемых задач_2023-04-25_09-50-12_image0.png]] | ||
+ | ----- | ||
+ | [[File:Моделирование труднорешаемых задач_2023-04-25_09-50-35_image0.png]] | ||
+ | ----- | ||
+ | [[File:Моделирование труднорешаемых задач_2023-04-25_09-51-03_image0.png]] | ||
+ | ----- | ||
+ | [[File:Моделирование труднорешаемых задач_2023-04-25_09-51-23_image0.png]] | ||
+ | ----- | ||
+ | [[File:Моделирование труднорешаемых задач_2023-04-25_09-51-39_image0.png]] | ||
+ | ----- | ||
+ | [[File:Моделирование труднорешаемых задач_2023-04-25_09-52-28_image0.png]] | ||
+ | </slides> | ||
+ | </noinclude> | ||
+ | |||
+ | ==== Что вы получите . ==== | ||
+ | * Навыки моделирования | ||
+ | ** в PYOMO, сразу см. [https://software.sandia.gov/downloads/pub/pyomo/Pyomo-Workshop-Summer-2018.pdf воркшоп], [https://i.0x1.tv/s/SYaESibH4fpkmDT Зеркало] | ||
+ | ** в PYSAT | ||
+ | ** Jupyter Notebooks | ||
+ | |||
+ | ---- | ||
+ | * → Бизнес-аналитик-алгоритмист! (нарасхват!) | ||
+ | * → Курсовые-дипломы-статьи в JN | ||
+ | ** В любой ситуации | ||
+ | |||
+ | ==== С чем работаем . ==== | ||
+ | * Настоящие классические задачи в одном месте (ГД+ВК+…) | ||
+ | ** [[Open Classic Hard Problems]] | ||
+ | *** Не пугайтесь, вам достаточно изучить одну задачу… но можно и все. | ||
+ | **** Не «книга, толщиной защищающая от прочтения» | ||
+ | * Там (см. беджики-ссылки) | ||
+ | ** Постановки | ||
+ | ** Наброски ноутбуков для всех задач в [[Lab17]] | ||
+ | ** Частично готовая модель | ||
+ | **** тестовые данные (генератор) | ||
+ | **** визуализация | ||
+ | **** сведение к ЦЛП через Pyomo | ||
+ | **** сведение с 3SAT к задаче | ||
+ | **** вероятностное тестирование | ||
+ | **** видео с разьяснениями | ||
+ | |||
+ | ==== Начать с простого . ==== | ||
+ | * [[Hardprob/Maximum Set Packing]] | ||
+ | * [[Hardprob/Minimum Set Cover]] | ||
+ | * [[Hardprob/Maximum Cut]] | ||
+ | * [[Hardprob/Maximum Set Splitting]] | ||
+ | |||
+ | ==== Ваш квест . ==== | ||
+ | * Pyomo-сведение к ЦЛП → {{has-pyomo-model}}, {{has-testdata-and-visualization}} | ||
+ | * 3SAT-сведение к задаче → {{has-npc-reduction}} | ||
+ | * Вероятностное тестирование → {{add-random-fuzzing-tests}} | ||
+ | * Можно | ||
+ | ** все для одной задачи, | ||
+ | ** можно для разных (исправление ошибки или улучшение — ОК) | ||
+ | |||
+ | ===== Желательно напрямую с 3SAT . ===== | ||
+ | |||
+ | Без классического дерева сведения (но можно копировать функции сведения тех задач). | ||
+ | |||
+ | [[File:Моделирование труднорешаемых задач_2023-04-27_00-05-30_image0.png|center|640px]] | ||
+ | |||
+ | ==== Как с этим работаем . ==== | ||
+ | * Выбирайте задачи из [[Open Classic Hard Problems]], переходите к редактированию по «Беру…» → | ||
+ | ** Зарезервированные задачи просто помечаются в том же списке, для простоты. | ||
+ | *** Если видите, что зарезервировано кем-то в прошлом году — можно снять чужое резервирование, и поставить свое. | ||
+ | ** Воркфлоу «взятия задачи» аналогичен блоку «[[Практикуемся_В_Алгоритмах]]» | ||
+ | ** Только здесь, в вики, на «странице решения» обсуждаем постановку (если что-то непонятно), а решением будет юпитер-ноутбук в «лаборатории».. | ||
+ | * Текущая лаборатория | ||
+ | ** [[Lab22]] | ||
+ | ** [[Lab17]] заболела (и может сдохла). | ||
+ | * Как поотлаживаться локально через VSCode — потом. | ||
− | + | === Еще раз обо всем этом на одном слайде . === | |
− | + | [[File:Idea-hard-problems-course.svg|800px|center]] | |
− | + | [{{filepath:Idea-hard-problems-course.svg}} Картинка в полный размер] | |
− | + | ||
− | + |
Текущая версия на 22:41, 9 мая 2024
- Заголовок
- Моделирование труднорешаемых задач
- Автор
- Стас Фомин
- Нижний колонтитул
- Моделирование труднорешаемых задач
- Дополнительный нижний колонтитул
- Стас Фомин, 22:41, 9 мая 2024
- Обязательно посмотрите
Цели: для осеннего курса 2023, где собрались скорее заинтересованные практикой, чем сложностью задач, можно
- Сделать одну задачу целиком (визуализация, постановка в ЦЛП и сведение от 3SAT)
- Или пару задач «поверхностно» — постановка + визуализация (это легкая часть), без части про сведение от 3SAT и тестирования (это может быть очень головоломно).
- Можно сделать и больше, такой же блок, может заменить решение задачи из Моделирование бизнес-задач, если те почему-то не понравились.
- Может можно будет даже сделать и меньше, если будет сделано качественно (красивая визуализация, или сложная задача и т.п) — т.е. не надо гнать количество, лучше сделать хорошо и красиво.
- Разумеется, можно использовать все, что найдете в интернете (код, статьи, книги), или подскажут нейросети (но они обычно подсказывают неверно).
Содержание
Проблема текущих подходов.
Проблема текущих подходов к преподаванию вычислительной сложности и труднорешаемых задач:
- «ненужная заумь для ботанов»
- «всякой фигни как матло у нас нет, у нас проектный подход»© (день открытых дверей МФТИ).
- множество книг, слайдов, видео и т.п. — но все как правило перепев «ГД», на досках или одноразовых веселых видео.
- но не «живые модели»!
Результат .
- Нет навыков проверяемых доказательств
- Не получаются навыки работы с труднорешаемыми задачами.
- Мучать «эвристики» и «нейросети» не приходя в сознание.
- «Какая у вас задача» — ну мы тут «GAN» сети пробовали, вот теперь трансформеры… — Задача то какая?
- Мучать «эвристики» и «нейросети» не приходя в сознание.
Что делать?.
- Научится формализованно формулировать
- ЦЛП
- 3SAT
- Использовать решатели
- ЦЛП (cbc, coin, SCIP, CPLEX, GUROBI, COPT, MIPT…)
- SAT (см. SAT-Races [1]).
Тогда можно .
- Часто решить задачу для реальных данных сходу
- Или покрутить постановку чтобы задача решалась (релаксация бизнес-ограничений).
- Начать тестировать
- Алгоритмы полиномиальные в среднем
- Приближенные алгоритмы с гарантией точности
- Вероятностные алгоритмы
- Эвристики
- Доказать труднорешаемость
- Конструктивное сведение кодом, тестирование
- Потом статья с объяснением.
Конструктивные алгоритмические доказательства .
Задача о раскраске в 4 цвета .
Что вы получите .
- → Бизнес-аналитик-алгоритмист! (нарасхват!)
- → Курсовые-дипломы-статьи в JN
- В любой ситуации
С чем работаем .
- Настоящие классические задачи в одном месте (ГД+ВК+…)
- Open Classic Hard Problems
- Не пугайтесь, вам достаточно изучить одну задачу… но можно и все.
- Не «книга, толщиной защищающая от прочтения»
- Не пугайтесь, вам достаточно изучить одну задачу… но можно и все.
- Open Classic Hard Problems
- Там (см. беджики-ссылки)
- Постановки
- Наброски ноутбуков для всех задач в Lab17
- Частично готовая модель
- тестовые данные (генератор)
- визуализация
- сведение к ЦЛП через Pyomo
- сведение с 3SAT к задаче
- вероятностное тестирование
- видео с разьяснениями
Начать с простого .
- Hardprob/Maximum Set Packing
- Hardprob/Minimum Set Cover
- Hardprob/Maximum Cut
- Hardprob/Maximum Set Splitting
Ваш квест .
- Pyomo-сведение к ЦЛП → — есть Pyomo-формулировка для ЦЛП., — есть тестовые данные и визуализация.
- 3SAT-сведение к задаче → — есть сведение на Python NP-полной задачи к данной.
- Вероятностное тестирование → Можно доработать — сделать Вероятностное тестирование NPC-сведения!
- Можно
- все для одной задачи,
- можно для разных (исправление ошибки или улучшение — ОК)
Желательно напрямую с 3SAT .
Без классического дерева сведения (но можно копировать функции сведения тех задач).
Как с этим работаем .
- Выбирайте задачи из Open Classic Hard Problems, переходите к редактированию по «Беру…» →
- Зарезервированные задачи просто помечаются в том же списке, для простоты.
- Если видите, что зарезервировано кем-то в прошлом году — можно снять чужое резервирование, и поставить свое.
- Воркфлоу «взятия задачи» аналогичен блоку «Практикуемся_В_Алгоритмах»
- Только здесь, в вики, на «странице решения» обсуждаем постановку (если что-то непонятно), а решением будет юпитер-ноутбук в «лаборатории»..
- Зарезервированные задачи просто помечаются в том же списке, для простоты.
- Текущая лаборатория
- Как поотлаживаться локально через VSCode — потом.