|
|
___
|
|
|
___
|
|
|
---
|
|
|
|
|
|
---
|
|
|
|
|
|
# content
|
|
|
|
... | ... | @@ -13,14 +14,14 @@ ___ |
|
|
- [analysis](#analysis)
|
|
|
- [detector number](#detector-number)
|
|
|
|
|
|
___
|
|
|
___
|
|
|
---
|
|
|
|
|
|
---
|
|
|
|
|
|
## detectors
|
|
|
|
|
|
| Name | Description | Ang. acceptance<br>HxV (deg) | Offset | Max tth | Det Num | Norm Det Num (d/I<sub>0</sub>) |
|
|
|
|:----:|:-------------:|:----------------------------:|:-----------:|:-------:|:-------:|:-------:|
|
|
|
|------|-------------|------------------------------|--------|---------|---------|--------------------------------|
|
|
|
| mesh (I<sub>0</sub>) | Au mesh | 1 cm<sup>2</sup> | n/a | n/a | D31 | n/a |
|
|
|
| tey | drain current | n/a | n/a | n/a | D32 | D36 |
|
|
|
| d4 | small diode | 0.25 x 2.5 | 0 | 151 | D34 | D38 |
|
... | ... | @@ -28,29 +29,25 @@ ___ |
|
|
| mcp | area det | diameter = 6 | 13 | 165 | D35 | D39 |
|
|
|
| vortex | fluorescence detector | 1 cm<sup>2</sup> | fixed port @ tth=-155 | n/a | D16 | D49 |
|
|
|
|
|
|
<br>
|
|
|
|
|
|
```python
|
|
|
setdet('d3') # select a given detector (d3,d4, or mcp)
|
|
|
# DOES NOT MOVE MOTORS!
|
|
|
mvtth(90) # moves the selected detector
|
|
|
cts(1) # set counting time to 1s
|
|
|
setgain('d3',2,'pA') # set gain for d3
|
|
|
scaler_cts(1) # set counting time to 1s
|
|
|
d3.setgain(2,'pA') # set gain for d3 to 2 pA
|
|
|
```
|
|
|
|
|
|
See below for a complete list of signals recorded during a scan and their corresponding [detector number](#detector-number) (Det Num).
|
|
|
|
|
|
<br>
|
|
|
|
|
|
## energy
|
|
|
|
|
|
|
|
|
```python
|
|
|
energy(932) # set undulator (ID), mono, apertures and mirror
|
|
|
polarization('V') # Turns the ID off and then sets the polarization:
|
|
|
# 'RCP', 'LCP', 'H', 'V'
|
|
|
# **need to set energy after a mode change!**
|
|
|
Switch_IDQP('V') # turns on quasiperiodic mode for V polarization
|
|
|
ID_start('V',75) # turns on quasiperiodic mode for V polarization at 75 percent periodic (QP_ratio: 70 - 100)
|
|
|
mono(500) # change mono
|
|
|
|
|
|
slit(100) # set energy resolving slits (and vertical beam size)
|
... | ... | @@ -61,14 +58,11 @@ fit_centroid(n) # to calculate avg centroid position during scan n |
|
|
|
|
|
scanhv # scan mono only
|
|
|
scanXAS # scan mono with variable step size; ID stays fix, can be offset with offset arg
|
|
|
scanXAS_BL # scan mono & ID with variable step size \
|
|
|
|
|
|
E_Ti=[[445,455,0.5],[455,468,0.1],[468,475,0.5],[475,480,1]]
|
|
|
scanXAS_BL(E_Ti,mcp=True,m3r=True);plot_latest()
|
|
|
```
|
|
|
|
|
|
<br>
|
|
|
|
|
|
## diffractometer
|
|
|
|
|
|
- m1 = kphi
|
... | ... | @@ -78,7 +72,6 @@ scanXAS_BL(E_Ti,mcp=True,m3r=True);plot_latest() |
|
|
- m7 = kap
|
|
|
- m8 = kth
|
|
|
- m9 = tth
|
|
|
<br>
|
|
|
|
|
|
```python
|
|
|
uan(tth,th) # moves th & tth simulatenously
|
... | ... | @@ -89,9 +82,7 @@ mprint() # prints current motor position |
|
|
# returns [x,y,z,tth,ktrh,kap,kphi]
|
|
|
mysample=['name',x,y,z,tth,ktrh,kap,kphi]
|
|
|
mvsample(mysample) # moves to mysample, does not move tth
|
|
|
|
|
|
```
|
|
|
<br>
|
|
|
|
|
|
## motor scans
|
|
|
|
... | ... | @@ -112,16 +103,13 @@ hkl=[0.5,0,0] |
|
|
E_Ti=[[445,455,0.5],[455,468,0.1],[468,475,0.5],[475,480,1]]
|
|
|
scanhkl_E(E_Ti,hkl,1,scan_ID=True) # energy list, Q, cts, scan_ID = False (fixed ID) or True
|
|
|
|
|
|
Clear_Scan_Positioners('Kappa') # remove extra positioners (eg after th2th or hkl scan)
|
|
|
scan_positioners_clear() # remove extra positioners (eg after th2th or hkl scan)
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
<br>
|
|
|
|
|
|
## srs setup
|
|
|
|
|
|
With shutter close or slit at 0 (faster), 'INPUT OFFSET' set 'ON' and 'UNCAL'
|
|
|
|
|
|
- make sure the count goes down (not up) when closing the shutter! If the count goes up without beam, change the INVERT ON/OFF - as of 2021_2 all of our SRSs are INVERT ON (D3/D4/TEY/mesh)
|
|
|
- Set gain relatively high for the offset (same as sensitivity or more)
|
|
|
- play with the tweak button one way or the other to get a stable number (ie does not slowly goes down to zero); you might need to play with the +/- for that
|
... | ... | @@ -129,10 +117,8 @@ With shutter close or slit at 0 (faster), 'INPUT OFFSET' set 'ON' and 'UNCAL' |
|
|
- the goal is to slowly bring the gain down while keeping a non zero signal; typically a few hundred Hz
|
|
|
- adjust until the final INPUT OFFSET gain should be at least 1 order of magnitude lower than the SENSITIVITY with a few hundreds counts
|
|
|
|
|
|
|
|
|
<br>
|
|
|
|
|
|
## mcp
|
|
|
|
|
|
```python
|
|
|
MPA_HV_ON()
|
|
|
MPA_HV_Set(2975)
|
... | ... | @@ -146,18 +132,17 @@ roi=3; MPA_ROI_SetUp(535,539,200,200,roi) #set up ROI3 = 200x200 at the center |
|
|
roi=4; MPA_ROI_SetUp(535,539,400,400,roi) #set up ROI4 = 400x400 at the center of MCP
|
|
|
```
|
|
|
|
|
|
|
|
|
<br>
|
|
|
|
|
|
## vortex
|
|
|
For detailed instructions see [manual here](https://git.aps.anl.gov/rodolakis/Macros_29id/-/wikis/RSXS/vortex).
|
|
|
|
|
|
For detailed instructions see [manual here](https://git.aps.anl.gov/rodolakis/Macros_29id/-/wikis/RSXS/vortex).
|
|
|
|
|
|
```python
|
|
|
vortex(855) # Sets vortex window based upon calibration
|
|
|
mcacounttime(2) # Sets count time for mca and other det to 2s
|
|
|
```
|
|
|
|
|
|
2 different acquisition modes:
|
|
|
|
|
|
```python
|
|
|
|
|
|
mcascan() # adds vortex channels as detectors in scan detector list (see detector numbers below)
|
... | ... | @@ -168,14 +153,12 @@ mcascan(save_image=True) # same as above + saves mca spectra taken at eac |
|
|
# MCA spectra are saved into subdirectories of the scan files / scan#
|
|
|
|
|
|
mcascan(add_vortex=False) # chooses to ignore vortex channels and removes them from scan detector list
|
|
|
|
|
|
```
|
|
|
|
|
|
<br>
|
|
|
|
|
|
## analysis
|
|
|
|
|
|
#### basic mda plots:
|
|
|
|
|
|
```python
|
|
|
# n1,n2,n3 is a scan number
|
|
|
# d1,d2,d3 is a detector number - see table below
|
... | ... | @@ -189,7 +172,9 @@ fit_mda(n, d, FWHM_guess,function) # 'gauss', 'lorz', 'erf', 'box' |
|
|
# xrange=[x1,x2] to fit subrange
|
|
|
fit_mda(n, d, poly_order,'poly')
|
|
|
```
|
|
|
|
|
|
Custom functions for scattering:
|
|
|
|
|
|
```python
|
|
|
plot_latest() # plot last scan with currently selected detector; use norm=31 to normalize with I0
|
|
|
fit_z() # erf fit for last scan on d3
|
... | ... | @@ -198,8 +183,8 @@ fit_d3() # gaussian fit for last scan on d3 |
|
|
fit_centroid(n) # to calculate avg centroid position during scan n
|
|
|
```
|
|
|
|
|
|
|
|
|
#### nData
|
|
|
|
|
|
```python
|
|
|
from Macros_29id.IEX_nData import *
|
|
|
|
... | ... | @@ -225,8 +210,8 @@ plt.show() |
|
|
%matplotlib inline # inline plot
|
|
|
```
|
|
|
|
|
|
|
|
|
#### mdaFile
|
|
|
|
|
|
```python
|
|
|
mydata=mdaFile(1,3) # loads mda scans 1 to 3
|
|
|
mydata.update(4) # loads another scan
|
... | ... | @@ -235,12 +220,10 @@ mydata.header[3].all # return dictionary of metadata |
|
|
mydata.header[3].UB # return dictionary of UB metadata
|
|
|
```
|
|
|
|
|
|
<br>
|
|
|
|
|
|
## detector number
|
|
|
|
|
|
| Detector | Det Number Raw signal | Det Number Normalized (d/I<sub>0</sub>) | Description | PV | Controller |
|
|
|
|:--------: |:---------------------: |:-------------------: |:-----------------------------------------------------: |:--------------------------: |:----------: |
|
|
|
|----------|-----------------------|-----------------------------------------|-------------|----|------------|
|
|
|
| | | | | | |
|
|
|
| Mesh | 31 | n/a | Incident energy (I0) | 29idMZ0:scaler1.S14 | SRS1 |
|
|
|
| TEY | 32 | 36 | Total Electron Yield | 29idMZ0:scaler1.S2 29idMZ0:scaler1_calc1.B | SRS2 |
|
... | ... | @@ -269,4 +252,3 @@ mydata.header[3].UB # return dictionary of UB metadata |
|
|
| phi | 57 | | | 29idKappa:Euler_PhiRBV | |
|
|
|
| | | | | | |
|
|
|
|
|
|
|