Do Video Games Fake Buoyancy?

Поделиться
HTML-код
  • Опубликовано: 26 сен 2024
  • Get a free 30 day trial and 20% off an annual plan at
    brilliant.org/... ! #ad
    Buoyancy seems easy to fake, but do games actually fake it? Who knows!
    Support me on Patreon!
    / acerola_t
    Socials:
    Twitter: / acerola_t
    Twitch: / acerola_t
    Discord: / discord
    Github: github.com/Gar...
    Code: github.com/Gar...
    References:
    gpuopen.com/gd...
    blog.maximehec...
    Music:
    Afternoon Break - Persona 3 OST
    Joy - Persona 3 OST
    This Mysterious Feeling - Persona 3 OST
    Junes Theme - Persona 4 OST
    In A Moment's Time - Skullgirls OST
    Fearful Experience - Persona 3 OST
    New Game - WORLD OF HORROR OST
    Underground Club - VA-11 Hall-A OST
    Police Station - Persona 1 OST
    During The Test - Persona 3 OST
    Every Day Is Night - VA-11 Hall-A OST
    Your Love Is A Drug - VA-11 Hall-A OST
    Those Who Dwell In The Shadows - VA-11 Hall-A OST
    Climactic Reasoning - Danganronpa 2 OST
    Thanks for watching!
    This video is dedicated to my friend, Alotryx.
    #acerola #graphics #gamedev #unity3d #graphics #shaders

