SaschaWillems / Vulkan-glTF-PBR

Physical based rendering with Vulkan using glTF 2.0 models
MIT License
979 stars 132 forks source link

`getMatrix` become too slow when the scene contains deeper node hierarchies. #40

Closed syoyo closed 6 months ago

syoyo commented 4 years ago

https://github.com/SaschaWillems/Vulkan-glTF-PBR/blob/08cf10dcd7609fa6f7d43b4e79ecca7431d09937/base/VulkanglTFModel.hpp#L511

getMatrix always loop over parent matrices until it reaches the root.

This become quite slow when the scene contains deeper node hierarchies(e.g. 100. such a deeper hierarchies would happen in character skeletons). For example, I get 120 fps(without getMatrix) -> 7 fps(with getMatrix) slowdown on Threadripper 1950X for a glTF model containing roughly 300 nodes.

The solution is obvious. Cache the node's matrix once after updating the matrix of each nodes. Probably we are better to add updateNodeMatrices() API before calling node->update()(If this change is OK, I can send a PR)

SaschaWillems commented 4 years ago

That's true. It's especially evident in debug mode, where some scenes run extremely slow even on my 3rd Gen Ryzen CPU. I'll take a look at matrix caching, and maybe try to add some parallelism to improve performance.

syoyo commented 4 years ago

I'll take a look at matrix caching

Thanks! For example, adding global_transform_matrix to Node, then compute it from the root node should work well.

  void updateGlobalTransformMatrix(glm::mat4 parentMatrix) {
    global_transform_matrix = parentMatrix * localMatrix();
    for (auto &child : children) {
      child->updateGlobalTransformMatrix(global_transform_matrix);
    }
  }
questgugou commented 1 year ago

thankyou you are good

SaschaWillems commented 6 months ago

I added a very basic "caching" algorithm to limit the number of matrix calculations per animation step. While very simple, this greatly improved performance on my side, esp. when running debug with MSVC.

syoyo commented 6 months ago

Thanks!

a glTF model containing roughly 300 nodes.

I don't have this glTF model to reproduce the issue anymore, but I think the "caching" fix https://github.com/SaschaWillems/Vulkan-glTF-PBR/commit/2ac4de59e1f9957595270733422fa4f79ee2972c should work well, so closing the issue.