Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature/iterative #59

Open
wants to merge 7 commits into
base: v1
Choose a base branch
from
Open

Conversation

avalero
Copy link

@avalero avalero commented Jul 23, 2019

The addTriangles recursive function gives a heap size exceeded exception when computing BSP over meshes with many triangles (max recursivility exceeded).

I have transformed the BSP Tree creation to an iterative function addTrianglesIterative(), so that it does not give that problem.

@avalero
Copy link
Author

avalero commented Jul 24, 2019

Same problem with the creation of the BSP occurrs when serializing BSP to buffer. It was a recursive function. Now serialization and deserialization of arraybuffer is iterative (non recursive).

Tests passed.

@avalero
Copy link
Author

avalero commented Jul 25, 2019

@chandlerprall after extensive benchmarking iterative algorithm is slowler than recursive. Recursive version (current version) reaches maximum recursivity (both in Chrome and Firefox) as soon as meshes have many triangles.

I have not managed to get the same speed with v1 that I get with master branch version (with iterative algrorithm, choosing triangles[0] as divider and lowing EPSILON to 1e-5)

The WASM version needs to be iterative (for same reason) and again, computation time is greater than master branch algorithm (although faster than js v1)

These are my conclusions. We (bitbloq) will stick to master branch algorithm by now, and keep on working on v1 around november (we have a planned release on october).

@chandlerprall
Copy link
Owner

Thanks for the feedback, and the PRs! It's really strange that the iterative approach is slower, I'll try to find some time to dig into that.

I believe main difference now between master and v1 is that master tracks polygons while v1 sticks to triangles, which would cause additional computations. My decision to change that aspect may need to be rolled back, if it is the cause of degraded performance.

@avalero
Copy link
Author

avalero commented Sep 17, 2019

Hi,
I have been testing the iterative methods, and in fact they are not slowler. I got slowler results because of a change I did in my code to adapt to iterative (sorry for the confussion). So it would be safe to accept PR.

In any case, as you said, maybe it's worth going back to triangles, as v1 keeps being slowler than master.

Also, in case you want to stick with recursion, this reading might be interesting (I have not tested it myself) https://medium.com/openmindonline/js-monday-06-adopting-memory-safe-recursion-d26dcee409c9

@johncalvinyoung
Copy link

@avalero you working on a WASM port? Is that direct crosscompilation from Typescript, or in C/CPP or Rust or something?

@avalero
Copy link
Author

avalero commented Sep 19, 2019

@johncalvinyoung is C++,

It's far from being production ready, but I got it to make some basic CSG operations. Then I got problems with stack (at the end you have a recursive js function). I should port it to iterative and check performance.

My problem was that the cost (in time) of serializing and deserializing the geometries from js -> wasm and from wasm -> js . At then end, the time spent de/serlializing geometries dit not allow to get an overall better computation time (which was my main goal).

You can check the code here https://github.com/avalero/wasmCSG

@johncalvinyoung
Copy link

@avalero that's really cool. I took a quick look, and got it to build locally. Been working on another port of CSG stuff to WASM (albeit an existing CPP port of CSG.js) and didn't get correct results, sadly. So I'll take a look at yours.

@avalero
Copy link
Author

avalero commented Sep 19, 2019

Well, it would be just great if can make it work. And I am sure @chandlerprall could also help, at the end, it's his algorithm.
You can find two branches: develop is based on this master repo. feature/v1 is based on this v1 repo branch.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants