An introduction to graph rewriting for procedural content generation

Поділитися
Вставка
  • Опубліковано 19 січ 2025

КОМЕНТАРІ • 39

  • @NateyC214
    @NateyC214 2 роки тому +16

    Simple explanations and pleasing diagrams, who could ask for more?

  • @Kazner0h
    @Kazner0h 8 місяців тому +3

    How could I *not* subscribe with such wonderful visuals and editing? Great video

  • @joelgomes1994
    @joelgomes1994 2 роки тому +5

    Your channel is pure gold, nice job!

  • @haydenap
    @haydenap 2 роки тому +4

    Always look forward to your videos. This has been really interesting, thanks for including extra links.

  • @pixtrick
    @pixtrick 8 місяців тому

    That was exactly what i was looking for. On top of that, that was brilliantly explained. Thanks mate

  • @pavlovsdoguk
    @pavlovsdoguk 2 роки тому

    your stuff on Graph rewriting is awesome. Subbing for this content.

    • @TheShaggyDev
      @TheShaggyDev  2 роки тому

      Thanks! If there's any other proc-gen topics that you're interested in, let me know! I keep a big list of topics and pull from it when I'm deciding what content to cover.

    • @pavlovsdoguk
      @pavlovsdoguk 2 роки тому

      @@TheShaggyDev Right now I'm working on a game that uses graph rewriting, but I've been very interested in Wave Function Collapse and genetic algorithms

  • @55fsm
    @55fsm 3 місяці тому +1

    Awesome video. Thanks.

  • @nickvatanshenas9251
    @nickvatanshenas9251 2 роки тому +1

    Great editing and explanations

  • @Sean-gx1sf
    @Sean-gx1sf 2 роки тому +2

    Damn, first image is the FTL map; you know your stuff

    • @TheShaggyDev
      @TheShaggyDev  2 роки тому +1

      FTL is one of my favorites! Gotta include it, at least visually, for anything related to proc gen.

  • @pokelizardo2298
    @pokelizardo2298 2 роки тому +1

    Great explination, a nice introdiction to graph rewriting.
    What would you say are biggest pros and cons of graph rewriting for pcg compared to other techniques?

    • @TheShaggyDev
      @TheShaggyDev  2 роки тому

      Glad you liked it!
      Biggest pro for me is the flexibility it offers, since you can control the generation as tightly as you want and can generate anything from quests to maps to building structures (which I came across but didn't cover in this video). As opposed to generation techniques that are just for grid-based maps or just for X, you could really dive deep into this technique and reuse it in a lot of ways.
      Biggest con imo is just the complexity involved. A lot of people aren't too familiar with graphs or don't work with them very often, and making good procedural content is hard enough without also having to deal with an unfamiliar data structure. You'd also probably need some custom tooling to make it easy to generate a large number of interesting replacements and rules to use.

    • @pokelizardo2298
      @pokelizardo2298 2 роки тому +1

      @@TheShaggyDev thanks a lot. I am currently working on my bachelor thesis on the usage of graph grammars and graph rewriting and both this video and your video about generative grammars were a godsend. After drowning in research papers it was nice to have a concise and understandable video with all the necessary information. Keep up the good work.

    • @TheShaggyDev
      @TheShaggyDev  2 роки тому +1

      @@pokelizardo2298 That's awesome to hear, thank you! And yeah, I had to read a fair number of papers for this one as well, but I guess I have to choice to skip those that are too boring 😅

  • @_gamma.
    @_gamma. 2 роки тому

    Great overview! 👏

  • @hawkgamedev
    @hawkgamedev 3 місяці тому

    this video is gold, also whats the name of the game you display at 2:24?

    • @TheShaggyDev
      @TheShaggyDev  3 місяці тому

      Thanks! That's Curse of the Dead Gods

  • @McHumaty
    @McHumaty Рік тому +1

    7:26 name of this game?

  • @Aleamanic
    @Aleamanic 9 місяців тому

    what is that game at 0:39 in the video?

  • @deeri638
    @deeri638 Рік тому

    How would you store a graph in Godot? Its the multi paths that Im not sure about, a simple tree is just children, but when a node can have multiple connections how would you store that

    • @TheShaggyDev
      @TheShaggyDev  Рік тому

      There's a proposal open to add graphs to Godot (github.com/godotengine/godot-proposals/issues/3848), but otherwise you'd need to make the structure yourself. Khan Academy (and other places) has some discussion on what that might look like: www.khanacademy.org/computing/computer-science/algorithms/graph-representation/a/representing-graphs

    • @deeri638
      @deeri638 Рік тому

      @@TheShaggyDev thanks, Ill take a look at the khan academy link. Saw that proposal and was looking at if A* would work, still wrapping my head around how to position everything

  • @realMenta
    @realMenta 2 роки тому

    Thanks

  • @SpudMackenzie
    @SpudMackenzie Рік тому +1

    Heads up, the metazelda link in the description appears to have died.

    • @TheShaggyDev
      @TheShaggyDev  Рік тому +1

      Thanks for letting me know! Replaced it with a Wayback Machine link.

  • @_mickmccarthy
    @_mickmccarthy 2 роки тому

    Nice! I spent quite some time running through Joris Dormans' papers on graph grammars, could've used these videos around 5 years ago! ;)
    Keep up the awesome work!
    Not sure if you've come across it before, but there's a great Zelda dungeon generator project based off his work created by someone called Beck Lavender. Definitely worth checking out if you haven't already.
    P.S. Haven't yet watched the whole video (but did see Unexplored get a mention!), so apologies if it's already covered!

    • @TheShaggyDev
      @TheShaggyDev  2 роки тому +1

      Oh cool! I had missed this one somehow, thinking Metazelda was the only major Zelda algorithm. Gonna read into it more!

  • @Nesetalis
    @Nesetalis Рік тому +2

    This video feels like the underpants gnomes... "first I have some nodes, then replace nodes by color and connections." "???" level design!"
    What is the aim of these replacements?
    Now that you have a random smattering of colored nodes, what are you doing with those nodes to generate rooms? Are edges corridors? Doors? Are hallways a node?
    And not once do you mention how you might program something. What is the underlying data type, how is it structured, how is memory allocated? What is the processing and memory cost of generating one of these graphs?
    Implementation detail, even as an example would be nice.

  • @G69G71
    @G69G71 2 роки тому

    hi, do you have discord?

    • @TheShaggyDev
      @TheShaggyDev  2 роки тому

      Afraid not at this time, at least for Shaggy Dev related stuff. I may look into setting up a server at some point, though...

    • @G69G71
      @G69G71 2 роки тому

      @@TheShaggyDevok, thx anyways

  • @신관용-y1p
    @신관용-y1p Рік тому

    2:30 what is the name of this game??

    • @TheShaggyDev
      @TheShaggyDev  Рік тому

      Curse of the Dead Gods. Decent roguelite