• Björn Tantau@swg-empire.de
    link
    fedilink
    English
    arrow-up
    15
    ·
    9 months ago

    The strain of going from a 32 x 22 image to a 256 x 176 one is evident in how much longer this secondary image took to render. From 879.75 seconds (nearly 15 minutes) to 61,529.88 seconds (over 17 hours). Luckily, some optimisations and time-saving tweaks meant this could be brought down to 8,089.52, or near-ish two and a half hours.

    Those are really reasonable values. I guess my laptop would take that long to render a 4k image as well.

      • frezik@midwest.social
        link
        fedilink
        English
        arrow-up
        1
        ·
        9 months ago

        Ray tracing speed primary depends on the number of pixels, not the complexity of the scene.

        • pixeltree@lemmy.blahaj.zone
          link
          fedilink
          English
          arrow-up
          2
          ·
          edit-2
          9 months ago

          The complexity of your scene makes a huge difference. If your scene has fewer things for light to bounce off of, doing the ray tracing is much faster

          (Source: I do blender renders with cycles)

          • frezik@midwest.social
            link
            fedilink
            English
            arrow-up
            2
            ·
            9 months ago

            So I’m not exactly sure how Blender implements this. There can be a few details that can make a huge difference. Just for starters, is Blender rendering 100% ray tracing here, or is it a hybrid model with a rasterizer. Rasterizers tend to scale with the number of objects, while ray tracing scales with the number of pixels. A hybrid will be, obviously, something in between.

            Then there is how it calculates collisions. There is a way to very quickly detect collisions of AABB boxes (basically rectangles that surround your more complicated object), but it takes a little effort to implement this and get the data structures right. You can actually do Good Enough sometimes by matching every ray to every AABB, and then you do more complex collision checking against what’s left, but there’s a certain scale where that breaks down.

            Blender is generally very well done from what little I know of it, but I’m not sure how it handles all these tradeoffs.

            • pixeltree@lemmy.blahaj.zone
              link
              fedilink
              English
              arrow-up
              1
              ·
              9 months ago

              So, as far as I know the cycles engine does ray tracing until it hits a noise threshold, then does ai denoising for the final cleanup. You can see where the more visually complex parts of your render are, because it will take a lot longer to render to a less noisy state. I don’t know specifics of how it works under the hood, but given how complex parts of your image take longer to tender to an acceptable threshold than simpler parts it seems obvious to me that render time scales with complexity.