aboutsummaryrefslogtreecommitdiff
path: root/scripts/move-entire-detector
diff options
context:
space:
mode:
Diffstat (limited to 'scripts/move-entire-detector')
-rwxr-xr-xscripts/move-entire-detector41
1 files changed, 38 insertions, 3 deletions
diff --git a/scripts/move-entire-detector b/scripts/move-entire-detector
index ffd6120f..9e31a281 100755
--- a/scripts/move-entire-detector
+++ b/scripts/move-entire-detector
@@ -21,13 +21,14 @@ op.add_argument('--output', dest='ofn', metavar='output.geom',
help="Output geometry file")
op.add_argument('--pixels', action='store_true', dest='px',
- help="Indicates that the shifts are in pixel units")
+ help="Indicates that the x and y shifts are in pixel units. "
+ "The z shift is always in millimeters")
op.add_argument('--mm', action='store_false', dest='px',
help="Indicates that the shifts are in millimeters (this is the default)")
op.add_argument('--beam', action='store_true', dest='beam',
- help="Shift the X-ray beam rather than the detector")
+ help="Shift the X-ray beam rather than the detector (reverses x and y shifts)")
op.add_argument('--detector', action='store_false', dest='beam',
help="Shift the detector rather than the X-ray beam. This is the default.")
@@ -41,6 +42,9 @@ op.add_argument('xshift', type=float, metavar='XXX',
op.add_argument('yshift', type=float, metavar='YYY',
help="The shift in the y direction")
+op.add_argument('zshift', type=float, metavar='ZZZ',
+ help="The shift in the z direction")
+
args = op.parse_args()
if not args.ofn:
@@ -59,7 +63,7 @@ else:
bm = 'detector'
print('Input filename {}\nOutput filename {}'.format(args.ifn,out))
-print('Shifting {} by {},{} {}'.format(bm, args.xshift, args.yshift, units))
+print('Shifting {} by {},{},{} {}'.format(bm, args.xshift, args.yshift, args.zshift, units))
if args.beam:
args.xshift = -args.xshift
@@ -68,12 +72,17 @@ if args.beam:
f = open(args.ifn, 'r')
h = open(out, 'w')
panel_resolutions = {}
+panels = []
+panels_have_coffset = []
prog1 = re.compile("^\s*res\s+=\s+([0-9\.]+)\s")
prog2 = re.compile("^\s*(.*)\/res\s+=\s+([0-9\.]+)\s")
prog3 = re.compile("^\s*(.*)\/corner_x\s+=\s+([0-9\.\-]+)\s")
prog4 = re.compile("^\s*(.*)\/corner_y\s+=\s+([0-9\.\-]+)\s")
+prog5 = re.compile("^\s*(.*)\/coffset\s+=\s+([0-9\.\-]+)\s")
+prog6 = re.compile("^\s*coffset\s+=\s+([0-9\.]+)\s")
default_res = 0
+default_coffset = None
while True:
fline = f.readline()
@@ -86,6 +95,12 @@ while True:
h.write(fline)
continue
+ match = prog6.match(fline)
+ if match:
+ default_coffset = float(match.group(1))
+ h.write("coffset = %f\n" % (default_coffset+args.zshift))
+ continue
+
match = prog2.match(fline)
if match:
panel = match.group(1)
@@ -98,6 +113,14 @@ while True:
match = prog3.match(fline)
if match:
panel = match.group(1)
+ if panel not in panels:
+ panels.append(panel)
+
+ # If we have a default coffset, this panel has a coffset
+ # (which has already been adjusted)
+ if default_coffset is not None:
+ panels_have_coffset.append(panel)
+
panel_cnx = float(match.group(2))
if panel in panel_resolutions:
res = panel_resolutions[panel]
@@ -127,8 +150,20 @@ while True:
h.write('%s/corner_y = %f\n' % (panel,panel_cny+(args.yshift*res*1e-3)))
continue
+ match = prog5.match(fline)
+ if match:
+ panel = match.group(1)
+ panel_coffset = float(match.group(2))
+ h.write('%s/coffset = %f\n' % (panel,panel_coffset+args.zshift*1e-3))
+ panels_have_coffset.append(panel)
+ continue
+
h.write(fline)
+h.write("\n")
+for p in [n for n in panels if n not in panels_have_coffset]:
+ h.write("%s/coffset = %f\n" % (p, args.zshift*1e-3))
+
f.close()
h.close()