I Made a Wave Function Collapse Castle Generator in Godot

แชร์
ฝัง
  • เผยแพร่เมื่อ 26 ม.ค. 2025

ความคิดเห็น • 246

  • @RachelfTech
    @RachelfTech  2 หลายเดือนก่อน +44

    This was another fun project! If you'd like to support the channel and get access to project source code, I just made a Patreon: www.patreon.com/RachelfTech. Thank you in advance for any support over there, but also just for being here and watching my videos, I really appreciate it! 🙌

    • @sonOfLiberty100
      @sonOfLiberty100 หลายเดือนก่อน

      I wanted to suggest you CNN or GAN's, but it takes to long time to train them. What you can use pretty quickly are Markov Chains. You have then to provide examples or have the transition weights. In my opinion with this approach you would avoid to build in the middle of the grass or have empty space like her 23:02

  • @beastbomber2316
    @beastbomber2316 2 หลายเดือนก่อน +263

    Ive spent a lot of time programming procedural algorithms in the past for games. I would suggest combine Wave Function Collapse with another algorithm to automatically generate a floorplan on the castle. Then set the bottom objects to those rooms. This will make a more organized castle generation. Look up dungeon generation algorithm to find a good one if this is a path you want to take.

    • @MrHaggyy
      @MrHaggyy 2 หลายเดือนก่อน +17

      I was tinking similar. When engineering a building you also build a hirachy of constraints and requirements. Like how many people will live in the castle. Then you derive what rooms they need and how big those needs to be. Then alignment etc.
      By making this hirarchy you eliminate design choices that would be possible, but not what people want. Like butting the bathroom as a connecting room between your door and your kitchen.

    • @jackturner7814
      @jackturner7814 หลายเดือนก่อน +1

      Game dev (Tech artist) here: What is the wave function collapse algorithm? I only know the term from beginning quantum mechanics...

    • @brandonmack111
      @brandonmack111 12 วันที่ผ่านมา +1

      ​@@jackturner7814it's exactly what she showed in the video. You have a set of tiles which have constraints that indicate what sorts of tiles can be on any of its sides. You then initialize one of your map spaces with one of the constrained tiles, and update the possible values of any surrounding tiles based on which one you picked. You continue oats, doing this for all the tiles around those ones (removing an option from one might make one on the next one over have options that are impossible, for example) and so on. If you have a space with no possible values, you'll have to backtrack or restart, since all spaces must be filled - otherwise, do it all again with another random tile selection on another random tile.

  • @b3agz
    @b3agz 2 หลายเดือนก่อน +94

    The eternal problem. "This works and I have no idea why... do I leave it?" 😂 Great video.

    • @MacronLacrom
      @MacronLacrom 23 วันที่ผ่านมา +1

      sometimes it seems like it only works when you type random things that have nothing to do with anything

  • @Pallerim
    @Pallerim 2 หลายเดือนก่อน +90

    The joy you exude explaining your projects is super contagious and inspirational. I am currently working on my own desktop pet, inspired by your previous project (mine is a squirrel).

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน +7

      Thanks so much! That's awesome to hear! 🐿️

    • @rmt3589
      @rmt3589 2 หลายเดือนก่อน

      I hope you make a tutorial. Any advice? Wanna make one myself.

  •  13 วันที่ผ่านมา +1

    great video! this seems fun to do. i knew about this algorithm and the references you showed but never tried myself, or seen anybody do it for a hobby project.
    for the height issue: maybe just lower the max height of the space so you dont get anything that tall? or dont allow pieces collapse that has only air around them so it would ground the generation process. it would feel like the castle is growing form the ground upwards and not materializing from every direction all at once

  • @Saitir942
    @Saitir942 2 หลายเดือนก่อน +70

    I do appreciate the tight but not miniscule scoping you use for these projects. Enough so that it's not just 'wow, look at this cool algorithm' (although depending on who you talk to some of that sort of thing might work well for the youtube algo gods), but not so much that you only release one video every 3 years.
    Hope you can remain excited about things!

    • @jtw-r
      @jtw-r 2 หลายเดือนก่อน +17

      100% and I love that she recognises that she has done enough in a day, and should come back with a fresh set of eyes.

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน +17

      Thank you! I'm still figuring out what scope works best for these videos, but I do like how they've been turning out so far! I'll probably continue doing a mix of projects around this size and a bit smaller; aiming to post around once per month :)

    • @Saitir942
      @Saitir942 2 หลายเดือนก่อน +2

      @@jtw-r Yeah, that's a great additional point. It's soooo easy to burn out all that early enthusiasm just pushing for one more feature/bug fix...
      "Morning" brain is a much better investment!

    • @Saitir942
      @Saitir942 2 หลายเดือนก่อน +1

      ​@@RachelfTechI'm sure you've looked into this way now than a casual viewer has, but if I've learnt anything about TH-cam channel growth from people's 100k,1 million retrospectives is mainly that it's never quite what you thought it would be, but as long as you can bring the same enthusiasm to the the idea that works, you can at least keep the mental health in decent shape.
      I'm sure you learnt a lot of those lessons from your guitar channel though!

  • @Fubes
    @Fubes หลายเดือนก่อน +6

    I love that you show all those struggles, imperfections and "I have no clue what I'm doing" situations of game design. You are super smart about the algorithm part but when it came to Blender I had to laugh because so many of us "techies" with no art background came across those same problems. Like when you said "I had to UV-unwrap my tiles but had no idea how to do" and then proceeded to do everything wrong, I just felt that so much :D

  • @superparadox
    @superparadox หลายเดือนก่อน +1

    ive had this in my watch later for weeks and im glad i finally watched it this is dope im subbing

  • @Lazdinger
    @Lazdinger หลายเดือนก่อน +1

    This is so freaking cool. I think the most interesting part for me was the bug hunting.. the visualizer you made to see exactly what the algo was doing. So satisfying, so cool.

  • @MaximumAxiom
    @MaximumAxiom 2 หลายเดือนก่อน +8

    I appreciate your videos, you do a good job of keeping it entertaining without really hiding your debugging journey. I also like how you go about troubleshooting. For instance, your approach to visualize the algorithm isn't something I almost ever do but it seems really wise to figure out what's going on.

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน +3

      Thanks so much!

  • @Nikrobaby
    @Nikrobaby 2 หลายเดือนก่อน +19

    Next project: Ok..I was not done with the Castle Generator...
    Amazing project! I understood like 5% but it was really entertaining to watch!

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน +3

      😄, thank you!

  • @Groufi
    @Groufi 2 หลายเดือนก่อน +13

    Love to see this project growing and you growing along

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน +5

      Thank you! :)

  • @MatthewDempsky
    @MatthewDempsky หลายเดือนก่อน +3

    Great video. I appreciate the part about pop_back vs pop_front, and that you returned to it rather than just letting it be. I've seen too many engineers who just accept the "seems to work solution," when they can't explain why alternatives fail.
    The name "wave function collapse" is quite silly though. I know you didn't name it, but I hadn't heard of it before, and the first few times this video showed up in my feed I assumed it involved quantum mechanics somehow and skipped over it, figuring it wasn't a practical technique.

  • @JacobJustice2141
    @JacobJustice2141 2 หลายเดือนก่อน +2

    I didn't really understand the algorithm itself until I saw the "debug" visualizer with the red blue and green blocks, then it all clicked for me instantly. Great video!

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน +2

      That's awesome to hear, I'm glad the visualizer helped!

  • @HansMilling
    @HansMilling 2 หลายเดือนก่อน +3

    Cool project. The thing is, when doing these PoC’s or small demo projects, you learn so much that will make you even better at the next project. I’ve been coding software for many, many years, and it’s funny how we all struggle with the same problems solving the code. I hope, whoever build these AI tools will focus on AI that can spot these mistakes we make, so coding will be a lot faster in the future. Right now AI is only good for making boiler plate code.
    I use Blender for Isometric tile sets. I use a sun ray instead of a point light to ensure that light fall equally on the models to not have the shading on a flat surface change. I also put all tiles into the same Blender files in different groups and build a script that will show, rotate and render all tiles from four angles.

  • @itsduno0001
    @itsduno0001 2 หลายเดือนก่อน +9

    I'm starting to notice a pattern in your love for squishy birds. I absolutely love these projects and the progress you are making on them. Keep up the great and inspiring work, it's so exciting to see.🐥

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน +3

      Thanks so much! 🐔

  • @CoryTheSimmons
    @CoryTheSimmons 18 วันที่ผ่านมา

    This is such a great project. Thanks for sharing your process and it looks great!

  • @JamieBainbridge
    @JamieBainbridge 2 หลายเดือนก่อน +14

    "It doesn't work and I don't understand why".
    "It works and i don't understand why".
    The programmer's dichotomy 😅

    • @prophetzarquon
      @prophetzarquon 2 วันที่ผ่านมา

      When I would fall asleep at the keyboard, wake up long enough to save, & come back later to find that I'd "fixed" something with a method I no longer recall, much less how to implement across the rest of the code...

  • @barrystan3682
    @barrystan3682 2 หลายเดือนก่อน +1

    Another excellent video. I've always been fascinated by procedural generation. Reading Notch's devlogs of creating Minecraft map generation was inspiring. I never understood exactly how it worked, but I do understand how to solve Sudoku (made my own solver years ago). I could follow what you were doing, but tackling something like that is way beyond me atm. Still struggling with TileMaps. Was fun to watch you get it working. Learning of EditorScript will help out in duplicating all my TileMapLayers while trying to create a season transition using tileset crossfades in my current project. Probably a dumb way to do it, but I don't know of a better one yet. Seeing the tools you use helps us beginners out.

  • @platibyte
    @platibyte หลายเดือนก่อน +2

    I ran into the same problem with WFC not being able to finish the generation. I used a red symbol with no constraints that was placed when no solution to the existing WFC state could be found. Then created new tiles to fill the gaps for these cases. It was like 15% more tiles i needed in the end.

  • @ashishnair97
    @ashishnair97 2 หลายเดือนก่อน +1

    Saw Townscaper and wanted to know how to and your video was the best learning experience... Thanks for you work 👍

    • @RachelfTech
      @RachelfTech  หลายเดือนก่อน +1

      Awesome to hear, glad it was helpful!

  • @DustinHarms
    @DustinHarms 12 วันที่ผ่านมา

    Man, these videos are so great. Always inspires me to keep my heart in gamedev. The projects are fun and I learn something from each video (though probably not nearly as much as you!)...and the delivery (it always seems like you're on the verge of laughing or something) just make for a really enjoyable video. It's just nice to have some purely fun explorative content in this space.

    • @RachelfTech
      @RachelfTech  12 วันที่ผ่านมา +1

      Really happy to hear that, thanks so much! More coming soon :)

  • @badsamaritan8223
    @badsamaritan8223 หลายเดือนก่อน +1

    I think you could add more rules/constraints that could make more castle-looking structures. Things like, requiring it to create an enclosed geometric shape, walls on the outside are always shorter than walls on the inside, corners always have a tower, etc.

  • @evanandrews8858
    @evanandrews8858 หลายเดือนก่อน

    This was a dope experiment to try out. Learned a lot without having to struggle to sort it out myself hahaha. More! More!

  • @iamsushi1056
    @iamsushi1056 2 หลายเดือนก่อน +1

    Another WFC video, what a good day

  • @sonodrome
    @sonodrome 2 หลายเดือนก่อน +2

    Great video! Love the project, the result turned out beautiful!!!
    When you were dealing with all the tall towers and thinking about how to reduce their frequency, it immediately made me think about weighted randomness, which is ultimately what you implemented. A real simple way I often go about this, is by generating two random values and always picking the lower of the two values, this will give you a linear distribution where the higher the value, the lower its frequency. If you need more of an extreme, you can just do the lowest of 3, 4 or more values, and that will give you more control over it. Anywho, love your work, especially all of the generative stuff, keep em coming!

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน +3

      Thanks so much! That's a cool way of handling weighted randomness, thanks for sharing!

  • @jlmonolith
    @jlmonolith 2 หลายเดือนก่อน +1

    This was the first time I've seen wave function collapse, so thanks for the explanation!

  • @michaelschlachter8865
    @michaelschlachter8865 หลายเดือนก่อน

    I tried to do some WFC stuff before and hit all the same things you did, and then I gave up! Your video is inspiring me to take another crack at it. you rock!

  • @galathiil
    @galathiil หลายเดือนก่อน

    New to Godot but a developer with some experience, I discovered your channel today and I'm already a fan! I devoured all your videos.
    I like your way of seeing things, solving problems and explaining concepts, it all speaks to me a lot. You seem to be a curious person, who gives 200%, who does not hesitate to rush headlong even into an area that you do not master, to search again and again to find THE solution and then share it. A true soul of a developer, rare, precious, never lose that.
    Unfortunately, my financial situation does not allow me to help you but know that my heart is in it!
    PS: Sorry for the quality of the English, it's not my original language. Google helps a lot but I don't know if I managed to transcribe all the expressions of my language.

    • @RachelfTech
      @RachelfTech  หลายเดือนก่อน

      Thanks so much for the kind words, I really appreciate it! It's great to hear people are enjoying the format of the videos :)

  • @Frank_G_Finster
    @Frank_G_Finster 2 หลายเดือนก่อน +2

    This wasnt only fun to watch, but also very inspiring. Thank you very much for sharing! 🙂

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน

      I'm so happy to hear that, thank you!

  • @stuaxo
    @stuaxo หลายเดือนก่อน

    This looks great fun, it's really good having something like this + just building and building.

  • @theagemaway
    @theagemaway 2 หลายเดือนก่อน +1

    Instead of picking a random point in the 3d space, run the WFC from the bottom layer first, then as it gets taller, eventually only the columns under the spires will be left, and they'll naturally choose a top.

  • @thedeadman6171
    @thedeadman6171 22 วันที่ผ่านมา

    YOU are my favourite youtuber ever sooo helpful

  • @DavidLindes
    @DavidLindes หลายเดือนก่อน +1

    Neat! Fun to see both your process and your result. And the click-on-bird thing is totes adorbs. :)
    Subscribed!

  • @mj2068
    @mj2068 2 วันที่ผ่านมา

    shout out to the godot & vscode editing combo. love the coding focus serious face😄 thx for making this

  • @cashewolddew
    @cashewolddew 2 หลายเดือนก่อน +4

    Such an exciting project! Well done 🥜

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน

      Thanks so much! :)

  • @whizzie3928
    @whizzie3928 หลายเดือนก่อน +1

    "but I was struggling with this and decided to take a break" is so relatable lmao

  • @DJMankiewicz
    @DJMankiewicz หลายเดือนก่อน

    This is an awesome walk through for something I've wanted to grok for a long time. Thanks!

  • @BrianHaddad
    @BrianHaddad 2 หลายเดือนก่อน +1

    You are quickly becoming one of my favorite game programming channels. Keep up the great work and thank you!

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน +1

      Thank you so much, I really appreciate it!

  • @GreySectoid
    @GreySectoid หลายเดือนก่อน

    As a fan of procedural generation this was very enjoyable to watch, seeing so much progress in half an hour feels like programming with super powers :)

  • @quentinarrius
    @quentinarrius หลายเดือนก่อน

    That was fantastic to watch! :D

  • @R4venshore
    @R4venshore หลายเดือนก่อน

    That looked like fun! Well done! I've done a ton of procedural generation, for no good reason really. One thing I recently did which was a lot of fun and really challenging, was generating whole cities, with streets and buildings. Especially if you want to streets to not be a perfectly square grid.

    • @RachelfTech
      @RachelfTech  หลายเดือนก่อน

      Thank you! That definitely sounds like a fun project as well, something I'd like to experiment with in the future too!

  • @Gijontin
    @Gijontin หลายเดือนก่อน

    Okay, just found this channel with this video, love it, subscribed!

  • @ChrisBrown-si1vg
    @ChrisBrown-si1vg หลายเดือนก่อน

    Very cool video. I've just started using godot and am really impressed with what can be done in it.

  • @derBartzer
    @derBartzer หลายเดือนก่อน

    Nice video which I enjoyed watching!

  • @gametail
    @gametail 2 หลายเดือนก่อน +1

    respect, I tried to implement this aswell and failed miserably on the constraint generation. You made it look so easy lol.

  • @ReasonMakesMusic
    @ReasonMakesMusic หลายเดือนก่อน

    This is so cool! I remember when Townscaper first came out I was so impressed by this kind of algorithm. Super fun to see more of this!

  • @DapperDilanzo
    @DapperDilanzo 2 หลายเดือนก่อน

    Youre a huge inspiration for a godot game developer like myself!! Keep making awesome stuff

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน

      Thanks so much, I really appreciate it!

  • @BoredDeveloper
    @BoredDeveloper 2 หลายเดือนก่อน +1

    I love your videos, keep it up!

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน

      Thank you!

  • @Illusion-clock
    @Illusion-clock หลายเดือนก่อน

    your smile is contagious, I keep smiling I dunno why

  • @Katzenha
    @Katzenha หลายเดือนก่อน

    I barly understand a word, but I love what I see (generators are SO awesome!) and your happy energy. :)

  • @sketchonk
    @sketchonk 2 หลายเดือนก่อน +2

    narrator rachel: now I decided for real I am done
    devlog rachel: now for real I am done
    these cuts make me chuckle

  • @juanurdaneta9844
    @juanurdaneta9844 19 วันที่ผ่านมา

    woah! really interesting surprise to see this channel after I followed your other guitar channel, I had to come into the video and see the guitars to really be sure haha, your channel was an inspiration for me to get back to guitar playing and I've been getting back into gamedev so it's really cool to see this!

    • @RachelfTech
      @RachelfTech  19 วันที่ผ่านมา

      Glad to hear people are randomly finding me here too! So cool to hear, thanks for watching :)

  • @_Draven
    @_Draven หลายเดือนก่อน

    Absolutely gorgeous😦

  • @rafikR85
    @rafikR85 2 หลายเดือนก่อน

    Wow ❤ this project is so cool - hats off girl 😊👏❤️ Im not in game dev thats random pop probably 😅 but your passion speak for themselve - very inspiring 😊

  • @_mickmccarthy
    @_mickmccarthy 2 หลายเดือนก่อน

    Awesome work! WFC is such a cool algorithm for procedural level generation, never used it myself but always looked like a very fun thing to create. Well, a full thing to have created, I always imagined it being a frustrating thing to actually create/debug due to all sorts of weird edge case possibilities!

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน +1

      Definitely ran into some frustrating debugging moments 😅, but it's really cool when it comes together!

  • @BananaftRu
    @BananaftRu หลายเดือนก่อน

    Thing hovering on top of grass is the grass texture wrapping around and showing bottom row of pixels on very top, you can fix that by switching texture sampling from wrap to clamp.

  • @Kry0000
    @Kry0000 2 หลายเดือนก่อน

    This was a very fun and informative video, thanks for sharing.

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน +1

      Thank you! 😁

  • @sammysofa1511
    @sammysofa1511 หลายเดือนก่อน

    woooweeeee very impressive! nice project

  • @Lion4de
    @Lion4de 2 วันที่ผ่านมา

    So amazing!!!

  • @KasperFrandsen
    @KasperFrandsen หลายเดือนก่อน

    This was lovely!

    • @RachelfTech
      @RachelfTech  หลายเดือนก่อน

      Thank you! :)

  • @Haakkon
    @Haakkon 23 วันที่ผ่านมา

    Great video! Pretty sure the normal map for your bricks is flipped in the Y direction. The depth might be inverted as a whole but I think the Y direction is just flipped which is why they look odd.

  • @SeanStClair-cr9jl
    @SeanStClair-cr9jl หลายเดือนก่อน +4

    This video is so relatable and awesome. I was obsessed with the idea of a WFC castle a while ago, and I am glad there are non-lazy people like you to actually put ideas like that into action

  • @janikarkkainen3904
    @janikarkkainen3904 หลายเดือนก่อน

    Great project! My only nitpick is that seems to me like the brick texture has the seams going out instead of in - so either the normal map or the normals themselves should be inverted. A great spot to see this is at 24:13

  • @Mark73
    @Mark73 หลายเดือนก่อน

    There was a company called Subversion that build a city generator, all the way down to the insides of buildings. Looked really good.
    The only problem was that they couldn't figure out a way to build a game around it.

  • @FOM_extras
    @FOM_extras หลายเดือนก่อน

    omg this is so cool!!

  • @Imevul
    @Imevul หลายเดือนก่อน

    I would have constrained the algorithm to start from the bottom and work up. That way, you wouldn't have the problem of randomly selecting a top grid cell that you _have_ to place something in. Usually, that's how buildings are constructed: from the bottom up. You could even add dynamic rules such that a wall tile is only valid as long as it doesn't have 5 or more wall tiles below it, or a spire can't have 5 or more spire tiles below it. Then you could better control the different castle size parameters. Might be difficult to save those kind of rules as a resource though.
    The suggestion from one of the top comments to generate a floor plan first is a step up from that as well.

  • @josh2878
    @josh2878 2 หลายเดือนก่อน

    Your videos are so entertaining. I love how happy you are talking about programming, it reminds me of The Coding Train.

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน

      Thanks so much!

  • @JoshGVarg
    @JoshGVarg หลายเดือนก่อน

    worked on something similar in college but much simpler definitely was a fun challenge translating the high level algo into actual code

  • @redshepard5306
    @redshepard5306 2 หลายเดือนก่อน

    your freaking awesome.

  • @lunerjuice1832
    @lunerjuice1832 2 หลายเดือนก่อน

    It would be so cool if the generative castles were a maze players could try and solve. They could either start from the outside trying to make their way to the center or from the center trying to make their way out. Adding more birds of varying colors could also be a fun way to earn points, it would be super cool if the birds only generated along paths that "could" lead to the end. Oh! And if it needs a story element it could be a Kind or Queen player looking for their missing crown. Or a little Knight character searching for it on their Majesties request. Each play through would be different keeping it interesting with a near limitless number of unique levels for one to go through! Okay now to step away from my own head for a moment lol, this was so much fun to watch. I felt like I learned something, I won't lie and say I'm gonna try this myself but I definitely wan to give it a try sometime in the near future. Just need to figure out where to start before diving in head first. Love the concept, 11/10 bird design, look forward to the next vid. :)

  • @mtrxishere
    @mtrxishere 2 หลายเดือนก่อน

    How are you so talented at everything!??

  • @merthyr1831
    @merthyr1831 2 หลายเดือนก่อน +3

    I WILL LAY DOWN MY LIFE FOR SQUISHY BIRD

  • @neogoo123
    @neogoo123 หลายเดือนก่อน

    Really cool stuff! The final product looks really nice, and it was interesting to see some of your findings! I have to say, I'm quite confused as to why it was faster to pop off the front of the array rather than the back... makes me think it was implemented as a queue instead of an array. I also feel like there's gotta be a faster way to propagate those constraints, but don't know what the algorithm would be off the top of my head. I feel like it'd be something related to adding the tiles around a changed tile to a stack and see if any of their constraints change, adding the tiles around *that* to the stack if it indeed did get more constrained.
    Edit: Just remembered doubly-linked lists, couldn't have been implemented that way

    • @RachelfTech
      @RachelfTech  หลายเดือนก่อน

      Thank you! I think in my case it's not that the pop front operation itself was actually faster, just that the algorithm ended up being able to resolve constraints faster in that order compared to the other way around. And yeah, I'm sure there are optimizations you could do to speed up the propagation! It's definitely not the fastest algorithm in general, but I also didn't spend much time thinking about optimization for this project.

  • @tom-sawyer-999
    @tom-sawyer-999 2 หลายเดือนก่อน

    Wow, impressive!

  • @jakebrooks3415
    @jakebrooks3415 2 หลายเดือนก่อน

    This is sick!
    I tried to implement a wave function collapse map generator myself and like you said i totally overcomplicated it. I was trying to generate constraints using a python script in blender that would identify vertices along the edges of some very low poly pieces and would calculate if it lined up. Looking back it was definitely a failure on my part to understand that WFC should generate constraints from an example output lol

    • @prophetzarquon
      @prophetzarquon 2 วันที่ผ่านมา +1

      I'm not so sure that WFC should _always_ generate from a single example; as another commenter noted, it can be useful to have a no-constraint block to drop when no block within constraints can be found: Upon review, you can then see where an example wasn't complete enough to demonstrate all potentials, & add the missing block type (including to any examples) going forward!
      Working on paper, with explicit step-by-step rules & paper tiles, can be illuminating in this regard; you're still doing wave-function-collapse, but your desired concept is the 'example' & _you_ are forced to find all the rules necessary to produce that concept repeatably yet with variation. There again, you may likely find points that can't be filled with the pieces
      ules you initially established.
      The example might not _always_ need to be monolithic or even strictly defined; just iterating through ruleset variations, can sometimes _reveal_ an ideal example that we didn't even know the full details of until we tried building them a few hundred different ways.

  • @Fighka303
    @Fighka303 หลายเดือนก่อน

    You make games now! Awesome!

  • @nicklansbury3166
    @nicklansbury3166 2 หลายเดือนก่อน

    Thanks. I really enjoyed watching this video.

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน

      So happy to hear, thanks!

  • @KrytenB
    @KrytenB หลายเดือนก่อน

    good job! keep it up!

  • @CharlesVanNoland
    @CharlesVanNoland หลายเดือนก่อน

    I've done a lot of procgen projects over the last 25 years but only recently have I started experimenting with hydraulic erosion. It seems obvious to me that the kind of mountain ranges you see in California or the northwestern coastal USA should be computable with a hydraulic erosion algorithm that's lattice-based, but I've really been struggling getting it to not just look like rock formations that have eroded into sand. Including a talus angle helped, but I still haven't been able to get those sharp angled ridges forming properly, which is what I'm going for. I assumed that IRL they form by large shallow flows eroding, and the erosion narrows as it grows deeper - but apparently the opposite is what happens. Instead, a narrow stream forms and stuff basically falls into it, while it keeps eroding deeper, resulting in the classic V-channel and angled ridges. Anyway, just thought I'd share a little bit of info about what I've been doing since you've shared your pursuits with us randos on here :]

  • @AverageDrafter
    @AverageDrafter 2 หลายเดือนก่อน

    Every time I see one of your titles I think "Hell yeah you did!"

  • @softgripper
    @softgripper 2 หลายเดือนก่อน

    This was a great video :) Thank you.

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน

      Thank you!

  • @isaacewing
    @isaacewing หลายเดือนก่อน

    very nice work ***hand-clap hand-clap hand-clap***

  • @Kavukamari
    @Kavukamari หลายเดือนก่อน

    maybe im projecting my own tendencies, but in the timelapses i can't help but imagine some of the faces you make as just "i can't believe this... why won't you just work"

  • @ReginaCæliLætare
    @ReginaCæliLætare 2 หลายเดือนก่อน

    Those are some crazy looking castles

  • @troligtvisme
    @troligtvisme 2 หลายเดือนก่อน

    Fun! :D You could add a "Hide and seek" mode where you have to look around the castle to find the bird, once found/clicked the bird will find a new hiding spot :))

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน +1

      That would be fun! 😁

  • @Lion_McLionhead
    @Lion_McLionhead หลายเดือนก่อน

    Good idea for a beast.

  • @davidmaaschdeyck
    @davidmaaschdeyck หลายเดือนก่อน

    these birds look HILARIOUS

  • @veorEL
    @veorEL 25 วันที่ผ่านมา

    You did good!

  • @NexusBaum
    @NexusBaum 2 หลายเดือนก่อน

    the fractured castle definitely has some appeal to it :)

  • @mattmmilli8287
    @mattmmilli8287 หลายเดือนก่อน

    Bucket list item to learn this 😭 so many ideas forever. No time tho

  • @needlessoptions
    @needlessoptions 2 หลายเดือนก่อน +1

    Hii great work !! just wanted to feed the algorithm and also say I love that I can actually hear you smiling all the time when you talk 😆😁

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน

      Thanks so much!

  • @ruthmoreton6975
    @ruthmoreton6975 หลายเดือนก่อน

    Hah, I ran into the exact same bug ( pop_front vs pop_back ) I mistakenly assumed that pop_front would get the last item pushed onto a stack whereas it actually gives the first. I've been procedurally generating mazes using a depth-first algorithm which seem to be similar to wave function collapse as constraints are added to adjacent cells based on the current cell.

  • @EmbeddedSorcery
    @EmbeddedSorcery หลายเดือนก่อน

    Ok this is cool. Imagine a Minecraft-like game with a megalopolis biome.

  • @TheYourdoom
    @TheYourdoom 2 หลายเดือนก่อน

    I think the problem with the high castles is caused by the pop_front/pop_back thing.
    In WFC you sort by the "entropy" of a tile so the tile being picked is the one that has the least options, so for this it should start generating from the bottom (we know it's not going to be a tower, only a castle floor or empty).
    You seem to have the order wrong making it so that it starts from the top. Which does mean it's *faster* because it can immediately eliminate a lot of options from the tiles below, but it does mean the quality of the result is less.
    A fun thing with WFC, optimizing for speed in this case means optimizing against quality.

    • @RachelfTech
      @RachelfTech  หลายเดือนก่อน

      I think my code is actually correctly picking from the cells with the fewest options first, it's just that the top of the map actually ends up with fewer options than the bottom because I pre-fill empty tiles around all sides of the map to prevent cut-off castles. And this results in fewer options for cells at the top of the map, because the only tiles allowed are castle top pieces. Also, the pop_front/pop_back part is for propagating constraints out from the chosen collapsed cell, and it's not actually used in the selection process for choosing which cell to collapse initially.
      So I think, in my case at least, a way to fix the tall spires would be to actually not choose cells to collapse based on entropy and instead manually choose to always go from bottom to top. Could be worth trying out at some point!

  • @fokeyjo
    @fokeyjo หลายเดือนก่อน

    I wondered about doing generated castles after seeing Townscape. It certainly looks fun to try, but I think the constraints of wave function collapse possibly aren't enough, in that they're great for filling in smaller details, but the bigger picture isn't working. E.g. you need castle walls to form contiguous enclosements. So as others say, there's another algorithm needed somewhere, or maybe several iterations of the WFC algorithm run at different scales of the structure. Maybe you can achieve it with components collapsing that aren't visible, like "inside-of-wall air" blocks?

    • @RachelfTech
      @RachelfTech  หลายเดือนก่อน

      Yeah you could definitely do more with it/modify the algorithm to make things more traditionally castle like! Would be interesting to explore further :)

  • @owenlloyd2528
    @owenlloyd2528 หลายเดือนก่อน

    Respect! 👍

  • @ThinkWithGames
    @ThinkWithGames 2 หลายเดือนก่อน +1

    Cool video! Is it true that pop_front was always faster? Or did it just so happen to be the case in a few examples? (I thought pop_back was always faster, though maybe your implementation didn't make that the case)

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน

      pop_front as an operation should be slower than pop_back, but the way I wrote the algorithm it seemed like processing constraints in the order set up by using pop_front was still always faster than the other way around. I didn't test this extensively though!

  • @weaponizedemoticon1131
    @weaponizedemoticon1131 หลายเดือนก่อน

    Man, that orientation problem in Blender is so familiar. :P
    Cool project!

  • @Tapsin
    @Tapsin 2 หลายเดือนก่อน

    Quick advise: Your normal maps are inverted by the end of the video, you just need to invert the green channel in photoshop or anything similar. I think Godot uses open gl normal map format and yours were maybe done for direct X :D

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน

      Interesting, will take a look, thanks!

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน

      @@Tapsin Looks like my normal map was indeed for Direct X, good catch! I'll just leave as is for now but good to know for future projects! Thanks :)

    • @Tapsin
      @Tapsin 2 หลายเดือนก่อน

      @ oh yes it was just a tip for future Rachel. Amazing videos by the way

    • @RachelfTech
      @RachelfTech  2 หลายเดือนก่อน

      @@Tapsin Thank you! :)