Обсуждение:Город Тумана
Алгоритм, которым я подсчитал вероятности
Оставляю тут — чтобы было легче проверить, что я не совершил ошибок, и адаптировать для построения подобных табличек в других статьях. Demetrius (обсуждение) 21:41, 5 февраля 2024 (MSK)
const броскиОднойКости = [1, 2, 3, 4, 5, 6] const суммы = броскиОднойКости.map(первая => броскиОднойКости.map(вторая => первая + вторая)).flat() const условияКолонок = [ сумма => сумма <= 6, сумма => (сумма >= 7) && (сумма <= 9), сумма => сумма >= 10, сумма => сумма >= 12 ] const прибавки = [] for (i = -5; i <= 7; i++) прибавки.push(i) function значенияКолонок(прибавка) { return условияКолонок.map( условие => { const подходящих = суммы.map(бросок => бросок + прибавка).filter(условие).length const всего = суммы.length return подходящих / всего } ) } function вероятностьКакПроценты(вероятность) { return (Math.round(вероятность * 10000) / 100) + '%' } function отформатироватьСтрокуТаблицы(прибавка) { const ячейкиТаблицы = [ (прибавка >= 0 ? '+' : '') + прибавка, ...значенияКолонок(прибавка).map(вероятностьКакПроценты) ] return `| ` + ячейкиТаблицы.join(' || ') } function отформатироватьТаблицу() { return [ ` {| class="wikitable" style="margin:auto" ! Прибавка !! Неудача<br>(<6) !! Частичный успех<br>(7—9) !! Полный успех<br>(>10) !! «Динамит» (>12)`, ...прибавки.map(отформатироватьСтрокуТаблицы) ].join("\n|-\n") + '\n|}' } console.log(отформатироватьТаблицу())
- Тема! А может, переделать это на Lua и сделать шаблоном, который легко включить в любые статьи? EvilCat (обсуждение) 09:52, 6 февраля 2024 (MSK)
- Спасибо! Мне нравится эта идея. Но сделать one-off код куда проще, чем сделать переиспользуемый модуль. Надо подумать, как это всё может выглядеть... Demetrius (обсуждение) 16:44, 6 февраля 2024 (MSK)
Я пока что представляю себе примерно такой DSL, который можно было бы скармливать Lua:
-- Year Zero Engine: вариант с пулом костей Столбец КоличествоКостей "Количество костей" Столбец "Шанс успеха" Столбец "Шанс успеха при переброске", вероятность: больший((КоличествоКостей * 2) раз d6) = 6 -- Year Zero Engine: вариант с атрибутами Столбец Атрибут "Бросаемые кости/Атрибут", список: d6, d8, d10, d12 Столбец Умение "Бросаемые кости/Умение", список: 0, d6, d8, d10, d12 Столбец "Шанс успеха", вероятность: Атрибут ≥ 6 или Умение ≥ 6 Столбел "Шанс успеха при переброске", вероятность: больший(2 раза Атрибут) ≥ 6 или больший(2 раза Умение) ≥ 6 -- City of Mist Столбец Прибавка, список: -5, -4, -3, -2, -1, 0, +1, +2, +3, +4, +5, +6, +7 Столбец "Неудача<br>(≤6)", вероятность: 2d6 + Прибавка ≤ 6 -- условие для одного и того же броска; возможно, проще сделать 7 ≤ 2d6 + прибавка ≤ 9 Столбец "Частичный успех<br>(7—9)", вероятность: [результат = 2d6 + Прибавка] результат ≥ 7 и результат ≤ 9 Столбец "Полный успех<br>(≥10)", вероятность: 2d6 + Прибавка ≥ 10 Столбец "«Динамит»<br>(≥12)", вероятность: 2d6 + Прибавка ≥ 12
Но это, кажется, чересчур амбициозно и сложно. Надо подумать, что можно упростить. Demetrius (обсуждение) 16:44, 6 февраля 2024 (MSK)
- Да, звучит как что-то чем только ты и я сможем пользоваться, а мне и JavaScript вполне удобен.
- Я думала о чём-то вроде модуль «Генератор таблиц вероятностей», параметра у которого были бы «тип броска» (2d6-2) и «условие успеха» (5+). Но, возможно, в этом и есть главная сложность — можно ли описать подобные проверки какой-то простой системой параметров? Или хотя бы вынести в слой абстракции, который человек с опытом Lua 1 месяц сможет напиать (функции «бросок» и «условие успеха»). Ладно, буду думать. EvilCat (обсуждение) 17:12, 6 февраля 2024 (MSK)
- А я сделал прототип на Lua! Вот: https://paste.mozilla.org/5c6PANo0/raw (запускать в консоли — или, например, тут: https://onecompiler.com/lua/423pauc7x ) Парсер DSL'а ещё не сделал (входные данные задаю как массивы Lua), но я думаю взять формат типа Лиспа, для которого парсер пишется тривиально. (По сути я хочу формат примерно как выше, но с изобилием скобок, как в Лиспе — чтобы не мучиться с приоритетом операторов и т.п.).
- Эта версия не расставляет
rowspan
/colspan
и в ней нет части нужных функций, но как прототип по-моему неплохо получилось. Demetrius (обсуждение) 23:17, 6 февраля 2024 (MSK) - Ещё мысли. Кажется, в Scribunto используется Lua 5.1? Вроде в ней аналог eval'а —
loadstring
, и вроде он не позволяет получить аргументы (и их надо передавать через глобальные переменные?). Звучит как-то некруто, не знаю (хотя в принципе можно и в глобальных... не знаю.) Если останоситься на написании условий на Lua, и не хочется глобальных переменных, то тогда логику условий придётся описывать в модулях отдельно от игры. ИМХО это чуть менее наглядно. (Мой DSL, конечно, труднее понять, чем Lua [особенно когда я его упростил до лиспоида] — но он будет прямо в коде статьи.) - Впрочем, думаю, в любом случае вряд ли в ближайшее время этим будет заниматься кто-то кроме нас. Так что можно на JS писать и вставлять уже сгенерированное. Demetrius (обсуждение) 02:38, 7 февраля 2024 (MSK)
- Вот пример подобного сложного модуля из другой вики — если открыть для правки, там будет удобный редактор. Можно посмотреть на шаблон, который его использует, и на страницы, которые его используют. EvilCat (обсуждение) 09:02, 7 февраля 2024 (MSK)
- Я верю, что на десктопе он удобный (сейчас с телефона, в нём этот редактор неюзабелен), но мне кажется менее удобным, что описание таблицы будет сильно далеко от текста статьи. Хотя, наверное, это не принципиально, можно и таким пользоваться. Demetrius (обсуждение) 10:47, 7 февраля 2024 (MSK)
- Я надеялась, ты доберёшься до подобных шаблонов и посмотришь, как там устроено задание параметров, которым случалось пользоваться с другим людям кроме автора %) EvilCat (обсуждение) 11:06, 7 февраля 2024 (MSK)
- Ну на первый взгляд выглядит, что там что-то типа моего DSL'а, с такими отличиями:
- (а) у меня новые строки, в этом шаблоне разные аргументы шаблона (мне мой вариант нраваится больше, но не принципиально)
- (б) есть вспомогательные шаблоны, которые генерируют отдельные строки для (у нас такое тоже можно сделать, хотя ИМХО это не принципиально).
- Вынесу в отдельную подветку, а то у нас что-то много вложенности уже. Demetrius (обсуждение) 15:55, 7 февраля 2024 (MSK)
- Ну на первый взгляд выглядит, что там что-то типа моего DSL'а, с такими отличиями:
- Я надеялась, ты доберёшься до подобных шаблонов и посмотришь, как там устроено задание параметров, которым случалось пользоваться с другим людям кроме автора %) EvilCat (обсуждение) 11:06, 7 февраля 2024 (MSK)
- Я верю, что на десктопе он удобный (сейчас с телефона, в нём этот редактор неюзабелен), но мне кажется менее удобным, что описание таблицы будет сильно далеко от текста статьи. Хотя, наверное, это не принципиально, можно и таким пользоваться. Demetrius (обсуждение) 10:47, 7 февраля 2024 (MSK)
- Вот пример подобного сложного модуля из другой вики — если открыть для правки, там будет удобный редактор. Можно посмотреть на шаблон, который его использует, и на страницы, которые его используют. EvilCat (обсуждение) 09:02, 7 февраля 2024 (MSK)
Сравнение моего прототипа с модулем Генеалогии
Общий принцип же такой же: на вход шаблону Генеалогия поступает текст типа такого (только вместо новых строк — |, каждая строка — отдельный аргумент):
child, Симба , Нала , Копа ,border-color: crimson child, Симба , Нала , Киара , child, Симба , Нала , Кайон ,
Просто пользователь не пишет данные в этом формате, а добавляет их через шаблоны типа Генеалогия/Персонаж, Генеалогия/Союз, Генеалогия/Потомок.
Это не так уж и отличается от моего
(столбец Атрибут список d6 d8 d10 d12) (столбец Умение список (0 —) d6 d8 d10 d12) (столбец "Вероятность без переброски" (- 1 (* (< Атрибут 6) (< Умение 6))))
Я взял S-выражения, потому что я хотел иметь произвольную математическую нотацию с возможностью добавлять новые функции. loadstring
(аналог eval
'а в Lua 5.1) я не брал потому, что передача данных через глобальные переменные или переменные окружения звучит... плохо. А парсер S-выражений написать довольно тривиально.)
Кстати, доп. шаблоны можно использовать, чтобы распарсить математическую нотацию. Типа, чтобы писать {{Вероятность/Столбец|Вероятность без переброски|1 - (Атрибут < 6)*(Умение < 6)}}
, и Шаблон:Вероятность/Столбец превращал формулу в S-выражения для основного шаблона. Demetrius (обсуждение) 15:55, 7 февраля 2024 (MSK)
Добавлено: возможно, для ясности стоит в математической нотации писать не Атрибут < 6
, а P(Атрибут < 6)
. Чтобы было ясно, что мы вероятность берём и дальше её умножает/отнимаем/etc. Demetrius (обсуждение) 16:03, 7 февраля 2024 (MSK)