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

flex 1.2 #6

Open
digitalwannabe opened this issue Jun 9, 2018 · 3 comments
Open

flex 1.2 #6

digitalwannabe opened this issue Jun 9, 2018 · 3 comments

Comments

@digitalwannabe
Copy link

hey, great project and very readable code, thanks for sharing!
I'm wondering if there are any plans on supporting the newest flex version (1.2)? I'm trying to share the resulting buffers on the gpu without reading it to the cpu, but I've found that others had problems doing so with 1.1, eg here: https://devtalk.nvidia.com/default/topic/1002238/physx-and-physics-modeling/-flex-direct3d11-get-set-buffer-issues/

Also I wonder if there is a specific reason why this is 64bit only, apart from performance issues?

thank you

@HeinzBenjamin
Copy link
Owner

HeinzBenjamin commented Jul 10, 2018

Hello there,
thanks a lot. Currently I don't plan to shift to 1.2 as I don't have enough time.
I actually never had the issues discussed in the thread you shared. Did you already try reading the buffers? Did it work?
I didn't chose x64-only support for a particular reason. I simply thought more people had x64 machines at this point and didn't manage to do both yet. If there's demand I can share an x86 version too. Would you need that?
Best
Ben

@digitalwannabe
Copy link
Author

hey ben, thanks for coming back to me.

I have tinkered quite a lot with your repo and did get sharing buffers on gpu to work in general- I had to add a second constructor for your Flex class, which accepts a pointer to the context of my app's renderer (I'm using vvvv), so I could create a dx11 buffer on that context, which I then registered with flex using NvFlexRegisterD3DBuffer....I did get back the particle positions, but I didn't try any further, as the original poster in the link above is the guy who has written the vvvv renderer I'm working with- if he didn't succeed, I surely won't. Also, as I found out now, the changelog for 1.2 states "Add support for device NvFlexBuffers on D3D" http://physxinfo.com/news/12866/nvidia-flex-1-2-0-is-released/ - so I assume they are just not fully supported before....

Anyways, in the meantime I've made all the necessary changes to your code to support version 1.2, no implementation of new features, only a port of the existing code; it compiles fine, however, for some reason vvvv doesn't find the new NvFlex....dlls. Not sure what's going on, but I think/hope it's unrelated to the actual code- if you find time you can see if it works for you:
https://github.com/digitalwannabe/FlexCLI

here's the minimal changes which would need to be reflected in grasshopper nodes:

Parameters:
-no more "isFluid" (set via new featureMode enum, which is not exposed to the user yet)
-no more plasticThreshold/plasticCreep, now part of each rigid
-no more SortAxis (don't know where it's gone)

plasticThreshold and plasticCreep; 2 more inputs for
-RegisterSoftBody
-SetRigids
-RegisterCustomConstraints

internal changes:

  • new SolverDescription, 2 new values, maxContactsPerParticle and featureMode, set to constant values atm
  • NvFlexUpdateTriangleMesh has been changed to a float4 Buffer as input, I have changed FlexCollisionGeometry accordingly

I have tried to mark all my changes to the original code with //dw

best
clemens

@digitalwannabe
Copy link
Author

digitalwannabe commented Jul 11, 2018

I forgot one more change, I have replaced GetRigidTransforms with GetRigids- it can now give back new rest positions/normals due to plastic deformations, also some other stuff which I believe is not necessary (offset, indices, stiffness, threhold, creep)....best

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

No branches or pull requests

2 participants