mx-bluesky 1.5.4__py3-none-any.whl → 1.5.6__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) hide show
  1. mx_bluesky/_version.py +2 -2
  2. mx_bluesky/beamlines/i04/__init__.py +6 -1
  3. mx_bluesky/beamlines/i04/redis_to_murko_forwarder.py +2 -3
  4. mx_bluesky/beamlines/i04/thawing_plan.py +173 -59
  5. mx_bluesky/beamlines/i24/serial/blueapi_config.yaml +1 -1
  6. mx_bluesky/beamlines/i24/serial/dcid.py +4 -25
  7. mx_bluesky/beamlines/i24/serial/extruder/EX-gui-edm/DetStage.edl +4 -7
  8. mx_bluesky/beamlines/i24/serial/extruder/EX-gui-edm/DiamondExtruder-I24-py3v1.edl +5 -5
  9. mx_bluesky/beamlines/i24/serial/extruder/i24ssx_Extruder_Collect_py3v2.py +18 -107
  10. mx_bluesky/beamlines/i24/serial/fixed_target/FT-gui-edm/CustomChip_py3v1.edl +1 -1
  11. mx_bluesky/beamlines/i24/serial/fixed_target/FT-gui-edm/DetStage.edl +1 -4
  12. mx_bluesky/beamlines/i24/serial/fixed_target/FT-gui-edm/DiamondChipI24-py3v1.edl +13 -13
  13. mx_bluesky/beamlines/i24/serial/fixed_target/FT-gui-edm/MappingLite-oxford_py3v1.edl +8 -8
  14. mx_bluesky/beamlines/i24/serial/fixed_target/FT-gui-edm/pumpprobe-py3v1.edl +7 -7
  15. mx_bluesky/beamlines/i24/serial/fixed_target/i24ssx_Chip_Collect_py3v1.py +8 -92
  16. mx_bluesky/beamlines/i24/serial/fixed_target/i24ssx_Chip_Manager_py3v1.py +2 -18
  17. mx_bluesky/beamlines/i24/serial/parameters/constants.py +0 -2
  18. mx_bluesky/beamlines/i24/serial/parameters/experiment_parameters.py +1 -6
  19. mx_bluesky/beamlines/i24/serial/parameters/fixed_target/cs/cs_maker.json +3 -3
  20. mx_bluesky/beamlines/i24/serial/run_extruder.sh +15 -0
  21. mx_bluesky/beamlines/i24/serial/run_fixed_target.sh +17 -0
  22. mx_bluesky/beamlines/i24/serial/set_visit_directory.sh +1 -1
  23. mx_bluesky/beamlines/i24/serial/setup_beamline/__init__.py +1 -2
  24. mx_bluesky/beamlines/i24/serial/setup_beamline/pv.py +0 -25
  25. mx_bluesky/beamlines/i24/serial/setup_beamline/pv_abstract.py +1 -30
  26. mx_bluesky/beamlines/i24/serial/setup_beamline/setup_beamline.py +0 -94
  27. mx_bluesky/beamlines/i24/serial/setup_beamline/setup_detector.py +4 -10
  28. mx_bluesky/beamlines/i24/serial/setup_beamline/setup_zebra_plans.py +12 -20
  29. mx_bluesky/beamlines/i24/serial/web_gui_plans/general_plans.py +4 -13
  30. mx_bluesky/beamlines/i24/serial/write_nexus.py +34 -9
  31. mx_bluesky/common/experiment_plans/common_flyscan_xray_centre_plan.py +25 -2
  32. mx_bluesky/common/external_interaction/callbacks/common/ispyb_callback_base.py +1 -1
  33. mx_bluesky/common/external_interaction/callbacks/common/plan_reactive_callback.py +2 -2
  34. mx_bluesky/common/external_interaction/callbacks/xray_centre/ispyb_callback.py +2 -2
  35. mx_bluesky/common/external_interaction/callbacks/xray_centre/nexus_callback.py +2 -2
  36. mx_bluesky/common/parameters/components.py +1 -0
  37. mx_bluesky/hyperion/__main__.py +16 -3
  38. mx_bluesky/hyperion/baton_handler.py +78 -11
  39. mx_bluesky/hyperion/experiment_plans/load_centre_collect_full_plan.py +19 -8
  40. mx_bluesky/hyperion/external_interaction/agamemnon.py +6 -2
  41. mx_bluesky/hyperion/external_interaction/alerting/constants.py +2 -7
  42. mx_bluesky/hyperion/external_interaction/callbacks/rotation/ispyb_callback.py +2 -2
  43. mx_bluesky/hyperion/parameters/constants.py +1 -0
  44. mx_bluesky/hyperion/plan_runner.py +2 -4
  45. mx_bluesky/hyperion/plan_runner_api.py +43 -0
  46. {mx_bluesky-1.5.4.dist-info → mx_bluesky-1.5.6.dist-info}/METADATA +2 -2
  47. {mx_bluesky-1.5.4.dist-info → mx_bluesky-1.5.6.dist-info}/RECORD +51 -50
  48. {mx_bluesky-1.5.4.dist-info → mx_bluesky-1.5.6.dist-info}/WHEEL +0 -0
  49. {mx_bluesky-1.5.4.dist-info → mx_bluesky-1.5.6.dist-info}/entry_points.txt +0 -0
  50. {mx_bluesky-1.5.4.dist-info → mx_bluesky-1.5.6.dist-info}/licenses/LICENSE +0 -0
  51. {mx_bluesky-1.5.4.dist-info → mx_bluesky-1.5.6.dist-info}/top_level.txt +0 -0
