В первом посте об этой игре я рассказал о технических сложностях, которые пришлось преодолеть. Второй пост, который вы сейчас читаете — более лёгкий для восприятия. Здесь я проиллюстрирую гифками весь путь построения физической модели и кратко расскажу о каждом шаге.

От создания нового проекта в Юнити до публикации бета-версии в Стиме прошло 10 месяцев. 90% времени ушло на создание, оптимизацию и вылизывание физической модели, остальное — на геймплей.

Цель была в том, чтобы создать полностью физический мир. Но подход, реализованный в Red Faction показался слишком громоздким и не слишком реалистичным. В той игре меши при взрыве разбивались на куски, на которые натягивались физические коллайдеры. Я решил не мучаться с сопроматом и множеством частных случаев разрушений, а сделать простую систему, работающую во всех случаях.

Сделал всё из взаимодействующих частиц: землю, здания, танки игроков, врагов, снаряды и бонусы — всё. Взаимодействия между частицами реализовал на видеокарте, поскольку для параллельных вычислений она в 50-100 раз производительней процессора.

Получившаяся из частиц материя сначала выглядела странно, и напоминала то ли жидкость, то ли газ:

image

А для игры нужно было что-то прочное, способное держать форму. Испробовав разные способы взаимодействия частиц, я нашёл, что сила Леннарда-Джонса даёт самую прочную субстанцию. Получилось что-то вроде манной каши. Для экспериментов я добавил взрывы по клику мыши.

image

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

Проблема со стабильностью вот в чём. Дискретность модели ограничивает величину силы взаимодействия между частицами, так как на большой скорости частицы могут за один шаг чрезмерно сблизиться, проигнорировав крутейшую (двенадцатой степени) кривую роста силы отталкивания. Это придаст им огромное ускорение, что сделает новое неестественное сближение ещё более вероятным. Закон сохранения энергии нарушается, материя взрывается. А вязкость позволяет ослабить этот эффект.

Когда материя стала вести себя более-менее удовлетворительно, я собрал из частиц танк и сделал для него управление: на каждом шагу вычислений в видеопамять передаются данные о нажатых игроком клавишах, и эти данные используются для управления вращением колёс и наклоном пушки:

image

Взаимодействовать с физически реалистичным миром было увлекательно, я был вдохновлён. Игра развивалась именно в том направлении, в котором я хотел.

Затем я добавил модуль построения уровня по картинке: считывались пиксели, и на их месте создавались физические частицы. Кроме того, материя «обугливалась», чернея от длительного воздействия высокой температуры.

На этом этапе обнажилось несовершенство физической модели. Каменные колонны вели себя как желе:

image

Пришлось пожертвовать производительностью, уменьшить шаг дискретизации, и за счёт этого увеличить силу взаимодействия между частицами, без риска нестабильности. Материя стала более прочной, и я создал несколько разных физических материалов: камень, металл, снег, песок, земля, лёд, желе, и т.д. Каждый материал немного отличался от других, песок был сыпучий, камень прочный, металл прочный и гибкий, а желе гибкое и хрупкое. Дерево горит и превращается в пепел, а лёд прочный, но легко плавится.

Затем я создал из тех же частиц несколько типов летающих тарелок, и всё там же, в выполняемом на видеокарте шейдерном коде, написал управляющую систему для врагов. Они неплохо целятся, уворачиваются друг от друга, и используют разные тактики боя.

Получилось уже довольно похоже на компьютерную игру в традиционном понимании:

image

На этой гифке можно заметить, что я использовал новую сущность — своего рода кости, задающие расстояние между частицами. Они же и мышцы, так как у них есть характеристика жёсткости и изменяемая во времени длина. Так что стало возможным укреплять высокие здания и делать на уровнях подвижные платформы.

Кроме того, я создал универсальную систему описания оружия, которая позволяла описывать широкий спектр средств уничтожения, просто нанизывая одни унифицированные эффекты на другие, создавая цепочки событий. Появились пулемёты, огнемёты, растраивающиеся в полёте снаряды, многолучевые солнца термоядерных взрывов, веера молний, лавомёты и целая куча силовых модификаторов материи.

И ещё я создал бонусики, чтобы можно было подбирать патроны, усиливать танк или влиять на уровень по принципу кнопка-событие. Например, здесь можно посмотреть, что происходит, когда игрок подбирает ключ:

image

Также можно заметить подобие интерфейса с полосками здоровья и прочих характеристик танка-персонажа, и со списком доступного оружия.

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

Гринлайт к тому моменту был пройдён, поскольку по мере готовности я публиковал гифки на реддите, вызывая стабильный интерес необычным подходом к построению мира.

Наконец, игра вышла в раннем доступе, вот трейлер:



(Музыка — из техно-оперы Виктора Аргонова «2032». Не очень подходит по смыслу, но волнующая).

Суммируя опыт разработки: эксперимент показал, что глубокое проникновение физики в геймплей технически реализуемо, но пока не слишком ясно, как это использовать с наибольшей пользой для геймплея. Нужно ещё разобраться, какие уникальные игровые фичи следуют из физического мира. Я сейчас работаю над кампанией для одного игрока, в которой пытаюсь задействовать необычные способы взаимодействия с миром, делаю эдакий гибрид «Леммингов» и платформера-стрелялки. В Леммингах надо было много копать, взрывать и строить, а в стрелялке — стрелять. Вот, посмотрим, какой гибрид у меня получится. Надеюсь, и игроки подскажут. В данный момент в опубликованной игре доступен только режим сражений, имитирующий игру Scorched Earth.

Цель этой публикации — поделиться с коллегами-разработчиками итогами этого эксперимента. Возможно, кто-то заинтересуется и захочет в своей игре тоже уделить физике побольше места. В комментариях наверняка будут спрашивать про страничку в Стиме, поэтому сразу её укажу.
Поделиться с друзьями
-->

