My first step in Strand-based Foliage Simulation

Поділитися
Вставка
  • Опубліковано 14 січ 2025

КОМЕНТАРІ • 41

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

    Amazing work as always Ghislain! I'm getting into compute shaders to generate procedural terrain and foliage myself and it is not easy, look forward to seeing what you do with this in the future.

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

      Good luck with compute shaders 😄

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

      @@ghislaingirardot I know right! 🤪 There are some better resources than there used to be, check out Shadeup.

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

    This guy deserves more views, this is very valuable info.

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

    So cool bro, cant wait to see the progress

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

    Nice work.happy to see you progress :)

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

    amazing talk! thank you sharing your tricks!

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

    This is fantastic.

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

    I love this! I've been interested in doing some nesting based gameplay for little forest birds. Vertex based plant movement is awesome for graphical movement, but it's difficult to get realistic interaction.
    I'd like to mix your method for nearby branches with vertex shaders or RTs for the remainder.

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

      You can definitely mix techniques for sure :)

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

    I been struggling with this and performance. well explained

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

    very interesting and clever solution. reminds me the famous crysis interactive foliage.

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

      It's hard to fathom how much Crysis was ahead of its time regarding tech 🙂

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

    You're brilliant

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

    Really cool stuff, Ive been working on a foliage generator in engine using geometry script and my own implementation of the LSystem branching algorithm.. with some tweaking it could output that point data no problem along with a generated mesh.

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

    Have you watched the Foliage section of the Battle-Testing UE5 Next-Gen Systems with Fortnite from GDC2023 where they talk about how they baked the bone influences to Textures and use a Texture with custom MIPS to do the Wind etc ?

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

      Also gone through in the Blog Post by EPIC called Bringing Nanite to Fortnite Battle Royale in Chapter 4

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

      @@shannenmr Yes I have. Like I said in the video, the skinning technique I used is similar to the one used for skeletal animation textures or bone-weighted anim textures in general. This has been around for a long time now. Skinning is just one of the many pieces of a giant puzzle. For Fortnite, they baked a wind animation texture from a simulation done in Houdini, so it's precomputed and can't react to player/change in wind etc. This is obviously not what I want.

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

    Very cool stuff, and impressive result. I was gonna suggest using XPBD but then you brought it up. I'm curious about trying the same approach. Is there any hurdles or limitations you ran into which would not make this a good approach? Did you manage to scale it up?

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

      No, I did not try to scale it up, yet. It's definitely on my long-term todo-list though. The child-parent constraint I have going on here is super *not* GPU friendly so I've not a lot of hope for my current implementation. Plus is jiggly as hell the more links you add. Cosserat rods/XPBD is probably the way to go but I still have quite a few mathematical hurddles to jump over until I get there

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

      I need to read up on the topic as well. There is an article which you probably have read, "Direct Position-Based Solver for Stiff Rods", but it's not scaled either. I think I want to utilize the XPBD for rigid bodies as well so I will dive into the topic later.
      For know I might just use the simpler skeletal mesh switching method (with the drawback of no wind). And vertex shader animations elsewhere. Thank you

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

    Pretty awesome

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

    does unreal not have the notion of a compute buffer? An array accessible by the gpu outside of having to encode the data as texture data and having to worry about compression and sampling? That would be a lot more convenient and comfortable to use I would think. Also for the verlet integration you can solve the edge length multiple times on the same tick. Then you do not need to set your frequency so high. Just step through the node updates once and something like 4 times through the edge solving algorithm.

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

      Hey! UE has a compute buffer afaik, but like I said in the video, it's a bit out of my league for now. Baby steps. Regarding substepping, yes, correct. Although some algorithm like XPBD prefer subticking the entire simulation, like I do, for more accurate velocities afaik. Same but different, I'm not sure it'll make a difference once ported to compute but it's something to try :)

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

      @@ghislaingirardot ah cheers. I understand. Compute buffers are actually super simple in my opinion, they just sound scary :D I am not sure how they are implemented in UE but from my experience simulating kelp in unity I can say that they are a blast to work with really

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

      @@kolupsy Oh yup, nothing too complicated about compute shaders, just that the UE rendering pipeline is definitely less straightforward and less documented than Unity's imho :D I'll just have to bite the bullet and dive into it rly

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

    blueprint struct 😱😱

  • @AK-trud
    @AK-trud 7 місяців тому

    Approximately after 30:00 my brain started to explode :)

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

    Could we use load instead of sample? Its faster and we dont get into interpolation problem.

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

      You could and you should. I forgot this was an option at the time.

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

    Find a girl that looks at you, the way Ghislain looks at foliage :)
    Let's go round ... I don't even count anymore ! :D

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

    the goat

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

    "Its a blueprints solution so its not performant at all" does this mean blueprints arent meant for priduction in these cases?

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

      There's no absolute truth. My statement was for this specific use case. Blueprint *is* definitely meant for production. Just have to know when it is and when it is not. Doing a custom simulation that is subticked at 240fps isn't what blueprints were designed for. Convert this to CPP and you get code that is orders of magnitude more performant. For gameplay/event-driven logic (GAS etc.) that is called here and there however, you often don't get as much performance by converting to CPP and some things are infinitely faster to code in BPs and/or must be exposed to a higher level in the engine for level/game designers etc.

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

    WOw!

  • @JieDu-yj2vd
    @JieDu-yj2vd 7 місяців тому

    It's more expensive to make vegetation interaction based on bones, so it's not as good as shader.

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

      Clearly, you haven't watched the video. This is not bones & it's a shader

    • @JieDu-yj2vd
      @JieDu-yj2vd 7 місяців тому

      @@ghislaingirardot Sorry, I didn't finish reading it