Coding Challenge 180: Falling Sand

แชร์
ฝัง
  • เผยแพร่เมื่อ 6 มิ.ย. 2024
  • It's Genuary 2024! Watch as I attempt to build a falling sand simulation in p5.js using a grid of pixels and simple rules. Code: thecodingtrain.com/challenges...
    🚀 Watch this video ad-free on Nebula nebula.tv/videos/codingtrain-...
    p5.js Web Editor Sketches:
    🕹️ Falling Sand: editor.p5js.org/codingtrain/s...
    🕹️ Falling Sand with Gravity: editor.p5js.org/codingtrain/s...
    🎥 Previous: • Coding Challenge 179: ...
    🎥 All: • Coding Challenges
    References:
    🔗 Genuary: genuary.art/
    🔗 Sandspiel by Max Bittker: sandspiel.club/
    🔗 Making a falling sand simulator: jason.today/falling-sand
    📕 The Nature of Code by Daniel Shiffman: natureofcode.com/
    Videos:
    🎥 Noita 1.0 Launch Trailer by Nolla Games: • Noita 1.0 Launch Trailer
    🚂 Wolfram CA: • Coding Challenge 179: ...
    🚂 The Game of Life: • Coding Challenge #85: ...
    Related Coding Challenges:
    🚂 179 Wolfram CA: • Coding Challenge 179: ...
    🚂 85 The Game of Life: • Coding Challenge #85: ...
    🚂 107 Sandpiles: • Coding Challenge #107:...
    🚂 132 Fluid Simulation: • Coding Challenge #132:...
    🚂 102 2D Water Ripple: • Coding Challenge 102: ...
    Timestamps:
    0:00 Introduction and references
    2:10 About cellular automata
    2:47 The rules for a sand simulation
    3:36 Code! Creating a grid
    5:04 Animating a falling grain of sand
    7:32 About matrix columns and rows
    8:04 Let's account for the bottom edge
    9:09 Adding mouse interaction
    9:42 More sophisticated sand behavior
    10:43 Oops! Some errors to fix
    11:30 Adding randomness
    12:26 Handling left and right edges
    14:00 Checking if mouse is within the canvas
    14:40 Making it more efficient
    14:56 More space and more sand
    16:55 Adding some color!
    18:54 Challenge complete! Let's do some refactoring
    20:58 How could we add gravity?
    21:57 Wrapping up
    Editing by Mathieu Blanchette
    Animations by Jason Heglund
    Music from Epidemic Sound
    🚂 Website: thecodingtrain.com/
    👾 Share Your Creation! thecodingtrain.com/guides/pas...
    🚩 Suggest Topics: github.com/CodingTrain/Sugges...
    💡 GitHub: github.com/CodingTrain
    💬 Discord: thecodingtrain.com/discord
    💖 Membership: th-cam.com/users/thecodingtrainjoin
    🛒 Store: standard.tv/codingtrain
    🖋️ Twitter: / thecodingtrain
    📸 Instagram: / the.coding.train
    🎥 Coding Challenges: • Coding Challenges
    🎥 Intro to Programming: • Start learning here!
    🔗 p5.js: p5js.org
    🔗 p5.js Web Editor: editor.p5js.org/
    🔗 Processing: processing.org
    📄 Code of Conduct: github.com/CodingTrain/Code-o...
    This description was auto-generated. If you see a problem, please open an issue: github.com/CodingTrain/thecod...
    #pixels #simulation #fallingsand #fluidsimulation #sandpilemodel #generativeart #p5js #javascript

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

  • @MagicalMongoose
    @MagicalMongoose 4 หลายเดือนก่อน +244

    I appreciate you showing your mistakes and your process for fixing errors

  • @YourLocalGrammarPolice
    @YourLocalGrammarPolice 4 หลายเดือนก่อน +472

    If we are now getting weekly/biweekly coding challenges, I will be so happy

    • @TheCodingTrain
      @TheCodingTrain  4 หลายเดือนก่อน +118

      biweekly is my goal!

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

      Same ❤

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

      @@TheCodingTrain2 a week? 👀😉

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

      ​@@garethwilliams2926or 1 in every 2 weeks? 👀

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

      ❤❤❤

  • @Kazner0h
    @Kazner0h 4 หลายเดือนก่อน +269

    I know you mentioned that this was unplanned, but it was super nice to watch you have the same "Wait, why isn't that working???" moments that I do 😂

    • @TheCodingTrain
      @TheCodingTrain  4 หลายเดือนก่อน +31

      I'm so happy to hear this feedback!

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

      i mainly get "wait, it is working??" moments

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

      @@lukeb0030 Ikr! or when you are stuck somewhere and your brain is like what if I do this without knowing the logic behind it.

  • @a1000joys
    @a1000joys 4 หลายเดือนก่อน +14

    Awesome. I'm so happy that Coding Challenge series still continues strong.
    I've been reading about sand simulators for the past few days and I thought this is an old video of yours that TH-cam is suggesting. What a timing!

  • @pie9994
    @pie9994 4 หลายเดือนก่อน +16

    Thanks for bringing back coding challenges. I find all the topics you cover very interesting.

  • @peek2much3
    @peek2much3 4 หลายเดือนก่อน +15

    Literally NONE does it better in YT. The modern iteration of Bob Ross for coding and teaching. Absolutely engaging let alone entertaining.

  • @keppycs
    @keppycs 4 หลายเดือนก่อน +12

    The animations are such a nice touch when trying to comprehend what you're explaining. You and the team are doing such an amazing job!

  • @iogamesplayer
    @iogamesplayer 4 หลายเดือนก่อน +37

    Very cool! I loved those flash games about placing stuff, and setting everything on fire with those "falling pixels".

  • @Muthwill
    @Muthwill 4 หลายเดือนก่อน +5

    I've been programming for quite a few years now but never seemed to be able to have beautiful code. This was really helpful to watch, seeing your entire process of creating, refactoring and cleaning up and finally adding the comments

  • @AustroPower
    @AustroPower 4 หลายเดือนก่อน +13

    Dan all your teaching and tuts are great, one can see you are a very passionate/dedicated man! 🙏👍💯

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

    I love your content, whenever I felt coding as something tiresome and stressful looking at your videos made me fall in love with coding again, thanks!

  • @whirlwind2831
    @whirlwind2831 4 หลายเดือนก่อน +13

    Frequent coding challenges!! Couldn't have had any better start with 2024

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

    I loved this! I tried doing this a few years ago and I just love how you explained it. It's also very cool to add more elements like water and stone

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

    Was trying to find motivation to do my coding homework today and got the TH-cam notification for this video got incredibly excited checked to make sure that this is the same coding language that I’m learning in my class, and I gasped and yelled “Yesssssssssss”, aloud in glee!

  • @mistakd3771
    @mistakd3771 4 หลายเดือนก่อน +11

    my one small contribution:
    to make the sand look more grainy you can add a random number to the hue like this:
    grid[col][row] = hueValue + random(-13, 13);

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

    Great job I think the way you talk through debugging and show the troubleshooting process is incredible and will help lots of people learn!

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

    This was great to follow along - I love how you show your thought process when it comes to debugging!

  • @BotaTamas85
    @BotaTamas85 4 หลายเดือนก่อน +46

    I loved the 'popcorn guy', especially when it dropped you a popcorn. 😂 I like when someone can practise self-criticism in a funny way 😊

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

    Your coding challenges are thoroughly enjoyable! I for one, with a mind that can barely stop working on a problem until it’s solved, watching you go through the process and laughing at yourself along the way is captivating. It’s nice to know this is exactly how I think through my own personal projects, not being anywhere near a professional at all. Starting from absolute scratch, deciding how to approach a problem by breaking it up into parts and then adding little bits at a time until it’s a complete program is satisfying and delightful

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

    I just encountered this series (this is my first episode that I watched) and I am already LOVING IT! I have been wanting to do a "falling sand" kind of project at some point (and give it custom rules!) so that everything would be so much easier! You just earned a subscriber :)

  • @TrosindelPascua-up6tm
    @TrosindelPascua-up6tm 4 หลายเดือนก่อน

    Your the reason i started programming, i like your personality and just listening to you makes me calm down. I hope you have a good life. ❤❤❤

  • @R74n
    @R74n 4 หลายเดือนก่อน +46

    Thank you for bringing more attention to falling-sand games! We're developing a browser-based one focused on chemistry and science education!! 💙

    • @justin.campbell
      @justin.campbell 4 หลายเดือนก่อน

      Hello! I remember visiting your site a couple years ago! Absolutely love it, beautifully simple design. I just checked out "Sandboxels", very fun to mess around with.

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

      I was going to check out your website, but then realized I already had. Sandboxels is really fun!

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

      You were what I thought of when I saw this video!

  • @jorgen7974
    @jorgen7974 4 หลายเดือนก่อน +49

    Bro mentioned everything except the powder toy

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

    This used to be my absolute favorite game...thanks Dan!!!!

  • @The111lord111
    @The111lord111 27 วันที่ผ่านมา

    Okay, okay, okay. This is the first video that I saw of this channel and I simply LOVE IT!
    I'll still watching when I have some time.
    Thanks for the lesson!!!
    Dev from Brazil

  • @vektracaslermd743
    @vektracaslermd743 4 หลายเดือนก่อน +9

    As an aspiring pythonista, I don't know much about JS... but you are still an absolute gem to watch. Absolutely the Bob Ross of coding. Stay awesome!

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

      If you are experienced with Python the only confusing code should be the for loop syntax.

    • @f.a.383
      @f.a.383 4 หลายเดือนก่อน

      "the Bob Ross of coding" couldn't have said it better myself

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

    Just adding the colour made its so beautiful.

  • @shanehebert396
    @shanehebert396 4 หลายเดือนก่อน +9

    Some years ago, I wrote something similar, but more connected with our current time of year (here in the USA) -- a snowfall simulation. Instead of having a single drop point, a (parameter controlled) number of 'snowflakes' were spawned at random points on the topmost line of pixels and then 'drifted' down (didn't go straight down, they had a chance to perturb the path to the left or right each time). Each had a random velocity (also parameterized for max). I also put a parameter for wind so all the snowflakes would tend to drift with the wind. All the parameters were sliders so they could be changed while it was running. Snow would accumulate at the bottom and would fall down to the localize minimum point to the left or right. It was kind of fun to write and watch.

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

      Thats a nice challenge! Ill be building that tomorrow!

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

    Fantastic job Dan!

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

    Amazing video! Seeing you code is really entertaining

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

    you are the very reason javascript code is even slightly legible to my eyes. thank you so much!

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

    Maaaan, this video was greatly inspirational! Your exictement about your coding is heartwarming!
    It really shows you're having fun, and kept me peeled to the reasoning with you.
    Marvelous job! Thanks for bringing us joy!

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

    another great video dan! thanks as always! when you are randomly choosing to move a pixel left or right, you are allowing pixels to merge with each other. if two pixels are next to each other, one has a pixel under it and the other doesn't, both pixels could end up in the same position after the update. this happens not only when the pixels hit the bottom, but also when you are spawning them with the mouse, that's why the spawned pixels are striped. the rules should check if it can fall right or left or one at random, but only if the pixels underneath aren't also falling.

  • @daylen577
    @daylen577 4 หลายเดือนก่อน +76

    You should have started your checking array from the bottom, that would have solved the sand separating like it does and instead just allow everything to drop as one big blob as it does IRL. Would probably not look as satisfying, but it would be a more accurate simulation as a real grain of sand does not wait for an already-falling grain of sand below it to be out of the way, it would instead add its own weight to the weight of the one below.

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

      Checking the array from the bottom would not change anything if the next frame is calculated only looking at the previous state. To solve that, you would have to account for a pile in air so that it all falls simultaneously. The striping is caused by grains in the air moving left and right because they have the cell below that’s occupied but not the cell below right or below left, while in the air that would not happen

    • @TheCodingTrain
      @TheCodingTrain  4 หลายเดือนก่อน +13

      I've been thinking so much about this! I'm hoping to address these kinds of improvements on a future live stream.

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

      @@Astervista thing is.. you don't have to calculate from a previous state. Adjust the bottom in the present state and then there is a gap on the place it previously was so you can put the grain on top of that immediately down too. Then if you calculate an entire row that way, it is way easier to calculate left and right on the next row above it too. That way you only need to have a single row in a previous state (or otherwise the grain of sand will always favour filling up the first new free position where in reality the next grain of sand might just as well go there.

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

      @@KylaraKuhn yes, of course in this simulation it would not have made a difference, because the fall is in one direction. In principle though you could have wind or something else and cannot rely on the fact that modifying the array in place does not introduce weird feedbacks

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

      i think you can fix this while looking only at previous state still - check *all* tiles below and if any are 0, move the sand down.

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

    Love that it wasn’t planned, got to see the actual thought process on how to work things out

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

    haven't watched any of your video in years. i love the new editing style😊

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

    holy shit ive been waiting for this without even knowing it
    pls continue on this project

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

    Thank you for making this video!

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

    Wow, impressive! I remember, when I used to do a random things on thoughts, but I don't do It now. Your video inspires me to back to these great days and make beautiful things on canvas

  • @kieran.stafford
    @kieran.stafford 4 หลายเดือนก่อน +1

    Dan, it's always a treat to see a new video from the Shiffmeister and Mrs Pickle. Loving the new production values although I'm glad you keep the screw ups and comedy. Makes it so entertaining and human in a domain that can be very ego driven. Just occurred to me - a great name for a cop show on TV that - The Shiffmeister and Mrs Pickle :)

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

    You make programming fun again with every coding challenge!

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

    Never stop these coding challenges

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

    Adding hue and seeing those rainbow layers was so much fun, I gonna make a version of mine taking inspiration from you. Thank you

  • @alexsandergutierrezgoncalves
    @alexsandergutierrezgoncalves 4 หลายเดือนก่อน +7

    very cool, p5 js many possibilities, one thing I always do when I draw the value of a 1D matrix on the canvas that is 2D is to convert the 1D index of the matrix to 2D coordinates like this:
    let x = i % cols;
    let y = floor(i / cols) % rows;
    so I can use a 1D array and just a single for loop.

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

    Loved the video! I've mostly done business programming, so I've never had to do anything like this. I'm definitely more interested in writing simulations in code. Comments in the code definitely made me wince.

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

    Yay, been waiting for this

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

    It's actually great that this video was unplanned, It is better to watch you go throught the proccesing of fixing the errors. thank you! do more of there :)

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

    Awesome as always. Thanks

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

    Love this Video and the animations.So good!

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

    thanks for u piece of code that has given me an idea of writing up the gravity implementation in ur code

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

    One smal timesaver - instead of a loop to fill the array with zeros, you can set it when you create it - arr[i] = new Array(rows).fill(0). The fill(0) will put a zero in every element. Great videos!!

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

    Wow this one is very pretty,... fun relaxing and easy going on this one. Really like the colors and artwork in this one. nice seeing new stuff

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

    You present coding in a very friendly way, thank you

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

    Thank you so much for this coding challenge. I decided to implement it with flutter, taught me quite a lot as regards drawing pixels on the screen

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

      Feel free to share in the passenger showcase! thecodingtrain.com/showcase

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

    This guy is a great teacher. I got my current programming mindset from watching these videos and that has landed me working on my largest project so far, Open world Minesweeper in Minecraft. I might even try my hand at making a video on it, which is unfortunately late in because I already have a basis on it and am adding more feature to flesh it out some.
    Quick tip for those curious about Processing. It is a library and compiler that allows you to learn programming without major setup. I never touched the JavaScript, but the Java side is just as brilliant. What does this have to do with Minecraft? Both use Java as a base. I might explain more sometime, but you might as well try processing since it is free.

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

    Nice video, and nice editing! Thanks for sharing!

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

    amazing content! keep it up bud!

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

    Great video! Loved it

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

    Congratulacion for the google video, i was so happy and surprise to see you

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

    Man I wish youtube was a thing when I was a kid. Channels like this would have made self learning a lot easier than it was.

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

    These make me so incredibly happy I don't know why

  • @NoVIcE_Source
    @NoVIcE_Source 4 หลายเดือนก่อน +24

    the powder toy!

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

      YES!!! this is exactly what i thought of! its something I STILL go back to. amazing lil game

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

      I LOVE the toy!

  • @acez28
    @acez28 24 วันที่ผ่านมา

    Great video man

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

    the Bob Ross of coding, thank you!

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

    Great work, thanks! Noticed that the amount of falling sand is greater than the amount of sand on the ground. This is due to the fact that there may be two granules in one place. It worth to add analysis of the grains on the left and right on same level, so that a grain of sand that has a void underneath will fall first compared to a grain of sand that should hit the same pixel on the left or right.

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

    Great editing!

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

    You are a god.
    Thank you for what you are.

  • @Mali.97
    @Mali.97 3 หลายเดือนก่อน

    Just found your channel i normally dont comment but you are an absolute hero

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

    I doubt I will ever code but your video inspired me and I subbed. Thank you!

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

    damn I remember watching coing train videos as a 15yo kid and thinking that was so cool. Time passes and now I'm 22, have a master in cs and am working fulltime in this field. Time really flies. Never thought looking a these random videos so many years ago would lead to this one way or the other. Great to see Daniel is as great as ever!

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

    To eliminate the striping you could loop from the bottom up, you need the lowest piece of sand to move out of the way so that sand above it can fall in the same update call.

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

      Yes! And this would also eliminate the need for a next frame grid as the blocks would always be visited only once even if they fall.

  • @user-ep2kz2jj4i
    @user-ep2kz2jj4i 4 หลายเดือนก่อน

    Your mood makes me happy

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

    Excellent!

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

    Amazing work with programming !

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

    Yes omg this is exactly what I wanted

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

    You also left another exercise for the viewers: Remove the stripey pattern. It's easy to realize that it happens because the sand grains are processed one after the other, and if one grain has another grain under it, it won't be moved this pass, even though the grain under it should itself me moved and leave room for the one above it. It is also easy to come up with the idea that maybe if you process the grid from the bottom and up, then you could maybe "fix" that issue. However, that solution is not very satisfying, because it depends on the knowledge that sand always falls down. What if you had a mix of particles with different properties, like sand and hot "air" that rises?

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

    Very cool! Thanks 🙏

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

    What a fun little challenge will give it go as well.

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

    FYI, the line pattern appears because the grid is checked columnwise from top to bottom.
    Changing it to row-wise bottom-to-top makes them disappear.
    You also get a fun delayed sand shape effect due the left-right randomness.
    Nice video!

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

    Love those coding challenges...thank you Dan!!!

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

    The universe spoke lol. I've been looking for a good video on coding a falling sand sim!

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

    Man this is dope asf~

  • @Isaac-mt9hx
    @Isaac-mt9hx 4 หลายเดือนก่อน

    That turned out so cool! I don't really code in JS but will sure give it a try in Python.

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

    great video thank you

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

    The most mindblowing demo I have ever seen was written in Euphoria, from 1993. Was an .exe someone
    contributed, and showed an eternal trip floating forwards way up in the clouds. It was simple, but very complicated and
    I cannot forget it.

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

    I love these vids

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

    that's cool simulation

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

    nice sand i should try that

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

    I fucking love your channel, you basically got me back into coding back in 2020 and now I'm going to college for computer science

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

      great for you! i had decided to major in comp sci before i started watching Coding Train, but these videos do open up my eyes to some of the fun problem solving bits I hadn't thought about for some scenarios. very fun!

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

    I just watched a video the other day about Falling Sand via Cellular Automata.. What a coincidence. It was by a TH-camr named MARF.
    Glad to see the Coding Challenges make a return!

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

    As a newbie when it comes to coding and having no idea how I would even attenpt this,I enjoyed wayching it.

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

    I’m glad that Noita was mentioned here! My favourite game, it’s just incredible.

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

    Once friends of mine wrote a small virus in assembler for dos. It spread itself, wroting itself in every exe file possible, checked for floppy disk and did same there. It did not really corrupt anything, except.... if one did not tip anything for several seconds all letters on a screen started to drop. Was quite a fun time :)

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

    Awesome

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

    No way! I've had the nature of code book for years and I didn't know it was written by you. I just got it because I saw it and it looked interesting (loved it btw)

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

      WOW!

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

    Damn.. I just spend 4 hours doing this in c++... :D About half of the time was just stupid testing of colors and making sure it runs at a constant speed on every pc... and then went back to actually watch the video. Thanks for the inspiration!

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

    This video made me feel so much better about my slapdash approach to coding

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

    You are amazing

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

    Awesome vid! Don't forget about the greatest falling pixel game: The Powder Toy

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

    re: Sandspiel (german for sand game)
    just fyi - Sand rhymes with hunt
    but props for getting the "spiel" part correct
    greetings from 🇩🇪

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

      This comment made my day!