Простая формула для корректировки цены на основе спроса и предложения
Я разрабатываю игру в жанре рпг / грязь с торговыми NPC, и я хочу, чтобы их цены динамически корректировались в зависимости от спроса и предложения.
Что я уже понял:
- Мне не нужна сложная, "реалистичная" система, а просто простой множитель, основанный на некоторых статистических данных
- Я хочу, чтобы алгоритм был устойчивым к злоупотреблениям и небольшому количеству игроков, поэтому, вероятно, множитель не должен генерироваться динамически, а должен храниться вместе с другими данными продавца и обновляться один раз в несколько дней.
- И поэтому требуемые статистические данные должны быть небольшого объема - будет много NPC, каждый со своим списком предметов, ценами и статистикой - так что они могут быстро увеличиваться в размере с развитием игрового мира.
Проблема в том, какая формула будет "лучшей" для такого рода множителей?
Отказ от ответственности:
- Может показаться, что это связано с моделированием спроса и предложения, но мне не нужна библиотека, только несколько советов о том, как сделать это самому.
- Я знаю, что уже может быть модель экономики, моделирующая эту проблему, но я никогда не изучал экономику, поэтому даже не знаю, что мне следует искать.
- Нет, это не домашняя работа, но, вероятно, она звучит как одна, поэтому я добавляю тег:P
1 ответ
Я разработчик игр, который изучал экономику, поэтому я могу дать вам ответ экономистов двумя руками.
С одной стороны, у вас есть экономика, где формула удивительно проста. Просто найдите его в Google или просмотрите главу 1 любой книги по экон. Вы можете использовать эту формулу, но поскольку экономика связана с личным поведением, она игнорирует сложности принятия человеком решений и просто называет это максимизацией (введите все, что здесь максимизируется). Это означает, что для того, чтобы использовать действительно простую формулу, вы должны реализовать действительно сложный ИИ, если игроки не будут единственным производителем / потребителем. Если вы не строите симуляцию, это не очень хороший способ.
С другой стороны, вы действительно заботитесь о веселье. Так что ни одна формула где-либо близко к реальному не в порядке Используйте линейное распределение, чтобы оно стало линейной функцией, а ваши переменные для игры - это наклон и Y. Используйте функцию кривой, и вы добавите экспоненту для игры. Поместите их в файл данных и играйте с ними, пока не станет весело. Поверьте мне, если вы повеселитесь, то мало кто заметит, что это неправильно.
Начните с предположения о базовой стоимости товара. Это не должно быть необычным спросом или предложением. Определите разумный инвентарь. Этот инвентарь не обязательно должен быть суммой, доступной в одном магазине, но доступной в целом. Затем определите максимальную сумму, которую кто-то заплатил бы за одну из них. Опять же, это просто для развлечения. возьмите доступную по оси x и стоимость по Y и вычислите уклон.
Меч довольно широко доступен, поэтому предположим, что в любой момент вы можете получить 10 на 5 золотых. Теперь предположим, что никто никогда не заплатит больше 20, если их всего 1. У вас есть две точки 10, 5 и 1, 20. Когда линия пересекает у =0, торговцы больше не будут покупать меч.
Линейные "кривые" довольно распространены в экономике. большинство кривых, таких как знаменитая кривая Лаффера, на графике действительно почти плоские.