aboutsummaryrefslogtreecommitdiff
path: root/lid_driven_cavity/cpp/generate.py
diff options
context:
space:
mode:
Diffstat (limited to 'lid_driven_cavity/cpp/generate.py')
-rwxr-xr-xlid_driven_cavity/cpp/generate.py40
1 files changed, 40 insertions, 0 deletions
diff --git a/lid_driven_cavity/cpp/generate.py b/lid_driven_cavity/cpp/generate.py
new file mode 100755
index 0000000..4222e98
--- /dev/null
+++ b/lid_driven_cavity/cpp/generate.py
@@ -0,0 +1,40 @@
+#!/usr/bin/env python
+
+import argparse
+
+from boltzgen import LBM, Generator, Geometry
+from boltzgen.lbm.model import D2Q9
+
+import config
+
+argparser = argparse.ArgumentParser(
+ description = 'Generate a C++ implementation of a lid driven cavity simulation using LBM')
+argparser.add_argument(
+ '--output', required = False, help = 'Target directory for the generated sources')
+
+args = argparser.parse_args()
+
+lbm = LBM(config.descriptor)
+generator = Generator(
+ descriptor = config.descriptor,
+ moments = lbm.moments(),
+ collision = lbm.bgk(f_eq = lbm.equilibrium(), tau = config.tau),
+ target = 'cpp',
+ precision = config.precision,
+ index = 'XYZ',
+ layout = 'AOS')
+
+if args.output is None:
+ args.output = '.'
+
+functions = ['collide_and_stream', 'equilibrilize', 'collect_moments', 'momenta_boundary']
+
+with open('%s/kernel.h' % args.output, 'w') as kernel:
+ kernel.write(generator.kernel(config.geometry, functions))
+
+ldc_src = ''
+with open('ldc.cpp.mako', 'r') as template:
+ ldc_src = template.read()
+
+with open('%s/ldc.cpp' % args.output, 'w') as app:
+ app.write(generator.custom(config.geometry, ldc_src))