@@ -4,7 +4,6 @@ This version in python3 new Feb2021 by RLO
4
4
  - March 21 added logging and Eiger functionality
5
5
  """
6
6
 
7
- import re
8
7
  import sys
9
8
  import time
10
9
  from datetime import datetime
@@ -23,13 +22,11 @@ from dodal.devices.i24.beamstop import Beamstop
23
22
  from dodal.devices.i24.dcm import DCM
24
23
  from dodal.devices.i24.dual_backlight import DualBacklight
25
24
  from dodal.devices.i24.focus_mirrors import FocusMirrorsMode
26
- from dodal.devices.i24.pilatus_metadata import PilatusMetadata
27
25
  from dodal.devices.motors import YZStage
28
26
  from dodal.devices.zebra.zebra import Zebra
29
27
 
30
28
  from mx_bluesky.beamlines.i24.serial.dcid import (
31
29
  DCID,
32
- get_pilatus_filename_template_from_device,
33
30
  read_beam_info_from_hardware,
34
31
  )
35
32
  from mx_bluesky.beamlines.i24.serial.log import (
@@ -40,9 +37,13 @@ from mx_bluesky.beamlines.i24.serial.log import (
40
37
  from mx_bluesky.beamlines.i24.serial.parameters import ExtruderParameters
41
38
  from mx_bluesky.beamlines.i24.serial.parameters.constants import (
42
39
  BEAM_CENTER_LUT_FILES,
43
- DetectorName,
44
40
  )
45
- from mx_bluesky.beamlines.i24.serial.setup_beamline import Pilatus, caget, caput, pv
41
+ from mx_bluesky.beamlines.i24.serial.setup_beamline import (
42
+ caget,
43
+ cagetstring,
44
+ caput,
45
+ pv,
46
+ )
46
47
  from mx_bluesky.beamlines.i24.serial.setup_beamline import setup_beamline as sup
47
48
  from mx_bluesky.beamlines.i24.serial.setup_beamline.setup_detector import (
48
49
  UnknownDetectorType,
@@ -89,7 +90,6 @@ def initialise_extruder(
89
90
  caput(pv.ioc13_gp9, 0)
90
91
  caput(pv.ioc13_gp10, 0)
91
92
  caput(pv.ioc13_gp15, det_type.name)
92
- caput(pv.pilat_cbftemplate, 0)
93
93
  SSX_LOGGER.info("Initialisation complete.")
94
94
  yield from bps.null()
95
95
 
@@ -109,19 +109,11 @@ def laser_check(
109
109
  resets the shutter mode to manual.
110
110
 
111
111
  WARNING. When using the laser with the extruder, some hardware changes need to be made.
112
- Because all four of the zebra ttl outputs are in use in this mode, when the \
113
- detector in use is the Eiger, the Pilatus cable is repurposed to trigger the light \
114
- source, and viceversa.
112
+ The cable previously used by Pilatus is repurposed to trigger the light source
115
113
  """
