aboutsummaryrefslogtreecommitdiff
path: root/lid_driven_cavity/opencl/common.py
diff options
context:
space:
mode:
authorAdrian Kummerlaender2019-11-06 21:24:08 +0100
committerAdrian Kummerlaender2019-11-06 21:26:03 +0100
commit4610b50bfe47ed0d75f30279fca69d0dcdc04ee2 (patch)
treec005d06da21bd1d383b4d1df330f8aa8838976f1 /lid_driven_cavity/opencl/common.py
parent527e8aa9c33d7c82b548b2280c979f653a7131ae (diff)
downloadboltzgen_examples-4610b50bfe47ed0d75f30279fca69d0dcdc04ee2.tar
boltzgen_examples-4610b50bfe47ed0d75f30279fca69d0dcdc04ee2.tar.gz
boltzgen_examples-4610b50bfe47ed0d75f30279fca69d0dcdc04ee2.tar.bz2
boltzgen_examples-4610b50bfe47ed0d75f30279fca69d0dcdc04ee2.tar.lz
boltzgen_examples-4610b50bfe47ed0d75f30279fca69d0dcdc04ee2.tar.xz
boltzgen_examples-4610b50bfe47ed0d75f30279fca69d0dcdc04ee2.tar.zst
boltzgen_examples-4610b50bfe47ed0d75f30279fca69d0dcdc04ee2.zip
Add basic AA pattern support for OpenCL example
Diffstat (limited to 'lid_driven_cavity/opencl/common.py')
-rw-r--r--lid_driven_cavity/opencl/common.py36
1 files changed, 36 insertions, 0 deletions
diff --git a/lid_driven_cavity/opencl/common.py b/lid_driven_cavity/opencl/common.py
new file mode 100644
index 0000000..717c68f
--- /dev/null
+++ b/lid_driven_cavity/opencl/common.py
@@ -0,0 +1,36 @@
+import pyopencl as cl
+mf = cl.mem_flags
+
+import numpy
+
+import matplotlib
+matplotlib.use('AGG')
+import matplotlib.pyplot as plt
+
+
+class CellList:
+ def __init__(self, context, queue, float_type, cells):
+ self.cl_cells = cl.Buffer(context, mf.READ_ONLY, size=len(cells) * numpy.uint32(0).nbytes)
+ self.np_cells = numpy.ndarray(shape=(len(cells), 1), dtype=numpy.uint32)
+ self.np_cells[:,0] = cells[:]
+
+ cl.enqueue_copy(queue, self.cl_cells, self.np_cells).wait();
+
+ def get(self):
+ return self.cl_cells
+
+ def size(self):
+ return (len(self.np_cells), 1, 1)
+
+def generate_moment_plots(lattice, moments):
+ for i, m in enumerate(moments):
+ print("Generating plot %d of %d." % (i+1, len(moments)))
+
+ gid = lattice.memory.gid
+ velocity = numpy.reshape(
+ [ numpy.sqrt(m[gid(x,y)*3+1]**2 + m[gid(x,y)*3+2]**2) for x, y in lattice.geometry.inner_cells() ],
+ lattice.geometry.inner_size())
+
+ plt.figure(figsize=(10, 10))
+ plt.imshow(velocity, origin='lower', cmap=plt.get_cmap('seismic'))
+ plt.savefig("result/ldc_2d_%02d.png" % i, bbox_inches='tight', pad_inches=0)