summaryrefslogtreecommitdiff
path: root/test/test_generator_vertex.py
diff options
context:
space:
mode:
authorStan Seibert <stan@mtrr.org>2011-09-19 14:36:13 -0400
committerStan Seibert <stan@mtrr.org>2011-09-19 14:36:13 -0400
commita21b05e4727403e2e061234289af9e60e6022e5a (patch)
tree7a7d4c5809c370f3e542cfc8cb0bec7c2e4f5cdc /test/test_generator_vertex.py
parentcfecff941fc619eb7269128afc62d9c11ae78aff (diff)
parenta38c56ff1e268298568077af7f03c8ac64c6fb82 (diff)
downloadchroma-a21b05e4727403e2e061234289af9e60e6022e5a.tar.gz
chroma-a21b05e4727403e2e061234289af9e60e6022e5a.tar.bz2
chroma-a21b05e4727403e2e061234289af9e60e6022e5a.zip
merge relayout branch
Diffstat (limited to 'test/test_generator_vertex.py')
-rw-r--r--test/test_generator_vertex.py23
1 files changed, 23 insertions, 0 deletions
diff --git a/test/test_generator_vertex.py b/test/test_generator_vertex.py
new file mode 100644
index 0000000..cec363d
--- /dev/null
+++ b/test/test_generator_vertex.py
@@ -0,0 +1,23 @@
+import unittest
+import itertools
+import numpy as np
+import chroma.generator.vertex
+
+class TestParticleGun(unittest.TestCase):
+ def test_constant_particle_gun_center(self):
+ '''Generate electron vertices at the center of the world volume.'''
+ vertex = chroma.generator.vertex.constant_particle_gun('e-', (0,0,0), (1,0,0), 100)
+ for ev in itertools.islice(vertex, 100):
+ self.assertEquals(ev.primary_vertex.particle_name, 'e-')
+ self.assertTrue(np.allclose(ev.primary_vertex.pos, [0,0,0]))
+ self.assertTrue(np.allclose(ev.primary_vertex.dir, [1,0,0]))
+ self.assertTrue(np.allclose(ev.primary_vertex.ke, 100))
+
+ def test_off_center(self):
+ '''Generate electron vertices at (1,0,0) in the world volume.'''
+ vertex = chroma.generator.vertex.constant_particle_gun('e-', (1,0,0), (1,0,0), 100)
+ for ev in itertools.islice(vertex, 100):
+ self.assertEquals(ev.primary_vertex.particle_name, 'e-')
+ self.assertTrue(np.allclose(ev.primary_vertex.pos, [1,0,0]))
+ self.assertTrue(np.allclose(ev.primary_vertex.dir, [1,0,0]))
+ self.assertTrue(np.allclose(ev.primary_vertex.ke, 100))