A Game Engine Built For Optimisation

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

КОМЕНТАРІ • 523

  • @SatisfiedOnion
    @SatisfiedOnion 7 місяців тому +3355

    I can sleep well at night knowing that my TI-NSpire 84 calculator will always be able to run this man's games

    • @Stromoto
      @Stromoto 7 місяців тому +72

      Maybe Vercidium will make sure that your TI-NSpire 84 calculator can finally play Sector's Edge in the future

    • @attilavs2
      @attilavs2 7 місяців тому +27

      "The Nspire 84 can't hurt you, it's not real"
      The nspire 84 :

    • @NoorquackerInd
      @NoorquackerInd 6 місяців тому +8

      Frick, as someone that got into embedded because of calculators, now I wanna port this to the Nspire

    • @cinderwolf32
      @cinderwolf32 6 місяців тому +6

      Aside from Nspire 84 not being a thing: I learned much of my initial programming knowledge on a TI-84 Plus Silver Edition, and I think that really taught me to value efficiency. Love seeing other people with similar stories!

    • @amir32806
      @amir32806 6 місяців тому

      You like modern AAA laggy games?

  • @sharksandbananas
    @sharksandbananas 7 місяців тому +801

    Amazing z-buffer visualization, never thought of the data in that way before!

  • @Baconator20000
    @Baconator20000 7 місяців тому +2002

    Jokes on you, my shitty laptop is still gonna find a way to lag from just rendering glorified pngs

    • @CharlesVanNoland
      @CharlesVanNoland 7 місяців тому +111

      I'm a sucker for coding stuff to run on ancient hardware because I started coding when I was a preteen in the 90s, when you had to know how to get the most out of a computer or your game ran like unplayable garbage. Nowadays devs just do whatever and ignore performance and optimization because they just let their end-user's hardware go to waste. EDIT: Indie devs, for the most part, is who I was referring to, but also companies like Bethesda that build layercakes of flashy FX ontop of their ancient engine.

    • @cosy_sweater
      @cosy_sweater 7 місяців тому +14

      I have a decent pc that can even run Cyberpunk 60fps. But for some unknown reason it freezes randomly even with no load. Like im experiencing 10 second freezes: on desktop; on lockscreen; opening explorer; randomly at any point. So even if the game can run at 10k fps on a calculator im still gonna have ~0.1fps

    • @pluralphilosophy6657
      @pluralphilosophy6657 7 місяців тому +15

      Jokes on you my shity laptop freezes when loading regular pngs

    • @alfiegordon9013
      @alfiegordon9013 7 місяців тому +21

      ​@@cosy_sweatermight wanna have a look at your power supply, if it's defective it could have random voltage drops on certain lines that would cause GPU issues

    • @theairacobra
      @theairacobra 7 місяців тому +7

      @@cosy_sweater i've had a similar issue, it was my motherboard doing silly things to the RAM voltage which sometimes crashed my entire PC, what motherboard do you have?

  • @buzinaocara
    @buzinaocara 7 місяців тому +325

    This works somewhat ok for your specific scene because you expect a buch of sparesly scattered beams in that specific scenario. This will just look weird in a scene not covered with trees, becaue those few hundred beams will not average out into a homogeneus volume, and if you increased their amount to the point where they do, you will be running slower than aproach nº 2, and will be severely bottlenecked by fillrate.
    You also seem to be spawning the beams from the floor towards the sky and checking for the shadowmap at that position. That means a beam that is being occluded by a tree before it hits the floor gets faded out in its entirety: no beam after the tree NOR BEFORE IT. That too might not look so obviously wrong in that scene, but can look decidedly worse in scenarios with higher depth complexity.
    Its a clever hack, but with very limited aplicability.

    • @kabinet0
      @kabinet0 7 місяців тому +56

      I agree, it's certainly no volumetric light system. Definitely cool, but more a highly specific trick than anything else.
      Unrelatedly, the CPU readback being involved immediately makes me dislike the technique. It would be slightly less painful if they operated on the opacity data in a compute shader.
      Kind of does get me thinking about some kind of cached (perhaps voxel based) approach though.

    • @DireWolfAirstrike
      @DireWolfAirstrike 7 місяців тому +12

      As long as the trees are also receiving shadows, I imagine you could do the same technique at the edges of those shadows.
      Looking at the window lighting that inspired this technique, I'd expect it to be one of those things like billboarding where it's "good enough" until you really pay attention to it.

    • @Vercidium
      @Vercidium  7 місяців тому +54

      Can you please elaborate on your second sentence about a few hundred beams and homogenous volumes?
      Great point about checking from the floor up. An enhancement could be to check the min and max shadow depth values of each sample, then render the beam between the highest position and the lowest position (using the same opacity formula)

    • @Vercidium
      @Vercidium  7 місяців тому +38

      @kabinet0 persistent mapped buffers and fences allow the CPU readback to happen asynchronously. With 2048 beams that's 2048 * 6 floats * 4 bytes = 49kb of data, which isn't enough to cause a bottleneck

    • @buzinaocara
      @buzinaocara 7 місяців тому +57

      @@Vercidium Your aproximation looks somewhat plausible in a scene with very spotty coverage such as bellow trees. A swiss cheese world would also apply hahaha. But try doing that in a wide open landscape. You will still have a bunch of randomly scattered beams instead of a homogeneous solid fog volume. The random beams will make no sense (what is dividing light up into small spot-light-like rays in an open sky?". It will look more like rain than fog in that context. I said "few hundred" out of guesswork. I dont know how many billboards you are actually spawning across the scene. But still, in reasonably consistent and robust implementations of god-rays the same fog that creates these small beams in some scenes, is the fog that creates a dense Z-buffer-fog-like effect in other contexts. Its all recreations of real-world light scatering and shadowing interacting.
      For good reference of how broad the effect is, take a look at a RDR2 presentation on their atmospherics system they show comparisons to real world and artistic depictions of the same phenomena. AC4:BF also has a description of their implementation in a graphics presentation of theirs, which I believe was the firsr shipping "Froxel" solution. TLoU2 also has an extensive presentation on myriad optimisations and quality improvements they did to it.
      All that said, what you came up with is still a clever little hack that can work in specific scenes. For a broader game you'll probably want some artist control over where billboards spawn and where they don't, so they are limited to places where they look plausible. If you have a clearing in the forest for example, you'd want to have no beams in the middle of it because then again, they'd lool like weird rain in that context instead of light.
      Even for a window, your solution might look inproper once you have dinamic objects. Since oclusion is checked from the floor, if a character steps in front of the window, not only will the beams be bocked from reaching the floor, they will misteriously not even hit the character either. A tall enough window and a short enough dynamic object can create a very visible effect of a moving object magically making the sun-rays disapear from the window as long as it passes over the sun-lit part of the floor.
      PS: I just rewatched the video and remembered your trick is to only draw beams "at the edge of light". Yeah, that reduces the occurance of the "light looking like rain" problem I described. Yet, the reality is that those wide open spaces should also have the volumetric light in them (including the ocean) just instead of scattered beams, it should be a larger volume. Your solution emulates the "feeling" of a subset of a light phonomena, rather than the real thing. Thats why I recomened looking up the RDR2 presentation, they really explain all the different cases where atmospheric scatering can influence a scene.

  • @lf6914
    @lf6914 7 місяців тому +670

    There is also a much better way to render volumetric lighting. It's called "Froxels". It was first introduced in Assassin's Creed Black Flag and was later adopted by EA, Naughty Dogs, Rockstar and many more! And also it looks absolutely stunning!

    • @juliandurchholz
      @juliandurchholz 7 місяців тому +133

      That's a state of the art approach, but what's "better" or "worse" really depends on your goals and target hardware ;)

    • @rednicstone3299
      @rednicstone3299 7 місяців тому +142

      @@juliandurchholz its not really state of the art, its close to 10 years old at this point. It ran great back then, and if you cant run foxels, you might as well give up running anything serious. Also it looks great in comparison with the nonsensical method proposed in this video.

    • @buzinaocara
      @buzinaocara 7 місяців тому

      @@rednicstone3299 Yeah. they were first used in Assassin's Creed Black Flag for XBone and PS4 if I'm not mistaken.

    • @juliandurchholz
      @juliandurchholz 7 місяців тому +22

      @@rednicstone3299 Well, RDR2 and Last of Us 2 use it, for instance. What more modern approaches would you say it's been succeeded by?

    • @SimonBuchanNz
      @SimonBuchanNz 7 місяців тому +70

      ​@@juliandurchholz"state of the art" technically just means "what the people that know what they're doing use", but the common use is "just invented, best available way to do something".

  • @LimakPan
    @LimakPan 7 місяців тому +150

    So it's not lighting, but god rays?

  • @magnomliman8114
    @magnomliman8114 7 місяців тому +222

    This optimization content is super interesting man.

  • @Rexhunterj
    @Rexhunterj 22 дні тому +2

    Such a great video on the topic.
    With how vast the internet is, there are still too few resources for learning this particular topic, especially OpenGL.
    Thanks for your hard work and for sharing.

  • @Chaos_God_of_Fate
    @Chaos_God_of_Fate 6 місяців тому +9

    Very clever. I never got into the technical side of things but when I worked in CryEngine (2007-2015ish). I was the optimization guy in the editor- did most of the optimizations for Mechwarrior: Living Legends environments... Kagoshima (a MW:LL level I designed) took a lot of tricks to get to run reasonably. Making Levels for that game/mod are some of my best memories, and it's still alive today, 15 Years later!

  • @zipsexe
    @zipsexe 3 місяці тому +4

    Give this man triple A budget

  • @cortanathelawless1848
    @cortanathelawless1848 6 місяців тому +11

    I love people who focus on optimisation because besides the truly impressive technical skills, you only get into optimisation out of two reasons: you cant run your own game/feedback from players, or and thats the reason i respect a lot because they want to make games more accessible. Games are art, more people should be able to enjoy art. Thank you!

    • @anon_y_mousse
      @anon_y_mousse 4 місяці тому +2

      Completely agree. Making a game more accessible by optimizing it for potato hardware is awesome. To this day I have never owned a discrete graphics card.

  • @mz_eth
    @mz_eth 7 місяців тому +11

    The editing on this is stunning 😍Also the fact that it was all about lighting had me instantly in love

    • @Vercidium
      @Vercidium  7 місяців тому +2

      Thanks Zeth! I agree, we need more videos about lighting

  • @digitalgh0stt
    @digitalgh0stt 7 місяців тому +29

    It looks alright, but you can tell all the beams are the same size.
    I wonder if increasing their width with the decrease in opacity would help make the overall scene look better and less uniform. Kind of simulating the beams becoming blurrier.

  • @alexm666
    @alexm666 7 місяців тому +11

    I don't know what's more precious in your videos - the insights to the amazing rendering tricks or the way you visualize them!

  • @martin128
    @martin128 7 місяців тому +19

    I think the static 2d planes variant of god rays was used in multiple games in 00s. I think Hitman 2 has it and Freedom Fighters, both are from IO Interactive.

    • @Capewearer
      @Capewearer 7 місяців тому +4

      Even Crysis 3 uses them, and still looks stunning. But such usage is limited to static scenes only. For dynamic things Crysis 3 uses screen-space Godrays effect. Works pretty well.

  • @honichi1
    @honichi1 5 місяців тому +1

    thank you, this is the type of optimisation we used to see in games back in the day when processing power was more limited

  • @mezohx
    @mezohx 7 місяців тому +12

    I learned more in 5 minutes by watching this video than I did in a week doing my own research. Wild

  • @TileBitan
    @TileBitan 7 місяців тому +143

    Maybe it's just me but the second approach still looks 100 times better than the last one. Last one makes it look like some early 2000s game

    • @trued7461
      @trued7461 7 місяців тому +35

      It does look better but 100 times better is pretty close to 70 times which his how much performance is saved, so tbh, worth it maybe?

    • @TileBitan
      @TileBitan 7 місяців тому +15

      @@trued7461 there is probably a middle ground where you gain a little bit of performance and it actually looks the same. But from those images it ain't it chief

    • @trashtrash2169
      @trashtrash2169 7 місяців тому +4

      They could be made wider. Maybe dynamically. They're pencil thin. Maybe if they're full opacity they're also double width and you scale the same as opacity...

    • @muggzzzzz
      @muggzzzzz 7 місяців тому +3

      It still could be useful for mobile game development.

    • @martinsanchez2395
      @martinsanchez2395 7 місяців тому +2

      For people with potato PC's is much better than disabling the effects all together

  • @knyght27
    @knyght27 7 місяців тому +7

    Very interesting! Always happy to see optimisation techniques explained in beginner-friendly terms

  • @nathanfranck5822
    @nathanfranck5822 7 місяців тому +17

    I had no idea a Feedback buffer was a thing! Thats cool

  • @SirGilt
    @SirGilt 6 місяців тому +2

    if we like this, and get this to the front page of youtube, we may see better performance in games if we are lucky.

  • @P-39_Airacobra
    @P-39_Airacobra 4 місяці тому +2

    I really appreciate content like this that tells us how to make our code both efficient and simple. I know what it's like to have a low-budget PC and still want to play games on it, and optimizations like this save the day for such gamers.
    Even if unoptimized code is "enough", it's preventing you as a game dev from implementing lots of interesting features. I wish the software engineering community as a whole would stop pretending resources are unlimited.

  • @zachbaldwin2925
    @zachbaldwin2925 7 місяців тому +2

    The dynamic beam approach was very interesting. I couldn't help but consider biasing the "dynamic beam" size/ density depending on distance to camera or splaying thebeam's mesh from the threshold of object and sky towards the ground, creating a trapezoid, to emulate penumbra.

  • @OGPatriot03
    @OGPatriot03 7 місяців тому +3

    The end result isn't stunning to me visually, however the approach to get there is highly intriguing and gives me all sorts of ideas. These videos are great for getting the indie dev mind thinking.

  • @DdiiaabbllooBlanco
    @DdiiaabbllooBlanco 6 місяців тому +1

    >Sees video title that I'm interested in.
    >All I hear is static in my brain with the well put together information because I don't understand.
    >Nice video.

  • @callibor3119
    @callibor3119 7 місяців тому +2

    I think the best move is color your models and textures like if light actually hit and color it like if light didn’t.
    What’s going on from I am seeing is everything is completely singularly functioned and not programmed to act like how light should hit the environment.
    The light shouldn’t be faked, but how you color the textures and models can be faked to the point that it looks real.
    If you let the engine itself do all the work, you won’t get the performances with its default settings, so getting the models and textures early on in development to look like it is real-time before the game engine, can break the limits of the engine and you won’t see the work break itself.

  • @nevintilch4962
    @nevintilch4962 7 місяців тому +128

    If you and acerola collaborated on a project, you would somehow manage to optimize something to render at the speed of light in a 360° POV with 4k resolution on every texture and also the game would do my homework and take me out to dinner

  • @wylskoe
    @wylskoe 6 місяців тому +1

    this is really interesting. I look forward to see what you learn and achieve during your game engine development

  • @Xaymar
    @Xaymar 5 місяців тому +1

    I know this is an older video now, but I'd like to share a method I used 15 years ago in Blitz3D (DirectX7). Calculate the intersection point between Sun and Camera ray, capture an Ortho view from that point towards the sun. Place up to 255 transparent planes along the sun ray, placing them at equal distance step, starting at the point that first intersects the frustum, and ending at the point that last intersects the frustum. This is effectively the 2nd method, but it should be significantly faster than the 2nd method. Downside is that you need to take care of gaps between planes by tilting them towards the player camera.

  • @Mushroom38294
    @Mushroom38294 7 місяців тому +3

    We need more game devs like you, I'm sick and tired of games taking up loads more resources than necessary

  • @fiffy6572
    @fiffy6572 7 місяців тому +3

    This is crazy
    This channel deserves so much more!!!
    Keep going with your amazing work! So inspirating for people like me who would love to make video games and also like the software engineering behind it!

    • @Vercidium
      @Vercidium  7 місяців тому +1

      Thanks so much!

    • @farianderson168
      @farianderson168 7 місяців тому +1

      Yeah, this channel is so much fun and inspiring for people like us who want to get involved in engine and optimization stuff.
      Probably not for those who think they know everything already, but great for me. I wish there was more contents and devlogs like this. It's like a light in the darkness.

    • @Vercidium
      @Vercidium  7 місяців тому +1

      That means a lot to hear, thank you

  • @poggarzz
    @poggarzz 7 місяців тому +1

    I may not understand everything but I surely can appreciate the beauty of it all.

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

    the passion you put into your videos is palpable, it’s inspiring! ❤️

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

      @@YagamoReba thank you so much!

  • @juliandurchholz
    @juliandurchholz 7 місяців тому +27

    Hey there, good video! Certainly a decent way to fake light shafts, but I wouldn't say it "looks the same" as raymarched volumetric lighting. True single-scattering will always be the most convincing second to raytracing. Your technique appears more flat and is restricted to a fixed amount of random light shafts, which probably leads to scene-dependent artifacts.
    What's your hardware for the given benchmarks? Would be nice to have that included somewhere.
    The "first" approach (screen-space post process) can also be extended to somewhat work for off-screen light sources, to a degree. Are you sure using an intermediate texture with directional blur is superior to epipolar sampling with weight function, as per the traditional GPU Gems 3 solution?
    I wish your video was a bit longer to cover those details and nuances, go into more depth when comparing other techniques, so as to really give an impression of the tradeoffs.

    • @Vercidium
      @Vercidium  7 місяців тому +4

      I haven't heard of epipolar sampling, I'll check that out thank you!
      I have a 10700F CPU and an RTX 3070 GPU

    • @abhishekak9619
      @abhishekak9619 7 місяців тому +1

      @@Vercidium i dont know what both of you are talking about. the other person never said epipolar sampling. am i missing something?

    • @Vercidium
      @Vercidium  7 місяців тому +1

      @@abhishekak9619 epipolar sampling is in the 2nd last paragraph of the original comment here

    • @abhishekak9619
      @abhishekak9619 7 місяців тому

      @@Vercidium oh i see now.

  • @ponyforhire
    @ponyforhire 6 місяців тому +1

    I always find it fascinating to see experts go ham in thier in their interests and listen in no matter how much i actually understand on the subject at hand 😂

  • @Beets_Creations
    @Beets_Creations 4 місяці тому +3

    This is extremely well broken down into understandable information. Great video!

    • @Vercidium
      @Vercidium  4 місяці тому

      @@Beets_Creations thank you!

  • @RawFish2DChannel
    @RawFish2DChannel 7 місяців тому +1

    Another banger video! I always find it very interesting when people find alternative ways of creating same visual effects but in much more optimized way.
    I also thought about optimizing one effect called SSR (Screen Space Reflections) and came up with a completely different way of doing it, but I haven't tested it yet.
    Also would be very interesting to see attempts of recreating ray tracing/path tracing with roughly same quality, but a lot more performance, since ray marching is very heavy task for a fragment shader. Would be very interesting to see alternative ways of doing it.

  • @askeladden450
    @askeladden450 7 місяців тому +38

    bro out here casually dropping absolute masterpieces every month

  • @nolram
    @nolram 7 місяців тому +7

    I don't think it's fair to say this looks the same as fully integrated volumetrics. Like, sure, in this one particular scenario in a forest where you want lots of small shafts this may work great, but what about other outside scenes where they aren't as closely occluded? What about local lights? What about generally open areas where the vast majority would be fog-filled? Generally this is a lovely technique for those very specific small beams of light, but I don't think this is anything even remotely close to volumetric scattering - hence why there aren't many games that use this particular method.
    Great video nonetheless, even if I would have hoped for a few more details about placement and transformation of the beams.

  • @solhsa
    @solhsa 7 місяців тому +1

    Wow, someone actually found a use for transform feedback.

  • @techbytefrontier
    @techbytefrontier 5 місяців тому

    you are built different man. just the animations to show this would take all my knowledge

  • @atunalamarinera
    @atunalamarinera 7 місяців тому +1

    Maybe it can't replace the second method but surely it will replace the first one, not only runs faster but also looks better.

  • @anzhel3268
    @anzhel3268 7 місяців тому +1

    cool, it's nice how a lot of problems get solved by just using quads in a smart way

  • @Goliath83
    @Goliath83 7 місяців тому +3

    Vercidium; God emperor of Game Optimization and priest of frames per second
    love what you do

    • @Vercidium
      @Vercidium  7 місяців тому

      Hahaha thank you

  • @mypaxa003
    @mypaxa003 7 місяців тому +34

    5:08
    "In this video on screen"
    Where? I dont see anything.

    • @Vercidium
      @Vercidium  7 місяців тому +17

      Just added it, thanks for letting me know!

  • @Skeffles
    @Skeffles 7 місяців тому +1

    What a fantastic improvement!

  • @mrousavy
    @mrousavy 7 місяців тому +2

    nice work! i love these kinds of videos

  • @SSS333-AAA
    @SSS333-AAA 7 місяців тому +1

    dude this is crazy, i'll rewatch when you translate this from smart to english.

    • @Vercidium
      @Vercidium  7 місяців тому

      Hahaha thanks

    • @SSS333-AAA
      @SSS333-AAA 7 місяців тому +1

      @@Vercidium why the fuck are you responding to me, there are genuine great questions down here you can read rather than read our shitpost.

  • @bl4ckk
    @bl4ckk 7 місяців тому +1

    I can't decide what's better, the split transitions, or the light rays

    • @Vercidium
      @Vercidium  7 місяців тому

      Haha thank you. I had to render it at half speed as my GPU couldn't render all 3 scenes at 60 FPS

  • @mild2616
    @mild2616 7 місяців тому +1

    Idk if this just common knowledge or if this man is just a genius but my god the game space is gonna be so much better from here on out if this guy is working on em. Great video!

  • @gbnam8
    @gbnam8 7 місяців тому +5

    the gpu-cpu-gpu roundtrip in 4:28 seems quite suboptimal, can a compute shader replace this step?

    • @Vercidium
      @Vercidium  7 місяців тому +3

      With persistent mapped buffers and fences the roundtrip happens asynchronously. There is a 2-3 frame delay but you'd never know while playing.
      Some other comments have mentioned that the vertex shader could read/write directly to an SSBO and calculate the average itself, I'll have to check that out

  • @darkfllame
    @darkfllame 6 місяців тому +1

    babe wake up Vercidium uploaded !

  • @VaibhavShewale
    @VaibhavShewale 7 місяців тому +2

    ooh man this one is just mind blowing!

  • @floschy_1
    @floschy_1 7 місяців тому +1

    1:19 I didnt know I need this visualisation in my life, but i do.

  • @kerduslegend2644
    @kerduslegend2644 6 місяців тому

    My god... You give one of the best explanation i could ever get, the video's awesome. Thankyou!

  • @Aminsx_
    @Aminsx_ 7 місяців тому +1

    The 3rd method in the first chapter of the video reminds me a lot of LIMBO

  • @nicklasfejersen4202
    @nicklasfejersen4202 7 місяців тому +1

    i can't wait for someone to implement this into a minecraft mod

  • @GreySectoid
    @GreySectoid 6 місяців тому +1

    Cool algorithm, graphics programming is so much fun!

  • @jacktruong7151
    @jacktruong7151 7 місяців тому +1

    I've to rewatch this over and over for about 7 times just to catch up with wtf is going on lol
    Damn cool

    • @Vercidium
      @Vercidium  7 місяців тому

      Hahaha thank you

  • @JMO-
    @JMO- 7 місяців тому +2

    In an old game prototype I made, I had a lot of grass models placed around the world, but they were physical objects and would lag a lot when loading/unloading and area because of them. There is probably a way to use a shader instead of the grass actually being real while still giving me a way to control where the grass is and have the player model interact with it (I'm just not good enough at shaders to make it). That could be a cool video idea, I would love to see you render millions of blades of grass a few thousand times a second lol.

    • @kabinet0
      @kabinet0 7 місяців тому +3

      Take a look at Acerola's series on modern grass in video games, it's a really good watch and describes pretty much exactly what you're talking about.

    • @Vercidium
      @Vercidium  7 місяців тому +2

      ^ Acerola's video on grass is excellent. My grass rendering is still pretty naïve, I have a lot to learn about vegetation rendering

    • @farianderson168
      @farianderson168 7 місяців тому

      @@Vercidium i think Acerola's approach laks your way of optimising memory for meshes by using only vertex indices. Also you have your own engine and probably don't need to run a compute shader each frame just to have a vertex buffer filled (that's what DrawMeshInstancedIndirect does in unity i think).
      Would really love to see how you implement grass, probably in future videos

  • @LinguisticMirage
    @LinguisticMirage 7 місяців тому +2

    that plane light thing is something from the early 2000's for example gta san andreas does that

  • @penial_
    @penial_ 7 місяців тому +1

    Another wonderful video from sectors edge guys

  • @omabang5002
    @omabang5002 7 місяців тому +1

    I have no idea what is this or why this video recommended to me but it's very cool!

    • @Vercidium
      @Vercidium  7 місяців тому

      Haha glad you liked it!

  • @Roxor128
    @Roxor128 6 місяців тому

    I wonder: what about a voxel map for where light goes?
    The map would be a 3D greyscale texture (you can tint it later). Initially fill it with all-white voxels, black out voxels where solid geometry exists, then do a directional blur away from the light sources (which would be a single direction for the sun, given it's far enough away that its rays can be considered parallel by the time they reach Earth), and repeat the black-out and blur steps a few times. When rendering, sample the voxel grid along the camera ray to get side-illumination data using a 3D texture sampler.
    You'd have to experiment to find how low a resolution you can get away with, but it could allow pre-calculating some of the lighting data, and as a bonus, you'd know ahead of time how many steps to take along the ray during rendering, just from the grid resolution and distance. If your swaying trees follow a predictable loop, you could calculate a few frames of voxel lighting data and select from the appropriate one, or even interpolate between them.
    I have no idea how fast this would be, and it absolutely would be memory-hungry, but by transforming the volumetric lighting to image-processing (just in 3D), it might be faster than doing the real thing. With luck, you could do it at load-time, or chunk-generation, rather than having to keep it on disk. Hell, you could probably do it in a compute shader on the GPU, so the CPU never needs to touch it. Now that I think about it, it sounds like it has a bit in common with Quake's lightmaps, except 3D and only concerned with direct illumination.

  • @MilanCoolant
    @MilanCoolant 7 місяців тому +2

    Beams of light in games is called god rays

  • @whitneysmiltank
    @whitneysmiltank 7 місяців тому +3

    These are the best videos on youtube.

    • @Vercidium
      @Vercidium  7 місяців тому +1

      Too kind, thank you!

  • @swagatggautam6630
    @swagatggautam6630 7 місяців тому +1

    This guy deserves a Nobel prize for Game Development.

  • @Jabjabs
    @Jabjabs 7 місяців тому +1

    I would recommend folks look at the GDC talk for how light beams were handled for the game Abzu. Very cool. In that talk as well is a great summary of how to animate thousand of creatures simply via vertex offsets on the GPU - but that isn't so related to this.

    • @Vercidium
      @Vercidium  7 місяців тому

      Thank you for the recommendation, I'll check it out

  • @Chris-op7yt
    @Chris-op7yt 7 місяців тому +1

    light is everywhere, except where there is shadows, which much attenuate it

  • @Exaspatial
    @Exaspatial 6 місяців тому +1

    11 thounsand frames per second is just diabolical

  • @ExtraTrstl
    @ExtraTrstl 7 місяців тому +1

    You’re doing divine work here.

  • @kaleygoode1681
    @kaleygoode1681 7 місяців тому +1

    If it's through leaves, the flickering isn't necessarily wrong - just annoyingly flashy, as flickering leaves are in real life!
    But crepuscular rays through clouds shouldn't flicker, so this is great for those

  • @darkfllame
    @darkfllame 6 місяців тому +2

    not gonna lie, i'm developping a 2D automation game and i'll make so that it can run smoothly on the most shittiest laptop you've ever seen. 16 bits vertex data, instancing and more. And the maps could be HUGE, up to 2^70^2 tiles: by separating the world into regions split into chunks. All of that with not that much resources consumption (in theory).
    I haven't done the game yet and i hope i could share it to the world. god dammit i love game dev.
    Also everything will be done with opengl in zig ! I'll a devlogs when I finish the rendering stuff (at least some sort of good rendering)

  • @I2ed3ye
    @I2ed3ye 7 місяців тому +1

    Now all my games run so well!

  • @baronbacku9984
    @baronbacku9984 6 місяців тому

    god daaaamn, i'd have never came up with something like this

  • @Digiur
    @Digiur 7 місяців тому +24

    Is that "optimized"? Or is it a completely different technique?

    • @perplexedon9834
      @perplexedon9834 6 місяців тому

      I think it's fair if the output looks comparable to the human eye. The thing that is being optimised is the graphical output, not the completion of a specific process. The fast inverse square Quake is a classic example. If someone replaced the true inverse square with the fast inverse square, I'd certainly consider that an optimisation even though it technically gives a slightly different output and technically isn't the inverse square.

    • @Digiur
      @Digiur 6 місяців тому

      @@perplexedon9834 Sure, sure. Some results different techniques. Not "optimization".

    • @survival_man7746
      @survival_man7746 6 місяців тому +5

      That's why it's much faster, it was reengineered. It is less acurate but still looks good like transforming a map into a grid for pathfinding

    • @Digiur
      @Digiur 6 місяців тому

      @@survival_man7746 I'm just being pedantic about the word "optimize"

    • @AlphaSeagull
      @AlphaSeagull 5 місяців тому +5

      I mean, a lot of bigger optimizations are just that: using a better technique

  • @Hector-bj3ls
    @Hector-bj3ls 7 місяців тому +2

    No wonder it goes faster. He was using some flat out floats in that shader code. They're way faster than normal floats.

    • @Vercidium
      @Vercidium  7 місяців тому +2

      Haha that's one tiny optimisation, but they all add up

  • @thor_whitemountain
    @thor_whitemountain 7 місяців тому +1

    I love how you're always just, "you know this thing?" I made it 500 TIMES FASTER., oh and it's pretty simple, and then give a simple explanation for everything :)

  • @bs_blackscout
    @bs_blackscout 7 місяців тому +1

    btw this is a much better title
    the previous one felt like a copy paste from another video I've seen before

  • @SaenGaems
    @SaenGaems 7 місяців тому +1

    would be cool to have the beams also move a little with the wind applied to the trees, looks just a little too static

    • @Vercidium
      @Vercidium  7 місяців тому

      That's a great idea! I could shift the beam towards the samples that are in the light

  • @SylvesterAshcroft88
    @SylvesterAshcroft88 7 місяців тому +1

    This is so incredibly clever!

  • @matthewboyd8689
    @matthewboyd8689 6 місяців тому +1

    Misread the title
    Thought it said gamers are for optimizing
    Started thinking about talk that a game developer said something about, gamers will optimize the fun out of a game. And I realized that in my own life and working life I've been optimizing things to work more efficiently as well. And to such degree that at one point I realized I was turning away experiences that I actually wanted to do just because it conflicted with my schedule that I made up and didn't have to follow.

    • @Vercidium
      @Vercidium  6 місяців тому

      That’s deep. I can relate to this

  • @fx-modding
    @fx-modding 7 місяців тому +2

    You should be able to use atomic's within the shader instead of a feedback transform. This will skip the extra step of having to communicate with the cpu.

    • @Vercidium
      @Vercidium  7 місяців тому

      I'll check atomics out, thank you!

  • @a6gittiworld
    @a6gittiworld 7 місяців тому +1

    damn bro! i shall call you shadow man

  • @omgnowairly
    @omgnowairly 7 місяців тому +1

    These videos are brilliant.

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

    Sick! Might implement this in Unity

  • @cookietheory
    @cookietheory 7 місяців тому +2

    Great video as always!

  • @scarecrow5848
    @scarecrow5848 6 місяців тому

    this would be SO good for VR.

  • @BMRG14
    @BMRG14 7 місяців тому +13

    Perfect perfect video and info, with a very bad title. :(
    It's not even searchable really.

    • @AkshayKumarX
      @AkshayKumarX 7 місяців тому +9

      This is the norm now with majority of youtube channels.
      Titles and thumbnails like these drive curiosity and get people to click on the video. Then the creator increases the viewer watchtime by being as vague as possible for the first minute or so to game the system and boost the video's popularity.
      The downside being that if you aren't staying up to date with every new video, old content is almost impossible to find via search.

    • @Vercidium
      @Vercidium  7 місяців тому +3

      Thank you :) I come up with 5-10 different titles and thumbnails for each video and test each of them, then leave it on the one that brought in the most views. It's all an algorithmic game

  • @FelipeMendez
    @FelipeMendez 7 місяців тому +2

    Id be curious to know if distance fields would help reduce the sample count while keeping good quality in approach 2

  • @bensoos
    @bensoos 6 місяців тому

    I think i found the guy, who make all the new Unreal Engine updates.

  • @JuhoSprite
    @JuhoSprite 6 місяців тому

    This must be like, revolutionary

  • @Willyuum
    @Willyuum 7 місяців тому

    Nice work and nice presentation

  • @Greywander87
    @Greywander87 7 місяців тому +1

    The key to creating a simulation that is both accurate and fast is to forget about accuracy, cheat as much as possible, and tell no one.
    No but for real there will be times when relying on good old RNG gives a result that is only slightly worse than running an expensive simulation. The real key is finding shortcuts and approximations that get you that "good enough" result where no one can honestly tell it isn't 100% accurate without costing too many system resources. Creating an accurate simulation is only half the job, the other half is figuring out the tricks that let you run the simulation in real time.

  • @patty4449
    @patty4449 7 місяців тому +1

    Ok I can add on this...
    When the day passes less beams should be on screen...
    Beams should't be statics but move slightly over time...
    Great concept...
    But I still can't get dynamic snow done in this way as the sheer amount of vertex points saved is the problem... Im getting closer tho...

  • @Xizilqou
    @Xizilqou 4 місяці тому +1

    Wouldn't another option be to do a shell texturing approach where you have planes always in front of the screen that are lit by the shadow map lighting you already have in a certain way that looks like volumetric "god rays?"

  • @the-guy-beyond-the-socket
    @the-guy-beyond-the-socket 5 місяців тому

    hearing Vercidium curse its like a fever dream

  • @Tikai77
    @Tikai77 7 місяців тому

    I just discovered your channel and it's awesome!
    I wanted to know if you've ever thought about making videos where you explain how things work / how things are optimized in other video games? (for example RDR2 lighting / clouds etc...)
    It could be fun I think, anyway gg!

  • @ValidatingUsername
    @ValidatingUsername 5 місяців тому

    It’s amazing that the scene calculations can accidentally be forced to figure out if an infinite set of objects exist in what needs to be rendered for each frame and then doing the calculations on what’s actually in the scene and ray tracing those objects

  • @fffrikkie1236
    @fffrikkie1236 7 місяців тому +9

    I like your content man, very well edited. Just wondering (and sorry if it's a stupid question), but do these optimizing techniques translate to other game engines or are they just specific to the one you're using?

    • @vexflorez6220
      @vexflorez6220 7 місяців тому

      If you want to, you can apply these optimization techniques yourself to other engines, though that means throwing away what the engine itself offers and writing things from scratch, while also building it in such a way that it works with all the other parts of the engine.

    • @Vercidium
      @Vercidium  7 місяців тому +1

      This should be possible in any engine that supports shadows and vertex readback. For example Valheim uses a custom render pipeline within Unity, I reckon they could add beams of sunlight like this.