|
___
|
|
---
|
|
___
|
|
|
|
|
|
---
|
|
|
|
|
|
# content
|
|
# content
|
|
|
|
|
... | @@ -13,44 +14,40 @@ ___ |
... | @@ -13,44 +14,40 @@ ___ |
|
- [analysis](#analysis)
|
|
- [analysis](#analysis)
|
|
- [detector number](#detector-number)
|
|
- [detector number](#detector-number)
|
|
|
|
|
|
___
|
|
---
|
|
___
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
## detectors
|
|
## detectors
|
|
|
|
|
|
| Name | Description | Ang. acceptance<br>HxV (deg) | Offset | Max tth | Det Num | Norm Det Num (d/I<sub>0</sub>) |
|
|
| 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|
|
|
| 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|
|
|
| tey | drain current | n/a | n/a | n/a | D32 | D36 |
|
|
| d4 | small diode | 0.25 x 2.5 | 0 | 151 | D34 | D38 |
|
|
| d4 | small diode | 0.25 x 2.5 | 0 | 151 | D34 | D38 |
|
|
| d3 | big diode | 2.5 x 2.5 | 24 | 175 | D33 | D37 |
|
|
| d3 | big diode | 2.5 x 2.5 | 24 | 175 | D33 | D37 |
|
|
| mcp | area det | diameter = 6 | 13 | 165 | D35 | D39 |
|
|
| 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 |
|
|
| vortex | fluorescence detector | 1 cm<sup>2</sup> | fixed port @ tth=-155 | n/a | D16 | D49 |
|
|
|
|
|
|
<br>
|
|
|
|
|
|
|
|
```python
|
|
```python
|
|
setdet('d3') # select a given detector (d3,d4, or mcp)
|
|
setdet('d3') # select a given detector (d3,d4, or mcp)
|
|
# DOES NOT MOVE MOTORS!
|
|
# DOES NOT MOVE MOTORS!
|
|
mvtth(90) # moves the selected detector
|
|
mvtth(90) # moves the selected detector
|
|
cts(1) # set counting time to 1s
|
|
scaler_cts(1) # set counting time to 1s
|
|
setgain('d3',2,'pA') # set gain for d3
|
|
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).
|
|
See below for a complete list of signals recorded during a scan and their corresponding [detector number](#detector-number) (Det Num).
|
|
|
|
|
|
<br>
|
|
|
|
|
|
|
|
## energy
|
|
## energy
|
|
|
|
|
|
|
|
|
|
```python
|
|
```python
|
|
energy(932) # set undulator (ID), mono, apertures and mirror
|
|
energy(932) # set undulator (ID), mono, apertures and mirror
|
|
polarization('V') # Turns the ID off and then sets the polarization:
|
|
polarization('V') # Turns the ID off and then sets the polarization:
|
|
# 'RCP', 'LCP', 'H', 'V'
|
|
# 'RCP', 'LCP', 'H', 'V'
|
|
# **need to set energy after a mode change!**
|
|
# **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
|
|
mono(500) # change mono
|
|
|
|
|
|
slit(100) # set energy resolving slits (and vertical beam size)
|
|
slit(100) # set energy resolving slits (and vertical beam size)
|
... | @@ -61,24 +58,20 @@ fit_centroid(n) # to calculate avg centroid position during scan n |
... | @@ -61,24 +58,20 @@ fit_centroid(n) # to calculate avg centroid position during scan n |
|
|
|
|
|
scanhv # scan mono only
|
|
scanhv # scan mono only
|
|
scanXAS # scan mono with variable step size; ID stays fix, can be offset with offset arg
|
|
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]]
|
|
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()
|
|
scanXAS_BL(E_Ti,mcp=True,m3r=True);plot_latest()
|
|
```
|
|
```
|
|
|
|
|
|
<br>
|
|
|
|
|
|
|
|
## diffractometer
|
|
## diffractometer
|
|
|
|
|
|
- m1 = kphi
|
|
- m1 = kphi
|
|
- m2 = x
|
|
- m2 = x
|
|
- m3 = y
|
|
- m3 = y
|
|
- m4 = z
|
|
- m4 = z
|
|
- m7 = kap
|
|
- m7 = kap
|
|
- m8 = kth
|
|
- m8 = kth
|
|
- m9 = tth
|
|
- m9 = tth
|
|
<br>
|
|
|
|
|
|
|
|
```python
|
|
```python
|
|
uan(tth,th) # moves th & tth simulatenously
|
|
uan(tth,th) # moves th & tth simulatenously
|
... | @@ -89,9 +82,7 @@ mprint() # prints current motor position |
... | @@ -89,9 +82,7 @@ mprint() # prints current motor position |
|
# returns [x,y,z,tth,ktrh,kap,kphi]
|
|
# returns [x,y,z,tth,ktrh,kap,kphi]
|
|
mysample=['name',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
|
|
mvsample(mysample) # moves to mysample, does not move tth
|
|
|
|
|
|
```
|
|
```
|
|
<br>
|
|
|
|
|
|
|
|
## motor scans
|
|
## motor scans
|
|
|
|
|
... | @@ -112,27 +103,22 @@ hkl=[0.5,0,0] |
... | @@ -112,27 +103,22 @@ hkl=[0.5,0,0] |
|
E_Ti=[[445,455,0.5],[455,468,0.1],[468,475,0.5],[475,480,1]]
|
|
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
|
|
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
|
|
## srs setup
|
|
|
|
|
|
With shutter close or slit at 0 (faster), 'INPUT OFFSET' set 'ON' and 'UNCAL'
|
|
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)
|
|
|
|
|
|
- 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)
|
|
- 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
|
|
- 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
|
|
- try decreasing the offset gain: if it drops to zero, then go back to previous gain and increase the number; try again.
|
|
- try decreasing the offset gain: if it drops to zero, then go back to previous gain and increase the number; try again.
|
|
- the goal is to slowly bring the gain down while keeping a non zero signal; typically a few hundred Hz
|
|
- 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
|
|
- 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
|
|
## mcp
|
|
|
|
|
|
```python
|
|
```python
|
|
MPA_HV_ON()
|
|
MPA_HV_ON()
|
|
MPA_HV_Set(2975)
|
|
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 |
... | @@ -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
|
|
roi=4; MPA_ROI_SetUp(535,539,400,400,roi) #set up ROI4 = 400x400 at the center of MCP
|
|
```
|
|
```
|
|
|
|
|
|
|
|
|
|
<br>
|
|
|
|
|
|
|
|
## vortex
|
|
## 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
|
|
```python
|
|
vortex(855) # Sets vortex window based upon calibration
|
|
vortex(855) # Sets vortex window based upon calibration
|
|
mcacounttime(2) # Sets count time for mca and other det to 2s
|
|
mcacounttime(2) # Sets count time for mca and other det to 2s
|
|
```
|
|
```
|
|
|
|
|
|
2 different acquisition modes:
|
|
2 different acquisition modes:
|
|
|
|
|
|
```python
|
|
```python
|
|
|
|
|
|
mcascan() # adds vortex channels as detectors in scan detector list (see detector numbers below)
|
|
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 |
... | @@ -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#
|
|
# 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
|
|
mcascan(add_vortex=False) # chooses to ignore vortex channels and removes them from scan detector list
|
|
|
|
|
|
```
|
|
```
|
|
|
|
|
|
<br>
|
|
|
|
|
|
|
|
## analysis
|
|
## analysis
|
|
|
|
|
|
#### basic mda plots:
|
|
#### basic mda plots:
|
|
|
|
|
|
```python
|
|
```python
|
|
# n1,n2,n3 is a scan number
|
|
# n1,n2,n3 is a scan number
|
|
# d1,d2,d3 is a detector number - see table below
|
|
# 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' |
... | @@ -189,7 +172,9 @@ fit_mda(n, d, FWHM_guess,function) # 'gauss', 'lorz', 'erf', 'box' |
|
# xrange=[x1,x2] to fit subrange
|
|
# xrange=[x1,x2] to fit subrange
|
|
fit_mda(n, d, poly_order,'poly')
|
|
fit_mda(n, d, poly_order,'poly')
|
|
```
|
|
```
|
|
|
|
|
|
Custom functions for scattering:
|
|
Custom functions for scattering:
|
|
|
|
|
|
```python
|
|
```python
|
|
plot_latest() # plot last scan with currently selected detector; use norm=31 to normalize with I0
|
|
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
|
|
fit_z() # erf fit for last scan on d3
|
... | @@ -198,8 +183,8 @@ fit_d3() # gaussian 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
|
|
fit_centroid(n) # to calculate avg centroid position during scan n
|
|
```
|
|
```
|
|
|
|
|
|
|
|
|
|
#### nData
|
|
#### nData
|
|
|
|
|
|
```python
|
|
```python
|
|
from Macros_29id.IEX_nData import *
|
|
from Macros_29id.IEX_nData import *
|
|
|
|
|
... | @@ -225,8 +210,8 @@ plt.show() |
... | @@ -225,8 +210,8 @@ plt.show() |
|
%matplotlib inline # inline plot
|
|
%matplotlib inline # inline plot
|
|
```
|
|
```
|
|
|
|
|
|
|
|
|
|
#### mdaFile
|
|
#### mdaFile
|
|
|
|
|
|
```python
|
|
```python
|
|
mydata=mdaFile(1,3) # loads mda scans 1 to 3
|
|
mydata=mdaFile(1,3) # loads mda scans 1 to 3
|
|
mydata.update(4) # loads another scan
|
|
mydata.update(4) # loads another scan
|
... | @@ -235,38 +220,35 @@ mydata.header[3].all # return dictionary of metadata |
... | @@ -235,38 +220,35 @@ mydata.header[3].all # return dictionary of metadata |
|
mydata.header[3].UB # return dictionary of UB metadata
|
|
mydata.header[3].UB # return dictionary of UB metadata
|
|
```
|
|
```
|
|
|
|
|
|
<br>
|
|
|
|
|
|
|
|
## detector number
|
|
## detector number
|
|
|
|
|
|
| Detector | Det Number Raw signal | Det Number Normalized (d/I<sub>0</sub>) | Description | PV | Controller |
|
|
| 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 |
|
|
| 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 |
|
|
| TEY | 32 | 36 | Total Electron Yield | 29idMZ0:scaler1.S2 29idMZ0:scaler1_calc1.B | SRS2 |
|
|
| D3 | 33 | 37 | Big diode (2.5 deg) | 29idMZ0:scaler1.S3 29idMZ0:scaler1_calc1.C | SRS3 |
|
|
| D3 | 33 | 37 | Big diode (2.5 deg) | 29idMZ0:scaler1.S3 29idMZ0:scaler1_calc1.C | SRS3 |
|
|
| D4 | 34 | 38 | Small diode (0.15 deg) | 29idMZ0:scaler1.S4 29idMZ0:scaler1_calc1.D | SRS4 |
|
|
| D4 | 34 | 38 | Small diode (0.15 deg) | 29idMZ0:scaler1.S4 29idMZ0:scaler1_calc1.D | SRS4 |
|
|
| | | | | | |
|
|
| | | | | | |
|
|
| MCP | 35 | 39 | TFY - analog signal | 29idMZ0:scaler1.S5 29idMZ0:scaler1_calc1.E | MPA |
|
|
| MCP | 35 | 39 | TFY - analog signal | 29idMZ0:scaler1.S5 29idMZ0:scaler1_calc1.E | MPA |
|
|
| MCP ROI1 | 41 | | 50x50 ROI centered on MCP center | 29iddMPA:Stats1:Total_RBV | |
|
|
| MCP ROI1 | 41 | | 50x50 ROI centered on MCP center | 29iddMPA:Stats1:Total_RBV | |
|
|
| MCP ROI2 | 42 | | 100x100 ROI centered on MCP center | 29iddMPA:Stats2:Total_RBV | |
|
|
| MCP ROI2 | 42 | | 100x100 ROI centered on MCP center | 29iddMPA:Stats2:Total_RBV | |
|
|
| MCP ROI3 | 43 | | 200x200 ROI centered on MCP center | 29iddMPA:Stats3:Total_RBV | |
|
|
| MCP ROI3 | 43 | | 200x200 ROI centered on MCP center | 29iddMPA:Stats3:Total_RBV | |
|
|
| MCP ROI4 | 44 | | 400x400 ROI centered on MCP center | 29iddMPA:Stats4:Total_RBV | |
|
|
| MCP ROI4 | 44 | | 400x400 ROI centered on MCP center | 29iddMPA:Stats4:Total_RBV | |
|
|
| MCP ROI5 | 45 | | MCP integrated intensity (stats) | 29iddMPA:Stats5:Total_RBV | |
|
|
| MCP ROI5 | 45 | | MCP integrated intensity (stats) | 29iddMPA:Stats5:Total_RBV | |
|
|
| | | | | | |
|
|
| | | | | | |
|
|
| Vortex | 16 | 49 | TFY - centered on desired energy | 29idVORTEX:mca1.R0 29idd:userTran1.D| |
|
|
| Vortex | 16 | 49 | TFY - centered on desired energy | 29idVORTEX:mca1.R0 29idd:userTran1.D | |
|
|
| Vortex | 17 | 50 | TFY - centered on Oxygen energy | 29idVORTEX:mca1.R1 29idd:userTran1.E | |
|
|
| Vortex | 17 | 50 | TFY - centered on Oxygen energy | 29idVORTEX:mca1.R1 29idd:userTran1.E | |
|
|
| | | | | | |
|
|
| | | | | | |
|
|
| H | 46 | | Miller index | 29idKappa:userArrayCalc1.L | |
|
|
| H | 46 | | Miller index | 29idKappa:userArrayCalc1.L | |
|
|
| K | 47 | | Miller index | 29idKappa:userArrayCalc2.L | |
|
|
| K | 47 | | Miller index | 29idKappa:userArrayCalc2.L | |
|
|
| L | 48 | | Miller index | 29idKappa:userArrayCalc3.L | |
|
|
| L | 48 | | Miller index | 29idKappa:userArrayCalc3.L | |
|
|
| kth | 51 | | | 29idKappa:m8.RBV | |
|
|
| kth | 51 | | | 29idKappa:m8.RBV | |
|
|
| kap | 52 | | | 29idKappa:m7.RBV | |
|
|
| kap | 52 | | | 29idKappa:m7.RBV | |
|
|
| kphi | 53 | | | 29idKappa:m1.RBV | |
|
|
| kphi | 53 | | | 29idKappa:m1.RBV | |
|
|
| tth | 54 | | | 29idKappa:m9.RBV | |
|
|
| tth | 54 | | | 29idKappa:m9.RBV | |
|
|
| th | 55 | | | 29idKappa:Euler_ThetaRBV | |
|
|
| th | 55 | | | 29idKappa:Euler_ThetaRBV | |
|
|
| chi | 56 | | | 29idKappa:Euler_ChiRBV | |
|
|
| chi | 56 | | | 29idKappa:Euler_ChiRBV | |
|
|
| phi | 57 | | | 29idKappa:Euler_PhiRBV | |
|
|
| phi | 57 | | | 29idKappa:Euler_PhiRBV | |
|
|
| | | | | | |
|
|
| | | | | | |
|
|
|
|
|
|
|
|
|