-
Notifications
You must be signed in to change notification settings - Fork 56
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
Error in results for spatially varying material property #23
Comments
In JAX-FEM, you may have variable parameters up to each quadrature. Is this function helpful for your case? Lines 712 to 731 in 55115e4
|
Hello, thank you for recommending this function. It does perform the desired task; however, I noticed that the final displacement field differs from the benchmark results. For example, the maximum displacement in the y-direction is 0.447056 mm with JAX, while it is 0.447335 mm from the benchmark. I have also cross-verified the cell values returned by the function, and they are identical to the benchmark values. Below is a MWE. It would be great if you could review it and provide additional insights.
|
What benchmark FEM software did you use? I think this is highly likely due to difference choices of linear solver as well as associated tolerance setting. For example, on my machine, I get the displacement to be 0.44705704246529027 with JAX solver, and 0.44626012034961243 with the PETSc solver (set |
I am using a custom-written MATLAB FEM solver as the benchmark. You're right, the difference in results might be due to the type of solver I have used and the associated tolerance settings. However, when I use a homogeneous property distribution, the results match up to five significant digits. Any thoughts? |
For homogeneous property distribution your final linear system will be better conditioned, so the solving will be easier and it matches for 5 digits for different solvers. But for inhomogeneous problems, the matrix will be worse conditioned, which will be harder for different solvers, hence they have different level of performance. |
That makes sense. Thank you. Another question, if one would need to provide hessian information to the optimizer, how to create a wrapper for that? I tried the following:
but got the following error: can't apply forward-mode autodiff (jvp) to a custom_vjp function. Got similar error while using |
Please allow us some time to implement this feature. @SNMS95 previously worked on this. There is an experimental version that you can play with jax-am/jax_am/fem/autodiff_utils.py Line 38 in 814384e
Should be able to provide you with higher order derivatives. |
Hi @tianjuxue, I have been working on solving a 2D elasticity problem under harmonic loading with spatially dependent material parameters. I was able to assemble the stiffness and mass matrices successfully. While the mass matrix is correct, the values in stiffness matrix are coming out to be less than the desired values. I have compared the stiffness matrix with an in-house MATLAB FEM solver. The values for the shape function and their gradients, JxW etc are consistent with the MATLAB based solver. I also checked the values for stiffness matrix with homogeneous material properties and error still persists. I have attached a screenshot for the same. |
JAX-FEM is well tested and compared with other software, e.g., FEniCS for stiffness matrix value, particularly for linear elastic problems. When compared with Abaqus, we indeed found a difference in the stiffness matrix, but the final solutions are the same. I am pinning @jiachenguoNU here, who has experience over this issue. |
Thank you @tianjuxue, for the clarification. I will double-check my stiffness matrix and compare the same with FEniCS as well. @jiachenguoNU: Any leads on this would be very helpful. |
Hi @tianjuxue, I was using the incorrect constitutive model, leading to a difference in the stiffness matrix. The values now match with that of the benchmark as well as FEniCS. Next, I was trying to solve the same problem but with a nonlinear material model (Neo-Hookean). Initially, I successfully solved the 3D cylinder problem and validated the displacement field against a benchmark (COMSOL). However, when I applied the same approach to a 2D problem, same as solved earlier with linear elasticity, the results were inaccurate. Although the solver converged, the displacement in the y-direction was way too large (max value: 14.58 mm). Attached below is the MWE of the same:
Could you please check it once? |
Hello, I am attempting to solve a 2D plane strain boundary value problem using a linear elastic material with Young's modulus that varies spatially, expressed as E = E(x,y) or E(nodes). I have used 'QUAD4' as element type. The basis functions utilized for the solution are assumed to support the Young's modulus. Below is the code I have employed to convert the values from nodes to the elements:
When I used a uniform material parameter distribution
(param = 0.01*np.ones((len(problem.flex_inds), 1)))
, the results matched those from a benchmark study. However, when I introduced a spatially varying (heterogeneous) distribution for the material parameter, the accuracy of the results decreased.I attempted to find solutions in existing examples, but most of them assumed that the varying field had a constant value within each element, which does not apply to my case.
I would appreciate any guidance or suggestions to identify where I might have made errors in my implementation for handling the spatially varying material parameter and to improve the accuracy of the results.
The text was updated successfully, but these errors were encountered: