Changes for page IDL cheat sheet
Last modified by fwilde on 2025/03/28 19:55
Summary
-
Page properties (1 modified, 0 added, 0 removed)
-
Objects (1 modified, 0 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -1,7 +1,13 @@ 1 - Thisisanoverview ofthemostcommonlyused commands duringabeamtime.1 +== {{id name="IDLcheatsheet-Coordinatesystem"/}}Coordinate system == 2 2 3 +Right-handed coordinate system with y-direction along the x-ray beam. 4 + 5 +[[image:attach:p05_uct.png||width="700"]] 6 + 3 3 == {{id name="IDLcheatsheet-Samplepositioning"/}}Sample positioning == 4 4 9 +=== {{id name="IDLcheatsheet-Relativemovement"/}}Relative movement === 10 + 5 5 (% class="wrapped fixed-table" %) 6 6 |=((( 7 7 IDL command ... ... @@ -11,7 +11,7 @@ 11 11 motion 12 12 ))) 13 13 |((( 14 -s_stage_x/z, 1 20 +##**s_stage_x/z, 1**## 15 15 )))|((( 16 16 move rotation stage in x/z-direction by 1 mm 17 17 )))|((( ... ... @@ -18,14 +18,14 @@ 18 18 relative [ mm ] 19 19 ))) 20 20 |((( 21 -s_pos_z, 1 27 +##**s_pos_x/y/z, 1**## 22 22 )))|((( 23 -move sample stage in z-direction by 1 mm ,29 +move sample stage in x/y/z-direction by 1 mm (caution with directions: stage mount on rotation axis) 24 24 )))|((( 25 25 relative [ mm ] 26 26 ))) 27 27 |((( 28 -s_pos_lateral, 1 34 +##**s_pos_lateral, 1**## 29 29 )))|((( 30 30 move sample stage in x-direction by 1 mm, regardless of position of rotation axis 31 31 )))|((( ... ... @@ -32,35 +32,16 @@ 32 32 relative [ mm ] 33 33 ))) 34 34 |((( 35 -s_angle, 90 41 +##**s_angle, 90**## 36 36 )))|((( 37 37 rotate sample around z axis 38 38 )))|((( 39 39 relative [ deg ] 40 40 ))) 41 -|((( 42 -s_in 43 -)))|((( 44 -move sample to "in" position 45 -)))|((( 46 -predefined 47 -))) 48 -|((( 49 -s_out 50 -)))|((( 51 -move sample to "out" position 52 -)))|((( 53 -predefined 54 -))) 55 -|((( 56 -s_change 57 -)))|((( 58 -move sample to "change" position 59 -)))|((( 60 -predefined 61 -))) 62 62 63 -(% class="relative-table wrapped" style="width: 72.9307%;" %) 48 +=== {{id name="IDLcheatsheet-Absolutemovement"/}}Absolute movement === 49 + 50 +(% class="relative-table wrapped" style="width: 67.0892%;" %) 64 64 |=((( 65 65 IDL command 66 66 )))|=((( ... ... @@ -69,7 +69,7 @@ 69 69 motion 70 70 ))) 71 71 |((( 72 -goto_s_stage_x/z, 1 59 +##**goto_s_stage_x/z, 1**## 73 73 )))|((( 74 74 move rotation stage in x/z-direction to 1 mm 75 75 )))|((( ... ... @@ -76,7 +76,7 @@ 76 76 absolute [ mm ] 77 77 ))) 78 78 |((( 79 -goto_s_pos_x/y/z, 1 66 +##**goto_s_pos_x/y/z, 1**## 80 80 )))|((( 81 81 move sample stage in x/y/z-direction to 1 mm 82 82 )))|((( ... ... @@ -83,14 +83,16 @@ 83 83 absolute [ mm ] 84 84 ))) 85 85 |((( 86 -goto_s_angle, 90 73 +##**goto_s_angle, 90**## 87 87 )))|((( 88 -rotate sample around z axis to 90° 75 +rotate sample around z axis to 90° (**alias command: s_rot**) 89 89 )))|((( 90 90 absolute [ deg ] 91 91 ))) 92 92 93 -(% class="relative-table wrapped" style="width: 67.1421%;" %) 80 +=== {{id name="IDLcheatsheet-Getcurrentposition"/}}Get current position === 81 + 82 +(% class="relative-table wrapped" style="width: 54.0627%;" %) 94 94 |=((( 95 95 IDL command 96 96 )))|=((( ... ... @@ -97,21 +97,74 @@ 97 97 description 98 98 ))) 99 99 |((( 100 -pos_s_stage_x/z() 89 +##**pos_s_stage_x/z()**## 101 101 )))|((( 102 102 return current rotation stage in x/z position 103 103 ))) 104 104 |((( 105 -pos_s_pos_x/y/z() 94 +##**pos_s_pos_x/y/z()**## 106 106 )))|((( 107 107 return current sample stage in x/y/z position 108 108 ))) 109 109 |((( 110 -pos_s_angle() 99 +##**pos_s_angle()**## 111 111 )))|((( 112 112 return current rotation stage angle 113 113 ))) 114 114 104 +=== {{id name="IDLcheatsheet-Predefinedpositions"/}}Predefined positions === 105 + 106 +(% class="relative-table wrapped" style="width: 55.721%;" %) 107 +|=((( 108 +IDL command 109 +)))|=((( 110 +description 111 +))) 112 +|((( 113 +##**s_in**## 114 +)))|((( 115 +move sample to "in" position 116 +))) 117 +|((( 118 +##**s_out**## 119 +)))|((( 120 +move sample to "out" position 121 +))) 122 +|((( 123 +##**s_change**## 124 +)))|((( 125 +move sample to "change" position 126 +))) 127 +|((( 128 +##**set_s_in_pos, 0**## 129 +)))|((( 130 +set s_in position to 0.0 mm 131 +))) 132 +|((( 133 +##**set_s_out_dist, 10**## 134 +)))|((( 135 +set s_out distance to 10.0 mm 136 +))) 137 + 138 +=== {{id name="IDLcheatsheet-Magnificationsets"/}}Magnification sets === 139 + 140 +(% class="wrapped" %) 141 +|=((( 142 +IDL command 143 +)))|=((( 144 +description 145 +))) 146 +|((( 147 +##**save_magn_set, 'dmm_11000ev_cmos_10x'**## 148 +)))|((( 149 +save current magnification set 150 +))) 151 +|((( 152 +##**restore_magn_set, 'dmm_11000ev_cmos_10x'**## 153 +)))|((( 154 +restore magnification set with the name 'dmm_11000ev_cmos_10x' 155 +))) 156 + 115 115 == {{id name="IDLcheatsheet-Detectorpositioning"/}}Detector positioning == 116 116 117 117 (% class="wrapped fixed-table" %) ... ... @@ -123,30 +123,30 @@ 123 123 motion 124 124 ))) 125 125 |((( 126 - pressure_on168 +##**o_ccd_dist, 5**## 127 127 )))|((( 128 -e nabledetector ymovement170 +move detector in y direction relative by 5 mm 129 129 )))|((( 130 - \\172 +relative [ mm ] 131 131 ))) 132 132 |((( 133 -o_ccd_dist, 5175 +##**goto_o_ccd_dist, 30**## 134 134 )))|((( 135 -move detector in y direction 177 +move detector in y direction absoilute to 30 mm 136 136 )))|((( 137 - relative [ mm ]179 +\\ 138 138 ))) 139 139 |((( 140 -p ressure_off182 +##**pos_o_ccd_dist()**## 141 141 )))|((( 142 - disabledetectormovement184 +return current of the camera stage distance 143 143 )))|((( 144 144 \\ 145 145 ))) 146 146 147 -== {{id name="IDLcheatsheet- Makeimage"/}}Makeimage==189 +== {{id name="IDLcheatsheet-Slitpositioning"/}}Slit positioning == 148 148 149 -(% class="wrapped fixed-table" %)191 +(% class="wrapped" %) 150 150 |=((( 151 151 IDL command 152 152 )))|=((( ... ... @@ -153,35 +153,85 @@ 153 153 description 154 154 ))) 155 155 |((( 156 -i =quick(100) &tv_quick,i & draw_box, [ x1,x2 ,z1,z2 ]198 +##**slit_oh, rx=1 (rz=1)**## 157 157 )))|((( 158 -m akeanimage& showimage& drawbox200 +moves oh slit aperture horizontally (vertically) by 1mm 159 159 ))) 160 160 |((( 161 - a=quick_abs(100) &tv_quick,a & draw_box, [ x1,x2 ,z1,z2 ]203 +##**slit_oh, rdx=1 (rdz=1)**## 162 162 )))|((( 163 - makeanabsorptionimage& showimage& drawbox205 +opens oh the slit aperture horizontally (vertically) by 1 mm 164 164 ))) 207 +|((( 208 +##**slit_eh2, rx=1 (rz=1)**## 209 +)))|((( 210 +moves eh2 slit aperture horizontally (vertically) by 1 mm 211 +))) 212 +|((( 213 +##**slit_eh2, rdx=1 (rdz=1)**## 214 +)))|((( 215 +opens eh2 the slit aperture horizontally (vertically) by 1 mm 216 +))) 217 +|((( 218 +##**slit_info**## 219 +)))|((( 220 +show all slit positions 221 +))) 165 165 166 - =={{id name="IDLcheatsheet-Monochromatorpositioning"/}}Monochromatorpositioning==223 +rx, rdx, rz and rdz can be concatenated in one command (e.g. slit_oh, rx=1, rz=-2, rdx=0.5, rdz=0.5) 167 167 225 +== {{id name="IDLcheatsheet-Makeandsaveimages"/}}Make and save images == 226 + 168 168 (% class="wrapped fixed-table" %) 169 169 |=((( 170 170 IDL command 171 171 )))|=((( 172 172 description 173 -)))|=((( 174 -motion 175 175 ))) 176 176 |((( 177 -calc_dcm_energy, 10000, /set 234 +##**i=quick(100) & display_image, BYSTCL(i, 0, 4096) 235 +**## 178 178 )))|((( 179 -set DCM and undulator to 10 keV 237 +make an image & scale image (eg. from 0 to 4096, usually from 0 to maximum value the camera can do) 238 +))) 239 +|((( 240 +##**a=quick_abs(100) & display_image, BYTSCL(a, 0, 2)**## 180 180 )))|((( 242 +make an absorption image & scale image (usually from 0 to to 2) 243 +))) 244 +|((( 245 +##**write_tiff, '/gpfs/current/raw/test_projection.tif', i, /SHORT**## 246 +)))|((( 247 +save i as 16-bit integer tiff in /gpfs/... 248 +))) 249 +|((( 250 +##**write_tiff, '/gpfs/current/raw/test_absorption.tif', a, /FLOAT**## 251 +)))|((( 252 +save a as 32-bit float tiff in /gpfs/... 253 +))) 254 + 181 181 \\ 256 + 257 +\\ 258 + 259 +{{info title="Monochromator positioning"}} 260 +ATTENTION: Setting up a Monochromator as well as positioning front end slits is **only** done by the beamline staff! 261 + 262 +The commands above may be used by users to realign the beam should it beam profile drift with time. 263 +{{/info}} 264 + 265 +== {{id name="IDLcheatsheet-DCMpositioning"/}}DCM positioning == 266 + 267 +(% class="wrapped fixed-table" %) 268 +|=((( 269 +IDL command 270 +)))|=((( 271 +description 272 +)))|=((( 273 +motion 182 182 ))) 183 183 |((( 184 -dcm_pitch, 0.00001 276 +##**dcm_pitch, 0.00001**## 185 185 )))|((( 186 186 move 2nd crystal pitch by 0.00001 deg 187 187 )))|((( ... ... @@ -188,7 +188,7 @@ 188 188 relative [ deg ] 189 189 ))) 190 190 |((( 191 -goto_dcm_pitch, -0.03976 283 +##**goto_dcm_pitch, -0.03976**## 192 192 )))|((( 193 193 move 2nd crystal pitch to -0.03976 deg 194 194 )))|((( ... ... @@ -195,7 +195,7 @@ 195 195 absolute [ deg ] 196 196 ))) 197 197 |((( 198 -reflex_opt 290 +##**reflex_opt**## 199 199 )))|((( 200 200 move 2nd crystal pitch to optimal flux position 201 201 )))|((( ... ... @@ -202,16 +202,108 @@ 202 202 \\ 203 203 ))) 204 204 205 -== {{id name="IDLcheatsheet- Saveanimageastiff"/}}Saveanmageas tiff==297 +== {{id name="IDLcheatsheet-DMMpositioning"/}}DMM positioning == 206 206 207 -(% class="wrapped" %) 299 +(% class="fixed-table wrapped" %) 208 208 |=((( 209 209 IDL command 210 210 )))|=((( 211 -desciption 303 +description 304 +)))|=((( 305 +motion 212 212 ))) 213 213 |((( 214 - write_tiff, '/gpfs/current/raw/test.tif',i, /SHORT308 +##**dmm_x2_rot, 0.001**## 215 215 )))|((( 216 -save i as 16-bit tiff in /gofs/... 310 +move 2nd crystal pitch by 0.00001 deg 311 +)))|((( 312 +relative [ deg ] 217 217 ))) 314 +|((( 315 +##**goto_dmm_x2_rot, 0.8923 316 +**## 317 +)))|((( 318 +move 2nd crystal pitch to 0.8923 deg 319 +)))|((( 320 +absolute [ deg ] 321 +))) 322 + 323 +\\ 324 + 325 +== {{id name="IDLcheatsheet-Generalsyntax"/}}General syntax == 326 + 327 +(% class="wrapped relative-table" style="width: 45.5603%;" %) 328 +|=((( 329 +Functionality 330 +)))|=((( 331 +IDL syntax 332 +))) 333 +|((( 334 +chaining commands 335 +)))|((( 336 +command_1 **&** command_2 **&** ... 337 +))) 338 +|((( 339 +absolute movement 340 +)))|((( 341 +**goto_**//motor//, position 342 +))) 343 +|((( 344 +relative movement 345 +)))|((( 346 +//motor//, position 347 +))) 348 +|((( 349 +current motor position 350 +)))|((( 351 +**pos_**//motor//() 352 +))) 353 + 354 +== {{id name="IDLcheatsheet-BeamshutterandInterlockcontrol"/}}Beamshutter and Interlock control == 355 + 356 +(% class="wrapped relative-table" style="width: 75.0455%;" %) 357 +|=((( 358 +IDL command 359 +)))|=((( 360 +description 361 +))) 362 +|((( 363 +##**bs_info**## 364 +)))|((( 365 +prints an overview of the beamline beamshutter status 366 +))) 367 +|((( 368 +##**bsoh_open / bsoh_close**## 369 +)))|((( 370 +opens / closes the optics hutch beamshutter. Closing the OH beamshutter will close all following beamshutters (EH1, EH2) 371 +))) 372 +|((( 373 +##**bseh1_open / bseh1_close**## 374 +)))|((( 375 +opens / closes the EH1 beamshutter. Opening will open the OH beamshutter as well. Closing the OH beamshutter will the EH2 beamshutter as well 376 +))) 377 +|((( 378 +##**bseh2_open / bseh2_close**## 379 +)))|((( 380 +opens / closes the EH2 beamshutter. Openening will open the OH and EH1 beamshutters as well. 381 +))) 382 +|((( 383 +##**ics_info**## 384 +)))|((( 385 +prints an overview of the beamline interlock status 386 +))) 387 +|((( 388 +##**ics_break_oh**## 389 +)))|((( 390 +closes all P05 beamshutters and breaks OH door interlock. P06 beamshutter must be closed for this command to work! 391 +))) 392 +|((( 393 +##**ics_break_eh1**## 394 +)))|((( 395 +closes EH1 beamshutter (and EH2 beamshutter if open) and breaks EH1 door interlock 396 +))) 397 +|((( 398 +##**ics_break_eh2**## 399 +)))|((( 400 +closes EH2 beshutter and breaks EH2 door interlock 401 +)))
- Confluence.Code.ConfluencePageClass[0]
-
- Id
-
... ... @@ -1,1 +1,1 @@ 1 - 1091670011 +297508006 - URL
-
... ... @@ -1,1 +1,1 @@ 1 -https://confluence.desy.de/spaces/P5I/pages/ 109167001/IDL cheat sheet1 +https://confluence.desy.de/spaces/P5I/pages/297508006/IDL cheat sheet