cgse 2023.38.0__py3-none-any.whl → 2024.1.4__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 (653) hide show
  1. README.md +27 -0
  2. bump.py +85 -0
  3. cgse-2024.1.4.dist-info/METADATA +38 -0
  4. cgse-2024.1.4.dist-info/RECORD +5 -0
  5. {cgse-2023.38.0.dist-info → cgse-2024.1.4.dist-info}/WHEEL +1 -2
  6. cgse-2023.38.0.dist-info/COPYING +0 -674
  7. cgse-2023.38.0.dist-info/COPYING.LESSER +0 -165
  8. cgse-2023.38.0.dist-info/METADATA +0 -144
  9. cgse-2023.38.0.dist-info/RECORD +0 -649
  10. cgse-2023.38.0.dist-info/entry_points.txt +0 -75
  11. cgse-2023.38.0.dist-info/top_level.txt +0 -2
  12. egse/__init__.py +0 -12
  13. egse/__main__.py +0 -32
  14. egse/aeu/aeu.py +0 -5235
  15. egse/aeu/aeu_awg.yaml +0 -265
  16. egse/aeu/aeu_crio.yaml +0 -273
  17. egse/aeu/aeu_cs.py +0 -626
  18. egse/aeu/aeu_devif.py +0 -321
  19. egse/aeu/aeu_main_ui.py +0 -912
  20. egse/aeu/aeu_metrics.py +0 -131
  21. egse/aeu/aeu_protocol.py +0 -463
  22. egse/aeu/aeu_psu.yaml +0 -204
  23. egse/aeu/aeu_ui.py +0 -873
  24. egse/aeu/arbdata/FccdRead.arb +0 -2
  25. egse/aeu/arbdata/FccdRead_min_points.arb +0 -2
  26. egse/aeu/arbdata/HeaterSync_FccdRead.arb +0 -2
  27. egse/aeu/arbdata/HeaterSync_ccdRead25.arb +0 -2
  28. egse/aeu/arbdata/HeaterSync_ccdRead31_25.arb +0 -2
  29. egse/aeu/arbdata/HeaterSync_ccdRead37_50.arb +0 -2
  30. egse/aeu/arbdata/HeaterSync_ccdRead43_75.arb +0 -2
  31. egse/aeu/arbdata/HeaterSync_ccdRead50.arb +0 -2
  32. egse/aeu/arbdata/Heater_FccdRead_min_points.arb +0 -2
  33. egse/aeu/arbdata/ccdRead25.arb +0 -2
  34. egse/aeu/arbdata/ccdRead25_150ms.arb +0 -2
  35. egse/aeu/arbdata/ccdRead31_25.arb +0 -2
  36. egse/aeu/arbdata/ccdRead31_25_150ms.arb +0 -2
  37. egse/aeu/arbdata/ccdRead37_50.arb +0 -2
  38. egse/aeu/arbdata/ccdRead37_50_150ms.arb +0 -2
  39. egse/aeu/arbdata/ccdRead43_75.arb +0 -2
  40. egse/aeu/arbdata/ccdRead43_75_150ms.arb +0 -2
  41. egse/aeu/arbdata/ccdRead50.arb +0 -2
  42. egse/aeu/arbdata/ccdRead50_150ms.arb +0 -2
  43. egse/alert/__init__.py +0 -1049
  44. egse/alert/alertman.yaml +0 -37
  45. egse/alert/alertman_cs.py +0 -234
  46. egse/alert/alertman_ui.py +0 -603
  47. egse/alert/gsm/beaglebone.py +0 -138
  48. egse/alert/gsm/beaglebone.yaml +0 -51
  49. egse/alert/gsm/beaglebone_cs.py +0 -108
  50. egse/alert/gsm/beaglebone_devif.py +0 -130
  51. egse/alert/gsm/beaglebone_protocol.py +0 -48
  52. egse/bits.py +0 -318
  53. egse/camera.py +0 -44
  54. egse/collimator/__init__.py +0 -0
  55. egse/collimator/fcul/__init__.py +0 -0
  56. egse/collimator/fcul/ogse.py +0 -1077
  57. egse/collimator/fcul/ogse.yaml +0 -14
  58. egse/collimator/fcul/ogse_cs.py +0 -154
  59. egse/collimator/fcul/ogse_devif.py +0 -358
  60. egse/collimator/fcul/ogse_protocol.py +0 -129
  61. egse/collimator/fcul/ogse_sim.py +0 -431
  62. egse/collimator/fcul/ogse_ui.py +0 -1108
  63. egse/command.py +0 -699
  64. egse/config.py +0 -410
  65. egse/confman/__init__.py +0 -1015
  66. egse/confman/confman.yaml +0 -67
  67. egse/confman/confman_cs.py +0 -239
  68. egse/confman/confman_ui.py +0 -381
  69. egse/confman/setup_ui.py +0 -565
  70. egse/control.py +0 -442
  71. egse/coordinates/__init__.py +0 -531
  72. egse/coordinates/avoidance.py +0 -103
  73. egse/coordinates/cslmodel.py +0 -127
  74. egse/coordinates/laser_tracker_to_dict.py +0 -120
  75. egse/coordinates/point.py +0 -707
  76. egse/coordinates/pyplot.py +0 -195
  77. egse/coordinates/referenceFrame.py +0 -1279
  78. egse/coordinates/refmodel.py +0 -737
  79. egse/coordinates/rotationMatrix.py +0 -85
  80. egse/coordinates/transform3d_addon.py +0 -419
  81. egse/csl/__init__.py +0 -50
  82. egse/csl/commanding.py +0 -78
  83. egse/csl/icons/hexapod-connected-selected.svg +0 -30
  84. egse/csl/icons/hexapod-connected.svg +0 -30
  85. egse/csl/icons/hexapod-homing-selected.svg +0 -68
  86. egse/csl/icons/hexapod-homing.svg +0 -68
  87. egse/csl/icons/hexapod-retract-selected.svg +0 -56
  88. egse/csl/icons/hexapod-retract.svg +0 -51
  89. egse/csl/icons/hexapod-zero-selected.svg +0 -56
  90. egse/csl/icons/hexapod-zero.svg +0 -56
  91. egse/csl/icons/logo-puna.svg +0 -92
  92. egse/csl/icons/stop.svg +0 -1
  93. egse/csl/initialisation.py +0 -102
  94. egse/csl/mech_pos_settings.yaml +0 -18
  95. egse/das.py +0 -1247
  96. egse/das.yaml +0 -7
  97. egse/data/conf/SETUP_CSL_00000_170620_150000.yaml +0 -5
  98. egse/data/conf/SETUP_CSL_00001_170620_151010.yaml +0 -69
  99. egse/data/conf/SETUP_CSL_00002_170620_151020.yaml +0 -69
  100. egse/data/conf/SETUP_CSL_00003_170620_151030.yaml +0 -69
  101. egse/data/conf/SETUP_CSL_00004_170620_151040.yaml +0 -69
  102. egse/data/conf/SETUP_CSL_00005_170620_151050.yaml +0 -69
  103. egse/data/conf/SETUP_CSL_00006_170620_151060.yaml +0 -69
  104. egse/data/conf/SETUP_CSL_00007_170620_151070.yaml +0 -69
  105. egse/data/conf/SETUP_CSL_00008_170620_151080.yaml +0 -75
  106. egse/data/conf/SETUP_CSL_00010_210308_083016.yaml +0 -138
  107. egse/data/conf/SETUP_INTA_00000_170620_150000.yaml +0 -4
  108. egse/data/conf/SETUP_SRON_00000_170620_150000.yaml +0 -4
  109. egse/decorators.py +0 -415
  110. egse/device.py +0 -269
  111. egse/dpu/__init__.py +0 -2681
  112. egse/dpu/ccd_ui.py +0 -508
  113. egse/dpu/dpu.py +0 -786
  114. egse/dpu/dpu.yaml +0 -153
  115. egse/dpu/dpu_cs.py +0 -272
  116. egse/dpu/dpu_ui.py +0 -668
  117. egse/dpu/fitsgen.py +0 -2077
  118. egse/dpu/fitsgen_test.py +0 -752
  119. egse/dpu/fitsgen_ui.py +0 -399
  120. egse/dpu/hdf5_model.py +0 -332
  121. egse/dpu/hdf5_ui.py +0 -277
  122. egse/dpu/hdf5_viewer.py +0 -506
  123. egse/dpu/hk_ui.py +0 -468
  124. egse/dpu_commands.py +0 -81
  125. egse/dsi/constants.py +0 -220
  126. egse/dsi/esl.py +0 -870
  127. egse/dsi/rmap.py +0 -1042
  128. egse/dsi/rmapci.py +0 -37
  129. egse/dsi/spw.py +0 -154
  130. egse/dsi/spw_state.py +0 -29
  131. egse/dummy.py +0 -258
  132. egse/dyndummy.py +0 -179
  133. egse/env.py +0 -278
  134. egse/exceptions.py +0 -88
  135. egse/fdir/__init__.py +0 -28
  136. egse/fdir/fdir_manager.py +0 -85
  137. egse/fdir/fdir_manager.yaml +0 -51
  138. egse/fdir/fdir_manager_controller.py +0 -228
  139. egse/fdir/fdir_manager_cs.py +0 -164
  140. egse/fdir/fdir_manager_interface.py +0 -25
  141. egse/fdir/fdir_remote.py +0 -73
  142. egse/fdir/fdir_remote.yaml +0 -37
  143. egse/fdir/fdir_remote_controller.py +0 -50
  144. egse/fdir/fdir_remote_cs.py +0 -97
  145. egse/fdir/fdir_remote_interface.py +0 -14
  146. egse/fdir/fdir_remote_popup.py +0 -31
  147. egse/fee/__init__.py +0 -114
  148. egse/fee/f_fee_register.yaml +0 -43
  149. egse/fee/fee.py +0 -631
  150. egse/fee/feesim.py +0 -750
  151. egse/fee/n_fee_hk.py +0 -761
  152. egse/fee/nfee.py +0 -187
  153. egse/filterwheel/__init__.py +0 -4
  154. egse/filterwheel/eksma/__init__.py +0 -24
  155. egse/filterwheel/eksma/fw8smc4.py +0 -661
  156. egse/filterwheel/eksma/fw8smc4.yaml +0 -121
  157. egse/filterwheel/eksma/fw8smc4_cs.py +0 -144
  158. egse/filterwheel/eksma/fw8smc4_devif.py +0 -473
  159. egse/filterwheel/eksma/fw8smc4_protocol.py +0 -81
  160. egse/filterwheel/eksma/fw8smc4_ui.py +0 -940
  161. egse/filterwheel/eksma/fw8smc5.py +0 -111
  162. egse/filterwheel/eksma/fw8smc5.yaml +0 -105
  163. egse/filterwheel/eksma/fw8smc5_controller.py +0 -307
  164. egse/filterwheel/eksma/fw8smc5_cs.py +0 -141
  165. egse/filterwheel/eksma/fw8smc5_interface.py +0 -65
  166. egse/filterwheel/eksma/fw8smc5_simulator.py +0 -29
  167. egse/filterwheel/eksma/fw8smc5_ui.py +0 -1068
  168. egse/filterwheel/eksma/testpythonfw.py +0 -215
  169. egse/fov/__init__.py +0 -65
  170. egse/fov/fov_hk.py +0 -712
  171. egse/fov/fov_ui.py +0 -861
  172. egse/fov/fov_ui_controller.py +0 -140
  173. egse/fov/fov_ui_model.py +0 -200
  174. egse/fov/fov_ui_view.py +0 -345
  175. egse/gimbal/__init__.py +0 -32
  176. egse/gimbal/symetrie/__init__.py +0 -26
  177. egse/gimbal/symetrie/alpha.py +0 -586
  178. egse/gimbal/symetrie/generic_gimbal_ui.py +0 -1521
  179. egse/gimbal/symetrie/gimbal.py +0 -877
  180. egse/gimbal/symetrie/gimbal.yaml +0 -168
  181. egse/gimbal/symetrie/gimbal_cs.py +0 -183
  182. egse/gimbal/symetrie/gimbal_protocol.py +0 -135
  183. egse/gimbal/symetrie/gimbal_ui.py +0 -361
  184. egse/gimbal/symetrie/pmac.py +0 -1006
  185. egse/gimbal/symetrie/pmac_regex.py +0 -83
  186. egse/graph.py +0 -132
  187. egse/gui/__init__.py +0 -47
  188. egse/gui/buttons.py +0 -378
  189. egse/gui/focalplane.py +0 -1281
  190. egse/gui/formatter.py +0 -10
  191. egse/gui/led.py +0 -162
  192. egse/gui/limitswitch.py +0 -143
  193. egse/gui/mechanisms.py +0 -588
  194. egse/gui/states.py +0 -148
  195. egse/gui/stripchart.py +0 -729
  196. egse/gui/switch.py +0 -112
  197. egse/h5.py +0 -274
  198. egse/help/__init__.py +0 -0
  199. egse/help/help_ui.py +0 -126
  200. egse/hexapod/__init__.py +0 -32
  201. egse/hexapod/symetrie/__init__.py +0 -138
  202. egse/hexapod/symetrie/alpha.py +0 -874
  203. egse/hexapod/symetrie/dynalpha.py +0 -1387
  204. egse/hexapod/symetrie/hexapod_ui.py +0 -1516
  205. egse/hexapod/symetrie/pmac.py +0 -1010
  206. egse/hexapod/symetrie/pmac_regex.py +0 -83
  207. egse/hexapod/symetrie/puna.py +0 -1167
  208. egse/hexapod/symetrie/puna.yaml +0 -193
  209. egse/hexapod/symetrie/puna_cs.py +0 -196
  210. egse/hexapod/symetrie/puna_protocol.py +0 -131
  211. egse/hexapod/symetrie/puna_ui.py +0 -434
  212. egse/hexapod/symetrie/punaplus.py +0 -107
  213. egse/hexapod/symetrie/zonda.py +0 -872
  214. egse/hexapod/symetrie/zonda.yaml +0 -337
  215. egse/hexapod/symetrie/zonda_cs.py +0 -172
  216. egse/hexapod/symetrie/zonda_devif.py +0 -415
  217. egse/hexapod/symetrie/zonda_protocol.py +0 -119
  218. egse/hexapod/symetrie/zonda_ui.py +0 -449
  219. egse/hk.py +0 -765
  220. egse/icons/aeu-cs-start.svg +0 -117
  221. egse/icons/aeu-cs-stop.svg +0 -118
  222. egse/icons/aeu-cs.svg +0 -107
  223. egse/icons/aeu_cs-started.svg +0 -112
  224. egse/icons/aeu_cs-stopped.svg +0 -112
  225. egse/icons/aeu_cs.svg +0 -55
  226. egse/icons/alert.svg +0 -1
  227. egse/icons/arrow-double-left.png +0 -0
  228. egse/icons/arrow-double-right.png +0 -0
  229. egse/icons/arrow-up.svg +0 -11
  230. egse/icons/backward.svg +0 -1
  231. egse/icons/busy.svg +0 -1
  232. egse/icons/cleaning.svg +0 -115
  233. egse/icons/color-scheme.svg +0 -1
  234. egse/icons/cs-connected-alert.svg +0 -91
  235. egse/icons/cs-connected-disabled.svg +0 -43
  236. egse/icons/cs-connected.svg +0 -89
  237. egse/icons/cs-not-connected.svg +0 -44
  238. egse/icons/double-left-arrow.svg +0 -1
  239. egse/icons/double-right-arrow.svg +0 -1
  240. egse/icons/erase-disabled.svg +0 -19
  241. egse/icons/erase.svg +0 -59
  242. egse/icons/fitsgen-start.svg +0 -47
  243. egse/icons/fitsgen-stop.svg +0 -48
  244. egse/icons/fitsgen.svg +0 -1
  245. egse/icons/forward.svg +0 -1
  246. egse/icons/fov-hk-start.svg +0 -33
  247. egse/icons/fov-hk-stop.svg +0 -37
  248. egse/icons/fov-hk.svg +0 -1
  249. egse/icons/front-desk.svg +0 -1
  250. egse/icons/home-actioned.svg +0 -15
  251. egse/icons/home-disabled.svg +0 -15
  252. egse/icons/home.svg +0 -13
  253. egse/icons/info.svg +0 -1
  254. egse/icons/invalid.png +0 -0
  255. egse/icons/led-green.svg +0 -20
  256. egse/icons/led-grey.svg +0 -20
  257. egse/icons/led-orange.svg +0 -20
  258. egse/icons/led-red.svg +0 -20
  259. egse/icons/led-square-green.svg +0 -134
  260. egse/icons/led-square-grey.svg +0 -134
  261. egse/icons/led-square-orange.svg +0 -134
  262. egse/icons/led-square-red.svg +0 -134
  263. egse/icons/limit-switch-all-green.svg +0 -115
  264. egse/icons/limit-switch-all-red.svg +0 -117
  265. egse/icons/limit-switch-el+.svg +0 -116
  266. egse/icons/limit-switch-el-.svg +0 -117
  267. egse/icons/location-marker.svg +0 -1
  268. egse/icons/logo-dpu.svg +0 -48
  269. egse/icons/logo-gimbal.svg +0 -112
  270. egse/icons/logo-huber.svg +0 -23
  271. egse/icons/logo-ogse.svg +0 -31
  272. egse/icons/logo-puna.svg +0 -92
  273. egse/icons/logo-tcs.svg +0 -29
  274. egse/icons/logo-zonda.svg +0 -66
  275. egse/icons/maximize.svg +0 -1
  276. egse/icons/meter.svg +0 -1
  277. egse/icons/more.svg +0 -45
  278. egse/icons/n-fee-hk-start.svg +0 -24
  279. egse/icons/n-fee-hk-stop.svg +0 -25
  280. egse/icons/n-fee-hk.svg +0 -83
  281. egse/icons/observing-off.svg +0 -46
  282. egse/icons/observing-on.svg +0 -46
  283. egse/icons/open-document-hdf5.png +0 -0
  284. egse/icons/open-document-hdf5.svg +0 -21
  285. egse/icons/ops-mode.svg +0 -1
  286. egse/icons/play-green.svg +0 -17
  287. egse/icons/plugged-disabled.svg +0 -27
  288. egse/icons/plugged.svg +0 -21
  289. egse/icons/pm_ui.svg +0 -1
  290. egse/icons/power-button-green.svg +0 -27
  291. egse/icons/power-button-red.svg +0 -27
  292. egse/icons/power-button.svg +0 -27
  293. egse/icons/radar.svg +0 -1
  294. egse/icons/radioactive.svg +0 -2
  295. egse/icons/reload.svg +0 -1
  296. egse/icons/remote-control-off.svg +0 -28
  297. egse/icons/remote-control-on.svg +0 -28
  298. egse/icons/repeat-blue.svg +0 -15
  299. egse/icons/repeat.svg +0 -1
  300. egse/icons/settings.svg +0 -1
  301. egse/icons/shrink.svg +0 -1
  302. egse/icons/shutter.svg +0 -1
  303. egse/icons/sign-off.svg +0 -1
  304. egse/icons/sign-on.svg +0 -1
  305. egse/icons/sim-mode.svg +0 -1
  306. egse/icons/small-buttons-go.svg +0 -20
  307. egse/icons/small-buttons-minus.svg +0 -51
  308. egse/icons/small-buttons-plus.svg +0 -51
  309. egse/icons/sponge.svg +0 -220
  310. egse/icons/start-button-disabled.svg +0 -84
  311. egse/icons/start-button.svg +0 -50
  312. egse/icons/stop-button-disabled.svg +0 -84
  313. egse/icons/stop-button.svg +0 -50
  314. egse/icons/stop-red.svg +0 -17
  315. egse/icons/stop.svg +0 -1
  316. egse/icons/switch-disabled-square.svg +0 -87
  317. egse/icons/switch-disabled.svg +0 -15
  318. egse/icons/switch-off-square.svg +0 -87
  319. egse/icons/switch-off.svg +0 -72
  320. egse/icons/switch-on-square.svg +0 -87
  321. egse/icons/switch-on.svg +0 -61
  322. egse/icons/temperature-control.svg +0 -44
  323. egse/icons/th_ui_logo.svg +0 -1
  324. egse/icons/unplugged.svg +0 -23
  325. egse/icons/unvalid.png +0 -0
  326. egse/icons/user-interface.svg +0 -1
  327. egse/icons/vacuum.svg +0 -1
  328. egse/icons/valid.png +0 -0
  329. egse/icons/zoom-to-pixel-dark.svg +0 -64
  330. egse/icons/zoom-to-pixel-white.svg +0 -36
  331. egse/images/big-rotation-stage.png +0 -0
  332. egse/images/connected-100.png +0 -0
  333. egse/images/cross.svg +0 -6
  334. egse/images/disconnected-100.png +0 -0
  335. egse/images/gui-icon.png +0 -0
  336. egse/images/home.svg +0 -6
  337. egse/images/info-icon.png +0 -0
  338. egse/images/led-black.svg +0 -89
  339. egse/images/led-green.svg +0 -85
  340. egse/images/led-orange.svg +0 -85
  341. egse/images/led-red.svg +0 -85
  342. egse/images/load-icon.png +0 -0
  343. egse/images/load-setup.png +0 -0
  344. egse/images/load.png +0 -0
  345. egse/images/pause.png +0 -0
  346. egse/images/play-button.svg +0 -8
  347. egse/images/play.png +0 -0
  348. egse/images/process-status.png +0 -0
  349. egse/images/restart.png +0 -0
  350. egse/images/search.png +0 -0
  351. egse/images/sma.png +0 -0
  352. egse/images/start.png +0 -0
  353. egse/images/stop-button.svg +0 -8
  354. egse/images/stop.png +0 -0
  355. egse/images/switch-off.svg +0 -48
  356. egse/images/switch-on.svg +0 -48
  357. egse/images/undo.png +0 -0
  358. egse/images/update-button.svg +0 -11
  359. egse/imageviewer/exposureselection.py +0 -475
  360. egse/imageviewer/imageviewer.py +0 -198
  361. egse/imageviewer/matchfocalplane.py +0 -179
  362. egse/imageviewer/subfieldposition.py +0 -133
  363. egse/lampcontrol/__init__.py +0 -4
  364. egse/lampcontrol/beaglebone/beaglebone.py +0 -178
  365. egse/lampcontrol/beaglebone/beaglebone.yaml +0 -62
  366. egse/lampcontrol/beaglebone/beaglebone_cs.py +0 -106
  367. egse/lampcontrol/beaglebone/beaglebone_devif.py +0 -150
  368. egse/lampcontrol/beaglebone/beaglebone_protocol.py +0 -73
  369. egse/lampcontrol/energetiq/__init__.py +0 -22
  370. egse/lampcontrol/energetiq/eq99.yaml +0 -98
  371. egse/lampcontrol/energetiq/lampEQ99.py +0 -283
  372. egse/lampcontrol/energetiq/lampEQ99_cs.py +0 -128
  373. egse/lampcontrol/energetiq/lampEQ99_devif.py +0 -158
  374. egse/lampcontrol/energetiq/lampEQ99_encode_decode_errors.py +0 -73
  375. egse/lampcontrol/energetiq/lampEQ99_protocol.py +0 -69
  376. egse/lampcontrol/energetiq/lampEQ99_ui.py +0 -465
  377. egse/lib/CentOS-7/EtherSpaceLink_v34_86.dylib +0 -0
  378. egse/lib/CentOS-8/ESL-RMAP_v34_86.dylib +0 -0
  379. egse/lib/CentOS-8/EtherSpaceLink_v34_86.dylib +0 -0
  380. egse/lib/Debian/ESL-RMAP_v34_86.dylib +0 -0
  381. egse/lib/Debian/EtherSpaceLink_v34_86.dylib +0 -0
  382. egse/lib/Debian/libetherspacelink_v35_21.dylib +0 -0
  383. egse/lib/Linux/ESL-RMAP_v34_86.dylib +0 -0
  384. egse/lib/Linux/EtherSpaceLink_v34_86.dylib +0 -0
  385. egse/lib/Ubuntu-20/ESL-RMAP_v34_86.dylib +0 -0
  386. egse/lib/Ubuntu-20/EtherSpaceLink_v34_86.dylib +0 -0
  387. egse/lib/gssw/python3-gssw_2.2.3+31f63c9f-1_all.deb +0 -0
  388. egse/lib/macOS/ESL-RMAP_v34_86.dylib +0 -0
  389. egse/lib/macOS/EtherSpaceLink_v34_86.dylib +0 -0
  390. egse/lib/ximc/__pycache__/pyximc.cpython-38 2.pyc +0 -0
  391. egse/lib/ximc/__pycache__/pyximc.cpython-38.pyc +0 -0
  392. egse/lib/ximc/libximc.framework/Frameworks/libbindy.dylib +0 -0
  393. egse/lib/ximc/libximc.framework/Frameworks/libxiwrapper.dylib +0 -0
  394. egse/lib/ximc/libximc.framework/Headers/ximc.h +0 -5510
  395. egse/lib/ximc/libximc.framework/Resources/Info.plist +0 -42
  396. egse/lib/ximc/libximc.framework/Resources/keyfile.sqlite +0 -0
  397. egse/lib/ximc/libximc.framework/libbindy.so +0 -0
  398. egse/lib/ximc/libximc.framework/libximc +0 -0
  399. egse/lib/ximc/libximc.framework/libximc.so +0 -0
  400. egse/lib/ximc/libximc.framework/libximc.so.7.0.0 +0 -0
  401. egse/lib/ximc/libximc.framework/libxiwrapper.so +0 -0
  402. egse/lib/ximc/pyximc.py +0 -922
  403. egse/listener.py +0 -73
  404. egse/logger/__init__.py +0 -243
  405. egse/logger/log_cs.py +0 -321
  406. egse/metrics.py +0 -98
  407. egse/mixin.py +0 -464
  408. egse/monitoring.py +0 -95
  409. egse/ni/alarms/__init__.py +0 -26
  410. egse/ni/alarms/cdaq9375.py +0 -300
  411. egse/ni/alarms/cdaq9375.yaml +0 -89
  412. egse/ni/alarms/cdaq9375_cs.py +0 -130
  413. egse/ni/alarms/cdaq9375_devif.py +0 -183
  414. egse/ni/alarms/cdaq9375_protocol.py +0 -48
  415. egse/obs_inspection.py +0 -163
  416. egse/observer.py +0 -41
  417. egse/obsid.py +0 -163
  418. egse/powermeter/__init__.py +0 -0
  419. egse/powermeter/ni/__init__.py +0 -38
  420. egse/powermeter/ni/cdaq9184.py +0 -224
  421. egse/powermeter/ni/cdaq9184.yaml +0 -73
  422. egse/powermeter/ni/cdaq9184_cs.py +0 -130
  423. egse/powermeter/ni/cdaq9184_devif.py +0 -201
  424. egse/powermeter/ni/cdaq9184_protocol.py +0 -48
  425. egse/powermeter/ni/cdaq9184_ui.py +0 -544
  426. egse/powermeter/thorlabs/__init__.py +0 -25
  427. egse/powermeter/thorlabs/pm100a.py +0 -380
  428. egse/powermeter/thorlabs/pm100a.yaml +0 -132
  429. egse/powermeter/thorlabs/pm100a_cs.py +0 -136
  430. egse/powermeter/thorlabs/pm100a_devif.py +0 -127
  431. egse/powermeter/thorlabs/pm100a_protocol.py +0 -80
  432. egse/powermeter/thorlabs/pm100a_ui.py +0 -725
  433. egse/process.py +0 -451
  434. egse/procman/__init__.py +0 -811
  435. egse/procman/cannot_start_process_popup.py +0 -43
  436. egse/procman/procman.yaml +0 -49
  437. egse/procman/procman_cs.py +0 -201
  438. egse/procman/procman_ui.py +0 -2081
  439. egse/protocol.py +0 -603
  440. egse/proxy.py +0 -522
  441. egse/randomwalk.py +0 -140
  442. egse/reg.py +0 -585
  443. egse/reload.py +0 -122
  444. egse/reprocess.py +0 -675
  445. egse/resource.py +0 -333
  446. egse/rst.py +0 -135
  447. egse/search.py +0 -182
  448. egse/serialdevice.py +0 -190
  449. egse/services.py +0 -212
  450. egse/services.yaml +0 -51
  451. egse/settings.py +0 -379
  452. egse/settings.yaml +0 -980
  453. egse/setup.py +0 -1180
  454. egse/shutter/__init__.py +0 -0
  455. egse/shutter/thorlabs/__init__.py +0 -19
  456. egse/shutter/thorlabs/ksc101.py +0 -205
  457. egse/shutter/thorlabs/ksc101.yaml +0 -105
  458. egse/shutter/thorlabs/ksc101_cs.py +0 -136
  459. egse/shutter/thorlabs/ksc101_devif.py +0 -201
  460. egse/shutter/thorlabs/ksc101_protocol.py +0 -69
  461. egse/shutter/thorlabs/ksc101_ui.py +0 -548
  462. egse/shutter/thorlabs/sc10.py +0 -82
  463. egse/shutter/thorlabs/sc10.yaml +0 -52
  464. egse/shutter/thorlabs/sc10_controller.py +0 -81
  465. egse/shutter/thorlabs/sc10_cs.py +0 -108
  466. egse/shutter/thorlabs/sc10_interface.py +0 -25
  467. egse/shutter/thorlabs/sc10_simulator.py +0 -30
  468. egse/simulator.py +0 -41
  469. egse/slack.py +0 -61
  470. egse/socketdevice.py +0 -218
  471. egse/sockets.py +0 -218
  472. egse/spw.py +0 -1479
  473. egse/stages/__init__.py +0 -12
  474. egse/stages/aerotech/ensemble.py +0 -247
  475. egse/stages/aerotech/ensemble.yaml +0 -205
  476. egse/stages/aerotech/ensemble_controller.py +0 -275
  477. egse/stages/aerotech/ensemble_cs.py +0 -110
  478. egse/stages/aerotech/ensemble_interface.py +0 -132
  479. egse/stages/aerotech/ensemble_parameters.py +0 -433
  480. egse/stages/aerotech/ensemble_simulator.py +0 -27
  481. egse/stages/aerotech/mgse_sim.py +0 -193
  482. egse/stages/arun/smd3.py +0 -111
  483. egse/stages/arun/smd3.yaml +0 -68
  484. egse/stages/arun/smd3_controller.py +0 -472
  485. egse/stages/arun/smd3_cs.py +0 -112
  486. egse/stages/arun/smd3_interface.py +0 -53
  487. egse/stages/arun/smd3_simulator.py +0 -27
  488. egse/stages/arun/smd3_stop.py +0 -16
  489. egse/stages/huber/__init__.py +0 -49
  490. egse/stages/huber/smc9300.py +0 -904
  491. egse/stages/huber/smc9300.yaml +0 -63
  492. egse/stages/huber/smc9300_cs.py +0 -178
  493. egse/stages/huber/smc9300_devif.py +0 -345
  494. egse/stages/huber/smc9300_protocol.py +0 -111
  495. egse/stages/huber/smc9300_sim.py +0 -547
  496. egse/stages/huber/smc9300_ui.py +0 -973
  497. egse/state.py +0 -173
  498. egse/statemachine.py +0 -274
  499. egse/storage/__init__.py +0 -1004
  500. egse/storage/persistence.py +0 -2295
  501. egse/storage/storage.yaml +0 -72
  502. egse/storage/storage_cs.py +0 -214
  503. egse/styles/dark.qss +0 -343
  504. egse/styles/default.qss +0 -48
  505. egse/synoptics/__init__.py +0 -412
  506. egse/synoptics/syn.yaml +0 -9
  507. egse/synoptics/syn_cs.py +0 -195
  508. egse/system.py +0 -1408
  509. egse/tcs/__init__.py +0 -14
  510. egse/tcs/tcs.py +0 -874
  511. egse/tcs/tcs.yaml +0 -14
  512. egse/tcs/tcs_cs.py +0 -202
  513. egse/tcs/tcs_devif.py +0 -292
  514. egse/tcs/tcs_protocol.py +0 -177
  515. egse/tcs/tcs_sim.py +0 -177
  516. egse/tcs/tcs_ui.py +0 -543
  517. egse/tdms.py +0 -171
  518. egse/tempcontrol/__init__.py +0 -23
  519. egse/tempcontrol/agilent/agilent34970.py +0 -109
  520. egse/tempcontrol/agilent/agilent34970.yaml +0 -44
  521. egse/tempcontrol/agilent/agilent34970_cs.py +0 -116
  522. egse/tempcontrol/agilent/agilent34970_devif.py +0 -182
  523. egse/tempcontrol/agilent/agilent34970_protocol.py +0 -99
  524. egse/tempcontrol/agilent/agilent34972.py +0 -111
  525. egse/tempcontrol/agilent/agilent34972.yaml +0 -44
  526. egse/tempcontrol/agilent/agilent34972_cs.py +0 -117
  527. egse/tempcontrol/agilent/agilent34972_devif.py +0 -189
  528. egse/tempcontrol/agilent/agilent34972_protocol.py +0 -101
  529. egse/tempcontrol/beaglebone/beaglebone.py +0 -342
  530. egse/tempcontrol/beaglebone/beaglebone.yaml +0 -110
  531. egse/tempcontrol/beaglebone/beaglebone_cs.py +0 -117
  532. egse/tempcontrol/beaglebone/beaglebone_protocol.py +0 -135
  533. egse/tempcontrol/beaglebone/beaglebone_ui.py +0 -681
  534. egse/tempcontrol/digalox/digalox.py +0 -107
  535. egse/tempcontrol/digalox/digalox.yaml +0 -36
  536. egse/tempcontrol/digalox/digalox_cs.py +0 -112
  537. egse/tempcontrol/digalox/digalox_protocol.py +0 -55
  538. egse/tempcontrol/keithley/__init__.py +0 -33
  539. egse/tempcontrol/keithley/daq6510.py +0 -662
  540. egse/tempcontrol/keithley/daq6510.yaml +0 -105
  541. egse/tempcontrol/keithley/daq6510_cs.py +0 -163
  542. egse/tempcontrol/keithley/daq6510_devif.py +0 -343
  543. egse/tempcontrol/keithley/daq6510_protocol.py +0 -78
  544. egse/tempcontrol/keithley/daq6510_sim.py +0 -186
  545. egse/tempcontrol/lakeshore/__init__.py +0 -33
  546. egse/tempcontrol/lakeshore/lsci.py +0 -361
  547. egse/tempcontrol/lakeshore/lsci.yaml +0 -162
  548. egse/tempcontrol/lakeshore/lsci_cs.py +0 -174
  549. egse/tempcontrol/lakeshore/lsci_devif.py +0 -292
  550. egse/tempcontrol/lakeshore/lsci_protocol.py +0 -73
  551. egse/tempcontrol/lakeshore/lsci_ui.py +0 -389
  552. egse/tempcontrol/ni/__init__.py +0 -0
  553. egse/tempcontrol/spid/spid.py +0 -109
  554. egse/tempcontrol/spid/spid.yaml +0 -81
  555. egse/tempcontrol/spid/spid_controller.py +0 -279
  556. egse/tempcontrol/spid/spid_cs.py +0 -136
  557. egse/tempcontrol/spid/spid_protocol.py +0 -107
  558. egse/tempcontrol/spid/spid_ui.py +0 -727
  559. egse/tempcontrol/srs/__init__.py +0 -22
  560. egse/tempcontrol/srs/ptc10.py +0 -875
  561. egse/tempcontrol/srs/ptc10.yaml +0 -227
  562. egse/tempcontrol/srs/ptc10_cs.py +0 -128
  563. egse/tempcontrol/srs/ptc10_devif.py +0 -118
  564. egse/tempcontrol/srs/ptc10_protocol.py +0 -42
  565. egse/tempcontrol/srs/ptc10_ui.py +0 -906
  566. egse/ups/apc/apc.py +0 -236
  567. egse/ups/apc/apc.yaml +0 -45
  568. egse/ups/apc/apc_cs.py +0 -101
  569. egse/ups/apc/apc_protocol.py +0 -125
  570. egse/user.yaml +0 -7
  571. egse/vacuum/beaglebone/beaglebone.py +0 -149
  572. egse/vacuum/beaglebone/beaglebone.yaml +0 -44
  573. egse/vacuum/beaglebone/beaglebone_cs.py +0 -108
  574. egse/vacuum/beaglebone/beaglebone_devif.py +0 -164
  575. egse/vacuum/beaglebone/beaglebone_protocol.py +0 -193
  576. egse/vacuum/beaglebone/beaglebone_ui.py +0 -638
  577. egse/vacuum/instrutech/igm402.py +0 -92
  578. egse/vacuum/instrutech/igm402.yaml +0 -90
  579. egse/vacuum/instrutech/igm402_controller.py +0 -128
  580. egse/vacuum/instrutech/igm402_cs.py +0 -108
  581. egse/vacuum/instrutech/igm402_interface.py +0 -49
  582. egse/vacuum/instrutech/igm402_simulator.py +0 -36
  583. egse/vacuum/keller/kellerBus.py +0 -256
  584. egse/vacuum/keller/leo3.py +0 -102
  585. egse/vacuum/keller/leo3.yaml +0 -38
  586. egse/vacuum/keller/leo3_controller.py +0 -83
  587. egse/vacuum/keller/leo3_cs.py +0 -101
  588. egse/vacuum/keller/leo3_interface.py +0 -33
  589. egse/vacuum/mks/evision.py +0 -86
  590. egse/vacuum/mks/evision.yaml +0 -75
  591. egse/vacuum/mks/evision_cs.py +0 -101
  592. egse/vacuum/mks/evision_devif.py +0 -316
  593. egse/vacuum/mks/evision_interface.py +0 -60
  594. egse/vacuum/mks/evision_simulator.py +0 -24
  595. egse/vacuum/mks/evision_ui.py +0 -704
  596. egse/vacuum/pfeiffer/acp40.py +0 -87
  597. egse/vacuum/pfeiffer/acp40.yaml +0 -60
  598. egse/vacuum/pfeiffer/acp40_controller.py +0 -117
  599. egse/vacuum/pfeiffer/acp40_cs.py +0 -109
  600. egse/vacuum/pfeiffer/acp40_interface.py +0 -40
  601. egse/vacuum/pfeiffer/acp40_simulator.py +0 -39
  602. egse/vacuum/pfeiffer/tc400.py +0 -113
  603. egse/vacuum/pfeiffer/tc400.yaml +0 -83
  604. egse/vacuum/pfeiffer/tc400_controller.py +0 -140
  605. egse/vacuum/pfeiffer/tc400_cs.py +0 -109
  606. egse/vacuum/pfeiffer/tc400_interface.py +0 -70
  607. egse/vacuum/pfeiffer/tc400_simulator.py +0 -24
  608. egse/vacuum/pfeiffer/tpg261.py +0 -81
  609. egse/vacuum/pfeiffer/tpg261.yaml +0 -66
  610. egse/vacuum/pfeiffer/tpg261_controller.py +0 -150
  611. egse/vacuum/pfeiffer/tpg261_cs.py +0 -109
  612. egse/vacuum/pfeiffer/tpg261_interface.py +0 -60
  613. egse/vacuum/pfeiffer/tpg261_simulator.py +0 -24
  614. egse/version.py +0 -174
  615. egse/visitedpositions.py +0 -398
  616. egse/windowing.py +0 -213
  617. egse/zmq/__init__.py +0 -28
  618. egse/zmq/spw.py +0 -160
  619. egse/zmq_ser.py +0 -41
  620. scripts/alerts/cold.yaml +0 -278
  621. scripts/alerts/example_alerts.yaml +0 -54
  622. scripts/alerts/transition.yaml +0 -14
  623. scripts/alerts/warm.yaml +0 -49
  624. scripts/analyse_n_fee_hk_data.py +0 -44
  625. scripts/check_hdf5_files.py +0 -192
  626. scripts/check_register_sync.py +0 -47
  627. scripts/create_hdf5_report.py +0 -295
  628. scripts/csl_model.py +0 -436
  629. scripts/csl_restore_setup.py +0 -230
  630. scripts/export-grafana-dashboards.py +0 -50
  631. scripts/fdir/cs_recovery/fdir_cs_recovery.py +0 -59
  632. scripts/fdir/fdir_table.yaml +0 -70
  633. scripts/fdir/fdir_test_recovery.py +0 -11
  634. scripts/fdir/hw_recovery/fdir_agilent_hw_recovery.py +0 -73
  635. scripts/fdir/limit_recovery/fdir_agilent_limit.py +0 -64
  636. scripts/fdir/limit_recovery/fdir_bb_heater_limit.py +0 -61
  637. scripts/fdir/limit_recovery/fdir_ensemble_limit.py +0 -33
  638. scripts/fdir/limit_recovery/fdir_pressure_limit_recovery.py +0 -71
  639. scripts/fix_csv.py +0 -80
  640. scripts/n_fee_supply_voltage_calculation.py +0 -92
  641. scripts/playground.py +0 -30
  642. scripts/print_hdf5_hk_data.py +0 -68
  643. scripts/print_register_map.py +0 -43
  644. scripts/sron/commanding/control_heaters.py +0 -44
  645. scripts/sron/commanding/pumpdown.py +0 -46
  646. scripts/sron/commanding/set_pid_setpoint.py +0 -19
  647. scripts/sron/commanding/shutdown_bbb_heaters.py +0 -10
  648. scripts/sron/commanding/shutdown_pumps.py +0 -33
  649. scripts/sron/tm_gen/tm_gen_agilent.py +0 -38
  650. scripts/sron/tm_gen/tm_gen_heaters.py +0 -4
  651. scripts/sron/tm_gen/tm_gen_spid.py +0 -13
  652. scripts/update_operational_cgse.py +0 -268
  653. scripts/update_operational_cgse_old.py +0 -273