Комментарии • 595

  • @Acerola_t
    @Acerola_t  9 месяцев назад +83

    Get a free 30 day trial and 20% off an annual plan at brilliant.org/acerola ! #ad
    Simple topic today thanks friends happy new year

    • @Levi1440p
      @Levi1440p 9 месяцев назад +6

      happy new year, Acerola

    • @llMarvelous
      @llMarvelous 9 месяцев назад +2

      I have only one question - is there any correlation between buoyancy of the objects and successfulness of their distant relationships?
      Having trouble with my drowning simulation

    • @YHK_YT
      @YHK_YT 8 месяцев назад +2

      You literally put cat videos beside the ad to keep people from not skipping?

    • @Acerola_t
      @Acerola_t  8 месяцев назад +8

      and i'll do it again@@YHK_YT

    • @YHK_YT
      @YHK_YT 7 месяцев назад

      @@Acerola_t I was so confused and shocked, does it work? Does it keep retention high?

  • @dotdotmod
    @dotdotmod 9 месяцев назад +1584

    I'm actually really glad the cat gag hasn't been removed because I find it genuinely fun to watch your cat

    • @Acerola_t
      @Acerola_t  9 месяцев назад +584

      it unironically works to keep people watching the ads lol

    • @teu009
      @teu009 9 месяцев назад +2

      ​@@Acerola_t lmao it works for me

    • @flameofphoenix5998
      @flameofphoenix5998 9 месяцев назад +128

      ​@@Acerola_ti absolutely watch the ads for the cat
      dont get me wrong i want to support the channel but the cat makes a billion timee better

    • @WannaComment2
      @WannaComment2 9 месяцев назад +49

      No shit, this was probably the first time in month I've not skipped an ad read and I didn't even realize until I read these comments.

    • @El_Poro
      @El_Poro 9 месяцев назад +39

      @@Acerola_t Whenever I'm about to skip the ad my brain goes "Just one more second of the cute cat plz" and suddenly the ad has ended

  • @ValeBridges
    @ValeBridges 9 месяцев назад +442

    "Did Archimedes ever take another bath?" Actually yes, IIRC there were historical records uncovered in 2011 stating that he once bathed in blood inside Heavy's ventral cavity

    • @makeandbreakgames1791
      @makeandbreakgames1791 9 месяцев назад +28

      TF2 reference = like

    • @holl7w
      @holl7w 9 месяцев назад +19

      Archimedes no!!

    • @heliusuniverse7460
      @heliusuniverse7460 8 месяцев назад +8

      eh, birds

    • @holl7w
      @holl7w 8 месяцев назад +15

      Now, most hearts couldn't withstand this voltage... but I'm fairly certain your heart-

    • @TheTicassShow
      @TheTicassShow 8 месяцев назад +1

      ​@@makeandbreakgames1791tf2 = cringelord

  • @Starling8563
    @Starling8563 9 месяцев назад +268

    The funny PNG computing man is back! My day has improved drastically

    • @TheSourovAqib
      @TheSourovAqib 9 месяцев назад +3

      Indeed

    • @locinolacolino1302
      @locinolacolino1302 8 месяцев назад +4

      Oh I didn't realise he was that sophisticated, I assumed they were Jpegs

    • @myrealusername2193
      @myrealusername2193 8 месяцев назад +3

      @@locinolacolino1302jpeg doesn’t have transparency so he couldn’t have done the green screen

  • @NateVolker
    @NateVolker 9 месяцев назад +220

    NO BATHS, NO MATHS

    • @aze4308
      @aze4308 9 месяцев назад +6

      NO BATHS, NO MATHS

    • @Datscrazi231
      @Datscrazi231 9 месяцев назад +7

      NO BALLS, NO MALLS.

    • @silverXnoise
      @silverXnoise 9 месяцев назад +5

      NO CATHS, NO SYLVIA PLATHS

  • @elizabethagudelo7179
    @elizabethagudelo7179 9 месяцев назад +564

    My favorite fake bouyancy is in the original half life.
    All they did was put a trigger plane slightly under the surface of the water, every time an object touches the plane it just kinda punches the object up a little bit
    And that's all it does

    • @spell105
      @spell105 8 месяцев назад +94

      Sometimes simple just works best. I think Acerola kinda touched on it here: at some point, the ocean becomes noise. The fact is that no one is really gonna notice if the object is tilting the correct way because the waves are such chaotic movement in the first place. You can really just fake things at this point.

    • @satibel
      @satibel 8 месяцев назад +50

      ​​@@spell105this is how they did it in half life alix for the bottle shader "it's gonna look chaotic anyway, so the bad approximation is good enough"

  • @llMarvelous
    @llMarvelous 9 месяцев назад +433

    I have one question - is there any correlation between buoyancy of the objects and successfulness of their distant relationships?
    Having trouble with my drowning simulation

  • @AutisticYui
    @AutisticYui 9 месяцев назад +90

    Great video! I had to create a relatively convincing buoyancy sim at work for VR interactable objects. You did a fantastic job with this break down! The difficulty I found, most of all, was creating an interface for designers to end up implementing the parameters, per object, to determine physical values. Lots of fun! Designers have such high standards but then want simple controls!

    • @eightstunningangles
      @eightstunningangles 9 месяцев назад +9

      Funny seeing you here, I used to watch your 1 2 Oatmeal remixes back in 2017

    • @AutisticYui
      @AutisticYui 9 месяцев назад +9

      @@eightstunningangles Of course! Love Prof. Rola's videos lmao. Thanks for watching mine, eons ago!

    • @baseddepartment9656
      @baseddepartment9656 8 месяцев назад +3

      Both are vital to being able to craft a good experience. They need to be able to author and tweak huge amounts of content and slowing that process tangibly impacts their output and the quality of the final product.

  • @soliform3485
    @soliform3485 9 месяцев назад +57

    Working on a buoyancy sim for my own ocean.. watching you go through the same thought processes as me was funny. To address the issues with the voxel approach (no control/ bad performance) i did a couple things instead of a plane fitting algorithm
    - Based the rotation of the object, if it aligned orthogonally with the oceans suface such that the cubes could same from ones "below" them, i could drastically cut down on the # of samples especially for ships which almost always maintain a similar equilibrium
    -To address control, i worked the buoyancy equation backwards to calculate the water density based on a desired height for the object to be at equilibrium for. This meant that for ships, all I had to do was set a specific y value to be the waterline and the program made it float there no matter what. It also meant the water density was different for each object, but that didn't have any effect so long as there weren't things that were Massively overweight and floating
    I have some questions about the gpu read back:
    What if you calculated, on the gpu, the lower frequency waves slightly ahead in the future such that when the packets arrived, they would be right on time instead of lagging behind (this would also help with noise). I'm not sure if its practical but I just thought of it now

    • @Acerola_t
      @Acerola_t  9 месяцев назад +30

      the latency is anywhere between 2-5 frames so calculating ahead of time, while it sounds cool, would probably have the same results visually lol

    • @soliform3485
      @soliform3485 9 месяцев назад +5

      @@Acerola_t Ah, so I guess the stutter is more from the low density of updates from the gpu rather than a delay. Thanks for responding!

    • @fimbulvntr
      @fimbulvntr 9 месяцев назад +6

      ​@@Acerola_tIt's not GPU-expensive to do so and you're not bandwidth-starved, are you?
      Couldn't you just pass 2-5 (or however much it is) worth of forward frame calculations to the CPU?
      Can you tell, after receiving a "GPU Packet", how long it took to deliver, and then pick the correct data point?
      For that matter, can't you just keep a "future stream" of data going?
      Also since the GPU is going to need to calculate the future anyways, can't you just store the future results instead of calculating them again? In effect you're just delaying the simulation.
      I guess it would have an effect if objects could affect the water simulation, but they can't in your example, so it doesn't matter, right?

    • @donovan6320
      @donovan6320 8 месяцев назад

      The problem is calculating. This data isn't reliable. It might give you the results for the current frame on that frame or it might give you the results for this frame in five frames. ​ You're essentially just dealing with a race condition. @@fimbulvntr

  • @iffn
    @iffn 9 месяцев назад +30

    Uh, thinking about the pressure on the surface of the object is actually way more applicable to how 3D objects in game engines are usually implemented.
    This can be done by using a displacement mesh, cutting it at the water surface and then calculating the pressure and area for each triangle to get the forces. Implementing things like slamming forces and surface friction also becomes possible.
    There is a great article by Jacques Kerner about the Just Cause 3 boat physics on the gamedeveloper website and a person called Habrador also has a Unity implementation with sample code based on it.

    • @Bruno-cb5gk
      @Bruno-cb5gk 9 месяцев назад +2

      Yeah, would be interested to see how a pressure approach compares.

  • @adrien5568
    @adrien5568 9 месяцев назад +12

    My first idea would be to sample the 4 corners, use a plane approximation, and filter that using a moving average window.

    • @Acerola_t
      @Acerola_t  9 месяцев назад +6

      that's an interesting idea i wish i thought of that

    • @znorfis
      @znorfis 9 месяцев назад +5

      I made the water physics for Aqua Moto Racing Utopia. I used something similar to get a plain around the floating objects. If the object was deeper then a hardcoded value, I added a force in the water normal direction. If the object normal was not in the same direction as the water normal, I added a torque to push the object towards the water normal. A lot of movement friction removes jerkiness.

  • @juxtopposed
    @juxtopposed 9 месяцев назад +70

    Amazing video. Love your content.

    • @Furetto126
      @Furetto126 9 месяцев назад +4

      yooooo

    • @KuroNK
      @KuroNK 9 месяцев назад +3

      love your's too

  • @EuphoricPentagram
    @EuphoricPentagram 9 месяцев назад +19

    One thing that could also work is having the gpu return a grid of water normals around the origin of the buoy to the cpu where you calculate the difference in normals over time and apply that to the buoy. That way the cpu is interpolating the data in order to calculate while waiting on the gpu, so the buoys are always animating.

    • @Acerola_t
      @Acerola_t  9 месяцев назад +10

      that's an interesting idea, it requires even more data to be read back though which sucks. i wonder if maybe you could estimate the normals from the read back height data and get a similar result

  • @ChrisFloofyKitsune
    @ChrisFloofyKitsune 9 месяцев назад +17

    I kept thinking, wouldn't it be better to ask for the data in bulk?
    The time to make lots of little requests scales way faster than making few big requests. This is due to the individual overhead attached to each request. (Now imagine instead of talking to the GPU, you're sending data over the internet. Had to tackle that in my job.)
    Probably just shoving the heightmap into a render texture and reading that.

    • @Acerola_t
      @Acerola_t  9 месяцев назад +11

      yes you could do that, as I said, there are many ways to do the exact same thing

  • @boggybolt6782
    @boggybolt6782 9 месяцев назад +6

    One thing I think could quite improve the simulation is drag. Objects in water experience significant drag which slows them down (tried running through a pool? Impossible). Moving objects, like ships, rely on there being far more drag sideways than forward/back in order to be able to turn properly.
    I made a game in 3rd year in high school where I implemented water simulation. The boats I used would sink noticably when jumping into the water, and would slide across when turned. Adding drag (high drag sideways, very high vertically) mostly fixed the issue.
    I don't remember much from his previous water sim video, but if the simulation isn't incredibly compute heavy, you can in fact just simulate it on the CPU for every point you need. I sampled 7 points on a boat's hull in order to determine the buoyancy.

    • @PTS1337
      @PTS1337 2 месяца назад +2

      It is rather heavy, but since each vertex is (IIRC) displaced in isolation, I'm thinking your idea of recalculating just the points we need for the interacting bodies will have basically negligible cost. Additionally, you probably don't need all of the sine waves to get it to look convincing, just the lower frequency ones, and if it's a big vessel, you can get away with sampling just the largest waves, because the small splashing will not have noticeable effect.

  • @SillyOrb
    @SillyOrb 9 месяцев назад +20

    Great video. Presenting vastly different solutions is very important, if you need to decide which solution fits your project the best with a limited time budget. Thank you for providing this to everybody, Acerola.
    The voxel solution looked very promissing here. It could be something that might become feasible in future games.
    Almost then years ago I worked on a game with a large body of water and wrote a full height field sim on the GPU and a per-sample sim on the CPU. They were deterministic and ran synchronised and used artist-controlled wave patterns to improve control over visuals and gameplay. It was similar to sum of sinuses, it makes several things simpler, but less realistic, as was pointed out in this and an earlier video. You could perform multiple thousands of CPU side "samples" (they were pattern samples and computations instead of actual samples of a map, the height field did not exist as such on the CPU side) within a reasonable budget (a single / few ms out of 33 / 16 ms per frame) on then-current consoles (with very weak tablet-level CPUs), of which we only used a small fraction in the final game (probably low hundreds, it never came up in the profiler, so I don't know). To reduce the CPU side overhead, you could bundle multiple samples that were then computed in one go. That yielded some meaningful savings for scenarios like the one in the video. The approach in that game was otherwise quite similar to the last solution. I was a little worried for a while, that I had missed an obvious better solution. 😅 Seriously, there is always something new to learn in these videos, even if you've already got some experience in the topic.
    PS: This is one of a few select channels where I don't mind the in-video ads. I usually don't skip them anyway, but with these channels, I genuinely enjoy the presentation, as weird as that might be.

    • @excrubulent
      @excrubulent 8 месяцев назад +2

      Yeah, I was thinking that since you can sample a single point out of the field, taking a handful of points on the CPU should work just fine.

  • @AlexTuduran
    @AlexTuduran 8 месяцев назад +4

    Since you mentioned the signal domain, the "noise" can be filtered with a simple damping filter (also known as Exponential Moving Average Infinite Impulse Response filter): o = lerp(i, o, t). This effectively removes high frequencies from your signal, simulating inertia and mass. Of course, you don't have to stop to just one filter (1st order), you can have up to 3 filters chained one after another for an even smoother frequency cutoff.

  • @itachi2011100
    @itachi2011100 9 месяцев назад +2

    a monogatari and persona 3 ref in first few seconds, you have my sub

  • @MattHassing
    @MattHassing 9 месяцев назад +6

    i remember doing this myself and following a bunch of tutorials and what we ended up doing is getting the bounding box and then at the 4 corners of the intersecting plane with the water use spring physics to pull the current “plane” into alignment. i by no means came up with his myself but it’s a neat solution that gave really nice results, especially since we had a full copy of the water shader living on the cpu and could then use this copy to interact with the rest of the cpu things

  • @qlwdy
    @qlwdy 9 месяцев назад +14

    Yo Ace I’m loving binging your whole channel as I learn blender

  • @lordquintus1419
    @lordquintus1419 8 месяцев назад +1

    At 16:00 I would recommend a dashpot/damper rather than a spring, I don't wanna overexplain if you know what it is, but basically instead of resisting based off distance like a spring, it resist motion from its current point, this prevents it from being pulled to the normal and instead allows it to drift around without being erratic

  • @qubit1788
    @qubit1788 9 месяцев назад +15

    I think you might be able to optimize considerably the voxel technique by using different shapes. With that buoy example, 4 or 5 well positioned voxels might be sufficient to do both the height and the tilt, with one in the center and the rest in corners...

  • @Relics_tv
    @Relics_tv 9 месяцев назад +9

    Fantastic video as always! We need more of what you have to offer! Your work researching, explaining, and covering topics without just talking about what your code does and showing code allows us to learn to code it on our own in our own ways. Keep this up! I'll for sure be subscribing to your Patreon!

    • @Bit_Crust
      @Bit_Crust 8 месяцев назад

      I hadn't noticed this. These videos have even better presentation than I thought.

  • @Xaymar
    @Xaymar 9 месяцев назад +94

    Isn't it possible to just stream a downscaled height texture of the water back to the CPU? That should be much faster than individual reads for each object.
    Also you can set a spring constraint in many physics engines, even the one unity uses. If you add an X/Z (or X/Y) lock to the body, you end up with a buoy that doesn't move and doesn't topple over (artist control) while still being physics based.

    • @Acerola_t
      @Acerola_t  9 месяцев назад +61

      yeah that's one option, like I said there are many ways to go about it lol either way it's taking awhile

    • @SillyOrb
      @SillyOrb 9 месяцев назад +29

      @@Acerola_t That's no joke. I find it genuinely impressive how fast you manage to make these videos at the high quality and the topic's depth, given that in production (albeit possibly with broader scope, more restrictions, artist requests and systems interacting etc.) these things can easily take up person months or years and then there's still a video that you need to writte and produced at the end.

    • @4crafters597
      @4crafters597 9 месяцев назад

      @@Acerola_t what is a while in this context? With 60fps frametime is around 20 msecs and gpu and cpu frequencies are much faster than that? Where is the bottleneck?

    • @Acerola_t
      @Acerola_t  9 месяцев назад +28

      no matter what there's going to be latency, I would consider anything >1 frame of latency to be 'awhile' because it's visible at that point already@@4crafters597

    • @monad_tcp
      @monad_tcp 9 месяцев назад +2

      @@Acerola_t I wish PCs eventually got an unified memory bus, but its not happening. So the best possible case scenario is at least 1 frame of latency.

  • @crestofhonor2349
    @crestofhonor2349 9 месяцев назад +5

    I'd love to see you take on some rudimentary water interaction physics pretty similar to how RDR2 detailed theirs in the GDC paper. I think that would be an extremely interesting thing to add to your ocean simulation. Plus it'll help as you add more objects to the world

  • @notablink2560
    @notablink2560 8 месяцев назад +2

    I like the part in the intro where it's just a color background with texts, reminds me of monogatari series, so nostalgic ahhh😊

  • @ronylouis0
    @ronylouis0 8 месяцев назад +1

    A physics video starting with a monogatari reference? What kind of dreamscape did i just stumble upon

  • @RandomProduct
    @RandomProduct 9 месяцев назад +21

    Love that you named your cat Brilliant, and that they sponsored this video 💕

  • @torstonvodesil6709
    @torstonvodesil6709 8 месяцев назад +1

    I don’t know what it is about the way you make videos but don’t stop, your videos feel so casual while still being informative and it’s great.

  • @themumfortofflying6415
    @themumfortofflying6415 9 месяцев назад +1

    I think adding a little blip noise when notes/corrections are put on screen would be helpful because I'm a listener not a watcher and wouldn't know what I heard was incorrect unless I saw the screen.

  • @a52productions
    @a52productions 9 месяцев назад +1

    15:40 If you measure and plot the normal vector angle fluctuations, and then tune the spring and damping constant so that the angular spring has a similar resonant frequency, the motion won't be quite as smoothed out.
    Alternatively, if you all you want is to keep the buoy upright, you could apply a similar angular spring to the physics-based system. That way you could keep the nice angular displacements, while having a tunable parameter that keeps it mostly upright.

    • @tequt
      @tequt 9 месяцев назад

      I was just thinking multiplying the non-"up" coordinates and then smoothing out that data to exaggerate the buoyancy and then make it look smooth.

  • @oliverx65
    @oliverx65 9 месяцев назад +2

    an acerola video a month keeps one feeling comf

  • @kinghotcoc0
    @kinghotcoc0 8 месяцев назад +1

    An interesting idea is to just combine them both!
    Have the cheaper method applied on buoys far away, where accuracy is not the greatest concern, and then when the buoys enter a close range of the player, switch it to physics mode.

    • @shinobuoshino5066
      @shinobuoshino5066 8 месяцев назад

      Buoys are irrelevant background objects for the purpose of a game and literally noone cares if they're realistic or not except people who don't play games to actually have fun but to instead whine about things that don't matter.
      If I wanted to look at buoys floating I'd rent out a boat and go check them out.

  • @monhi64
    @monhi64 8 месяцев назад +3

    I love this video because the topic is one of the most obvious things that regular game players haven’t ever thought about. How I went my entire life without questioning how they make things float in games is wild

  • @SadeN_0
    @SadeN_0 9 месяцев назад +3

    My immediate thought in regards to the lag is that since it, gameplay-wise, doesn't matter what time the ocean simulation is at, if you could hold back the clock for the rendering time, you could have the wave visual sync up with the values you got from the gpu->cpu reads.
    I'm too lazy to go back to the previous vid to chek how the sim was stored, but given it's not just a simple function of time like a sum of sines would be, I suppose this might require a circular history buffer of wave maps or something

  • @JanbluTheDerg
    @JanbluTheDerg 9 месяцев назад +3

    Me, small brain: *Lerp it for smoothness*

  • @hohohaha5297
    @hohohaha5297 8 месяцев назад +1

    But Acerola?? How do you make these informative and entertaining videos about an obscure topic that is very hard hard to learn??
    On a serious note your channel just became my favorite, thanks for all the hard work!

  • @ihonestlydontcare5894
    @ihonestlydontcare5894 9 месяцев назад +4

    Why did acerola have to go so far with the longterm situationship? Definitely hit a bit too close to home for me😂

  • @rmt3589
    @rmt3589 8 месяцев назад +2

    You say bad game design, but I think it's perfect. I want large waters to be anti-player boarders in my dream game. Having rough seas that actively move the player is perfect! I want a 99% game over, but with a real possibility of survival. Like an irl rip tide. They don't automatically kill you, miracles can happen, but you're probably dead.

  • @entangledatoms7153
    @entangledatoms7153 9 месяцев назад +4

    It’s a bad game if the developers don’t take into consideration Quantum Entanglement.

  • @morgan0
    @morgan0 9 месяцев назад +1

    16:00 so my suggestion is to use a first order lowpass filter here (there's some similarity between ideal springs and lowpass filters), each frame setting the value to partway between the last value and the updated value. any changes too far above the filter's cutoff will be reduced and that smooths it out. it can completely remove changes if they happen too fast, so sometimes it requires scaling up the input or output to compensate, but a higher order filter could more easily allow changes you want while still smoothing it out. a higher order filter could have a higher Q and rock back and forth faster when the frequency is just right, as often happens. there's possibly some overlap between this and what you were doing but hopefully it gives you some ideas to explore.

  • @casperes0912
    @casperes0912 9 месяцев назад +7

    Acerola must’ve tried a long distance relationship that went bad. Cause that was very accurate

  • @QberryShortcake
    @QberryShortcake Месяц назад

    If you want to level up your ocean simulation even further, you can add in ripples and boat wakes with Cem Yuksel's Wave Particles whitepaper. This has nothing to do with particle systems, but instead is about creating a displacement map that looks pretty darn convincing. Cem Yuksel also has a really good paper on caustics for underwater light simulaiton.

  • @alexyz9430
    @alexyz9430 9 месяцев назад +1

    9:06 Tony the Tiger... ❤️

  • @aqueleindie
    @aqueleindie 9 месяцев назад +1

    there was no need for the long distance relationship gag because that literally happened to me and now I'm crying
    great video tho

  • @chronickat5453
    @chronickat5453 8 месяцев назад

    3:50 was not expecting that to hit way that close to home for me. reopened some wounds there

  • @MythicalCS
    @MythicalCS 8 месяцев назад

    0:47 why does this remind me of “speedy thing goes in speedy thing goes out” 💀

  • @glowpon3
    @glowpon3 8 месяцев назад

    The final problem just looks like a PID tuning situation.

  • @ArenSpace
    @ArenSpace 9 месяцев назад +1

    cant wait to see you fully simulate the wind forces and buoyancy of a pirate ship having the sails and rudder actually work

  • @KoshakiDev
    @KoshakiDev 9 месяцев назад +1

    I learned something new, the video is enjoyable, and there is variety of options presented!
    🎉 10/10 video

  • @txikitofandango
    @txikitofandango 8 месяцев назад

    Watching your videos with the sound off is like solving a rebus puzzle

  • @rogerrandom3840
    @rogerrandom3840 2 месяца назад

    6:50 godot does in fact now have async read backs. man i love being one of the maybe 4 people using godot for this sort of task.

  • @beamshooter
    @beamshooter 8 месяцев назад

    Dude your videos are so good. Your timing between images is impeccable

  • @EdgyPuer
    @EdgyPuer 2 месяца назад

    Love the non-transparent transparent red arrow

  • @bluesoman
    @bluesoman 9 месяцев назад +1

    You need to set your center of mass on the buoy to be lower to automatically correctly avoid the stuck on its side problem and apply the force at the voxel position not at center of mass. It will then naturally want to tip to an upright position.

    • @Acerola_t
      @Acerola_t  9 месяцев назад +4

      stuck on its side wasnt a problem i was just using the same model to demo how it would look if it did topple over

  • @maglev_
    @maglev_ 8 месяцев назад +1

    the monogatari editing is so peak

  • @onieyoh9478
    @onieyoh9478 8 месяцев назад +1

    "Fake it till you make it."
    -Video Games

  • @jeffffff
    @jeffffff 8 месяцев назад

    "why youtubers hold microphones now" is in my sidebar while watching this lol

  • @Katharoni
    @Katharoni 8 месяцев назад

    I feel like a better version of the amazon package analogy is having a frozen dinner already ready, sticking it in the microwave, and not being able to do anything but wait for the food to be done because tbh you have nothing else to do and you're hungry and maybe it'll cook faster if you stare at it (it wont)

  • @julianlanty2066
    @julianlanty2066 9 месяцев назад

    what a nice way to end the year with another acerola graphics adventures

  • @jessehunter362
    @jessehunter362 3 месяца назад

    yo i actually predicted where a video was going to go for once!!! i thought you were going to start off with the plane fitting algorithm thing and then was very disappointed but you CAME BACK TO IT

  • @JosephCatrambone
    @JosephCatrambone 8 месяцев назад

    My solution to all denoising for movement is recency-weighted exponential falloff. position and orientation = (alpha * previous) + ((1.0 - alpha) * newest values). When alpha is 0 you get the jittery one. When alpha is low you get slow movement. Tune it low for turbulent waves and heavy objects. High for light weight plastics and flags.

  • @Trigger0x10c
    @Trigger0x10c 9 месяцев назад

    Happy new year Acerola! Great vid as always)

  • @DamianReloaded
    @DamianReloaded 9 месяцев назад +1

    Very nice. I imagine that if the object wasn't interactive you could simulate it all in a shader.

  • @sleepyyui
    @sleepyyui 8 месяцев назад +1

    3:34 Jesus Christ that is accurate

  • @RayznGames
    @RayznGames 8 месяцев назад

    Beautifull! I loved the plot twist with reading data back from the GPU!, and seeing you go through a similar thinking process for bouyancy,, even though, i never went with the voxel approach for performance concerns, i did, stategically placed a number of "buoyant detectors" arround what i decided would be the bouyancy line of a given boat model,, theese detectoirs simply read a few data points for our ocean, and apply the bouyant force at a rigidbody at each detector location., if they are below the ocean water., they push up, and if not they fall, by gravity, wich ensures that the rotation of the bouyant object will match the waves outline arrount it, although that push up or down is running in cpu, is constantly in motion riding them with no lag. I love to see you took the simulation approach! Amazing!!

  • @Roxor128
    @Roxor128 8 месяцев назад

    One possible way to handle the lag might be to run the water simulation ahead of what's needed for rendering by an amount sufficient to cover the lag. If you've got five frames of lag, have the part of the simulation currently being run on the GPU being for frame N+5, with frames N though N+4 buffered in VRAM ready to be used in rendering when needed. When N+5 finishes simulating, send the bits needed for the physics to the CPU, then draw frame N. By the time the CPU gets what was just sent, it'll be up to frame N+5 in its physics work and frame N+5 will have moved down the GPU's queue to become the frame to render, while the GPU simulation is now being done for frame N+10.
    Downside, of course, is that this requires a bit more VRAM to store the simulation results that are ahead of the current rendering, and that you can't really affect the water.

  • @novadea1643
    @novadea1643 9 месяцев назад

    For the more realistic simulation a thing that came to mind that would give quite a bit of artistic control and shouldn't be that much heavier to compute, just have a buoyancy multiplier for the voxels/areas and then you can easily make different parts of the object more or less buoyant. With that just making the top more or the bottom less buoyant should make the buoy auto correct unless it's completely inverted.

  • @brownspottedcat
    @brownspottedcat 9 месяцев назад

    that's so cool, acerola. happy new year.
    edit: i just watched an entire ad read because cat videos were playing off on the side. genius?

  • @danielhidefjall5060
    @danielhidefjall5060 8 месяцев назад

    "2,000 years ago a mathematician took a bath for the first time ever, leading to a new law of physics" is hilarious

  • @jaxon_hill
    @jaxon_hill 9 месяцев назад

    *create animation clip
    *make loop go boing boing
    *place slightly underwater
    *make the object follow wave height

  • @cinderheart2720
    @cinderheart2720 9 месяцев назад +2

    Acerola uploads, we watch.

  • @itsmemae
    @itsmemae 7 месяцев назад

    i appreciate the use of WORLD OF HORROR music for like 5 seconds

  • @ianweckhorst3200
    @ianweckhorst3200 8 месяцев назад

    Of course the equation for the semi circle is represented by the equation -sqrt(1-x^2), or if you do want to go further, you can replace one with r^2, but it’s helpful to start with a base case

  • @boggo3848
    @boggo3848 9 месяцев назад +1

    I feel like doing as many FFT computations as there are voxels in the object to get the water height only at that point might not be too expensive to do on the CPU, as long as the grid is sort of coarse.

  • @n7sArchive
    @n7sArchive 8 месяцев назад +1

    the cat video was a brilliant idea

  • @symmetry8049
    @symmetry8049 9 месяцев назад +1

    cool the buoy interacts with the water.
    Now make the water interarct with the buoy - currently its just clipping into the water mesh.
    fr tho, great content

  • @yrus7802
    @yrus7802 9 месяцев назад

    It would be interesting to see how the amount of voxels, (and maybe their shapes & distribution in the cube) changes the simulation. Great video as always !

  • @ripper132212
    @ripper132212 8 месяцев назад

    for natural looking movement you would want a 2nd order ODE, say like you'd implement a PID controller for a reference height (1dof sim) or normal angle (2(?)dof sim)

  • @CodyDreams
    @CodyDreams 9 месяцев назад +1

    Hey why you want use point upward force, basically I mean sample the ocean surface at some point divide by you then add upward force at point. Also gpu is better because it doing all vertex, but CPU can do that little times like 10 to 100 times with no problem. That mean no need to take data from gpu to CPU, just directly run the algorithm in CPU, also point that I mention is preferred by you, for me 4 to 6 point enough for your model

  • @copperweave
    @copperweave 2 месяца назад

    You could probably get similar performance but better aesthetic results using the last method, but applying a vertical acceleration instead, as well as a rotational acceleration independently. Then you can simply clamp rotation within the desired volume. This way, you have denoising built into the algorithm without needing to run a full physics simulation, only two axis rotational acceleration.
    Tbh, you could probably raytrace from the corners of the bounding box, and use the length of the ray to approximate the volume of the water displaced by the object as well. And since we are assuming that the object can't sink entirely, we can assume that the object always takes up all the volume between the bottom of its bounding box and the surface.
    Since we are manually clamping rotation, this would probably result in instances where extreme waves could make a bouy stay at a fixed angle for a long time... you could probably alleviate that by applying a counter force against the current direction of lean, ideally asymptomatically approaching infinity as you near the limit of your desired range, basically just a spring, but you'd have to fine tune some magic constants to keep it from looking too stiff. That, or have this corrective force asymptotically approach infinity as you get closer to a complete inversion and remove the manual clamping entirely?
    I might have explained this poorly, I'm on mobile and using voice typing so it might be a bit too stream of consciousness.

  • @9klass100
    @9klass100 8 месяцев назад

    It amazes me how similar is sound/music field to video game/grogramming. All these algorythms pretty much work the same but with different data. It makes me optimistic that if i understand one i'll eventually undarstand another.

  • @felderup
    @felderup 9 месяцев назад

    want some more fun? most buoys are chained to a weight on the ocean floor, it'll drift and set at a distance versus chain angle, then swivel toward vertical instead of lift straight up and down, then slowly move back toward the drift position, distance depending on wave speed. more applicable to tides really, a stuff in tides simulations could be fun.

  • @lineriderrulz
    @lineriderrulz 7 месяцев назад

    The spring thing you mention towards the end sounds like a PID controller. Maybe that kind of implementation could lead to good results, but I imagine the implementation is somewhere between as expensive as the approximation and the voxel simulation so probably less desirable when you have many buoyant objects.

  • @realpv_aka_vp
    @realpv_aka_vp 9 месяцев назад

    "It's at this point that our problem space moves from physics to signal processing, as all things do."
    this line goes insanely hard

  • @ThatChronomancer
    @ThatChronomancer 9 месяцев назад

    I didnt remember why i was subbed to you until i saw that tony the tiger thumbs up image. THAT of all things is what reminded me of who you were

  • @swanijam
    @swanijam 8 месяцев назад

    thanks for continuing to provide the good knowledge acerola

  • @joycezhang140
    @joycezhang140 9 месяцев назад

    I just want to say Acerola’s cat + advertisement segment is the smartest thing ever.

  • @CAxPH
    @CAxPH 9 месяцев назад

    You could set a linear interval to sample the gpu requests to smooth out the raw data coming in. That could be a "sample rate" variable that you can set wherein a higher sample rate is more accurate but has more noise, whereas lower sample rates result in less accurate but smoother motion.
    You could also simply bake the motion if the object is static. Since the sin waves won't change at that exact position after a each cycle.

  • @buzbuz33-99
    @buzbuz33-99 9 месяцев назад

    Very entertaining. It seems that this is a case where the delay is not only helpful, but you want more of it. Because water is compressible, objects (especially heavy objects) don't react immediately to changes in height or direction. Thus you could send some portion of the changes into an "accumulator" that would release an average of the changes. I did this with a flight sim where I wanted to add a little lag into the time between inputs and results - to reflect that controls wires stretch and contract (like springs) and air is compressible. It worked like a charm. That might just be the tweak that you need.

    • @AR-cy6uj
      @AR-cy6uj 8 месяцев назад

      Air is compressible, but water is practically incompressible. It takes a ridiculous amount of force to compress water by a non trivial amount.

    • @buzbuz33-99
      @buzbuz33-99 8 месяцев назад

      @@AR-cy6uj You are absolutely correct. When I used the term, I was thinking about the ability of the water to flow around the object - the thing that allows me to dive into a pool of water and not go "splat". Perhaps the term I should have used is density. And perhaps the true explanation even more complex - having more to do with the weight of the object and how far the object is submerged in the water. In any case, this appears to be one situation where lag is not a bad thing - it is just a matter of making that lag look smooth and realistic.

  • @PanzerschrekCN
    @PanzerschrekCN 9 месяцев назад +1

    Running waves simulation on CPU is perfectly fine, until you calculate it only for some positions (where bounce objects are located). And you may avoid computing waves with length less than object size.

  • @gabriel_wingard
    @gabriel_wingard 9 месяцев назад +2

    If you only have a few objects, wouldn't calculating the y-position from the xz-position (and time) on the cpu be better than sending it from the gpu? Or did your new waves not really support that compared to the sin waves? Or is it still too expensive?

  • @SpringySpring04
    @SpringySpring04 9 месяцев назад

    I always get such a happy feeling of excitement when this dude uploads
    I love the silly and random cool and interesting programming videos, it's so fun!

  • @eggseatpegs
    @eggseatpegs 8 месяцев назад +1

    make the water go splish splash when the thing falla

  • @RiedlerMusics
    @RiedlerMusics 9 месяцев назад +1

    hey um
    why can't the buoye live on the gpu? All you'd need to do for that is define some constraints where the buoye can be and make a static invisible collision cylinder there. Or just assume the player can't interact with it in the first place (e.g. for decorations outside the world boundary - or at the world boundary)
    and at that point since you're already "just" computing the buoye vertical position, pitch and roll on the gpu, you could send this relatively little data back to the cpu and approximate a better collision cylinder with that.

    • @Acerola_t
      @Acerola_t  9 месяцев назад +2

      i mentioned in the video that either the buoy goes to the gpu or the ocean comes to the cpu, in this video I chose the latter, you can do whatever you think is best.

  • @piskamil7315
    @piskamil7315 8 месяцев назад

    just found out your channel. loves the extensive use of persona ost 😭😭😭

  • @blackbriarmead1966
    @blackbriarmead1966 9 месяцев назад

    This was my final project for my computer animation class in my last semester of college

  • @CecilMerrell
    @CecilMerrell 3 месяца назад

    In my old project using gersnter waves in ue, I used a physics component spring to dampen out the movement lol

  • @tozpeak
    @tozpeak 8 месяцев назад

    Feels like spring has "too tough" coefficient. It takes several guessing iterations to find a nice look. At least in cloth simulation from scratch it took for me.

  • @StodOneR
    @StodOneR 8 месяцев назад

    Have you tried adding weight somehow in the base of the buoy?
    That's why buoys , ships etc stay upright , think of a fishing float/bobberit would sit sideways in water if it didn't have lead on the bottom.