169 похожих чатов

Попытался разобраться, как составить школьное расписание. Оказалось надо много математики.

Но @noraltavir спас и навел на https://www.optaplanner.org/ Для меня это вообще как магия какая то, еще пытаюсь разобраться. Может у кого был опыт с этим? Пытаюсь составить правило на то, чтобы всегда был первый урок, но пока не получается. https://quarkus.io/guides/optaplanner

12 ответов

16 просмотров

Это не я спас, а Брендан. Но да, задача весьма сложная. Единственное, что могу сказать по существу задачи, это то, что надо ставить мягкие условия, а потом их ужесточать потому что для многих условий решений вообще нет, или есть, но гиперобъем параметров для них очень маленький и приближенными методами найти их нельзя.

я делал расписание когда-то давно. И обошлось без математики. Наивно и в лоб всё решалось. У группы есть набор предметов, предметы ведут преподы на которых тоже считалась нагрузка. Обошелся циклами и кучей if'ов

Lev-Shagalov Автор вопроса
Alexander Nozik
Это не я спас, а Брендан. Но да, задача весьма сло...

Сам ты гиперобъем. Для задачи что я решаю, есть ряд условий, которые надо выполнить по требованиям местного минобра. Например - у каждого класса каждый день должен быть первый урок. И не должно быть промежутков в уроках.

Lolus Kekus
я делал расписание когда-то давно. И обошлось без ...

При количестве параметров больше 10 оно уже брут-форсом не решается

Lev-Shagalov Автор вопроса
Lolus Kekus
я делал расписание когда-то давно. И обошлось без ...

Да, можно наверное. Может и со мной прокатит. Но субьективно для меня это не будет интересным решением)

Lev Shagalov
Сам ты гиперобъем. Для задачи что я решаю, есть ря...

ой как знакомо, то же для местного минобра как раз и делали

Lev-Shagalov Автор вопроса
Lolus Kekus
ой как знакомо, то же для местного минобра как раз...

Не, я для классухи делаю. По совместительству завуч. А она под минобром %) А мне интересно.

Lev Shagalov
Сам ты гиперобъем. Для задачи что я решаю, есть ря...

Так это и есть гиперобъем :) Ладно перевожу на русский. Не для всех ограничений есть решение. Поэтому надо не ставить эти ограничения жесткими. Впрочем, это уже не тот чат

Lev-Shagalov Автор вопроса
Alexander Nozik
Так это и есть гиперобъем :) Ладно перевожу на рус...

Для тех, что я задал - решается. У меня на руках человеческое решение. Ну и задал я не все ограничения. У меня вопрос то в api, поэтому ищу, может кто юзал.

OptaPlanner норм тема. Показывай что написал - посмотрим. Я 3 года назад как раз делал планировщик расписания для конференций. Потом оно уехало в закрытый репозиторий, но что-то посмотреть можно тут (тогда я на Kotlin не умел, поэтому Java+YAML, я предупредил ;) ): https://github.com/vlsi/confplanner И, да, рекомендуют сначала описывать hard constraints, а потом переходить к soft.

Lev-Shagalov Автор вопроса

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта