Document how to set up and run OpenFoam for microfluidics cases to solve for vector velocity field with icoFoam and time-dependent analyte diffusion using scalarTransportFoam. Note that the latter case depends on already having the vector velocity field, which is what icoFoam solves for.
I am creating this repository primarily to aid my students in learning how to set up and use OpenFoam for our 3D printed microfluidics research. An example of our work can be found in the following open-access paper, Spatially and optically tailored 3D printing for highly miniaturized and integrated microfluidics, published in Nature Communications in 2021.
- Bash command line.
- Use bash commands and bash scripts to do almost everything for running OpenFoam simulations.
 
- Docker OpenFoam installation.
- Use to run OpenFoam without having to do lengthy and possibly difficult install to run natively on your operating system.
- Set up parabolicVelocityboundary condition to use for microfluidic velocity field simulations withicoFoam.
 
- Paraview.
- Use for 3D visualization and analysis.
 
- Python and jupyter lab/notebook
- Use for 2D visualization and analysis.
- Line scans.
- 2D planar scalar (concentration, pressure) and vector (velocity) field sampling.
 
- Directory and file organization.
- Make it easy to use git to save base cases to a github repository without saving massive data files generated by actual run cases.
 
- Make sure you have a bash shell (terminal app) on your computer.
- On Mac OS I use iTerm2.
- On Windows, you can use Windows Subsystem for Linux or git-bash, which is installed as part of Git for Windows.
- On Linux, use the native terminal app.
 
- Install Docker for your operating system.
- Get OpenFoam docker image. I assume use of Openfoam v2112.
- Mac OS M1/M2 processors:
- Follow openfoam-docker-arm
 
- Other OS's and Mac OS Intel processors:
 
- Mac OS M1/M2 processors:
- Install parabolicVelocityboundary condition into Docker OpenFoam installation. See boundary_conditions/README.md.
- Install Paraview.
- Install python/jupyterlab.
- The simplest method is to just install Anaconda python. This is the method I recommend.
- I've documented my preferred solution at Mac OS python setup, which may be more complicated than many people want to do, but it makes it easy for me to use virtual environments and keep my setup up-to-date without much hassle.
 
- Set up directory structure
OpenFOAM by default only works with 3D mesh elements so to run a 2D case (say in x-y), you need to create a 3D mesh where the mesh is only 1 cell thick in the z dimension, and the boundary type is set to empty for the top and bottom boundaries (+z and -z surface normals).
- Create 3D geometry with Openscad and save as STL file.
- Sort STL file faces and create new STL file with only those parts needed by cfMesh'scartesian2DMesh.
- Get velocity field.
- Set up velocity field case.
- Use cartesian2DMeshto create mesh from STL file.
- Run icoFoam
 
- Get time-dependent diffusion scalar field.
- Set up diffusion case.
- Copy mesh from velocity field case.
- Copy velocity field from velocity field case.
- Run scalarTransportFoam.
- Run postProcessto get line scans.
- Run postProcessto get velocity field and analyte concentration over a plane. Do this for specific time step(s).
 
- Visualize with ParaView.
- Analyze files created by postProcesswith python in jupyterlab.
cases/straight_channels/straight_channel_rotate_0deg → See bash commands in scripts/run_mesh_1_cases.txt.
cases/straight_channels/straight_channel_rotate_45deg See bash commands in scripts/run_mesh_1_cases.txt.
- Move analysisfor straight channel cases up one directory and update jupyter notebook accordingly.
- ✅ Consolidate mesh and icoFoamcases for straight channels.
- Add diffusion (scalarTransportFoam) cases for straight channels.
- Add Paraview screen saves for ✅ mesh, ✅ velocity field, and analyte concentration.
- ✅ Add linescans for velocity field using postProcess
- Analyze linescans in jupyter notebook.
- ✅ Add planar sampling of velocity field using postProcess
- Analyze planar sampling in jupyter notebook and create streamline plot.
- Add a READMEto straight channel cases directory?
- Include how to parallelize running a case locally?
- What case to use as an example, or use several cases?
- Straight channel.
- 45° rotated channel.
- Something more complicated?
 
TBD: insert instructions here.