@@ -1,875 +0,0 @@
1
- """
2
- This module defines the basic classes to access the MaRi regulation ensured by
3
- SRS PTC10 controller that will be used in the IAS TVAC setup.
4
- """
5
- import logging
6
- from typing import List
7
-
8
-
9
- from egse.decorators import dynamic_interface
10
- from egse.device import DeviceInterface
11
- from egse.tempcontrol.srs.ptc10_devif import ptc10Error
12
- from egse.tempcontrol.srs.ptc10_devif import ptc10TelnetInterface
13
- from egse.proxy import Proxy
14
- from egse.settings import Settings
15
- from egse.zmq_ser import connect_address
16
- from egse.mixin import dynamic_command
17
- from egse.mixin import add_lf
18
- from time import sleep, strftime, gmtime
19
- from egse.confman import ConfigurationManagerProxy
20
- from egse.system import format_datetime
21
- from datetime import datetime
22
-
23
-
24
- LOGGER = logging.getLogger(__name__)
25
-
26
- CTRL_SETTINGS = Settings.load("SRS PTC10 Control Server")
27
- PTC10_SETTINGS = Settings.load("SRS PTC10 Controller")
28
- DEVICE_SETTINGS = Settings.load(filename="ptc10.yaml")
29
-
30
- def load_setup_from_configuration_manager():
31
- """Loads a Setup YAML file from the Configuration Manager."""
32
- with ConfigurationManagerProxy() as cm:
33
- setup = cm.get_setup()
34
-
35
- return setup
36
-
37
-
38
- class ptc10Interface(DeviceInterface):
39
- """
40
- Interface definition for the Temp regulation SRS PTC10 Controller, Simulator and Proxy..
41
- """
42
-
43
- @dynamic_interface
44
- def connect(self):
45
- """Connects to the Temp regulation device.
46
-
47
- Raises:
48
- DeviceNotFoundError: when the Temp regulation device is not connected.
49
- """
50
-
51
- raise NotImplementedError
52
-
53
- @dynamic_interface
54
- def disconnect(self):
55
- raise NotImplementedError
56
-
57
- @dynamic_interface
58
- def reconnect(self):
59
- raise NotImplementedError
60
-
61
- @dynamic_interface
62
- def is_connected(self):
63
- """Check if the Temp Controller is connected."""
64
- raise NotImplementedError
65
-
66
- @dynamic_interface
67
- def is_simulator(self):
68
- raise NotImplementedError
69
-
70
- @dynamic_interface
71
- def info(self) -> str:
72
- """
73
- Returns basic information about the device, its name, firmwre version etc.
74
- Returns:
75
- An identification string of the instrument.
76
- """
77
- raise NotImplementedError
78
-
79
- @dynamic_interface
80
- def alarm_status(self) -> str:
81
- """
82
- Returns the current value of the Alarm Status Register (ASR), and then clears the register.
83
- """
84
- raise NotImplementedError
85
-
86
- @dynamic_interface
87
- def get_names(self):
88
- """
89
- Returns a tuple of 2 lists with the names of inputs (3 sensors) in the first list and the names of
90
- outputs (3 heaters) in the second list.
91
- """
92
- raise NotImplementedError
93
-
94
- @dynamic_interface
95
- def set_name(self, old_name: str, new_name: str):
96
- """Modifies the name of the specified channel (input or output)."""
97
- raise NotImplementedError
98
-
99
- @dynamic_interface
100
- def clear_error(self):
101
- """
102
- Erases all error messages for the port over which the instruction was transmitted. Also clears all messages
103
- from the System.Com. Errors window regardless of which port generated them.
104
- """
105
- raise NotImplementedError
106
-
107
- @dynamic_interface
108
- def stop(self):
109
- """
110
- kill.all stops all currently running macros with the given runtime name. The runtime name is assigned with the
111
- "name" instruction and is not necessarily the same as the file name that a macro may be saved under.
112
- The kill.all instruction stops all currently-running macros regardless of name or which port started the macro.
113
- """
114
- raise NotImplementedError
115
-
116
- @dynamic_interface
117
- def standby(self):
118
- """
119
- Puts the PTC10 into stby mode, in which the outputs are turned off, data acquisition is paused, macros are
120
- paused, the front panel display and system fan are shut off, and the system does not respond to remote commands.
121
- The PTC321's excitation currents remain on, and the chassis cooling fan may switch on occassionally.
122
- Press the "Output Enable" key to exit standby mode. There is no remote command to leave stand by mode.
123
- """
124
- raise NotImplementedError
125
-
126
- @dynamic_command(
127
- cmd_type="write",
128
- cmd_string="*RST",
129
- process_cmd_string=add_lf,
130
- )
131
- def reset(self):
132
- """
133
- Resets the PTC10.
134
-
135
- The *RST instruction is equivalent to turning the instrument off and back on again, except the Power On bit of
136
- the Event Status Register is not set. *RST has the following effects:
137
- - Outputs are disabled (as if the “Output enable” button were pressed).
138
- - All currently-running macros are stopped, regardless of whether the macros were started by the GPIB interface,
139
- another I/O port, or the Program screen.
140
- - The instrument returns to the Select screen.
141
- -Partially-received instructions on all I/O ports are cleared.
142
- - All pending transmissions on all I/O ports are cancelled.
143
- - The error queues for all I/O ports are cleared.
144
- - The plot screen returns to showing the most recent data on autoscaled Y axes.
145
- - The instrument automatically triggers at the rate set with the “A/D rate” control.
146
- - Clears all locally-stored log data. Logs on USB devices are not affected. If data is not being logged to a
147
- USB storage device, the Plot screen shows no accumulated data immediately after a *RST command.
148
- """
149
- raise NotImplementedError
150
-
151
- @dynamic_interface
152
- def read_temperature(self):
153
- """
154
- Reads the temperature from the 3 PT1000 corresponding to TRP2/TRP3/TRP4.
155
-
156
- Notes: <channel>.value? returns the current value of the channel. Ex: 2A.value? queries the output of channel 2A
157
- <channel>? also works
158
- """
159
-
160
- raise NotImplementedError
161
-
162
- @dynamic_interface
163
- def read_heater(self):
164
- """
165
- Reads the 3x heater outputs with the unit (W, A or V).
166
- Returns a tuple. 1st element is a list with the 3 values of the heaters. 2nd element is a string with the unit
167
- ('W', 'A' or 'V').
168
- """
169
-
170
- raise NotImplementedError
171
-
172
- @dynamic_interface
173
- def disable_heater(self, output_ch: int):
174
- """
175
- Disables the specified heater output. output_ch = 1, 2, 3
176
-
177
- Notes: <channel>.Off cancels any active autotuning process, turns PID feedback off, and sets the channel's
178
- output to zero or the lower limit.
179
- """
180
-
181
- raise NotImplementedError
182
-
183
- @dynamic_interface
184
- def outputs_enable(self):
185
- """Enables all outputs. Equivalent to press the red button twice on the front panel of the PTC10 when outputs disabled."""
186
- raise NotImplementedError
187
-
188
- @dynamic_interface
189
- def outputs_disable(self):
190
- """Disables all outputs. Equivalent to press the red button on the front panel of the PTC10 when output enabled."""
191
- raise NotImplementedError
192
-
193
- @dynamic_interface
194
- def disable_all(self):
195
- """Both disable_heater function used for all heaters AND outputs_disable."""
196
- raise NotImplementedError
197
-
198
- @dynamic_interface
199
- def is_outputs_enable(self) -> bool:
200
- """
201
- Returns a boolean corresponding to the state of the red button/light on the front panel of the PTC10.
202
- True means outputs enabled (red light switch on)
203
- False means outputs disabled (red light switch off)
204
- """
205
-
206
- raise NotImplementedError
207
-
208
- @dynamic_interface
209
- def output_limit(self, output_ch: int, low: float, high: float):
210
- """
211
- Sets the min and max output and can be used to prevent the PID loop for delivering excessive power to a
212
- heater. The limits must be expressed in the same units that the output is expressed in. The limits must
213
- normally be reset when the output units are changed, since the limits are not converted to the new units.
214
- output_ch = 1, 2, 3
215
- low = float >= 0
216
- high = float > low
217
-
218
- Notes:
219
- by default the DC heater driver output is measured in watts. But can be changed to either A or V.
220
- <channel>.Units{W, A, V}
221
- """
222
-
223
- raise NotImplementedError
224
-
225
- @dynamic_interface
226
- def output_unit(self, unit: str):
227
- """
228
- Sets the unit for the 3 heaters
229
- unit = W, A, V, or in lowercase w, a, v
230
- """
231
-
232
- raise NotImplementedError
233
-
234
- @dynamic_interface
235
- def set_heater_input(self, output_ch: int, input: str):
236
- """
237
- Sets the sensor as input for the specified heater.
238
- output_ch = 1, 2, 3
239
- input = name of the sensor (e.g. TRP2)
240
- """
241
-
242
- raise NotImplementedError
243
-
244
- @dynamic_interface
245
- def setpoint(self, output_ch: int, setpoint: float):
246
- """
247
- Sets the temperature setpoint. The PID attemps to keep the input at this value by changing the output.
248
- output_ch = 1, 2, 3
249
- setpoint = float (°C)
250
-
251
- Notes:
252
- usage: <channel>.PID.Setpoint<setpoint>
253
- """
254
-
255
- raise NotImplementedError
256
-
257
- @dynamic_interface
258
- def get_PID(self, output_ch: int) -> dict:
259
- """
260
- Returns a dictionary with P, I and D parameters as float, {"P": P_value, "I": I_value, "D": D_value}
261
- output_ch = 1, 2, 3
262
- """
263
-
264
- raise NotImplementedError
265
-
266
- @dynamic_interface
267
- def set_PID(self, input_ch: int, output_ch: int, PID: List[float]):
268
- """
269
- The input must be stable before either Step or Relay tuning is started. Furthermore, the output must be greater
270
- than half the step height before starting relay tuning. The best time to start a step response is when the
271
- system is first turned on at the beginning of the day, i.e the heater is cold and its temperature stable.
272
- See User Manual for further details.
273
- input_ch parameter sets the PID input channel which is the temperature that the PID feedback loop controls. intput_ch = 1, 2, 3
274
- output_ch parameter sets the PID output channel. output_ch = 1, 2, 3
275
- PID parameter sets the three coefficients respectively in P, I and D. PID = [float, float, float]
276
-
277
- Notes
278
- PID: <channel>.PID.D<value>, <channel>.PID.I<value>, <channel>.PID.P<value>
279
- <channel>.PID.Input<channel name>
280
- """
281
-
282
- raise NotImplementedError
283
-
284
- @dynamic_interface
285
- def autotune_PID(self, input_ch: int, output_ch: int):
286
- """
287
-
288
- """
289
-
290
- raise NotImplementedError
291
-
292
- @dynamic_interface
293
- def set_auto(self, output_ch: int, setpoint: float):
294
- """
295
- Enables the specified output to reach the specified setpoint automatically.
296
- output_ch = 1, 2, 3
297
- setpoint = float (°C)
298
- """
299
- raise NotImplementedError
300
-
301
- @dynamic_interface
302
- def set_manual(self, output_ch: int, value: float):
303
- """
304
- Enables the specified output manually with the specified value.
305
- The unit is the one currently in effect (W, A or V).
306
- output_ch = 1, 2, 3
307
- value = float >= 0
308
- """
309
-
310
- raise NotImplementedError
311
-
312
- @dynamic_interface
313
- def set_survival(self):
314
- """
315
- Sets all outputs to the min Non op temperature for TRP2, TRP3 and TRP4 as given in the Setup YAML file.
316
- We assume that P, I and D coefficients are already correctly set.
317
- """
318
-
319
- raise NotImplementedError
320
-
321
- @dynamic_interface
322
- def set_stable(self, setpoint: float):
323
- """
324
- Sets all outputs to the same temperature setpoint given as parameter.
325
- We assume that P, I and D coefficients are already correctly set.
326
- """
327
-
328
- raise NotImplementedError
329
-
330
- @dynamic_interface
331
- def set_custom(self, outputs_dict: dict):
332
- """
333
- Sets the outputs given as parameter to the corresponding temperature given as parameter.
334
- If an output channel is not given as parameter in the dictionary outputs_dict, this output channel will remain
335
- at the same state and with same setpoint as before.
336
- outputs_dict = {output_ch: setpoint} for example: {3: -110, 1: -106}
337
- """
338
-
339
- raise NotImplementedError
340
-
341
- @dynamic_interface
342
- def heater_sensor_error(self) -> list:
343
- """
344
- Returns a list with names of sensors (TRP) and heaters which cannot be read by the PTC10.
345
- """
346
-
347
- raise NotImplementedError
348
-
349
- @dynamic_interface
350
- def disable_heater_error(self):
351
- """
352
- Disables heaters whose PT1000 sensors are faulty.
353
- This function does not re-enable heater if a PT1000 is no longer faulty.
354
- """
355
-
356
- raise NotImplementedError
357
-
358
- @dynamic_interface
359
- def get_time(self) -> str:
360
- """
361
- Returns PTC10 time as a string.
362
- """
363
-
364
- raise NotImplementedError
365
-
366
-
367
- @dynamic_interface
368
- def update_time(self):
369
- """
370
- Updates the PTC10 date and time in UTC from the server's time which is ntp synchronised.
371
- """
372
-
373
- raise NotImplementedError
374
-
375
-
376
- class ptc10Simulator(ptc10Interface):
377
- """
378
- The ptc10 Simulator class.
379
- """
380
-
381
- def __init__(self):
382
- self._is_connected = True
383
- self.temp_operation = False
384
-
385
- def is_connected(self):
386
- return self._is_connected
387
-
388
- def is_simulator(self):
389
- return True
390
-
391
- def connect(self):
392
- self._is_connected = True
393
-
394
- def disconnect(self):
395
- self._is_connected = False
396
-
397
- def reconnect(self):
398
- self.connect()
399
-
400
- def info(self):
401
- pass
402
-
403
- def read_temperature(self):
404
- pass
405
-
406
- def read_heater(self):
407
- pass
408
-
409
-
410
- class ptc10Controller(ptc10Interface):
411
- """The ptc10Controller allows controlling a SRS ptc10 temperature regulation device."""
412
-
413
- def __init__(self):
414
- """Initialize the ptc10 Controller interface."""
415
- self.output_mode_var = None
416
- self.setpoint_var = None
417
- self.PID = None
418
- self.limits = None
419
- setup = load_setup_from_configuration_manager()
420
- self.T_min_NOP = setup.gse.PTC10.T_min_NOP # TRP2, TRP3 and TRP4 min NOP (°C)
421
-
422
- super().__init__()
423
-
424
- LOGGER.debug("Initializing PTC10")
425
-
426
- try:
427
- self.temp = ptc10TelnetInterface()
428
- self.temp.connect(PTC10_SETTINGS.HOSTNAME)
429
- except ptc10Error as exc:
430
- LOGGER.warning(f"TempError caught: Couldn't establish connection ({exc})")
431
- raise ptc10Error(
432
- "Couldn't establish a connection with the Temp PTC10 controller."
433
- ) from exc
434
-
435
- def connect(self):
436
- """Connects to the Temp regulation device.
437
-
438
- Raises:
439
- DeviceNotFoundError: when the Temp regulation device is not connected.
440
- """
441
- try:
442
- self.temp.connect(PTC10_SETTINGS.HOSTNAME)
443
- except ptc10Error as exc:
444
- LOGGER.warning(f"ptc10Error caught: Couldn't establish connection ({exc})")
445
- raise ConnectionError("Couldn't establish a connection with the SRS PTC10 controller.") from exc
446
-
447
- def disconnect(self):
448
- try:
449
- self.temp.disconnect()
450
- except ptc10Error as exc:
451
- raise ConnectionError("Couldn't establish a connection with the SRS PTC10 controller.") from exc
452
-
453
- def reconnect(self):
454
- if self.is_connected():
455
- self.disconnect()
456
- sleep(1)
457
- self.connect()
458
-
459
- def is_connected(self):
460
- """Check if the Temp Controller is connected."""
461
- return self.temp.is_connected()
462
-
463
- def is_simulator(self):
464
- return False
465
-
466
- def info(self):
467
- """
468
- Returns basic information about the device, its name, firmwre version etc.
469
- Returns:
470
- An identification string of the instrument.
471
- """
472
-
473
- self.temp.write("*IDN?")
474
- _info = self.temp.read()
475
- return _info
476
-
477
- def alarm_status(self) -> str:
478
- """Returns the current value of the Alarm Status Register (ASR), and then clears the register."""
479
-
480
- self.temp.write("*ASR?")
481
- status = self.temp.read()
482
- return status
483
-
484
- def get_names(self):
485
- """
486
- Returns a tuple of 2 lists with the names of inputs (4 sensors) in the first list and the names of
487
- outputs (3 heaters) in the second list.
488
- """
489
-
490
- self.temp.write("getOutput.names")
491
- NAMES = self.temp.read().split(", ")
492
-
493
- Sensors = NAMES[3:7]
494
-
495
- Heaters = NAMES[:3]
496
-
497
- return Sensors, Heaters
498
-
499
- def set_name(self, old_name: str, new_name: str):
500
- """Modifies the name of the specified channel (input or output)."""
501
-
502
- self.temp.write(f'({old_name}.Name) "{new_name}"')
503
-
504
- def clear_error(self):
505
- """
506
- Erases all error messages for the port over which the instruction was transmitted. Also clears all messages
507
- from the System.Com. Errors window regardless of which port generated them.
508
- """
509
-
510
- self.temp.write("clearerrors")
511
-
512
- def stop(self):
513
- """
514
- kill.all stops all currently running macros with the given runtime name. The runtime name is assigned with the
515
- "name" instruction and is not necessarily the same as the file name that a macro may be saved under.
516
- The kill.all instruction stops all currently-running macros regardless of name or which port started the macro.
517
- """
518
-
519
- self.temp.write("kill.all")
520
-
521
- def standby(self):
522
- """
523
- Puts the PTC10 into stby mode, in which the outputs are turned off, data acquisition is paused, macros are
524
- paused, the front panel display and system fan are shut off, and the system does not respond to remote commands.
525
- The PTC321's excitation currents remain on, and the chassis cooling fan may switch on occassionally.
526
- Press the "Output Enable" key to exit standby mode. There is no remote command to leave stand by mode.
527
- """
528
-
529
- self.temp.write("standby")
530
-
531
- def reset(self):
532
- """
533
- Resets the PTC10.
534
-
535
- The *RST instruction is equivalent to turning the instrument off and back on again, except the Power On bit of
536
- the Event Status Register is not set. *RST has the following effects:
537
- - Outputs are disabled (as if the “Output enable” button were pressed).
538
- - All currently-running macros are stopped, regardless of whether the macros were started by the GPIB interface,
539
- another I/O port, or the Program screen.
540
- - The instrument returns to the Select screen.
541
- -Partially-received instructions on all I/O ports are cleared.
542
- - All pending transmissions on all I/O ports are cancelled.
543
- - The error queues for all I/O ports are cleared.
544
- - The plot screen returns to showing the most recent data on autoscaled Y axes.
545
- - The instrument automatically triggers at the rate set with the “A/D rate” control.
546
- - Clears all locally-stored log data. Logs on USB devices are not affected. If data is not being logged to a
547
- USB storage device, the Plot screen shows no accumulated data immediately after a *RST command.
548
- """
549
-
550
- self.temp.write("*RST")
551
-
552
- def read_temperature(self) -> list:
553
- """Reads the temperature from the 3 PT1000 corresponding to TRP2/TRP3/TRP4."""
554
-
555
- Sensor_names = self.get_names()[0]
556
- Sensors_values = []
557
- for channel_name in Sensor_names:
558
- self.temp.write(f"({channel_name}?)")
559
- Sensors_values.append(float(self.temp.read()))
560
- return Sensors_values
561
-
562
- def read_heater(self) -> tuple:
563
- """
564
- Reads the 3x heater outputs with the unit (W, A or V).
565
- Returns a tuple. 1st element is a list with the 3 values of the heaters. 2nd element is a string with the unit
566
- ('W', 'A' or 'V').
567
- """
568
-
569
- Heater_names = self.get_names()[1]
570
- Heaters_values = []
571
- for channel_name in Heater_names:
572
- self.temp.write(f"({channel_name}?)")
573
- Heaters_values.append(float(self.temp.read()))
574
- self.temp.write(f"({Heater_names[0]}.Units?)")
575
- heater_unit = self.temp.read()
576
- return Heaters_values, heater_unit
577
-
578
- def disable_heater(self, output_ch: int):
579
- """
580
- Disables the specified heater output. output_ch = 1, 2, 3
581
-
582
- Notes: <channel>.Off cancels any active autotuning process, turns PID feedback off, and sets the channel's
583
- output to zero or the lower limit.
584
- """
585
-
586
- self.temp.write(f"({self.get_names()[1][output_ch - 1]}.Off)")
587
-
588
- def outputs_enable(self):
589
- """Enables all outputs. Equivalent to press the red button twice on the front panel of the PTC10 when outputs disabled."""
590
-
591
- self.temp.write("outputEnable = on")
592
-
593
- def outputs_disable(self):
594
- """Disables all outputs. Equivalent to press the red button on the front panel of the PTC10 when output enabled."""
595
-
596
- self.temp.write("outputEnable = off")
597
-
598
- def disable_all(self):
599
- """Both disable_heater function used for all heaters AND outputs_disable."""
600
-
601
- for output_ch in [1,2,3]:
602
- self.disable_heater(output_ch)
603
- self.outputs_disable()
604
-
605
- def is_outputs_enable(self) -> bool:
606
- """
607
- Returns a boolean corresponding to the state of the red button/light on the front panel of the PTC10.
608
- True means outputs enabled (red light switch on)
609
- False means outputs disabled (red light switch off)
610
- """
611
-
612
- is_enable = {"On": True, "Off": False}
613
- self.temp.write("outputEnable?")
614
- return is_enable[self.temp.read()]
615
-
616
- def output_limit(self, output_ch: int, low: float, high: float):
617
- """
618
- Sets the min and max output and can be used to prevent the PID loop for delivering excessive power to a
619
- heater. The limits must be expressed in the same units that the output is expressed in. The limits must
620
- normally be reset when the output units are changed, since the limits are not converted to the new units.
621
- output_ch = 1, 2, 3
622
- low = float >= 0
623
- high = float > low
624
-
625
- Notes:
626
- by default the DC heater driver output is measured in watts. But can be changed to either A or V.
627
- <channel>.Units{W, A, V}
628
- """
629
-
630
- heater = self.get_names()[1][output_ch - 1]
631
- self.temp.write(f"({heater}.Low lmt) {low}")
632
- self.temp.write(f"({heater}.Hi lmt) {high}")
633
-
634
- def output_unit(self, unit: str):
635
- """
636
- Sets the unit for the 3 heaters
637
- unit = W, A, V, or in lowercase w, a, v
638
- """
639
-
640
- unit = unit.upper()
641
- for output_ch in [1, 2, 3]:
642
- heater = self.get_names()[1][output_ch - 1]
643
- self.temp.write(f'({heater}.Units) "{unit}"')
644
-
645
- def set_heater_input(self, output_ch: int, input: str):
646
- """
647
- Sets the sensor as input for the specified heater.
648
- output_ch = 1, 2, 3
649
- input = name of the sensor (e.g. TRP2)
650
- """
651
-
652
- heater = self.get_names()[1][output_ch - 1]
653
- self.temp.write(f'({heater}.PID.Input) "{input}"')
654
-
655
- def setpoint(self, output_ch: int, setpoint: float):
656
- """
657
- Sets the temperature setpoint. The PID attemps to keep the input at this value by changing the output.
658
- output_ch = 1, 2, 3
659
- setpoint = float (°C)
660
-
661
- Notes:
662
- usage: <channel>.PID.Setpoint<setpoint>
663
- """
664
-
665
- heater = self.get_names()[1][output_ch - 1]
666
- self.temp.write(f"({heater}.PID.Setpoint) {setpoint}")
667
-
668
- def get_PID(self, output_ch: int) -> dict:
669
- """
670
- Returns a dictionary with P, I and D parameters as float, {"P": P_value, "I": I_value, "D": D_value}
671
- output_ch = 1, 2, 3
672
- """
673
- heater = self.get_names()[1][output_ch - 1]
674
-
675
- self.temp.write(f"({heater}.PID.P?)")
676
- P = float(self.temp.read())
677
- self.temp.write(f"({heater}.PID.I?)")
678
- I = float(self.temp.read())
679
- self.temp.write(f"({heater}.PID.D?)")
680
- D = float(self.temp.read())
681
-
682
- return {"P": P, "I": I, "D": D}
683
-
684
- def set_PID(self, input_ch: int, output_ch: int, PID: List[float]):
685
- """
686
- The input must be stable before either Step or Relay tuning is started. Furthermore, the output must be greater
687
- than half the step height before starting relay tuning. The best time to start a step response is when the
688
- system is first turned on at the beginning of the day, i.e the heater is cold and its temperature stable.
689
- See User Manual for further details.
690
- input_ch parameter sets the PID input channel which is the temperature that the PID feedback loop controls. intput_ch = 1, 2, 3
691
- output_ch parameter sets the PID output channel. output_ch = 1, 2, 3
692
- PID parameter sets the three coefficients respectively in P, I and D. PID = [float, float, float]
693
-
694
- Notes
695
- PID: <channel>.PID.D<value>, <channel>.PID.I<value>, <channel>.PID.P<value>
696
- <channel>.PID.Input<channel name>
697
- """
698
-
699
- sensor = self.get_names()[0][input_ch - 1]
700
- heater = self.get_names()[1][output_ch - 1]
701
-
702
- self.temp.write(f'({heater}.PID.Input) "{sensor}"')
703
- PID_dict = {"P": PID[0], "I": PID[1], "D": PID[2]}
704
- for corrector in PID_dict:
705
- self.temp.write(f"({heater}.PID.{corrector}) {PID_dict[corrector]}")
706
-
707
- def autotune_PID(self, input_ch: int, output_ch: int):
708
- """
709
- Configures the PID with autotune.
710
- User Manual p.50 "If the system has never been tuned, start with the feedback turned off and the heater at ambient temperature.
711
- If the system has been tuned before, it’s better to wait for the temperature to stabilize at the setpoint.
712
- In either case, the key to successful autotuning is to start with a stable temperature."
713
- Prints message if failure to autotune PID. Old values for P, I and D are retained.
714
- input_ch parameter sets the PID input channel which is the temperature that the PID feedback loop controls. intput_ch = 1, 2, 3
715
- output_ch parameter sets the PID output channel. output_ch = 1, 2, 3
716
- """
717
-
718
- sensor = self.get_names()[0][input_ch - 1]
719
- heater = self.get_names()[1][output_ch - 1]
720
- output_enable_state = self.is_outputs_enable()
721
- self.temp.write(f"({heater}.PID.Mode?)")
722
- PID_mode = self.temp.read()
723
- self.temp.write(f"({heater}.Value?)")
724
- heater_initial_value = self.temp.read()
725
-
726
- PID_initial = self.get_PID(output_ch)
727
-
728
- self.temp.write(f"({heater}.PID.Mode) off")
729
- self.temp.write(f'({heater}.PID.Input) "{sensor}"')
730
- if not output_enable_state:
731
- self.temp.write("outputEnable = on")
732
- self.temp.write(f"({heater}.Tune.Mode) Auto")
733
-
734
- self.temp.write(f"({heater}.Tune.mode?)")
735
- Tune_mode = self.temp.read()
736
- while Tune_mode != "Off":
737
- self.temp.write(f"({heater}.Tune.mode?)")
738
- Tune_mode = self.temp.read()
739
- self.temp.write(f"({heater}.PID.Mode) {PID_mode}")
740
- if PID_mode == "Off":
741
- self.temp.write(f"({heater}.Value) {heater_initial_value}")
742
- if not output_enable_state:
743
- self.temp.write("outputEnable = off")
744
-
745
- #TODO: investigate to find a better way to know if autotune was successful or not (maybe with status function?)
746
- PID_final = self.get_PID(output_ch)
747
- if PID_initial == PID_final:
748
- print(f"Failure to autotune PID. Old values for P, I and D are retained.\nP = {PID_final['P']}\nI = {PID_final['I']}\nD = {PID_final['D']}\n"
749
- "The key to successful autotuning is to start with a stable temperature.")
750
- else:
751
- print(f"Successful PID autotuning!!\nP = {PID_final['P']}\nI = {PID_final['I']}\nD = {PID_final['D']}")
752
-
753
- def set_auto(self, output_ch: int, setpoint: float):
754
- """
755
- Enables the specified output to reach the specified setpoint automatically.
756
- output_ch = 1, 2, 3
757
- setpoint = float (°C)
758
- """
759
-
760
- heater = self.get_names()[1][output_ch - 1]
761
- self.temp.write(f"({heater}.PID.Setpoint) {setpoint}")
762
- self.temp.write(f"({heater}.PID.mode) on")
763
-
764
- if not self.is_outputs_enable():
765
- self.temp.write("outputEnable = on")
766
-
767
- def set_manual(self, output_ch: int, value: float):
768
- """
769
- Enables the specified output manually with the specified value.
770
- The unit is the one currently in effect (W, A or V).
771
- output_ch = 1, 2, 3
772
- value = float >= 0
773
- """
774
-
775
- heater = self.get_names()[1][output_ch - 1]
776
- output_enable_state = self.is_outputs_enable()
777
- if not output_enable_state:
778
- self.temp.write("outputEnable = on")
779
-
780
- self.temp.write(f"({heater}.PID.mode) off")
781
- self.temp.write(f"({heater}.Value) {value}")
782
- response = self.temp.read()
783
- if response != "":
784
- print(f"{response}. The old value is retained.")
785
- if not output_enable_state:
786
- self.temp.write("outputEnable = off")
787
-
788
- def set_survival(self):
789
- """
790
- Sets all outputs to the min Non op temperature for TRP2, TRP3 and TRP4 as given in the Setup YAML file.
791
- We assume that P, I and D coefficients are already correctly set.
792
- """
793
-
794
- for output_ch in [1,2,3]:
795
- self.set_auto(output_ch, self.T_min_NOP)
796
-
797
- def set_stable(self, setpoint: float):
798
- """
799
- Sets all outputs to the same temperature setpoint given as parameter.
800
- We assume that P, I and D coefficients are already correctly set.
801
- """
802
-
803
- for output_ch in [1, 2, 3]:
804
- self.set_auto(output_ch, setpoint)
805
-
806
- def set_custom(self, outputs_dict: dict):
807
- """
808
- Sets the outputs given as parameter to the corresponding temperature given as parameter.
809
- If an output channel is not given as parameter in the dictionary outputs_dict, this output channel will remain
810
- at the same state and with same setpoint as before.
811
- outputs_dict = {output_ch: setpoint} for example: {3: -110, 1: -106}
812
- """
813
-
814
- channels = [1,2,3]
815
- for output_ch in channels:
816
- if output_ch in outputs_dict:
817
- self.set_auto(output_ch, outputs_dict[output_ch])
818
-
819
- def heater_sensor_error(self) -> list:
820
- """
821
- Returns a list with names of sensors (TRP) and heaters which cannot be read by the PTC10.
822
- """
823
-
824
- INPUTS_OUTPUTS = self.read_temperature() + self.read_heater()[0]
825
- NAMES = self.get_names()
826
- NAMES = NAMES[0] + NAMES[1]
827
- ERROR = []
828
- for i in range(len(INPUTS_OUTPUTS)):
829
- in_out = INPUTS_OUTPUTS[i]
830
- if in_out != in_out: # This line tests if in_out is NaN
831
- ERROR.append(NAMES[i])
832
- return ERROR
833
-
834
- def disable_heater_error(self):
835
- """
836
- Disables heaters whose PT1000 sensors are faulty.
837
- This function does not re-enable heater if a PT1000 is no longer faulty.
838
- """
839
-
840
- list_error = self.heater_sensor_error()
841
- sensor_names = self.get_names()[0]
842
- for i in sensor_names:
843
- if i in list_error[:4]:
844
- self.disable_heater(sensor_names.index(i) + 1)
845
-
846
- def update_time(self):
847
- """Updates the PTC10 date and time in UTC from the server's time which is ntp synchronised."""
848
- self.temp.write("systemtime.dmy " + strftime("%d/%m/%Y", gmtime()))
849
- self.temp.write("systemtime.hms " + strftime("%H:%M:%S", gmtime()))
850
-
851
- def get_time(self) -> str:
852
- smhdmy = self.temp.trans("Systemtime.smh?")
853
- timestamp = format_datetime(datetime.strptime(smhdmy + " +0000", '%S %M %H %d %m %Y %z'))
854
- return timestamp
855
-
856
- class ptc10Proxy(Proxy, ptc10Interface):
857
- """The ptc10Proxy class is used to connect to the control server and send commands to
858
- the SRS PTC10 device remotely."""
859
- def __init__(
860
- self,
861
- protocol=CTRL_SETTINGS.PROTOCOL,
862
- hostname=CTRL_SETTINGS.HOSTNAME,
863
- port=CTRL_SETTINGS.COMMANDING_PORT,
864
- timeout=CTRL_SETTINGS.TIMEOUT * 1000 # timeout in ms
865
- ):
866
- """
867
- Args:
868
- protocol: the transport protocol [default is taken from settings file]
869
- hostname: location of the control server (IP address)
870
- [default is taken from settings file]
871
- port: TCP port on which the control server is listening for commands
872
- [default is taken from settings file]
873
- """
874
- super().__init__(connect_address(protocol, hostname, port))
875
-