Курс лекций «Эффективные алгоритмы» — различия между версиями
StasFomin (обсуждение | вклад) |
StasFomin (обсуждение | вклад) |
||
(не показано 26 промежуточных версий этого же участника) | |||
Строка 4: | Строка 4: | ||
* [[Special:MediawikiQuizzer/GRE-CS-v01|Еженедельная проверка — сегодня экспериментальная]] | * [[Special:MediawikiQuizzer/GRE-CS-v01|Еженедельная проверка — сегодня экспериментальная]] | ||
--> | --> | ||
+ | <!-- * [[Special:MediawikiQuizzer/Python|Еженедельная проверка]] --> | ||
{{SideBar| | {{SideBar| | ||
− | {{Special:Wikilog/Blog:Advanced Algorithms/Template:BlogInformerLine/ | + | {{Special:Wikilog/Blog:Advanced Algorithms/Template:BlogInformerLine/12/sort=wlp_talk_updated}} |
|style=max-width:35% | |style=max-width:35% | ||
}} | }} | ||
Строка 13: | Строка 14: | ||
* [[Special:MediawikiQuizzer/Эффективные алгоритмы-Экзамен|Тест для экзамена]] | * [[Special:MediawikiQuizzer/Эффективные алгоритмы-Экзамен|Тест для экзамена]] | ||
--> | --> | ||
− | + | <!-- | |
[[Special:MediawikiQuizzer/Algs-6-course-ispras-weekly|Еженедельная тренировка]] | [[Special:MediawikiQuizzer/Algs-6-course-ispras-weekly|Еженедельная тренировка]] | ||
+ | --> | ||
+ | |||
Курс лекций «Эффективные алгоритмы» для 6 курса МФТИ. | Курс лекций «Эффективные алгоритмы» для 6 курса МФТИ. | ||
Строка 22: | Строка 25: | ||
---- | ---- | ||
+ | <!-- | ||
В целом голосование за время созвона прошло, результаты на странице [[Голосование за выбор времени созвона]], | В целом голосование за время созвона прошло, результаты на странице [[Голосование за выбор времени созвона]], | ||
но если сильно изменится ситуация — заходите и переголосуйте там. | но если сильно изменится ситуация — заходите и переголосуйте там. | ||
+ | --> | ||
<!-- | <!-- | ||
Строка 32: | Строка 37: | ||
;Преподаватель: [mailto:stas-fomin@yandex.ru С.А. Фомин] | ;Преподаватель: [mailto:stas-fomin@yandex.ru С.А. Фомин] | ||
− | Запись на курс 2021 года завершена, всем спасибо, исключений нет. | + | <!-- Запись на курс 2021 года завершена, всем спасибо, исключений нет. --> |
− | |||
Для ФУПМов 6 курса, желающих записаться на курс по выбору «Эффективные алгоритмы», нужно: | Для ФУПМов 6 курса, желающих записаться на курс по выбору «Эффективные алгоритмы», нужно: | ||
{{:Как зарегистрироваться на курс}} | {{:Как зарегистрироваться на курс}} | ||
<poll> | <poll> | ||
− | UNSAFE_ID=aa- | + | UNSAFE_ID=aa-20220901 |
ALTERNATIVE | ALTERNATIVE | ||
OPEN_RESULTS | OPEN_RESULTS | ||
Строка 45: | Строка 49: | ||
AUTHORIZED | AUTHORIZED | ||
ALLOW_REVOTE | ALLOW_REVOTE | ||
− | END_POLL | + | END_POLL 2022-10-15 |
− | Записываемся на курс «Advanced Algorithms- | + | Записываемся на курс «Advanced Algorithms-2022»? |
Да | Да | ||
Нет | Нет | ||
</poll> | </poll> | ||
− | + | * Установочный созвон будет наверно 9 сентября, раньше обычно бессмысленно. | |
<!-- | <!-- | ||
Строка 88: | Строка 92: | ||
− | Вопросы пишите на [mailto:stas-fomin@yandex.ru почту], или задавайте в [ | + | Вопросы пишите на [mailto:stas-fomin@yandex.ru почту], или задавайте в [{{active-telegram-group-link}} группе]. |
<!-- | <!-- | ||
Строка 97: | Строка 101: | ||
---- | ---- | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
* Проблемы → [mailto:stas-fomin@yandex.ru Стасу Фомину] | * Проблемы → [mailto:stas-fomin@yandex.ru Стасу Фомину] | ||
− | |||
− | |||
<html><center> | <html><center> | ||
Строка 132: | Строка 114: | ||
Если вы в зеленой группе — вы кандидат на «отлично автоматом». | Если вы в зеленой группе — вы кандидат на «отлично автоматом». | ||
+ | <!-- | ||
«Отличники-автоматом» будут выбраны с помощью жадного алгоритма, и вероятностого округления, с использованием настоящих случайных чисел с http://random.org | «Отличники-автоматом» будут выбраны с помощью жадного алгоритма, и вероятностого округления, с использованием настоящих случайных чисел с http://random.org | ||
+ | --> | ||
− | + | == Блок 1 == | |
+ | ---- | ||
+ | {{:Практикуемся В Алгоритмах}} | ||
+ | ---- | ||
− | + | Разберитесь, как зарегистрироваться на «лабе» | |
− | * [[ | + | * [[Lab]] |
− | + | == Блок 2 == | |
− | + | Моделирование труднорешаемых задач и решение из промышленными солверами. | |
− | + | ||
− | + | ||
− | + | ||
− | - | + | {{:Моделирование бизнес-задач}} |
+ | |||
+ | == Блок 3 == | ||
+ | |||
+ | Выберем несколько тем и теоретических задач. | ||
+ | |||
+ | Те, кто по результатам предущих блоков вышел на «хор», смогут улучшить оценку (но не затягивайте, держите в курсе, если это делаете). | ||
+ | ---- | ||
+ | {{:НаучныйПоиск}} | ||
+ | |||
+ | |||
+ | <!-- | ||
== Блок 1 == | == Блок 1 == | ||
{{vimeoembed|324745701|800|450}} | {{vimeoembed|324745701|800|450}} | ||
Строка 173: | Строка 168: | ||
* [[MAX-SAT: дерандомизация]] | * [[MAX-SAT: дерандомизация]] | ||
* [[Приближенный алгоритм для метрической задачи коммивояжера]] | * [[Приближенный алгоритм для метрической задачи коммивояжера]] | ||
+ | --> | ||
− | + | <!-- | |
+ | <!-- | ||
== Блок 2 == | == Блок 2 == | ||
+ | ;Квест «4 задачи»: До 3 декабря | ||
* [[Blog:Advanced_Algorithms/2021-10-15_Practical_Block]] | * [[Blog:Advanced_Algorithms/2021-10-15_Practical_Block]] | ||
+ | * Прохождение квеста гарантирует «уд» | ||
+ | * Непрохождение → «неуд» | ||
+ | ;Квест «2 задачи из Spojcoding/Codechefing» | ||
+ | * До 15 декабря. | ||
+ | * Прохождение квеста гарантирует «хор» (7) | ||
+ | * Повторим условия: | ||
+ | ** Не Leetcoding | ||
+ | ** Только Python | ||
+ | ** Да, должна проходить TL | ||
+ | |||
+ | ;Квест «4 задачи из Spojcoding/Codechefing» | ||
+ | * До 15 декабря. | ||
+ | * Прохождение квеста гарантирует «отл» (8) | ||
+ | * Повторим условия: | ||
+ | ** Не Leetcoding | ||
+ | ** Только Python | ||
+ | ** Да, должна проходить TL | ||
+ | --> | ||
+ | |||
+ | |||
+ | <!-- | ||
== Блок 3 == | == Блок 3 == | ||
Выберем несколько тем и теоретических задач. | Выберем несколько тем и теоретических задач. | ||
− | |||
− | |||
+ | Те, кто по результатам предущих блоков вышел на «хор» до 12 декабря, смогут улучшить оценку | ||
+ | * [[Blog:Advanced_Algorithms/2021-11-15_Research_Block]] | ||
+ | --> | ||
+ | <!-- | ||
= Темы = | = Темы = | ||
Замечания по каждой презентации можно (и нужно) писать на вкладку «Обсуждение», для соответствующего PDF-файла. | Замечания по каждой презентации можно (и нужно) писать на вкладку «Обсуждение», для соответствующего PDF-файла. | ||
Строка 195: | Строка 216: | ||
* [[Полностью полиномиальная аппроксимационная схема (FPTAS) для задачи о рюкзаке]] | * [[Полностью полиномиальная аппроксимационная схема (FPTAS) для задачи о рюкзаке]] | ||
− | |||
* [[Полиномиальный в среднем алгоритм для задачи упаковки]] | * [[Полиномиальный в среднем алгоритм для задачи упаковки]] | ||
* [[Полиномиальный в среднем алгоритм для задачи о рюкзаке]] | * [[Полиномиальный в среднем алгоритм для задачи о рюкзаке]] | ||
Строка 205: | Строка 225: | ||
* [[Приближенный алгоритм для метрической задачи коммивояжера]] | * [[Приближенный алгоритм для метрической задачи коммивояжера]] | ||
− | + | * [[Вероятностно проверяемые доказательства. PCP-системы. PCP-теорема]] | |
− | |||
* [[Формально об алгоритмах. Вычислительные модели]] | * [[Формально об алгоритмах. Вычислительные модели]] | ||
* [[Временная и пространственная сложность алгоритмов]] | * [[Временная и пространственная сложность алгоритмов]] | ||
Строка 216: | Строка 235: | ||
* [[PCP и аппроксимируемость]] | * [[PCP и аппроксимируемость]] | ||
− | |||
* [[Параллельный алгоритм Люби для максимального по включению независимого множества]] | * [[Параллельный алгоритм Люби для максимального по включению независимого множества]] | ||
Строка 225: | Строка 243: | ||
== Задачи == | == Задачи == | ||
* [[LeetCoding]] | * [[LeetCoding]] | ||
− | + | --> | |
<!-- | <!-- | ||
Все статьи в этой категории — задачи, которые можно пытаться решать. | Все статьи в этой категории — задачи, которые можно пытаться решать. | ||
Строка 268: | Строка 286: | ||
--> | --> | ||
− | = Видеолекции = | + | = Материалы = |
+ | Наверно не пригодятся для курса 2022 года. | ||
+ | |||
+ | == Видеолекции == | ||
* [[/Лекции осеннего семестра 2011]] | * [[/Лекции осеннего семестра 2011]] | ||
** [http://narod.ru/disk/63720373001.d936acd53e1a20473d5073cbd232bc49/discopal.torrent.html торрент] с прошлогодними видео. | ** [http://narod.ru/disk/63720373001.d936acd53e1a20473d5073cbd232bc49/discopal.torrent.html торрент] с прошлогодними видео. |
Версия 00:02, 23 декабря 2022
- 2024-04-18: Обзор квестов курса ← Advanced Algorithms
- 2024-03-28: Эксперимент — улучшаем старые решения ← Advanced Algorithms
- 2024-03-28: Python-решения — давайте потренируемся их сделать питонистей ← Advanced Algorithms
- 2024-02-26: Feedback ← Advanced Algorithms
- 2024-02-14: Регистрируемся, начинаем работать, выбираем удобное время созвонов ← Advanced Algorithms
- 2023-12-28: Разбор задачи «Независимое множество ребер» ← Advanced Algorithms
- 2023-12-22: Разбор задачи «Управление загрязняющими продуктами» ← Advanced Algorithms
- 2023-12-17: Разбор задачи «Управление Дисциплинами» ← Advanced Algorithms
- 2023-11-29: Разбор задачи «Домостроительство» ← Advanced Algorithms
- 2023-11-28: Разбор задачи «Размещение административных учреждений» ← Advanced Algorithms
- 2023-11-24: Что делать, если солвер непонятно ругается ← Advanced Algorithms
- 2023-11-13: Разбор задачи «Назначение студентов в группы» ← Advanced Algorithms
Курс лекций «Эффективные алгоритмы» для 6 курса МФТИ.
Кратко, что будет, чего не будет и что ждать.
- Лекций — не будет. Это бред и бессмыслица, особенно при дистанционке. Созвоны будут при небходимости, в формате семинара, может индивидуальные.
- Будет путешествие-квест, с разными активностями.
- Берем только практические вещи — алгоритмы для разных задач, особенно NP-полных.
- Условно будет три блока
- Теоретический — прочитать темы, посмотреть записи лекций, пройти тестирование, возможно решить некоторые теорзадачи.
- Тут будет первый отсев — если не проходите тесты (отсеим, скажем, 25% нижних), то «досвидания».
- Не рекламируйте этот курс — чем меньше народу, тем будет лучше. Я заинтересован сократить численность всеми способами. Особенно нафиг я посылаю всех, кто пытается запрыгнуть в курс в середине семестра и позже. Без шансов. Когда-то прогибался в виде исключения, сейчас не буду.
- Легкий практический — решение нескольки задач, даваемых на собеседованиях в IT-компаниях, типа LeetCoding, SpojCoding, CodeChefing и т.п.
- Тут будет второй отсев — но можно будет тут свалить, получив «уд» — кому нужно время, и не очень все это интересно.
- Теор-практический — взять некоторую тему из заданных (свежая статья, я отберу), и сделать ее разбор-презентацию-реализацию в каком-нибудь jupyter или cocalc-ноутбуке (там будет видно). Тут возможно будет и индивидуальная работа и может тренировка презентейшн скиллс, что полезно для ваших дипломов (сколько я смотрел защит, все ужасно).
Ну остальные новости будут в группе, если что. Вопросы тоже там или напрямую.
Как зарегистрироваться — написано на основной странице курса, где все и будет https://discopal.ispras.ru/Advanced-algorithms
Регистраций открыта до 15 октября.
Подумайте еще раз — надо ли вам это. «Халявы», «Лекций», «Оценок за удаленную посещаемость» тут не будет. Даже «уд. нахаляву». Посмотрите, вокруг полно интересных курсов по выбору.
- Преподаватель
- С.А. Фомин
Для ФУПМов 6 курса, желающих записаться на курс по выбору «Эффективные алгоритмы», нужно:
- Зарегистрироваться здесь. Залогинится.
- Зайти на страницу настроек, указать свой email и подтвердить его.
- На своей личной странице (это не страница настроек, это то, что сверху слева, с иконкой человечка), написать хотя бы ФИО и группу.
- Боже, как много народу с рассеянным вниманием уже до сюда не дочитывает.
- Присоединится к телеграмм-группе.
- Отметится в этом голосовании:
Записываемся на курс «Advanced Algorithms-2022»?
|
Вы должны войти в систему, чтобы участвовать в этом голосовании.
- Установочный созвон будет наверно 9 сентября, раньше обычно бессмысленно.
Формат flipped classroom — т.е. по существующим материалам не будем повторять лекции, встречаться будем только для семинаров, и активной работы (решение задач, разбор сложных моментов, что-нибудь интересное придумаю) по заранее изученным материалам.
Вопросы пишите на почту, или задавайте в группе.
- Проблемы → Стасу Фомину
В списке вы можете видеть разные цифры, отражающие вашу активность по темам курса. В конце — некоторые суммарные метрики, рассчитанные по волшебным формулам.
Если вы в зеленой группе — вы кандидат на «отлично автоматом».
Содержание
Блок 1
Концептуально:
- Win-Win!
- Абсолютно практические задачи с собеседований.
- LeetCode
- CodeChef
- SpojCode
- Сотни решенных и нерешенных
- Условно поделены на «Dynamic Programming», «Greedy», «Random», «Sorting», «Numbers»
- Нужно быть залогиненным
- Скрыто из интернета
- Изучайте Решенные практические задачи (Их там 1027)
- Надо решить N задач из 4 разных разделов. На Python.
- 8 если до 2024-03-08
- 12 если до 2024-04-08
- 16 если до 2024-05-08
- За задачи из CodeChef и SpojCoding будут дополнительные бонусные очки (2 балла из настоящей 10 бальной оценки!), их решать сложнее, там не подсказывают тест вызвавший ошибку, там могут быть жесткие TL, надо больше стараться, и да, их надо решать именно на Python (любом, который есть на сервисе, хоть PyPy) оптимизировать вам могут помочь статьи:
- Бонусные задачи вполне решаются, если их не боятся → вот из последних решений → Участник:Mishaglik/Solutions/Spoj/FRQPRIME
- Выбирайте задачи из Открытые практические задачи, переходите к редактированию по «Беру…» →
- помечайте их как {{reserve-task|~~~~~}}
- Зарезервированные задачи убираются в Зарезервированные практические задачи
(Их там 63)
- Не нужно брать десятки задач на себя сразу, и освобождайте то, что не получается.
- Решенное
- Ну смотрите, как оформлено в прошлые годы
- Решение на подстранице вашей личной страницы
- Вики-ссылка на задачу
- Python-код в «<source lang="python"></source>»
- Метка «{{checkme}}», когда решите.
- Внизу вставка всего этого по клику →
- Они попадут в Категория:На проверку
(Их там 14)
- Как легче решать Python
- Загрузка данных
- Выбирайте более свежий CPython или PyPy.
Разберитесь, как зарегистрироваться на «лабе»
Блок 2
Моделирование труднорешаемых задач и решение из промышленными солверами.
Концептуально:
- Win-Win!
- Бизнес-аналитикам, алгоритмистам, прожект и продукт-менеджерам.
- Воркфлоу «взятия задачи» аналогичен блоку «Практикуемся_В_Алгоритмах»
- Только здесь, в вики, на «странице решения» обсуждаем постановку (если что-то непонятно), а решением будет юпитер-ноутбук в Lab17.
- Надо решить одну! задачу, но очень желательно сделать это красиво!
- Если все совсем шикарно — бонусные очки (если задача окажется сложной — тоже).
- Выбирайте задачи из Открытые бизнес-задачи, переходите к редактированию по «Беру…» →
- Зарезервированные задачи убираются в Зарезервированные практические задачи
- Идем на Lab17
- «adv2022-course-pyomo-business-optimization» — курсы.
- Если совсем новые в юпитер-ноутбуках — см. jupyter-intro
- Параллельно можно смотреть воркшоп по Pyomo
- Можно править, комментировать, но без вандализма, полезные улучшения (визуализации, исправления ошибок → бонус).
- Там будет видео в каждом питон-ноутбуке.
- Оформляем свои ноутбуки в папке «homeworks-2023», заведите там подпапку по вашему логину, желательно без пробелов.
- Учимся на готовых решениях коллег - Решенные бизнес задачи, ну и в папке «optprob»
Блок 3
Выберем несколько тем и теоретических задач.
Те, кто по результатам предущих блоков вышел на «хор», смогут улучшить оценку (но не затягивайте, держите в курсе, если это делаете).
Для тех, кому не хватило баллов, обязательная программа (алгоритмические задачи и бизнес-задачи) выполнена, и готовы идти на «отлично».
Концептуально:
- Это на «отл»
- Win-Win!
- Подготовка к защите дипломов-курсовых-кандидатских — моделирование диплома-научной работы и ее защиты.
- Анализ научной статьи про алгоритмы, с переложением ключевой части в Jupyter-ноутбук.
- Полностью «переписывать статью не надо» — не надо переводить-копировать все содержание.
- Доказательства не нужны.
- Разобраться в введении
- Моделировать постановку задачи (обычно это ЦЛП)
- Возможно придумать тестовые данные, если их там нет или не прилагались к статье.
- Воспроизвести максимально декомпозировав, основной алгоритм — попробовать смоделировать и воспроизвести алгоритм для решения.
- Некоторые примеры работ в папке articles2jupyter-examples
- глобальная проблема воспроизводимости + https://paperswithcode.com/ → мы помогаем решать.
- Если что не получается — пингуйте.
- Запишите к ним видеоролик, как в Blog:Advanced Algorithms/2022-12-01 Кто решил бизнес-задачи, запишите по ним видеоролики
- Научитесь пользоваться OBS — (см. также [1]), попробуйте использовать экранное рисование ([2]) и сделать это живым и доступным.
- Запишите видео-презентацию и забросьте мне (unlisted youtube, файлохранилища…)
- Полностью «переписывать статью не надо» — не надо переводить-копировать все содержание.
- Если предлагаемые статьи не понравились, а есть что-то про алгоритмы по теме вашей работы-диплома → можете работать над этим.
- Может прямо это и будет драфтом дипломной работы
- Презентацию можно сделать прямо из Jupyter-ноутбука, см RISE.
- Воркфлоу «взятия задачи» аналогичен блоку «Практикуемся_В_Алгоритмах» и «Моделирование бизнес-задач»
- Также, в вики, на «странице решения» обсуждаем постановку (если что-то непонятно), а решением будет юпитер-ноутбук в Lab.
- Выбирайте задачи из Открытые статьи для разбора, переходите к редактированию по «Беру…», резервируйте, как обычно …
- Идем на Lab
- Оформляем свои ноутбуки в папке «advalg-2022-homeworks»
- Учимся на готовых решениях коллег в соседних папках и решениях прошлых лет → articles2jupyter-examples
Материалы
Наверно не пригодятся для курса 2022 года.
Видеолекции
- /Лекции осеннего семестра 2011
- торрент с прошлогодними видео.
- /Лекции осеннего семестра 2012
- Курс_лекций_«Сложность_алгоритмов»_(ИСПРАН,_3_курс_МФТИ)/Лекции_весеннего_семестра_2013
Книга
Специальная верстка для чтения с ноутбуков и КПК:
- альбомная ориентация
- крупные беззасечные шрифты
Кому не нравится — пишите обоснованные протесты (почему, конструктивные предложения).
Пишите замечания по содержимому — про проблемы с версткой и библиографией не писать, все там только в процессе.
File:Book-advanced-algorithms.pdf
Примечания и ссылки
- Рекомендуется прочитать хотя бы первые лекции по введению в Python и научные вычисления.
Полезная сопутствующая литература по курсу.
- Очень хорошие лекции по классической теории сложности, написанные одним из корифеев оной: Introduction to Complexity Theory by Oded Goldreich
- Более краткий курс по классической теории сложности, университет Technion.
- Еще один классический курс лекций по теории сложности от László Lovász.
- А. Китаев, А. Шень, М. Вялый, Классические и квантовые вычисления — замечательная книга. Содержит отличное введение в теорию сложности.
- С. Дасгупта, Х. Пападимитриу, У. Вазирани, Алгоритмы [3]