I Made a Wave Function Collapse Castle Generator in Godot

Поділитися
Вставка
  • Опубліковано 25 гру 2024

КОМЕНТАРІ • 222

  • @RachelfTech
    @RachelfTech  Місяць тому +39

    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 17 днів тому

      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 Місяць тому +233

    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 29 днів тому +12

      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 2 дні тому

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

  • @b3agz
    @b3agz Місяць тому +75

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

  • @Pallerim
    @Pallerim Місяць тому +78

    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  Місяць тому +6

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

    • @rmt3589
      @rmt3589 28 днів тому

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

  • @Saitir942
    @Saitir942 Місяць тому +66

    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 Місяць тому +16

      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  Місяць тому +16

      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

      @@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 Місяць тому +1

      ​@@RachelfTechI'm sure you've looked into this way now than a casual viewer has, but if I've learnt anything about UA-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 20 днів тому +4

    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

  • @Lazdinger
    @Lazdinger 5 днів тому

    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 28 днів тому +6

    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.

  • @MatthewDempsky
    @MatthewDempsky 14 днів тому +2

    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.

  • @Groufi
    @Groufi Місяць тому +12

    Love to see this project growing and you growing along

  • @galathiil
    @galathiil 14 днів тому

    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  14 днів тому

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

  • @Nikrobaby
    @Nikrobaby Місяць тому +17

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

  • @JamieBainbridge
    @JamieBainbridge 28 днів тому +6

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

  • @itsduno0001
    @itsduno0001 Місяць тому +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.🐥

  • @evanandrews8858
    @evanandrews8858 19 днів тому

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

  • @stuaxo
    @stuaxo 6 днів тому

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

  • @whizzie3928
    @whizzie3928 14 днів тому +1

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

  • @DavidLindes
    @DavidLindes 19 днів тому +1

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

  • @Frank_G_Finster
    @Frank_G_Finster Місяць тому +2

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

    • @RachelfTech
      @RachelfTech  Місяць тому

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

  • @sonodrome
    @sonodrome Місяць тому +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  Місяць тому +3

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

  • @michaelschlachter8865
    @michaelschlachter8865 15 днів тому

    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!

  • @Katzenha
    @Katzenha 9 днів тому

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

  • @jlmonolith
    @jlmonolith 29 днів тому +1

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

  • @JacobJustice2141
    @JacobJustice2141 Місяць тому +1

    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  29 днів тому +1

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

  • @barrystan3682
    @barrystan3682 29 днів тому

    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.

  • @BrianHaddad
    @BrianHaddad Місяць тому +1

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

    • @RachelfTech
      @RachelfTech  Місяць тому +1

      Thank you so much, I really appreciate it!

  • @ReasonMakesMusic
    @ReasonMakesMusic 25 днів тому

    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!

  • @GreySectoid
    @GreySectoid 24 дні тому

    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 :)

  • @R4venshore
    @R4venshore 18 днів тому

    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  18 днів тому

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

  • @Seedzification
    @Seedzification 12 днів тому

    your smile is contagious, I keep smiling I dunno why

  • @DJMankiewicz
    @DJMankiewicz 21 день тому

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

  • @Gijontin
    @Gijontin 8 днів тому

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

  • @quentinarrius
    @quentinarrius 22 дні тому

    That was fantastic to watch! :D

  • @DapperDilanzo
    @DapperDilanzo Місяць тому

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

    • @RachelfTech
      @RachelfTech  29 днів тому

      Thanks so much, I really appreciate it!

  • @cashewolddew
    @cashewolddew Місяць тому +4

    Such an exciting project! Well done 🥜

  • @derBartzer
    @derBartzer 3 дні тому

    Nice video which I enjoyed watching!

  • @rafikR85
    @rafikR85 Місяць тому

    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 😊

  • @ChrisBrown-si1vg
    @ChrisBrown-si1vg 25 днів тому

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

  • @HansMilling
    @HansMilling 29 днів тому +2

    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.

  • @platibyte
    @platibyte 22 дні тому +1

    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.

  • @_Draven
    @_Draven 22 дні тому

    Absolutely gorgeous😦

  • @ashishnair97
    @ashishnair97 28 днів тому

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

    • @RachelfTech
      @RachelfTech  27 днів тому

      Awesome to hear, glad it was helpful!

  • @sammysofa1511
    @sammysofa1511 11 днів тому

    woooweeeee very impressive! nice project

  • @SeanStClair-cr9jl
    @SeanStClair-cr9jl 25 днів тому +3

    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

  • @FOM_extras
    @FOM_extras 24 дні тому

    omg this is so cool!!

  • @josh2878
    @josh2878 Місяць тому

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

  • @BoredDeveloper
    @BoredDeveloper 29 днів тому +1

    I love your videos, keep it up!

  • @_mickmccarthy
    @_mickmccarthy Місяць тому

    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  Місяць тому +1

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

  • @sketchonk
    @sketchonk Місяць тому +2

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

  • @redshepard5306
    @redshepard5306 29 днів тому

    your freaking awesome.

  • @tom-sawyer-999
    @tom-sawyer-999 29 днів тому

    Wow, impressive!

  • @Kry0000
    @Kry0000 Місяць тому

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

  • @KasperFrandsen
    @KasperFrandsen 25 днів тому

    This was lovely!

  • @Fighka303
    @Fighka303 9 днів тому

    You make games now! Awesome!

  • @KrytenB
    @KrytenB 25 днів тому

    good job! keep it up!

  • @gametail
    @gametail 28 днів тому +1

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

  • @JoshGVarg
    @JoshGVarg 20 днів тому

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

  • @Mark73
    @Mark73 16 днів тому

    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.

  • @jakebrooks3415
    @jakebrooks3415 28 днів тому

    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

  • @owenlloyd2528
    @owenlloyd2528 27 днів тому

    Respect! 👍

  • @iamsushi1056
    @iamsushi1056 29 днів тому

    Another WFC video, what a good day

  • @merthyr1831
    @merthyr1831 29 днів тому +3

    I WILL LAY DOWN MY LIFE FOR SQUISHY BIRD

  • @lunerjuice1832
    @lunerjuice1832 Місяць тому

    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. :)

  • @janikarkkainen3904
    @janikarkkainen3904 16 днів тому

    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

  • @nicklansbury3166
    @nicklansbury3166 Місяць тому

    Thanks. I really enjoyed watching this video.

  • @BananaftRu
    @BananaftRu 22 дні тому

    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.

  • @softgripper
    @softgripper Місяць тому

    This was a great video :) Thank you.

  • @isaacewing
    @isaacewing 22 дні тому

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

  • @Imevul
    @Imevul 21 день тому

    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.

  • @badsamaritan8223
    @badsamaritan8223 27 днів тому

    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.

  • @Lion_McLionhead
    @Lion_McLionhead 12 днів тому

    Good idea for a beast.

  • @davidmaaschdeyck
    @davidmaaschdeyck 23 дні тому

    these birds look HILARIOUS

  • @theagemaway
    @theagemaway 29 днів тому

    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.

  • @AverageDrafter
    @AverageDrafter 29 днів тому

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

  • @ReginaCæliLætare
    @ReginaCæliLætare 28 днів тому

    Those are some crazy looking castles

  • @neogoo123
    @neogoo123 19 днів тому

    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  19 днів тому

      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.

  • @mattmmilli8287
    @mattmmilli8287 20 днів тому

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

  • @glenneric1
    @glenneric1 5 днів тому

    Nice!

  • @troligtvisme
    @troligtvisme Місяць тому

    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 :))

  • @CharlesVanNoland
    @CharlesVanNoland 24 дні тому

    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 :]

  • @sameeranadgaonkar9756
    @sameeranadgaonkar9756 22 дні тому

    this is interesting!

  • @NexusBaum
    @NexusBaum Місяць тому

    the fractured castle definitely has some appeal to it :)

  • @Kavukamari
    @Kavukamari 22 дні тому

    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"

  • @mtrxishere
    @mtrxishere 28 днів тому

    How are you so talented at everything!??

  • @michelprins
    @michelprins 29 днів тому

    great video thx

  • @ThinkWithGames
    @ThinkWithGames 29 днів тому +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  29 днів тому

      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!

  • @ruthmoreton6975
    @ruthmoreton6975 6 днів тому

    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 22 дні тому

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

  • @fokeyjo
    @fokeyjo 25 днів тому

    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  25 днів тому

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

  • @weaponizedemoticon1131
    @weaponizedemoticon1131 21 день тому

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

  • @NADLABS
    @NADLABS 6 днів тому

    Going down the rabbit hole of bird click = tweet is too relatable

  • @flamingo2946
    @flamingo2946 Місяць тому

    very interesting!

  • @MiragemGames-dev
    @MiragemGames-dev Місяць тому +1

    you're such a talented person! great video.

  • @TheYourdoom
    @TheYourdoom 27 днів тому

    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  27 днів тому

      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!

  • @needlessoptions
    @needlessoptions Місяць тому +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 😆😁

  • @OnyxIdol
    @OnyxIdol Місяць тому

    cool project!

  • @DanielLCarrier
    @DanielLCarrier 26 днів тому

    Add floating islands. Preferably with lakes and waterfalls.

  • @Serhii_Volchetskyi
    @Serhii_Volchetskyi 25 днів тому

    You can try using a SAT solver for wave function collapse. It’s a bit of overkill though.

    • @Serhii_Volchetskyi
      @Serhii_Volchetskyi 25 днів тому

      1) Google already implemented the algorithm in C/C++, BTW.
      2) With the algo, you might implement way more complicated collapsing algorithms like multiple conditionals, physics corrections, etc.

    • @Serhii_Volchetskyi
      @Serhii_Volchetskyi 25 днів тому

      To understand it, see video from AlphaPhoenix about Game of Life.

  • @protobeing3999
    @protobeing3999 24 дні тому

    awesome stuff thank you from a noob coder. those birds though... lol

  • @valeriehammond3664
    @valeriehammond3664 20 днів тому

    Great demo! Does your implementation solve tiles by minimal entropy? If the ground level is seeded with grass (no pun intended), the algorithm should build from the ground up since the adjacent cells will have fewer unsolved neighbors than the cells in the air with no unsolved neighbors. This might explain why your castles are so tall though I like the aesthetic tbh

    • @RachelfTech
      @RachelfTech  20 днів тому

      Thanks! It is indeed using minimal entropy, but because the edges of the map were seeded with empty tiles to prevent cut off castles from forming, this actually resulted in fewer options for tiles at the top of the map (only castle top pieces) compared to the layer above the ground. Definitely could have fixed the towers by enforcing some sort of other way to start from the bottom of the map though, but yeah I'm not upset with the final look!