From 0d7af9bbf02c34557c7fdb106ecab63c009672fc Mon Sep 17 00:00:00 2001
From: Adam Frisby
Date: Sun, 22 Jul 2007 02:42:29 +0000
Subject: * Added Navier Stokes computational fluid dynamics algorithms to
libTerrain.Channel.
---
.../Channel/Manipulators/NavierStokes.cs | 33 +++++++++++++++++++++-
1 file changed, 32 insertions(+), 1 deletion(-)
(limited to 'OpenSim/Region/Terrain.BasicTerrain/libTerrainBSD')
diff --git a/OpenSim/Region/Terrain.BasicTerrain/libTerrainBSD/Channel/Manipulators/NavierStokes.cs b/OpenSim/Region/Terrain.BasicTerrain/libTerrainBSD/Channel/Manipulators/NavierStokes.cs
index df42487..f01b2860 100644
--- a/OpenSim/Region/Terrain.BasicTerrain/libTerrainBSD/Channel/Manipulators/NavierStokes.cs
+++ b/OpenSim/Region/Terrain.BasicTerrain/libTerrainBSD/Channel/Manipulators/NavierStokes.cs
@@ -220,9 +220,40 @@ namespace libTerrain
}
}
- private void nsSimulate(int N, int rounds, double dt, double diff, double visc, double force, double source)
+ private void nsSimulate(int N, int rounds, double dt, double diff, double visc)
{
+ int size = (N * 2) * (N * 2);
+ double[] u = new double[size]; // Force, X axis
+ double[] v = new double[size]; // Force, Y axis
+ double[] u_prev = new double[size];
+ double[] v_prev = new double[size];
+ double[] dens = (double[])map.Clone();
+ double[] dens_prev = (double[])map.Clone();
+
+ for (int i = 0; i < rounds; i++)
+ {
+ u_prev = u;
+ v_prev = v;
+ dens_prev = dens;
+
+ nsVelStep(N, ref u, ref v, ref u_prev, ref v_prev, visc, dt);
+ nsDensStep(N, ref dens, ref dens_prev, ref u, ref v, diff, dt);
+ }
+
+ nsBufferToDoubles(ref dens, N, ref this.map);
+ }
+
+ ///
+ /// Performs computational fluid dynamics on a channel
+ ///
+ /// The number of steps to perform (Recommended: 20)
+ /// Delta Time - The time between steps
+ /// Fluid diffusion rate
+ /// Fluid viscosity
+ public void navierStokes(int rounds, double dt, double diff, double visc)
+ {
+ nsSimulate(this.h, rounds, dt, diff, visc);
}
}
}
\ No newline at end of file
--
cgit v1.1