Комментарии (124)


  1. TheShock
    10.05.2017 02:31
    +5

    На этом этапе обнажилось несовершенство физической модели. Каменные колонны вели себя как желе:

    Я понимаю, что это немного не соответствует идеологии, но почему бы не добавить для некоторых объектов твердые кости, которые бы разрушались только при достаточной силе взрыва? Тогда и интересный эффект сохранится и дополнительно можно было бы делать что-то вроде твердых предметов, стремящихся сохранить свою форму и, при этом увеличить шаг, чтобы было меньше отрицательного влияния на производительность.


    1. ThisIsZolden
      10.05.2017 13:23
      +3

      Твёрдые объекты, усиленные костями есть. Например, тот же танк:

      image

      Многие здания на уровнях внутри тоже усилены.

      Но это не помогло бы увеличить шаг с сохранением твёрдости. Кость задаёт расстояние между парой частиц, все друг к другу не закрепишь. А события, нарушающие закон созранения энергии происходят по всему объёму. И если увеличить шаг, кости не спасут материю от спонтанной детонации.


      1. HerrDonUlt
        10.05.2017 14:08

        я конечно дилетант, но может вместо просчёта частиц, стоит считать связи, и их характеристики. При должной архитектуре, не придётся вводить костыли, вроде костей, и колонны не будут похожи на желе.


        1. ThisIsZolden
          10.05.2017 14:11
          +1

          Для просчёта частиц, собственно, и считаются связи между ними. Но на уровне связей прочность можно увеличить только ценой производительности. Так что я пошёл на компромисс с «костями». Чтобы добиться большей прочности, и сделать игру играбельной на слабых видеокартах.

          Но у костей есть и дополнительная роль, они анимируют мостики. Так что их существование оправдано расширением геймплея.


  1. Zav
    10.05.2017 09:07
    +1

    Хотел спросить как реализованы предсказания в мультиплеере при таком большом количестве расчётов, но посмотрев страницу в стиме понял что он только локальный (или вообще с одного компьютера).

    Предполагаю что адекватного решения для мультиплеера в реальном времени тут и не сделать никак, т.к. в отличии от других игр с меньшим количеством значимых изменений поведение будет слишком разниться.
    Можно, конечно, отрисовывать только то, что получено от сервера, рандом считать с общим семенем, но тогда очень лимитируется расстояние до самого сервера, особенно с учетом прям реалтайм действий.
    Буду рад если меня тут поправят и расскажут о адекватных вариантах.


    1. agentx001
      10.05.2017 09:45

      Можно, конечно, отрисовывать только то, что получено от сервера, рандом считать с общим семенем, но тогда очень лимитируется расстояние до самого сервера, особенно с учетом прям реалтайм действий.

      Не соглашусь. 30-50 мс — это вполне комфортная задержка, которой не замечаешь. Знаю из опыта облачного гейминга :)


      1. Zav
        10.05.2017 10:15
        +6

        30-50 мс — это очень хорошая задержка, мой столичный друг :-)
        Но так выходит что не все живут в одном городе, и, зачастую, задержки идут в районе 100-200мс, на которых это всё уже отличается ощутимо.
        И то, ребята с ДВ, вполне возможно, позавидуют и таким задержкам.


    1. VioletGiraffe
      10.05.2017 10:16
      +1

      Я думаю, тут нужен тот же подход, что в большинстве крупных современных реалтайм мультиплеерных проектов — все расчёты на сервере, на клиенте только отображение плюс миллион уловок для lag compensation.


      1. Zav
        10.05.2017 10:22

        Так я о том и написал — в отличии от современных реалтайм мультиплеерных проектов тут значимой информации на порядки больше — всё окружение изменяемо, каждый пиксель влияет на другой.
        Как в таких случаях организовывать lag compensation?


        1. veydlin
          10.05.2017 11:36

          Можно, как вы и сказали, синхронизировать семя рандома и просто сообщать место взрыва, тогда у всех клиентов будет одинаковый просчет физики

          Как я понял игра пошаговая, как worms, там что тут не нужна реакция на изменение в мире в реальном времени


          1. Torvald3d
            10.05.2017 16:42
            +2

            синхронизировать семя рандома и просто сообщать место взрыва

            Скажу по опыту — не все видеокарты считают одинаково. Так что могут быть серьезные расхождения в мире из миллиона частиц


            1. ThisIsZolden
              10.05.2017 18:12

              Да, поэтому предлагали переходить на int-значения. Разные видеокарты могут по-разному работать с float. Потеряю в точности, но совсем незначительно. Зато будет шанс сделать симуляцию детерминированной вне зависимости от видеокарты.


              1. Torvald3d
                11.05.2017 16:00

                Теоретически — да, если как-то хитро синхронизировать циклы. Допустим, симуляция у вас детерменированная и физика обрабатывается 20 раз в секунду. У одного клиента что-то тормознуло и цикл либо пропустился либо выполнился чуть позже. Если подтормаживания возникают регулярно, то время будет идти по-разному. А если пропускать итерации, то физика будет вести себя не одинаково.
                Кстати, даже с интами видеокарты ведут себя по-разному. Когда-нибудь проверяли, что будет, если ноль поделить на ноль на гпу разных производителей? или корень из минус единицы? Что будет, если вывести в цвет значение nan или бесконечность? Помню был случай, когда при записи в цвет +бесконечность некоторые гпу выводили белый цвет, а некоторые черный. Конечно все это граничные условия, которые по-хорошему бы обрабатывать отдельно, но все же…
                Есть еще вероятность, что с интами видеокарта будет работать медленнее.


                1. ThisIsZolden
                  12.05.2017 23:36

                  Симуляция работает из-под Update(), а не из-под FixedUpdate(), то есть, у каждого со своей скоростью, которая зависит от производительности видеокарты. Поэтому, в любом случае при одновременной игре придётся ориентироваться на самого медленного игрока. Я на принципиальном уровне представляю, как это нужно организвать, чтобы всё работало синхронно, без пропусков. Но сетевого кода никогда не писал, так что подводных камней предвидеть — знаний не хватает.

                  Касательно интов — да, мне говорили, что видеокарты внутри себя всё во float считают, а инты будут медленней. При этом, существует ряд intrinsic atomic functions, которые пишут общие данные в защищённом режиме, так вот, эти функции существуют только для целы чисел, а для с плавающей точкой — нет. Странно.

                  А компилятор говорит, что вместо интов лучше использовать uint, потому что они быстрей. Так что сделаю на uint, всего вероятней. Потому что обработать граничные случаи, чтоб разные карточки не имели вольности можно, а вот если производительность потеряю, это будет хуже.


                  1. DaylightIsBurning
                    13.05.2017 11:32

                    Касательно интов — да, мне говорили, что видеокарты внутри себя всё во float считают, а инты будут медленней.
                    А зачем гадать? Можно же посмотреть cycles per instruction throughput для нужного GPU и выяснить наверняка.


                    1. ThisIsZolden
                      13.05.2017 13:34

                      Там про CUDA написано; это всё применимо к случаю, когда шейдерный код компилится в directx или openCL?

                      Или вот вопрос, там говорится про int и float, а у меня компилятор говорит: чтоб быстрей считать, используйте uint вместо int. А в таблице этого различия не упомянуто, в чём может быть дело?


                      1. DaylightIsBurning
                        13.05.2017 13:37

                        К OpenCL точно применимо, думаю что и к DirectX тоже — вычислительные модули одни и те же ведь. Но я раньше аналогичные таблицы и для OpenCL находил, в т.ч. и для AMD. Про uint/int не знаю, надо гуглить.


                  1. DaylightIsBurning
                    13.05.2017 11:38

                    обратите также внимание на if statements, по этой причине в ПО для MD избегают «обрезанных» версий потенциалов, стараясь так настроить симуляции, что бы частички никогда не попадали в «обрезанную» зону.


                    1. ThisIsZolden
                      13.05.2017 13:36

                      Да, слышал про if statements, стараюсь избавляться, где возможно. У меня обрезание пиков происходит через clamp() расстояния между частицами.


                      1. DaylightIsBurning
                        13.05.2017 13:51

                        Не знаю, какая производительность clamp(), но думаю что намного хуже чем add/multiply. Надо проверять, простенький кернел сделать и проверить.


                        1. ThisIsZolden
                          13.05.2017 16:10

                          Ок, потестирую. Наверняка сейчас недооптимизированность есть в подобных мелочах.


                      1. DaylightIsBurning
                        13.05.2017 14:02

                        Throughput of single-precision floating-point add, multiply, and multiply-add is 8 operations per clock cycle.

                        Throughput of compare, min, max is 8 operations per clock cycle.

                        nvidia_opencl_programmingguide.pdf
                        То есть наравне, можно пользоваться.


                        1. ThisIsZolden
                          13.05.2017 16:11

                          Спасибо за ссылки!


        1. VioletGiraffe
          10.05.2017 14:31

          Хм, да, вы правы. Не имеет значения, где запущен сервер, на отдельном компьютере или на одном из клиентов.


    1. ThisIsZolden
      10.05.2017 13:53

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

      Так что я собираюсь попытаться сделать синхронизацию детерминированной. Для этого я перейду с float на int, и сделаю все вычисления не зависящими от порядка обращения параллельных потоков к общим данным.

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

      А если не получится с детерминированностью, буду мудрить с оптимизацией синхронизации, это будет сложно, но очень хочется мультиплеер, можно заморочиться.


  1. VioletGiraffe
    10.05.2017 11:01

    А в каком subreddit вы описывали ход разработки?


    1. ThisIsZolden
      10.05.2017 13:31

      Ход разработки — в r/Unity3D и в r/Unity2D

      А просто гифки, чтобы заинтересовать игроков, постил в r/Gaming, там аудитория шире.


  1. Here_and_Now
    10.05.2017 11:02

    Я так понимаю, чтобы добавить деталей в вашем движке надо симулировать все бОльшее количество точек.
    Интересно было бы почитать про это.


    1. ThisIsZolden
      10.05.2017 13:37

      Да, чем больше точек-частиц, тем больше, собственно, материи, из которой всё лепится. Но чем их больше, тем выше вычислительная нагрузка и ниже скорость работы. Так что я примерно по 20-30 тысяч частиц на уровень использую, чтоб с моей видеокартой работало. А если б я ориентировался на самые мощные модели, типа GTX 1080, можно было бы хоть 100К частиц использовать.

      А почитать об этом, кроме упомянутого первого поста на хабре, можно ещё в моём посте на пикабу.


  1. auine
    10.05.2017 11:22
    +1

    На мак будет)?


    1. geakstr
      10.05.2017 12:08

      +

      Если будет под мак — поддержу покупкой :)


    1. ThisIsZolden
      10.05.2017 13:39

      В новой версии Юнити появилась возможность копилить compute shader под Мак. Так что теоретически я могу выпустить игру для Мака. И планирую жто сделать, но не сразу, хочется сначала доделать до окончательной версии. Так что через пару месяцев только.


  1. Alex_ME
    10.05.2017 11:43

    Очень здорово! Сам думал о таком, вдохновившись The Powder Toy, так же, с подвижными объектами, разрушениями, плавлением, расчетами на видеокарте и т.п, но дальше теоретического фантазирования дело так и не дошло.


    P.S. Не нашел информации, OpenCL или CUDA? Будет работать на AMD видеокартах?


    1. ThisIsZolden
      10.05.2017 13:42

      Я тоже вдохновился именно The Powder Toy.

      Сделал в Юнити, на compute shader. Код шейдера пишется на HLSL, и юнити компилит его на directX или openCL. Так что на вполне AMD работает. А новая версия даже умеет компилить под Metal.


  1. stargazr
    10.05.2017 12:30
    +1

    Мне кажется, КДПВ с "сырой" реализацией выглядит гораздо лучше остальных.
    Причем, полагаю, именно в GIF, за счет дизеринга. Такой-то веб-панковский вид.


    1. ThisIsZolden
      10.05.2017 13:56

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


  1. svanichkin
    10.05.2017 13:13

    В скорче было оружие выжигающее куски земли, без разлета в разные стороны, меганюка например. И во всех играх, как в скорче, так и в леммингах, чевях можно были строить конструкции или засыпать участки землей.


    1. ThisIsZolden
      10.05.2017 13:58

      Я сразу решил, что реализм на первом месте. Так что выжигания не будет, земля будет разлетаться. Но диапазон типов оружия я расширю со всем уважением к богатству оружия в скорче.


  1. sgenie
    10.05.2017 13:13

    Здорово! У меня два вопроса есть:

    1. Можно ли код интегратора посмотреть?
    2. Когда игра будет доступна?


    1. ThisIsZolden
      10.05.2017 14:00

      1. Интегратор тривиальный, кажется это называется методом Эйлера. К координатом на каждом шагу прибавляются значения скоростей. А скорости обновляются с учётом действующих сил.

      2. Уже доступна на раннем доступе в стиме для винды, в конце поста ссылочка есть.


      1. sjkopiloff
        10.05.2017 16:34

        Эта разностная схема (Эйлера) 1-го порядка точности. Преимущества: менее требовательна к железу, больше скорость, а вот недостатки: ее на больших временных шагах нельзя использовать — ошибка быстро нарастает.
        А контактная модель соударения (взаимодействия) частиц какая используется? У вас при бОльшем шаге dt смещение частиц большое, они перекрываются больше и по закону Гука нормальная составляющая контактной силы F=kx очень большая, а из-за нее, соответственно, ускорение большое и скорость на следующей итерации у частиц очень большая, поэтому частицы улетают «в небеса». Опишите подробнее контактное взаимодействие. Возможно, его можно поднастроить. Хотя бы общая формула. Обычно, нормальная составляющая выражает упруго-пластическое взаимодействие, тангенциальная — силу трения. У вас, наверное, так.


        1. pavel_kudinov
          10.05.2017 17:08

          да, поддерживаю вопрос, тоже хочется деталей по этой части, для собственных экспериментов


          1. ThisIsZolden
            10.05.2017 18:42

            Я ответил, смотри камент ниже.


        1. ThisIsZolden
          10.05.2017 18:41

          Контактное взаимодействие? Если я правильно понимаю термин, то я отказался от такого взаимодействия. Вначале, когда шаг был большой, я рассчитывал, не пересекаются ли траектории частиц, и если пересекаются, вычислял точку контакта и реализовывал упругое мгновенное столкновение, изменяя скорости и координаты столкнувшихся частиц.

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

          Так что сейчас используется только сила Леннарда-Джонса. Небольшая доля частиц движется быстро, и, действительно, перекрываются в столкновении, с возникновением неадекватных величин в нормальной составляющей силы взаимодействия. Но я это исправил, обрезав пики у кривой Леннарда-Джонса, оставив плато. Большинство частиц взаимодействуют в области вблизи равновесия между отталкиванием и притяжением, и там значения величины силы корректное. А если экстремальное сближение происходит, сила не растёт.

          Из-за редкости такого события, её влияние на модель незначительно, хотя есть случаи, когда оно играет главную роль. Например, в окрестности мощных взрывов материя проминается взрывом, так как сразу много частиц взаимодействуют в области плато из-за большой внешней силы. Или если большой твёрдый кусок материи сталкивается на высокой скорости с землёй или другим куском, столкновение демпфируется именно этим эффектом взаимодействия в области плато в области контакта кусков.

          Эти случаи, конечно, ослабляют реализм, но я расцениваю их адекватной платой за повышенную жёсткость материи.

          Помимо силы Леннарда-Джонса, есть ещё вязкость. При чём — не помню, из каких соображений — я реализовал только нормальную компоненту вязкости. Пара частиц обменивается долей их относительной скорости, проецирующейся на соединяющую их центры прямую.

          Вместо разностной схемы мне на реддите предложили попробовать rk4. Я счёл, что это исправит ситуацию для экстремальных градиентов поля, но за это придётся заплатить большим количеством вычислений, так что выигрыш не гарантирован. Поэтому, я пока не спешу её пробовать. Скрее всего попробую её позже, когда возьмусь за перевод модели с float значений на int, в надежде сделать симуляцию детерминированной.


          1. dimaleks
            11.05.2017 00:44
            +1

            Попробуйте метод Верле, стандартный в молекурярной динамике. Выше порядок точности, гораздо лучше сохраняет полную энергию системы (в вашем случае это неважно, но всё же), а вычислений сил столько же, сколько и в Эйлере. На английской википедии Velocity Verlet написан и сам алгоритм, смотрите тот, который из четырёх пунктов


            1. ThisIsZolden
              11.05.2017 13:40

              Спасибо.


        1. maisvendoo
          10.05.2017 22:09

          Преимущества: менее требовательна к железу, больше скорость, а вот недостатки: ее на больших временных шагах нельзя использовать — ошибка быстро нарастает.

          А ещё она теряет устойчивость при решении жестких систем уравнений, которые как раз это самое контактное взаимодействие и описывают

          Можно использовать неявную схему Эйлера, если система уравнений линейная, то получается вообще шикарно


  1. Segmentq
    10.05.2017 13:13

    Почему просто не хотите оперировать плотностью, вязкостью и твердостью. У вас же получается физика жидких тел, но не твердых. Вот и вытекает желейность. Скелет тут погоды особой не сделает, он только сгруппирует частицы «желе» вокруг себя.


    1. ThisIsZolden
      10.05.2017 14:05
      +1

      Я вначале экспериментировал с моделью без частиц, с полем векторов, с динамикой жидкости. Но меня эта модель не устроила, для описания земли лучше подошла модель с частицами. Всё же идеал — это твёрдое тело. Пусть он не достижим из-за слишком большого шага, но приближение меня устроило. «Бетон» качается и ходит волнами, но даже в виде горизонтальной балки он держит танк игрока, и это примерно то, чего я хотел получить.


      1. sjkopiloff
        10.05.2017 16:47

        Еще пара вопросов:
        1. А форма частиц какая? Только круглые? Примените прямоугольники-квадраты — будет более стабильно смотреться. Однако у «движка» скорость упадет — больше вычислений на детектирование коллизий между объектами и вычисление контактных сил.
        2. Масса у всех частиц одинаковая? Может некоторым частицам массы добавить — инерция увеличится и не будет заметно «желе»?


        1. pavel_kudinov
          10.05.2017 17:11

          если частицы будут не круглыми, то придётся считать физику вращения и пересечения граней, что очень накладно (более-менее эффективно это делает, например, Bullet на OpenCL, но количества частиц сразу становятся несравнимыми)

          SPH симуляции («на круглых частицах») — наиболее эффективно считаются в Soft Body, даже nVidia в nVidia Flex даунсемплит до массивов круглых шариков объекты, чтобы физику мягкого тела можно было считать в realtime


        1. ThisIsZolden
          10.05.2017 18:51

          Масса одинаковая. Кажется, я решил не усложнять вычислений вводя различие масс. Но если будет необходимость, можно ввести. Я подумывал о жидкостях с разной плотностью, чтоб в каких-то плавать, в других тонуть. Но возможно, до этого не дойдёт.

          А формы у частиц нет, они как точки взаимодействуют, столкновений не происходит, только взаимные силы с градиентом величины по расстоянию.


          1. sjkopiloff
            11.05.2017 08:58

            Интересная физическая модель. Попробуйте все же с массой поиграться. Нужно в физ. движок добавить только одно действие — деление результирующей силы для данной частицы на ее массу. Т.е. посчитали «взаимные силы» для данной частицы, потом поделили на ее массу, получили ускорение, обновили скорость частицы (прибавка будет небольшая), обновили положение — приращение тоже будет небольшое. Если массу частицы взять достаточно большой, то она будет практически неподвижна.


            1. ThisIsZolden
              11.05.2017 13:41

              Да, попробую, это довольно интересно.


  1. Ravaldini
    10.05.2017 13:13

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


    1. ThisIsZolden
      10.05.2017 14:07

      Такое станет возможным лет через десять, если темпы развития вычислительных мощностей не ослабнут. Тогда можно будет строить действительно сложный трёхмерный мир из десятков миллионов частиц. Пока частиц лишь десятки тысяч, этого маловато для описанного вами геймплея.


      1. QDeathNick
        10.05.2017 14:36

        Мне кажется стоит смотреть в сторону динамической детализации. Сколько частиц не считай, всё равно будет мало. Важно правильно выбирать детализацию. Нужен LOD для физики.
        В Minecraft был мод — LittleBlocks, жаль забросили его уже много лет. Позволял разбить блок на более мелкие детали, но физики там не было. Был мод с физикой(не очень интересной, но всё же), но он не работал с LittleBlocks. Скрестить бы их, уже было бы хорошо. Что-то оставляем в виде плохой детализации, что-то в более хорошей.
        Пока лучшее, что я видел с физикой в 3D, это заброшенный проект SoA.
        Но перестал следить, может есть что-то более интересное?


        1. QDeathNick
          10.05.2017 15:05

          Оказывается VoxelFarm, продолжает как-то развиваться.
          B AtomontageEngine тоже не совсем мёртв.
          Но вообще идея с воксельной физикой почему-то очень медленно развивается.
          Я пять лет назад думал, что появится очень быстро много интересных проектов.
          Но все мертвы.
          Удачи вам хотя бы с 2D.


          1. infobox
            10.05.2017 15:21

            x


          1. ThisIsZolden
            10.05.2017 18:57

            В VoxelFarm, кажется, тот же подход, что в Red Faction. Коллайдеры динамически натягиваются на оставшиеся без опоры меши. Но в видео заметно, что если меш хоть маленькой стеночкой соединён с основным зданием, то эта стеночка не сломается, хотя должна бы. То есть, этот подход требует учёта большого объёма частных случаев. Разработчики Red Faction тоже жаловались на эту сложность. Возможно, в ней кроется медленное развитие направления воксели+физика. Слишком сложно.


        1. ThisIsZolden
          10.05.2017 16:18

          Вы правы, если сделать большой мир, но просчитывать только кусок в видимой области, то ограничения по размеру мира снимутся. Именно в этом направлении я планирую развивать свой движок. Но это уже после того, как доделаю игру. А то на новые эксперименты времени уйдёт много.

          SoA прикольно выглядит, спасибо за ссылку.

          А из интересного я недавно видел вот такую штуку: там тоже материя из частиц, но в 3д и с VR.


  1. partureg
    10.05.2017 14:07
    +1

    Замените title в оконной версии. Там сейчас Compute Shader Test :)


    1. ThisIsZolden
      10.05.2017 14:07

      Ага, спасибо, не заметил :)


  1. perfect_genius
    10.05.2017 15:17

    Игра — это ограничивающие правила. Где можно разрушить правила — там вряд ли может быть игра.


    1. ThisIsZolden
      10.05.2017 16:33

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

      Простой пример: дать ограниченое число патронов для мощной пушки. Будет выбор: проломить стену и обойти врага или сохранить их для битвы с боссом. Впрочем, я только начал делать уровни кампании и тестировать задумки. Возможно, многие из них окажутся непрактичны из-за открывающихся коротких путей.


      1. Ravaldini
        11.05.2017 12:54
        +1

        Вот отличный пример игры:
        http://buildandshoot.com/
        Режим игры babel очень интересный. Команды должны строить лестницы, чтобы захватить чемоданчик. Можно ломать лестницу другой команды, можно копать туннели…


  1. EqualsZero
    10.05.2017 16:18

    Чтоб решить проблему со стабильностью можно модифицировать потенциал Леннарда-Джонса так, чтобы он был конечен в 0. Например, добавить к радиусу константу, т.е. вычислять не U( r) а U(r+c). Вообще разные варианты гуглить можно по «lennard jones soft-core».
    В итоге можно увеличивать шаг(ценой точности) и использовать больше частиц, хотя некоторые soft-core потенциалы могут быть сами по себе сложнее для вычислений, что скажется на FPS.


    1. ThisIsZolden
      10.05.2017 16:23

      Ага, я сейчас так и поступаю, пик потенциала срезан, вместо него плато, куда попадают самые быстрые частицы, хотя для большинства части градиент силы вычисляется на неискажённом участке кривой вблизи равновесия между отталкиванием и притяжением. У меня ещё несколько подобных хитростей использовано там и сям, так что можно сказать, что исчерпан весь диапазон возможностей увеличения жёсткости материи без оплаты производительностью.


      1. DaylightIsBurning
        11.05.2017 13:19

        Гармонический потенциал?


  1. HaMI
    10.05.2017 16:52
    +5

    >Материя стала более прочной, и я создал несколько разных физических материалов: камень, металл, снег, песок, земля, лёд, желе, и т.д.
    Почти Библия. Очень вдохновляющий рассказ


  1. niko83
    10.05.2017 17:49

    «Размолотить в кашу» хороший термин описывающий то что получилось.
    кататься по поверхности как-то примитивно, подумайте над тем чтоб соеднить физику полёта в Rokez (https://www.youtube.com/watch?v=SnAIuJsBQKQ) и ваш «мир»

    А так конечно получилось забавно, интересная статья, спасибо


    1. ThisIsZolden
      10.05.2017 19:00

      Ага, как раз над полётом думаю. Вероятно, на некоторых уровнях вместо танка будет летающий кораблик с реактивной тягой. Я это даже отчасти с танком реализовал, когда сделал у огнемёта слишком большую отдачу от выстрела, и танк летал с хвостом пламени.


  1. KSF000
    10.05.2017 19:00

    что-то новенькое. попробуй майнкрафт сделать из этого


    1. ThisIsZolden
      10.05.2017 19:02

      Если получится сделать мультиплеер с одновременной игрой в рилтайме, непременно попробую, должно быть круто. Но симуляция пока недетерминирована, так что мультиплеер только в задумке.

      Но как минимум я сделаю редактор уровней. И ещё добавлю разные сорта оружия, влияющего на материю. Уже сейчас можно копать в какой-то мере. И это довольно кайфово.


  1. partureg
    10.05.2017 19:55

    Немного обидно за мою 980M, которая набрала всего 5.8 ниже оптимального. Быстрее её работают ни так уж и много видеокарт :)


    1. ThisIsZolden
      11.05.2017 00:45

      Проверка видеокарты глючит :)


  1. DaylightIsBurning
    10.05.2017 20:16

    В науке подобные симуляции используются в Molecular Dynamics Simulations. Силы, характеризующие кристаллические (прочные, типа бетона или металлов) структуры неплохо описываются гармоническим потенциалом: U=k(x-x0)^2, где x0 задает длину связи, а k — её жесткость. Соответственно для создания жесткой структуры достаточно добавить от каждой частички по 6 (например) гармонических связей к её соседям и получится нечто жесткое. И от 12й степени получится уйти. Ну а проблема несохранения энергии в физических симуляциях решается введением термо/баро-статов. Способов реализации термостатов довольно много, но в Вашем случае, наверное, лучше всего что-то типа термостата ланжевена подошло бы.
    Ну и реализацию molecular dynamics на GPU можно подсмотреть, например тут или тут, может какие-то интересные идеи Вам пригодятся.


    1. DaylightIsBurning
      10.05.2017 20:38

      Для ориентира, openMM обеспечивает производительность в примерно 2.3 тысячи шагов симуляции в секунду для системы из 23558 атомов на NVIDIA Titan X Pascal. На GTX 980 получается примерно половина от этого. Под шагом я понимаю интервал временной дискретизации. А сколько шагов симуляции вы делаете между кадрами? Я так понял, что 10?


      1. ThisIsZolden
        11.05.2017 14:05

        Да, 10 шагов между кадрами, то есть 300 в секунду на 30 fps. Для примерно 20000 частиц. Я бы с удовольствием сделал шаг поменьше, но приходится ориентироваться на свою карточку gtx 750m, чтоб не тестировать игру на низких fps.

        Насчёт функции силы я согласен, наверняка есть более эффективная альтернатива. Я поэкспериментирую с предложенным вами вариантом, когда снова возмусь за физику.

        А уход от двенадцатой степени не самоценнен, intrinsic вункции языка HLSL на удивление быстрые, видимо там на низком уровне много ускорения математики. Важна в основном кривая в узкой области вблизи равновесия, её вклад в реакцию материи на толчки — наибольший. У функции U=k(x-x0)^2 вблизи точки равновесия иная кривизна, чем у леннарда-джонса, и сложно предсказать, что даст лучшее поведение материи. Так что поэкспериментирую.


    1. ACPrikh
      11.05.2017 08:43

      У меня тоже сразу возникла мысль уйти от Леннарда Джонса на потенциал вида -1/((X-Xo)^2+a). Быстрее считает, уход от авоста от 12 степени, не надо срезать. Не надо Рунге-Кутта, Эйлера достаточно. Да и детального сохранения энергии не надо. Единственное, что жалко — красивое название :)

      Чтобы уйти от желейности поиграть с вязкостью, так как именно она определяет затухание (а не срезка потенциала Л-Д). Если бы поподробнее о текущих формулах вычисления вязкости…

      Видел начало этой работы не помню где. Запало в душу ещё тогда. Молодца!


      1. ThisIsZolden
        11.05.2017 14:16

        Хвост всё равно будет, потому что придётся использовать огромный коэффициент у функции второй степени, чтобы создать значительную силу уже на небольшом расстоянии от точки равновесия, иначе материя будет кашей.

        А затухание у меня задаётся вообще читерским способом. Дело в том, что если что-то делать с абсолютной скоростью, то летящие в воздухе куски материи будут неестественно тормозиться. А если через вязкость распространять между частицами доли их относительной скорости, то общая энергия системы не будет падать, а это нужно, чтоб после взрывов всё успокаивалось.

        Поэтому, я ввёл систему, которая на каждом шагу выясняет для каждой частицы, является ли она частью большого покоящегося на земле куска или летит в воздухе. И если является. то из её абсолютной скорости вычитается малая доля.

        А формулы для вязкости сейчас таковы, что отсутствует обмен тангенциальной компонентой скорости между соседями. Потому что это тормозило вращение небольших кусков материи. Обмен происходит только долями нормальной компоненты скорости.


        1. ACPrikh
          11.05.2017 16:19
          +2

          Никакого огромного коэффициента:
          image
          Разница в потенциалах лишь в коэффициентах.
          Яма у шестой степени у дна более прямоугольная. Соответственно, более кашеобразный материал получается. Наклон и, соответственно, сила равный при а =7.

          А вязкость приведет к затуханию, если не сохранять кинетическую энергию. Уводить в нагрев, если по чесноку физику отбивать. Тангенциальная компонента совершенно правильно игнорируется. Определять к чему относится частица, вроде, накладно.

          Разница в потенциалах лишь в коэф а. Поэтому расчет при равной скорости.


          1. ThisIsZolden
            13.05.2017 00:04

            Если использовать формулу леннарда-джонса, то кривая потенциала пересекает точку равновесия под углом. А в случае приведённой вами формулы точка равновесия совпадает с пиком v-образной кривой. Вблизи пика кривая почти горизонтальна. Из-за чего возникает эдакий микро-люфт у точки равновесия. То есть, покоящаяся материя несколько расхлябана.

            Уход кинетической энергии в нагрев, кстати, есть, я сейчас подумал. При обмене нормальной компонентой относительной скорости часть энергии гасится. Но вязкость у меня считается не для каждой пары достаточно близких частиц, а только если между ними возникает «связь». У каждой частицы есть аналог валентности. Связь может возникнуть с шестью частицами или меньше. Условия возникновения и разрыва связей зависят от типа физического материала. А если делать вязкость для всех частиц, вне зависимости от связей, то материя проявляет жидкостную динамику более, чем динамику твёрдого тела. Для песка или крошашегося бетона это не очень хорошо.

            А определять, к чему относится частица — не накладно, там просто у меня есть две маски — гравитации и плотности. Они обновляются тоже через многопоточность, математика там тривиальная, так что считается быстро. Но пересечение эти масок позволяет выделить подмножества частиц, из которых можно отбирать избыток кинетической энергии, возникающий из-за ошибки большого шага, и в результате иметь больший коэффициент сил при большем шаге, то есть без оплаты производительностью.


            1. ACPrikh
              15.05.2017 09:27

              есть аналог валентности… есть две маски — гравитации и плотности…

              мы в восхищении, королева в восхищении (С)

              Пожалуй, лучше сосредоточится на рекламе и прочем пиаре.
              Желаю коммерческого успеха!


    1. ACPrikh
      11.05.2017 08:54

      Кстати, если уж модифицировать потенциал сил (и вязкости), то возможно, материалы можно задавать типом потенциала — формой его дна, крутизной стенок. На производительности почти не скажется, а многообразие резко увеличится.


      1. ThisIsZolden
        11.05.2017 14:20

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

        Для настройки типов физики у меня сейчас используется что-то около десяти параметров взаимодействия частиц. Это даёт довольно широкий простор для изменений. Единственное ограничение — сила связи. Но мне выше посоветовали использовать другой интегратор, и есть шанс, что он уменьшит ошибку большого шага, что позволит увеличить потолок сил, и это расширит диапазон физических свойств материалов.


        1. FlameStorm
          16.05.2017 13:31

          А что если обсчёт очередного dt вести в несколько подшагов — в несколько прогонов вычислений для частиц каждого из разнотипных материалов отдельно?
          Тогда вместо обсчёта всех 20000 частиц медленным вычислением, можно будет обсчитать 5000 медленным и 15000 быстрым. И значит будет возможность снизить требования к мощи видюх пользователей, или даже заметно увеличить число частиц на уровне.


    1. ACPrikh
      11.05.2017 08:59

      Сократить число взаимодействий убрав дальнодействие — разбить все пространство на области и считать взаимодействия только внутри областей. Чтобы не появились граничные эффекты на границах областей области должны быть перекрывающимися. Так сказать черепица.


      1. ThisIsZolden
        11.05.2017 14:21

        Именно так всё в данный момент и происходит.


  1. santa324
    10.05.2017 23:26
    +1

    Поделюсь своим опытом:
    Я как-то тоже делал такой 2D физический движек, сила взаимодействия между частицами у меня была 2 типов:
    1) отталкивающая между любыми близкими частицами
    2) заранее (при конструировании мира) заданный набор притягивающих связей. Эти связи разрушались, если частицы отдалялись друг от друга далее определьного расстояния.
    image

    Вместо желе получились вполне нормальные упругие тела.


    1. ThisIsZolden
      11.05.2017 00:50

      Здорово! А это оно в реальном времени так прыгает? И сколько частиц в сцене? В моей модели тоже жёстко получается, если сделать лчень маленький шаг, и увеличить силу взаимодействия. Но это повлияло бы напроизводительность, потому что ради быстрых вычислений в реальном времени пришлось бы сократить число частиц в сцене.


      1. santa324
        11.05.2017 10:06

        Да это в реальном времени около 2000 частиц, в один поток, на CPU, на Mac Pro 2015.
        Чтобы получить такую жесткость действительно пришлось сильно уменьшить шаг интегрирования (100 микросекунд), при большем шаге тела ближе к пудингу. Вообще асимптотика нагрузки на CPU от «жесткости» не знаю какая но очень крутая, надо как-нибудь попробовать вывести… Давно мечтаю придумать что-нибудь чтобы ее улучшить, но идеи пока сырые… ))
        Но в такой конфигурации сил тела по крайней мере сохраняют форму. Я тоже пробовал с силой Леннарда-Джонса, но тела тогда расползаются и деформируются, а тут гнутся до предела — потом рвутся. Наверно так можно разные материалы моделировать.


        1. ThisIsZolden
          11.05.2017 14:29

          Я на леннарде-джонсе использовал высокие коэффициенты, так что тела ближе к упругости. Использовал бы ещё более высокие, но это потребовало бы уменьшения шага, чтоб всё не взрывалось из-за ошибки большого шага.

          Но я тут подумал, что леннард-джонс вообще-то для трёхмерных тел вычислен. В двумерном случае силы должны быть выше, для достижения того же эффекта. Выяснение оптимальной формы и кривизны кривой сил вблизи точки равновесия — интересный вопрос. Оптимальной — именно с точки зрения количества производительности, затрачиваемой на единицу жёсткости. Я бы подэкспериментировал с этим, но хочется от физики перейти к геймплею, чтоб игру закончить.

          Кстати, разрыв связей при привышении порога я тоже сделал. То есть, у меня две системы наложены. Примерно такая, что у вас действует до разрушения, а после — чистый леннард-джонс без запрета на разрыв связи.


          1. santa324
            11.05.2017 15:46

            Я еще заранее собираю тела в правильной кристаллической решетке (6-гранные соты). Все связи заданы заранее в 6 направлениях от каждой частицы.
            Не делал точных замеров но по ощущениям увеличивает эффективную прочность тел.


            1. ThisIsZolden
              13.05.2017 00:16

              Я тоже собираю, все уровни так строятся, частицы размещаются в узлах шестиугольной решётки, чтоб сразу попасть в равновесие. А в первых экспериментах этого не делалось, частицы просто вбрасывались на уровень кучей. И там можно было наблюдать интересный эффект, как внутри тела существуют конкурирующие кристаллы с разным углом кристаллизации, и если нагревать эту материю, то одни области поглощаюд другие, распространяя на них свой порядок.


      1. santa324
        11.05.2017 10:13

        Кстати, а какой метод интегрирования у Вас?
        У меня Верле, хотя и Эйлер не сильно по эффективности отличается (по экспериментам: процентов на 10 примерно уменьшение шага интегрирования компенсирует разницу между ними)


        1. ThisIsZolden
          11.05.2017 14:31

          10%? Неплохо. Я как раз хочу перейти с Эйлера на Верле, как мне тут посоветовали. А с Рунге-Куттой не сравнивали?


          1. santa324
            11.05.2017 15:27

            Эффективность я оцениваю так: на одной и той же сцене какой максимальной длинны можно сделать шаг интегрирования прежде чем все взрывается. От метода зависит очень слабо.
            Рунге-Кутта не пробовал, вычислительно сложнее а выигрыш точности явно не скомпенсирует этого. Тут бы придумать что-то для неравномерного интегрирования, чтобы одни частицы чаще другие реже…


            1. ThisIsZolden
              13.05.2017 00:09

              Да, именно такой способ оценки эффективности меня интересует. Спасибо, что поделились опытом сравнения интеграторов с этих позиций.

              Насчёт неравномерного интегрирования я тоже думал, но есть ощущение, что выигрыш упразднится стоимостью вычислений, позволяющих исключить некоторые частицы из обсчёта. По этой дорожке луче идти до конца, и большую часть материи держать в виде полигональных коллайдеров, а там тоже всякие сложности возникают…


              1. santa324
                15.05.2017 09:24

                На самом деле есть ощущение что иеравномерное интегрирование могло бы тать не просто большую, а асимптотическую выгоду.
                Простой пример: большая часть материи не сцене неподвижна, и какую бы жесткость не задать, ее нет смысла интегрировать часто.
                Но как это реализовать чтобы не развалилась физика…


      1. santa324
        11.05.2017 10:17

        А как Вы распараллеливали вычисления? Делили сцену на сегменты по потокам, если так то как синхронизовывали стыки?


        1. ThisIsZolden
          11.05.2017 14:33

          Параллелизация идёт по частицам. На каждую частицу — один поток на каждом шаге вычислений.

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


          1. santa324
            11.05.2017 15:34

            Поток на частицу? У Вас тысячи потоков? А структура данных по которой вы ищете ближайших соседей синхронизуется каждый тик по всему объему? Мне не доводилось считать на GPU не знаю особенностей.
            Я предполагал что-то вроде разбиения сцены на N не пересекающихся участков и в каждом обсчитывать все частицы в одном потоке. Возникают нюансы синхронизации на стыке этих участков.


            1. ThisIsZolden
              12.05.2017 23:20

              Так тоже делают, с разбиением пространства. Хотя, обычно каждый кусок протранства считают на отдельной видеокарте.

              И да, у меня десятки тысяч потоков, по числу частиц. А когда текстура рендерится — по потоку на пиксель -> миллион потоков. Архитектура GPU очень развита для работы с таким количеством.

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


      1. DaylightIsBurning
        11.05.2017 10:19

        Ваша задача очень хорошо исследована, еще с 70х годов, обычно проходит под именем «молекулярная механика» («molecular mechanics») или «молекулярная динамика» (molecular dynamics). В последние лет 10 исследовано также применение GPU и даже FPGA и ASIC к этой задаче. Также исследованы в контексте этой задачи алгоритмы интегрирования, термостаты, способы уменьшения сложности вычислений уходом от дальнодействия (distance cutoffs, reaction field, Particle Mesh Ewald, etc). Есть готовые open-source реализации на C/C++/Fortran/CUDA/OpenCL с очень высокой производительностью (ссылки давал выше).

        В MD обычно применяют многокомпонентные потенциалы. Близкое взаимодействие происходит от гармонического потенциала и других, а дальнее — леннард-джонс + кулон.


        1. DaylightIsBurning
          11.05.2017 10:29

          Вот типичный потенциал, используемый в молекулярной механике. Объяснение.


          1. ThisIsZolden
            11.05.2017 14:51

            У меня он и используется, но упрощённо — чистый леннард-джонс.

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

            То есть, борьба идёт за удешевление жёсткости взаимодействия в валюте производительности. Но борьба эта идёт уже в области высокой ошибки из-за большого шага, так как это неизмежный компромисс. И поэтому признаные оптимальные решения для областей с малым шагом и малой ошибкой могут быть неприменимы в данном случае, так как они могут быть слишком чувствительны к ошибке. Я использовал силу леннард-джонса с крутым коэффициентом, но обрезал пик. Это уже очень грубое решение. Но оно позволяет получить большую жёткость для слабых взаимодействий между частицами. Так что мой случай несколько в стороне от типичных расчётов, и приходится искать оптимальные решения самостоятельно.

            На данный момент у меня есть два вопроса: какой интегратор покажет лучшие резальтаты меньшей ценой производительности. И можно ли на что-то заменить силу ланнарда-джонса, с тем же критерием.


        1. santa324
          11.05.2017 10:36

          Спасибо за информацию и ссылки, обязательно почитаю.
          Как я понимаю, там все же больше уклон именно в точное моделирование для научных целей. Тут нужно для игры и приемлемы любые хаки, которые сохранят визуальную правдоподобность и не более.


          1. DaylightIsBurning
            11.05.2017 10:52

            Согласен, но для научного моделирования важна производительность, поэтому все возможные хаки и не хаки тоже рассматриваются и оцениваются с точки зрения преимуществ/недостатков и можно было бы про это прочитать и может быть даже взять что-то, от чего в MD в своё время отказались.


  1. inquisitio
    11.05.2017 00:45

    На linux будет?


    1. ThisIsZolden
      11.05.2017 00:47

      Да, технически это возможно, но у меня нет машины на Линуксе, чтоб сделать билд, так что я пока игру доделаю до более вменяемого вида, и тогда выпущу для Линукса и МакОС.


  1. TriBar
    11.05.2017 14:34

    Поздравляю с ранний релизом! Уважаю за упорность развития проекта.
    Хотел поделиться парой мыслей насчет развития, хотя, вероятно, изменения слишком радикальные для уже отрелиженной игры.
    Вы не думали отойти от стилистики scorched earth в сторону чего-то другого? У вас уже есть отличный движок, но вы пошли по пути дополнения модели, чтобы все хорошо выглядело в выбранной стилистике. Другой путь был бы: если все выглядит как манная каша и желе — то и стилистика должна соответствовать манной каше и желе. Это могут быть зефирки или орешки истребляющие друг друга за место в мороженом, или инопланетные личинки в слизи… ну или что-нибудь еще такое не серьезное, но яркое и интересное.


    1. ThisIsZolden
      11.05.2017 14:37

      Я сделал пару уровней с кондитерской тематикой. В остальном, пока хочется придерживаться реализма в декорациях. А дальше посмотрю по массовой реакции игроков. Если для людей будет неприемлема желейность в бетонных столбах, придётся менять стиль.


  1. KitScribe
    12.05.2017 18:09

    Мне это напомнило какую-то игру, которая у меня была на Sony Ericsson. Только там нельзя было двигаться, и танки стреляли поочерёдно.


    Сделано очень круто! Поздравляю!


    Я сейчас работаю над кампанией для одного игрока

    Я бы на вашем месте начал с кооператива. Сейчас мало кто играет одиночные игры. Большинство игроков в Steam покупают инди игры для того, чтобы повеселиться с друзьями, а не проходить историю.


    Посмотрите хотя бы на "BattleBlock Theater" или "Move or Die". История не так увлекает, как возможность пофаниться с друзьями. А в вашей игре, с написанной вами физикой, фана будет море, судя по всему.


    1. KitScribe
      12.05.2017 18:31

      Кстати, решил открыть свой стим и посмотреть список рекомендуемого. Нашёл там это.


      Вот примерно о таком конечном результате я говорил. Отзывы "Очень положительные". Синглплеер в такой игре вряд ли кого заинтересует, ибо делать там нечего особо, а вот мультиплеер...


      1. ThisIsZolden
        12.05.2017 23:23

        Согласен, мультиплеер — основной источник интереса. Мультиплеер я запланировал, но для этого нужно сначала исправить недетерминированность симуляции, чтобы синхронизация была не слишком сложной.


        1. ACPrikh
          15.05.2017 09:36

          А стоит ли уж так дотошно синхронизировать? Лишь бы не до уровня «победил игрок 1 и одновременно с победил игрок 2». А о разнице в деталях мы никому не скажем.


  1. KwisatzHaderach
    13.05.2017 00:10

    Было бы интересно поиграть с такой физикой, но в сеттинге Teeworlds(с теми же режимами deathmatch,capture the flag,etc).
    Имхо это была бы не бомба, но весьма востребованной игрой.)


    1. ThisIsZolden
      13.05.2017 00:12

      Да, интересно. Я в эту сторону движок как раз и поведу. Чтоб строить полноценные уровни из разрушаемой материи, и на них играть в мультиплеере.


  1. sldp
    13.05.2017 15:57

    Отличная идея. Удачи вам!
    Позволю несколько советов/замечаний:

    • Никогда не оправдывайтесь, что игра платная (видел ваши ответы под роликом на ютубе). Любой труд должен быть оплачен.
    • Интересно бы было иметь возможно собирать свой танк, как из конструктора(это добавило вариативность в прохождение). Причем не просто из декоративных модулей, а именно функциональных.
    • Трейлер не очень. Вроде и неплохо, музыка хорошая, красивые кадры, но он должен интриговать и привлекать внимание с первых же кадров, а вы наоборот весь сок ближе к концу разместили. Ну и таких мелочей в рекламном видеоролики много.
    • Свяжитесь с летсплейщиками (тот же куплинов), которые смогут отлично продвинуть игру просто играя на своих каналах. Причем бесплатно для Вас.
    • Ну и «Кооператив наше все» (с) десятые годы 2 тысячелетия.



    1. ThisIsZolden
      13.05.2017 16:05

      Спасибо за замечания.

      Модульность танка я обдумываю. Сейчас пока есть прямая прокачка. Купил апгрейд двигателя — едет мощнее. Но новые разновидности танков понадобятся, так что скорее всего сделаю конструктор из универсальных деталей.

      С летсплейщиками свяжусь когда кампания будет готова, чтобы им было во что поиграть. Пока только hot seat есть, это не так зрелищно.

      Мультиплеер — в ближайших планах. Пока есть технические трудности, но вроде решаемые.

      С трейлером пока непонятно, как поступать. Я его по сути собрал из гифок, которые привлекли внимание раньше на реддите. Почитаю что-нибудь на эту тему.


      1. TheShock
        13.05.2017 18:02

        (Музыка — из техно-оперы Виктора Аргонова «2032». Не очень подходит по смыслу, но волнующая).

        Вот это — очень серьезная ошибка. Есть узкий круг людей, которым такая музыка нравится. Им будет «волнующая». Для всех остальных она будет только «не подходит по смыслу и жанру». Необходимо чувствовать жанр и подбирать музыку под него. Вот другому разработчику нравится Гарри Мур и он тоже б в трейлер вставил волнующую, но не подходящую по смыслу музыку.

        В общем, мой вам совет — подберите не то, что вам нравится слушать, а то, что подходит под игру. Потому что сейчас из-за неудачной музыки теряется 80% динамизма трейлера.


        1. 1eqinfinity
          17.05.2017 15:01

          Я тоже хотел откомментить про музон :) Это частая ошибка.

          Но сама игра очень заинтересовала. Желейные колонны тоже понравились.


  1. FromArcanum
    18.05.2017 12:24

    Напомнило Cortex Command, но там физика по ощущениям ближе к твердым телам