Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Interpolating a scalar field in a 3D space

I have a 3D space (x, y, z) with an additional parameter at each point (energy), giving 4 dimensions of data in total.

I would like to find a set of x, y, z points which correspond to an iso-energy surface found by interpolating between the known points.

The spacial mesh has constant spacing and surrounds the iso-energy surface entirely, however, it does not occupy a cubic space (the mesh occupies a roughly cylindrical space)

Speed is not crucial, I can leave this number crunching for a while. Although I'm coding in Python and NumPy, I can write portions of the code in FORTRAN. I can also wrap existing C/C++/FORTRAN libraries for use in the scripts, if such libraries exist.

All examples and algorithms that I have so far found online (and in Numerical Recipes) stop short of 4D data.

like image 480
Brendan Avatar asked Dec 28 '09 23:12

Brendan


1 Answers

There are quite a few options here...

In order to get your energy into your mesh, you'll need to use some form of interpolation. Shepard's method is a common, and reasonably simple, method to implement, and tends to work well if your data distribution is reasonable.

Once you have that done, you'll need to do some form of isosurface generation.

There are some libraries out there to make this easy. Most notably, VTK includes python wrappers and has all of the tools required to do both of these steps.

For details on how this could be done in VTK, you can check vtkShepardMethod and vtkContourFilter.

like image 184
Reed Copsey Avatar answered Sep 29 '22 17:09

Reed Copsey