opencl_fdtd/README.md

48 lines
1.5 KiB
Markdown
Raw Normal View History

2016-05-30 22:43:14 -07:00
# opencl_fdtd
2016-03-30 15:00:00 -07:00
2016-05-30 22:43:14 -07:00
**opencl_fdtd** is a python application for running 3D time-domain
2016-04-13 04:01:45 -07:00
electromagnetic simulations on parallel compute hardware (mainly GPUs).
2016-03-30 15:00:00 -07:00
**Performance** highly depends on what hardware you have available:
* A 395x345x73 cell simulation (~10 million points, 8-cell absorbing boundaries)
runs at around 42 iterations/sec. on my Nvidia GTX 580.
* On my laptop (Nvidia 940M) the same simulation achieves ~8 iterations/sec.
* An L3 photonic crystal cavity ringdown simulation (1550nm source, 40nm
discretization, 8000 steps) takes about 5 minutes on my laptop.
**Capabilities** are currently pretty minimal:
* Absorbing boundaries (CPML)
* Conducting boundaries (PMC)
2016-05-30 22:41:06 -07:00
* Anisotropic media (eps_xx, eps_yy, eps_zz, mu_xx, ...)
2016-03-30 15:00:00 -07:00
* Direct access to fields (eg., you can trivially add a soft or hard
current source with just sim.E[1] += sin(f0 * t), or save any portion
of a field to a file)
## Installation
**Requirements:**
* python 3 (written and tested with 3.5)
* numpy
* pyopencl
* h5py (for file output)
* [gridlock](https://mpxd.net/gogs/jan/gridlock)
* [masque](https://mpxd.net/gogs/jan/masque)
2016-04-13 04:01:45 -07:00
To get the code, just clone this repository:
2016-04-13 04:00:08 -07:00
```bash
2016-05-30 22:41:06 -07:00
git clone https://mpxd.net/gogs/jan/opencl_fdtd.git
2016-04-13 04:00:08 -07:00
```
2016-03-30 15:00:00 -07:00
You can install the requirements and their dependencies easily with
```bash
2016-04-13 04:00:27 -07:00
pip install -r requirements.txt
2016-03-30 15:06:10 -07:00
```
## Running
The root directory contains ``fdtd.py``, which sets up and runs a sample simulation
(cavity ringdown).
```bash
python3 fdtd.py
2016-04-13 04:00:08 -07:00
```