-
Notifications
You must be signed in to change notification settings - Fork 10
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
fix_IndexSwarmVariable #267
Conversation
Nice work Neng! Just a suggestion, would it be worth implementing something similar to the marker chain method? I.e. the material properties are taken at/close to the centre of the element (when degree = 0)? This would give us results to directly compare against and we know it works well in both mesh types |
Thanks, Ben. Yes, and it can be done by setting the proxy_continuous as False. Sth related to the marker chain method or level set method, I am thinking about: can we use some strategies like adaptive particle refinement in SPH (smoothed particle hydrodynamics) method to improve the performance in the particle-in-cell method, as mesh elements inside the materials and far away from the interface between different materials do not need so many particles in them, and near the interface we need more particles to better "describe" the interface. |
Nice one mate, good to know we can reproduce the MC method with the index swarm! SPH looks interesting, will be keen to see what you come up with |
I think the n-particles to nodes is consistent with what we do for our other mappings (eg. the evalf function). It might well be worth investigating other methods for mapping the properties but it would also make sense to use the existing PETSc functionality for this instead. Not sure I understand your comments about Marker Chain, Ben. Would we be able to use the same strategy for a swarm that is restricted to the interface ? |
1e5d32a
to
d499998
Compare
2ff32fd has introduced a fix in swarm.py that allows for two methods of assigning material properties. To call: Update Type Descriptions:
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think it is sensible to provide the additional options, as long as they default to the previous behaviour. I'll flag two things:
- The docstrings should go through a copy-editing step to make sure a typical user can understand what is intended (this is the dev branch so another issue can be raised after the merge)
- There is code repetition in the branching between different options. This is probably sensible in the dev phase (perhaps we will remove all the different options when we have done more testing) but, again, should not be merged to the release branches in this state.
Agree, and now the code includes several options available to users, such as the following:
I need to conduct more tests to determine the optimal suggestion settings for users. |
update two files
Test IndexSwarmVariable in getting the right value on the Symmetrical Points.
Vis the errors in the original code uw.swarm.IndexSwarmVariable._update(), and provide two methods to fix that.
The values on mesh_levelset nodes (for M_0 indicated by red, P=10.0, for M_1 indicated by blue, P=1.0)
The particles used to calculate the value on nodes 6 (blue) and 7 (red) (nodes 6 & 7 are the points in the middle of the left and right wall)
Need a further review of these two methods. They work fine for the structured box, but not well in the unstructured_irregular box.