116
114
  SSX_LOGGER.debug(f"Laser check: {mode}")
117
115
 
118
- det_type = yield from get_detector_type(detector_stage)
119
-
120
- LASER_TTL = (
121
- zebra.mapping.outputs.TTL_EIGER
122
- if isinstance(det_type, Pilatus)
123
- else zebra.mapping.outputs.TTL_PILATUS
124
- )
116
+ LASER_TTL = zebra.mapping.outputs.TTL_PILATUS # Update with dodal changes
125
117
 
126
118
  if mode == "laseron":
127
119
  yield from bps.abs_set(
@@ -164,17 +156,6 @@ def read_parameters(detector_stage: YZStage, attenuator: ReadOnlyAttenuator):
164
156
  det_type = yield from get_detector_type(detector_stage)
165
157
  SSX_LOGGER.warning(f"DETECTOR TYPE: {det_type}")
166
158
  filename = caget(pv.ioc13_gp3)
167
- # If file name ends in a digit this causes processing/pilatus pain.
168
- # Append an underscore
169
- if det_type.name == "pilatus":
170
- m = re.search(r"\d+$", filename)
171
- if m is not None:
172
- # Note for future reference. Appending underscore causes more hassle and
173
- # high probability of users accidentally overwriting data. Use a dash
174
- filename = filename + "-"
175
- SSX_LOGGER.info(
176
- f"Requested filename ends in a number. Appended dash: {filename}"
177
- )
178
159
 
179
160
  transmission = yield from bps.rd(attenuator.actual_transmission)
180
161
 
@@ -216,7 +197,6 @@ def main_extruder_plan(
216
197
  parameters: ExtruderParameters,
217
198
  dcid: DCID,
218
199
  start_time: datetime,
219
- pilatus_metadata: PilatusMetadata,
220
200
  ) -> MsgGenerator:
221
201
  beam_center_pixels = sup.compute_beam_center_position_from_lut(
222
202
  BEAM_CENTER_LUT_FILES[parameters.detector_name],
@@ -245,57 +225,7 @@ def main_extruder_plan(
245
225
  SSX_LOGGER.debug(f"Filepath {filepath}")
246
226
  SSX_LOGGER.debug(f"Filename {parameters.filename}")
247
227
 
248
- if parameters.detector_name == "pilatus":
249
- SSX_LOGGER.info("Using pilatus mini cbf")
250
- caput(pv.pilat_cbftemplate, 0)
251
- SSX_LOGGER.info(f"Pilatus quickshot setup: filepath {filepath}")
252
- SSX_LOGGER.info(f"Pilatus quickshot setup: filepath {parameters.filename}")
253
- SSX_LOGGER.info(
254
- f"Pilatus quickshot setup: number of images {parameters.num_images}"
255
- )
256
- SSX_LOGGER.info(
257
- f"Pilatus quickshot setup: exposure time {parameters.exposure_time_s}"
258
- )
259
-
260
- if parameters.pump_status:
261
- SSX_LOGGER.info("Pump probe extruder data collection")
262
- SSX_LOGGER.info(f"Pump exposure time {parameters.laser_dwell_s}")
263
- SSX_LOGGER.info(f"Pump delay time {parameters.laser_delay_s}")
264
- yield from sup.pilatus(
265
- "fastchip",
266
- [
267
- filepath,
268
- parameters.filename,
269
- parameters.num_images,
270
- parameters.exposure_time_s,
271
- ],
272
- )
273
- yield from setup_zebra_for_extruder_with_pump_probe_plan(
274
- zebra,
275
- parameters.detector_name,
276
- parameters.exposure_time_s,
277
- parameters.num_images,
278
- parameters.laser_dwell_s,
279
- parameters.laser_delay_s,
280
- pulse1_delay=0.0,
281
- wait=True,
282
- )
283
- else:
284
- SSX_LOGGER.info("Static experiment: no photoexcitation")
285
- yield from sup.pilatus(
286
- "quickshot",
287
- [
288
- filepath,
289
- parameters.filename,
290
- parameters.num_images,
291
- parameters.exposure_time_s,
292
- ],
293
- )
294
- yield from setup_zebra_for_quickshot_plan(
295
- zebra, parameters.exposure_time_s, parameters.num_images, wait=True
296
- )
297
-
298
- elif parameters.detector_name == "eiger":
228
+ if parameters.detector_name == "eiger":
299
229
  SSX_LOGGER.info("Using Eiger detector")
300
230
 
301
231
  SSX_LOGGER.debug(f"Creating the directory for the collection in {filepath}.")
@@ -359,12 +289,10 @@ def main_extruder_plan(
359
289
  )
360
290
 
361
291
  # Do DCID creation BEFORE arming the detector
292
+ filetemplate = f"{parameters.filename}.nxs"
362
293
  if parameters.detector_name == "eiger":
363
- filetemplate = f"{parameters.filename}.nxs"
364
- else:
365
- filetemplate = yield from get_pilatus_filename_template_from_device(
366
- pilatus_metadata
367
- )
294
+ complete_filename = cagetstring(pv.eiger_ODfilenameRBV)
295
+ filetemplate = f"{complete_filename}.nxs"
368
296
  dcid.generate_dcid(
369
297
  beam_settings=beam_settings,
370
298
  image_dir=parameters.collection_directory.as_posix(),
@@ -377,10 +305,7 @@ def main_extruder_plan(
377
305
  # Collect
378
306
  SSX_LOGGER.info("Fast shutter opening")
379
307
  yield from open_fast_shutter(zebra)
380
- if parameters.detector_name == "pilatus":
381
- SSX_LOGGER.info("Pilatus acquire ON")
382
- caput(pv.pilat_acquire, 1)
383
- elif parameters.detector_name == "eiger":
308
+ if parameters.detector_name == "eiger":
384
309
  SSX_LOGGER.info("Triggering Eiger NOW")
385
310
  caput(pv.eiger_trigger, 1)
386
311
 
@@ -390,7 +315,7 @@ def main_extruder_plan(
390
315
  SSX_LOGGER.debug("Call nexgen server for nexus writing.")
391
316
  beam_x = yield from bps.rd(beam_center_device.beam_x)
392
317
  beam_y = yield from bps.rd(beam_center_device.beam_y)
393
- call_nexgen(
318
+ yield from call_nexgen(
394
319
  None,
395
320
  parameters,
396
321
  beam_settings.wavelength_in_a,
@@ -435,9 +360,7 @@ def collection_aborted_plan(
435
360
  """A plan to run in case the collection is aborted before the end."""
436
361
  SSX_LOGGER.warning("Data Collection Aborted")
437
362
  yield from disarm_zebra(zebra) # If aborted/timed out zebra still armed
438
- if detector_name == "pilatus":
439
- caput(pv.pilat_acquire, 0)
440
- elif detector_name == "eiger":
363
+ if detector_name == "eiger":
441
364
  caput(pv.eiger_acquire, 0)
442
365
  yield from bps.sleep(0.5)
443
366
  end_time = datetime.now()
@@ -462,9 +385,7 @@ def tidy_up_at_collection_end_plan(
462
385
  yield from reset_zebra_when_collection_done_plan(zebra)
463
386
 
464
387
  # Clean Up
465
- if parameters.detector_name == "pilatus":
466
- yield from sup.pilatus("return-to-normal", None)
467
- elif parameters.detector_name == "eiger":
388
+ if parameters.detector_name == "eiger":
468
389
  yield from sup.eiger("return-to-normal", None, dcm)
469
390
  SSX_LOGGER.debug(f"{parameters.filename}_{caget(pv.eiger_seqID)}")
470
391
  SSX_LOGGER.debug("End of Run")
@@ -478,10 +399,7 @@ def tidy_up_at_collection_end_plan(
478
399
  def collection_complete_plan(
479
400
  collection_directory: Path, detector_name: str, dcid: DCID
480
401
  ) -> MsgGenerator:
481
- if detector_name == "pilatus":
482
- SSX_LOGGER.info("Pilatus Acquire STOP")
483
- caput(pv.pilat_acquire, 0)
484
- elif detector_name == "eiger":
402
+ if detector_name == "eiger":
485
403
  SSX_LOGGER.info("Eiger Acquire STOP")
486
404
  caput(pv.eiger_acquire, 0)
487
405
  caput(pv.eiger_ODcapture, "Done")
@@ -506,8 +424,6 @@ def run_extruder_plan(
506
424
  mirrors: FocusMirrorsMode = inject("focus_mirrors"),
507
425
  attenuator: ReadOnlyAttenuator = inject("attenuator"),
508
426
  beam_center_eiger: DetectorBeamCenter = inject("eiger_bc"),
509
- beam_center_pilatus: DetectorBeamCenter = inject("pilatus_bc"),
510
- pilatus_metadata: PilatusMetadata = inject("pilatus_meta"),
511
427
  ) -> MsgGenerator:
512
428
  start_time = datetime.now()
513
429
  SSX_LOGGER.info(f"Collection start time: {start_time.ctime()}")
@@ -518,11 +434,7 @@ def run_extruder_plan(
518
434
  # Create collection directory
519
435
  parameters.collection_directory.mkdir(parents=True, exist_ok=True)
520
436
 
521
- beam_center_device = (
522
- beam_center_eiger
523
- if parameters.detector_name is DetectorName.EIGER
524
- else beam_center_pilatus
525
- )
437
+ beam_center_device = beam_center_eiger
526
438
 
527
439
  # DCID - not generated yet
528
440
  dcid = DCID(emit_errors=False, expt_params=parameters)
@@ -541,7 +453,6 @@ def run_extruder_plan(
541
453
  parameters=parameters,
542
454
  dcid=dcid,
543
455
  start_time=start_time,
544
- pilatus_metadata=pilatus_metadata,
545
456
  ),
546
457
  except_plan=lambda e: (
547
458
  yield from collection_aborted_plan(zebra, parameters.detector_name, dcid)
@@ -690,7 +690,7 @@ botShadowColor index 11
690
690
  font "arial-medium-r-18.0"
691
691
  numCmds 1
692
692
  command {
693
- 0 "blueapi -c CONFIG_LOCATION controller run cs_reset '\{\"pmac\":\"pmac\"\}'"
693
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION cs_reset '\{\"pmac\":\"pmac\"\}'"
694
694
  }
695
695
  endObjectProperties
696
696
 
@@ -83,15 +83,12 @@ font "arial-medium-r-18.0"
83
83
  numItems 2
84
84
  symbolTag {
85
85
  0 "Eiger"
86
- 1 "Pilatus"
87
86
  }
88
87
  symbol0 {
89
88
  0 "E9M"
90
- 1 "P6M"
91
89
  }
92
90
  PV0 {
93
91
  0 "eiger"
94
- 1 "pilatus"
95
92
  }
96
93
  endObjectProperties
97
94
 
@@ -113,7 +110,7 @@ font "arial-medium-r-18.0"
113
110
  buttonLabel "Move Stage"
114
111
  numCmds 1
115
112
  command {
116
- 0 "blueapi -c CONFIG_LOCATION controller run setup_detector_stage '\{\"expt_type\":\"Serial Fixed\"\}'"
113
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION setup_detector_stage '\{\"expt_type\":\"Serial Fixed\"\}'"
117
114
  }
118
115
  endObjectProperties
119
116
 
@@ -280,7 +280,7 @@ botShadowColor index 14
280
280
  font "arial-medium-r-18.0"
281
281
  numCmds 1
282
282
  command {
283
- 0 "blueapi -c CONFIG_LOCATION controller run moveto_preset '\{\"place\":\"load_position\"\}'"
283
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION moveto_preset '\{\"place\":\"load_position\"\}'"
284
284
  }
285
285
  endObjectProperties
286
286
 
@@ -301,7 +301,7 @@ botShadowColor index 14
301
301
  font "arial-medium-r-18.0"
302
302
  numCmds 1
303
303
  command {
304
- 0 "blueapi -c CONFIG_LOCATION controller run moveto_preset '\{\"place\":\"collect_position\"\}'"
304
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION moveto_preset '\{\"place\":\"collect_position\"\}'"
305
305
  }
306
306
  endObjectProperties
307
307
 
@@ -323,7 +323,7 @@ font "helvetica-bold-r-24.0"
323
323
  buttonLabel "Start"
324
324
  numCmds 1
325
325
  command {
326
- 0 "blueapi -c CONFIG_LOCATION controller run run_fixed_target_plan"
326
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION run_fixed_target_plan"
327
327
  }
328
328
  endObjectProperties
329
329
 
@@ -615,7 +615,7 @@ botShadowColor index 14
615
615
  font "arial-medium-r-18.0"
616
616
  numCmds 1
617
617
  command {
618
- 0 "blueapi -c CONFIG_LOCATION controller run cs_maker"
618
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION cs_maker"
619
619
  }
620
620
  endObjectProperties
621
621
 
@@ -1157,7 +1157,7 @@ botShadowColor index 14
1157
1157
  font "arial-medium-r-18.0"
1158
1158
  numCmds 1
1159
1159
  command {
1160
- 0 "blueapi -c CONFIG_LOCATION controller run initialise_stages"
1160
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION initialise_stages"
1161
1161
  }
1162
1162
  endObjectProperties
1163
1163
 
@@ -1538,7 +1538,7 @@ botShadowColor index 14
1538
1538
  font "arial-medium-r-18.0"
1539
1539
  numCmds 1
1540
1540
  command {
1541
- 0 "blueapi -c CONFIG_LOCATION controller run block_check"
1541
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION block_check"
1542
1542
  }
1543
1543
  endObjectProperties
1544
1544
 
@@ -2912,7 +2912,7 @@ font "helvetica-medium-r-18.0"
2912
2912
  buttonLabel "Set Fiducial 2"
2913
2913
  numCmds 1
2914
2914
  command {
2915
- 0 "blueapi -c CONFIG_LOCATION controller run fiducial '\{\"point\":\"2\"\}'"
2915
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION fiducial '\{\"point\":\"2\"\}'"
2916
2916
  }
2917
2917
  endObjectProperties
2918
2918
 
@@ -2934,7 +2934,7 @@ font "helvetica-medium-r-18.0"
2934
2934
  buttonLabel "Goto Fiducial 2"
2935
2935
  numCmds 1
2936
2936
  command {
2937
- 0 "blueapi -c CONFIG_LOCATION controller run moveto '\{\"place\":\"f2\"\}'"
2937
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION moveto '\{\"place\":\"f2\"\}'"
2938
2938
  }
2939
2939
  endObjectProperties
2940
2940
 
@@ -2978,7 +2978,7 @@ font "helvetica-medium-r-18.0"
2978
2978
  buttonLabel "Set Fiducial 1"
2979
2979
  numCmds 1
2980
2980
  command {
2981
- 0 "blueapi -c CONFIG_LOCATION controller run fiducial '\{\"point\":\"1\"\}'"
2981
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION fiducial '\{\"point\":\"1\"\}'"
2982
2982
  }
2983
2983
  endObjectProperties
2984
2984
 
@@ -3000,7 +3000,7 @@ font "helvetica-medium-r-18.0"
3000
3000
  buttonLabel "Goto Fiducial 1"
3001
3001
  numCmds 1
3002
3002
  command {
3003
- 0 "blueapi -c CONFIG_LOCATION controller run moveto '\{\"place\":\"f1\"\}'"
3003
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION moveto '\{\"place\":\"f1\"\}'"
3004
3004
  }
3005
3005
  endObjectProperties
3006
3006
 
@@ -3555,7 +3555,7 @@ x 595
3555
3555
  y 360
3556
3556
  w 280
3557
3557
  h 20
3558
- controlPv "BL24I-MO-IOC-01:GP100"
3558
+ controlPv "BL24I-MO-IOC-13:GP100"
3559
3559
  font "arial-medium-r-16.0"
3560
3560
  fgColor index 25
3561
3561
  bgColor index 7
@@ -3731,7 +3731,7 @@ botShadowColor index 14
3731
3731
  font "arial-medium-r-18.0"
3732
3732
  numCmds 1
3733
3733
  command {
3734
- 0 "blueapi -c CONFIG_LOCATION controller run moveto '\{\"place\":\"zero\"\}'"
3734
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION moveto '\{\"place\":\"zero\"\}'"
3735
3735
  }
3736
3736
  endObjectProperties
3737
3737
 
@@ -3773,7 +3773,7 @@ botShadowColor index 14
3773
3773
  font "arial-medium-r-18.0"
3774
3774
  numCmds 1
3775
3775
  command {
3776
- 0 "blueapi -c CONFIG_LOCATION controller run moveto_preset '\{\"place\":\"microdrop_position\"\}'"
3776
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION moveto_preset '\{\"place\":\"microdrop_position\"\}'"
3777
3777
  }
3778
3778
  endObjectProperties
3779
3779
 
@@ -40,7 +40,7 @@ font "helvetica-medium-r-14.0"
40
40
  buttonLabel "Load Map File"
41
41
  numCmds 1
42
42
  command {
43
- 0 "blueapi -c CONFIG_LOCATION controller run load_lite_map"
43
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION load_lite_map"
44
44
  }
45
45
  endObjectProperties
46
46
 
@@ -2124,7 +2124,7 @@ botShadowColor index 11
2124
2124
  font "arial-medium-r-18.0"
2125
2125
  numCmds 1
2126
2126
  command {
2127
- 0 "blueapi -c CONFIG_LOCATION controller run load_stock_map '\{\"map_choice\":\"clear\"\}'"
2127
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION load_stock_map '\{\"map_choice\":\"clear\"\}'"
2128
2128
  }
2129
2129
  endObjectProperties
2130
2130
 
@@ -2145,7 +2145,7 @@ botShadowColor index 11
2145
2145
  font "arial-medium-r-18.0"
2146
2146
  numCmds 1
2147
2147
  command {
2148
- 0 "blueapi -c CONFIG_LOCATION controller run load_stock_map '\{\"map_choice\":\"x88\"\}'"
2148
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION load_stock_map '\{\"map_choice\":\"x88\"\}'"
2149
2149
  }
2150
2150
  endObjectProperties
2151
2151
 
@@ -2232,7 +2232,7 @@ botShadowColor index 11
2232
2232
  font "arial-medium-r-18.0"
2233
2233
  numCmds 1
2234
2234
  command {
2235
- 0 "blueapi -c CONFIG_LOCATION controller run load_stock_map '\{\"map_choice\":\"x66\"\}'"
2235
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION load_stock_map '\{\"map_choice\":\"x66\"\}'"
2236
2236
  }
2237
2237
  endObjectProperties
2238
2238
 
@@ -2290,7 +2290,7 @@ botShadowColor index 11
2290
2290
  font "arial-medium-r-18.0"
2291
2291
  numCmds 1
2292
2292
  command {
2293
- 0 "blueapi -c CONFIG_LOCATION controller run load_stock_map '\{\"map_choice\":\"x44\"\}'"
2293
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION load_stock_map '\{\"map_choice\":\"x44\"\}'"
2294
2294
  }
2295
2295
  endObjectProperties
2296
2296
 
@@ -2366,7 +2366,7 @@ font "helvetica-medium-r-18.0"
2366
2366
  buttonLabel "Define Chip In PMAC"
2367
2367
  numCmds 1
2368
2368
  command {
2369
- 0 "blueapi -c CONFIG_LOCATION controller run define_current_chip '\{\"chipid\":\"oxford\",\"pmac\":\"pmac\"\}'"
2369
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION define_current_chip '\{\"chipid\":\"oxford\",\"pmac\":\"pmac\"\}'"
2370
2370
  }
2371
2371
  endObjectProperties
2372
2372
 
@@ -2522,7 +2522,7 @@ botShadowColor index 11
2522
2522
  font "arial-medium-r-18.0"
2523
2523
  numCmds 1
2524
2524
  command {
2525
- 0 "blueapi -c CONFIG_LOCATION controller run load_stock_map '\{\"map_choice\":\"half1\"\}'"
2525
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION load_stock_map '\{\"map_choice\":\"half1\"\}'"
2526
2526
  }
2527
2527
  endObjectProperties
2528
2528
 
@@ -2601,7 +2601,7 @@ botShadowColor index 11
2601
2601
  font "arial-medium-r-18.0"
2602
2602
  numCmds 1
2603
2603
  command {
2604
- 0 "blueapi -c CONFIG_LOCATION controller run load_stock_map '\{\"map_choice\":\"half2\"\}'"
2604
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION load_stock_map '\{\"map_choice\":\"half2\"\}'"
2605
2605
  }
2606
2606
  endObjectProperties
2607
2607
 
@@ -160,7 +160,7 @@ botShadowColor index 11
160
160
  font "arial-medium-r-18.0"
161
161
  numCmds 1
162
162
  command {
163
- 0 "blueapi -c CONFIG_LOCATION controller run pumpprobe_calc"
163
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION pumpprobe_calc"
164
164
  }
165
165
  endObjectProperties
166
166
 
@@ -707,7 +707,7 @@ botShadowColor index 14
707
707
  font "arial-medium-r-18.0"
708
708
  numCmds 1
709
709
  command {
710
- 0 "blueapi -c CONFIG_LOCATION controller run laser_control '\{\"laser_setting\":\"laser1off\",\"pmac\":\"pmac\"\}'"
710
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION laser_control '\{\"laser_setting\":\"laser1off\",\"pmac\":\"pmac\"\}'"
711
711
  }
712
712
  endObjectProperties
713
713
 
@@ -749,7 +749,7 @@ botShadowColor index 14
749
749
  font "arial-medium-r-18.0"
750
750
  numCmds 1
751
751
  command {
752
- 0 "blueapi -c CONFIG_LOCATION controller run laser_control '\{\"laser_setting\":\"laser1on\",\"pmac\":\"pmac\"\}'"
752
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION laser_control '\{\"laser_setting\":\"laser1on\",\"pmac\":\"pmac\"\}'"
753
753
  }
754
754
  endObjectProperties
755
755
 
@@ -976,7 +976,7 @@ botShadowColor index 14
976
976
  font "arial-medium-r-18.0"
977
977
  numCmds 1
978
978
  command {
979
- 0 "blueapi -c CONFIG_LOCATION controller run laser_control '\{\"laser_setting\":\"laser2off\",\"pmac\":\"pmac\"\}'"
979
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION laser_control '\{\"laser_setting\":\"laser2off\",\"pmac\":\"pmac\"\}'"
980
980
  }
981
981
  endObjectProperties
982
982
 
@@ -1018,7 +1018,7 @@ botShadowColor index 14
1018
1018
  font "arial-medium-r-18.0"
1019
1019
  numCmds 1
1020
1020
  command {
1021
- 0 "blueapi -c CONFIG_LOCATION controller run laser_control '\{\"laser_setting\":\"laser2on\",\"pmac\":\"pmac\"\}'"
1021
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION laser_control '\{\"laser_setting\":\"laser2on\",\"pmac\":\"pmac\"\}'"
1022
1022
  }
1023
1023
  endObjectProperties
1024
1024
 
@@ -1334,7 +1334,7 @@ botShadowColor index 14
1334
1334
  font "arial-medium-r-18.0"
1335
1335
  numCmds 1
1336
1336
  command {
1337
- 0 "blueapi -c CONFIG_LOCATION controller run laser_control '\{\"laser_setting\":\"laser1burn\",\"pmac\":\"pmac\"\}'"
1337
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION laser_control '\{\"laser_setting\":\"laser1burn\",\"pmac\":\"pmac\"\}'"
1338
1338
  }
1339
1339
  endObjectProperties
1340
1340
 
@@ -1376,7 +1376,7 @@ botShadowColor index 14
1376
1376
  font "arial-medium-r-18.0"
1377
1377
  numCmds 1
1378
1378
  command {
1379
- 0 "blueapi -c CONFIG_LOCATION controller run laser_control '\{\"laser_setting\":\"laser2burn\",\"pmac\":\"pmac\"\}'"
1379
+ 0 "blueapi -c CONFIG_LOCATION controller run -i $INSTRUMENT_SESSION laser_control '\{\"laser_setting\":\"laser2burn\",\"pmac\":\"pmac\"\}'"
1380
1380
  }
1381
1381
  endObjectProperties
1382
1382