Changes for page IDL cheat sheet

Last modified by fwilde on 2025/03/28 19:55

From version 22.1
edited by fwilde
on 2018/11/28 17:53
Change comment: There is no comment for this version
To version 46.1
edited by fwilde
on 2020/10/10 12:21
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -1,11 +3,13 @@
1 -This is an overview of the most commonly used commands during a beamtime.
2 -
3 3  == {{id name="IDLcheatsheet-Coordinatesystem"/}}Coordinate system ==
4 4  
5 -[[image:attach:P5I.Instrumentation.P05 experimental hutch 2.Micro Tomography setup overview.WebHome@eh2_setup_povray_labeled.png||height="400"]]
3 +Right-handed coordinate system with y-direction along the x-ray beam.
6 6  
5 +[[image:attach:p05_uct.png||width="700"]]
6 +
7 7  == {{id name="IDLcheatsheet-Samplepositioning"/}}Sample positioning ==
8 8  
9 +=== {{id name="IDLcheatsheet-Relativemovement"/}}Relative movement ===
10 +
9 9  (% class="wrapped fixed-table" %)
10 10  |=(((
11 11  IDL command
... ... @@ -15,7 +15,7 @@
15 15  motion
16 16  )))
17 17  |(((
18 -s_stage_x/z, 1
20 +##**s_stage_x/z, 1**##
19 19  )))|(((
20 20  move rotation stage in x/z-direction by 1 mm
21 21  )))|(((
... ... @@ -22,14 +22,14 @@
22 22  relative [ mm ]
23 23  )))
24 24  |(((
25 -s_pos_z, 1
27 +##**s_pos_x/y/z, 1**##
26 26  )))|(((
27 -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)
28 28  )))|(((
29 29  relative [ mm ]
30 30  )))
31 31  |(((
32 -s_pos_lateral, 1
34 +##**s_pos_lateral, 1**##
33 33  )))|(((
34 34  move sample stage in x-direction by 1 mm, regardless of position of rotation axis
35 35  )))|(((
... ... @@ -36,35 +36,16 @@
36 36  relative [ mm ]
37 37  )))
38 38  |(((
39 -s_angle, 90
41 +##**s_angle, 90**##
40 40  )))|(((
41 41  rotate sample around z axis
42 42  )))|(((
43 43  relative [ deg ]
44 44  )))
45 -|(((
46 -s_in
47 -)))|(((
48 -move sample to "in" position
49 -)))|(((
50 -predefined
51 -)))
52 -|(((
53 -s_out
54 -)))|(((
55 -move sample to "out" position
56 -)))|(((
57 -predefined
58 -)))
59 -|(((
60 -s_change
61 -)))|(((
62 -move sample to "change" position
63 -)))|(((
64 -predefined
65 -)))
66 66  
67 -(% 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%;" %)
68 68  |=(((
69 69  IDL command
70 70  )))|=(((
... ... @@ -73,7 +73,7 @@
73 73  motion
74 74  )))
75 75  |(((
76 -goto_s_stage_x/z, 1
59 +##**goto_s_stage_x/z, 1**##
77 77  )))|(((
78 78  move rotation stage in x/z-direction to 1 mm
79 79  )))|(((
... ... @@ -80,7 +80,7 @@
80 80  absolute [ mm ]
81 81  )))
82 82  |(((
83 -goto_s_pos_x/y/z, 1
66 +##**goto_s_pos_x/y/z, 1**##
84 84  )))|(((
85 85  move sample stage in x/y/z-direction to 1  mm
86 86  )))|(((
... ... @@ -87,14 +87,16 @@
87 87  absolute [ mm ]
88 88  )))
89 89  |(((
90 -goto_s_angle, 90
73 +##**goto_s_angle, 90**##
91 91  )))|(((
92 -rotate sample around z axis to 90°
75 +rotate sample around z axis to 90° (**alias command: s_rot**)
93 93  )))|(((
94 94  absolute [ deg ]
95 95  )))
96 96  
97 -(% 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%;" %)
98 98  |=(((
99 99  IDL command
100 100  )))|=(((
... ... @@ -101,21 +101,74 @@
101 101  description
102 102  )))
103 103  |(((
104 -pos_s_stage_x/z()
89 +##**pos_s_stage_x/z()**##
105 105  )))|(((
106 106  return current rotation stage in x/z position
107 107  )))
108 108  |(((
109 -pos_s_pos_x/y/z()
94 +##**pos_s_pos_x/y/z()**##
110 110  )))|(((
111 111  return current sample stage in x/y/z position
112 112  )))
113 113  |(((
114 -pos_s_angle()
99 +##**pos_s_angle()**##
115 115  )))|(((
116 116  return current rotation stage angle
117 117  )))
118 118  
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 +
119 119  == {{id name="IDLcheatsheet-Detectorpositioning"/}}Detector positioning ==
120 120  
121 121  (% class="wrapped fixed-table" %)
... ... @@ -127,7 +127,7 @@
127 127  motion
128 128  )))
129 129  |(((
130 -pressure_on
168 +##**pressure_on**##
131 131  )))|(((
132 132  enable detector y movement
133 133  )))|(((
... ... @@ -134,7 +134,7 @@
134 134  \\
135 135  )))
136 136  |(((
137 -o_ccd_dist, 5
175 +##**o_ccd_dist, 5**##
138 138  )))|(((
139 139  move detector in y direction
140 140  )))|(((
... ... @@ -141,7 +141,7 @@
141 141  relative [ mm ]
142 142  )))
143 143  |(((
144 -pressure_off
182 +##**pressure_off**##
145 145  )))|(((
146 146  disable detector movement
147 147  )))|(((
... ... @@ -148,8 +148,34 @@
148 148  \\
149 149  )))
150 150  
151 -== {{id name="IDLcheatsheet-Makeimage"/}}Make image ==
189 +== {{id name="IDLcheatsheet-Slitpositioning"/}}Slit positioning ==
152 152  
191 +(% class="wrapped" %)
192 +|=(((
193 +IDL command
194 +)))|=(((
195 +description
196 +)))
197 +|(((
198 +##**slit_eh2, rx=1 (rz=1)**##
199 +)))|(((
200 +moves eh2 slit aperture horizontally (vertically) by 1mm , **works analoguous for slit_oh and slit_ps2**
201 +)))
202 +|(((
203 +##**slit_eh2, rdz=1 (rdz=1)**##
204 +)))|(((
205 +opens eh2 the slit aperture horizontally (vertically) by 1 mm, **works analoguous for slit_oh and slit_ps2**
206 +)))
207 +|(((
208 +##**slit_info**##
209 +)))|(((
210 +show all slit positions
211 +)))
212 +
213 +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)
214 +
215 +== {{id name="IDLcheatsheet-Makeimages"/}}Make images ==
216 +
153 153  (% class="wrapped fixed-table" %)
154 154  |=(((
155 155  IDL command
... ... @@ -157,15 +157,20 @@
157 157  description
158 158  )))
159 159  |(((
160 -i=quick(100) & tv_quick, i & draw_box, [ x1, x2 ,z1 ,z2 ]
224 +##**i=quick(100) & tv_quick, i & draw_box, [ x1, x2 ,z1 ,z2 ]**##
161 161  )))|(((
162 162  make an image & show image & draw box
163 163  )))
164 164  |(((
165 -a=quick_abs(100) & tv_quick, a & draw_box, [ x1, x2 ,z1 ,z2 ]
229 +##**a=quick_abs(100) & tv_quick, a & draw_box, [ x1, x2 ,z1 ,z2 ]**##
166 166  )))|(((
167 167  make an absorption image & show image & draw box
168 168  )))
233 +|(((
234 +##**write_tiff, '/gpfs/current/raw/test.tif', i, /SHORT**##
235 +)))|(((
236 +save i as 16-bit tiff in /gpfs/...
237 +)))
169 169  
170 170  == {{id name="IDLcheatsheet-Monochromatorpositioning"/}}Monochromator positioning ==
171 171  
... ... @@ -178,7 +178,7 @@
178 178  motion
179 179  )))
180 180  |(((
181 -calc_dcm_energy, 10000, /set
250 +##**calc_dcm_energy, 10000, /set**##
182 182  )))|(((
183 183  set DCM and undulator to 10 keV
184 184  )))|(((
... ... @@ -185,7 +185,7 @@
185 185  \\
186 186  )))
187 187  |(((
188 -dcm_pitch, 0.00001
257 +##**dcm_pitch, 0.00001**##
189 189  )))|(((
190 190  move 2nd crystal pitch by 0.00001 deg
191 191  )))|(((
... ... @@ -192,7 +192,7 @@
192 192  relative [ deg ]
193 193  )))
194 194  |(((
195 -goto_dcm_pitch,  -0.03976
264 +##**goto_dcm_pitch,  -0.03976**##
196 196  )))|(((
197 197  move 2nd crystal pitch to -0.03976 deg
198 198  )))|(((
... ... @@ -199,23 +199,101 @@
199 199  absolute [ deg ]
200 200  )))
201 201  |(((
202 -reflex_opt
271 +##**reflex_opt**##
203 203  )))|(((
204 204  move 2nd crystal pitch to optimal flux position
205 205  )))|(((
206 206  \\
207 207  )))
277 +|(((
278 +##**gap, 0.01**##
279 +)))|(((
280 +move undulator gap relative by 0.01 mm
281 +)))|(((
282 +relative [ mm ]
283 +)))
284 +|(((
285 +##**goto_gap, 10.0**##
286 +)))|(((
287 +move undulator gap absolute to 10.0 mm
288 +)))|(((
289 +absolute [ mm ]
290 +)))
208 208  
209 -== {{id name="IDLcheatsheet-Saveanimageastiff"/}}Save an image as tiff ==
292 +== {{id name="IDLcheatsheet-Generalsyntax"/}}General syntax ==
210 210  
211 -(% class="wrapped" %)
294 +(% class="wrapped relative-table" style="width: 45.5603%;" %)
212 212  |=(((
296 +Functionality
297 +)))|=(((
298 +IDL syntax
299 +)))
300 +|(((
301 +chaining commands
302 +)))|(((
303 +command_1 **&** command_2 **&** ...
304 +)))
305 +|(((
306 +absolute movement
307 +)))|(((
308 +**goto_**//motor//, position
309 +)))
310 +|(((
311 +relative movement
312 +)))|(((
313 +//motor//, position
314 +)))
315 +|(((
316 +current motor position
317 +)))|(((
318 +**pos_**//motor//()
319 +)))
320 +
321 +== {{id name="IDLcheatsheet-BeamshutterandInterlockcontrol"/}}Beamshutter and Interlock control ==
322 +
323 +(% class="wrapped relative-table" style="width: 75.0455%;" %)
324 +|=(((
213 213  IDL command
214 214  )))|=(((
215 -desciption
327 +description
216 216  )))
217 217  |(((
218 -write_tiff, '/gpfs/current/raw/test.tif', i, /SHORT
330 +##**bs_info**##
219 219  )))|(((
220 -save i as 16-bit tiff in /gofs/...
332 +prints an overview of the beamline beamshutter status
221 221  )))
334 +|(((
335 +##**bsoh_open / bsoh_close**##
336 +)))|(((
337 +opens / closes the optics hutch beamshutter. Closing the OH beamshutter will close all following beamshutters (EH1, EH2)
338 +)))
339 +|(((
340 +##**bseh1_open / bseh1_close**##
341 +)))|(((
342 +opens / closes the EH1 beamshutter. Opening will open the OH beamshutter as well. Closing the OH beamshutter will the EH2 beamshutter as well
343 +)))
344 +|(((
345 +##**bseh2_open / bseh2_close**##
346 +)))|(((
347 +opens / closes the EH2 beamshutter. Openening will open the OH and EH1 beamshutters as well.
348 +)))
349 +|(((
350 +##**ics_info**##
351 +)))|(((
352 +prints an overview of the beamline interlock status
353 +)))
354 +|(((
355 +##**ics_break_oh**##
356 +)))|(((
357 +closes all P05 beamshutters and breaks OH door interlock. P06 beamshutter must be closed for this command to work!
358 +)))
359 +|(((
360 +##**ics_break_eh1**##
361 +)))|(((
362 +closes EH1 beamshutter (and EH2 beamshutter  if open) and breaks EH1 door interlock
363 +)))
364 +|(((
365 +##**ics_break_eh2**##
366 +)))|(((
367 +closes EH2 beshutter and breaks EH2 door interlock
368 +)))
Confluence.Code.ConfluencePageClass[0]
Id
... ... @@ -1,1 +1,1 @@
1 -109167004
1 +179783458
URL
... ... @@ -1,1 +1,1 @@
1 -https://confluence.desy.de/spaces/P5I/pages/109167004/IDL cheat sheet
1 +https://confluence.desy.de/spaces/P5I/pages/179783458/IDL cheat sheet