-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathtest_ParticleRigidityCalculationTools.py
77 lines (42 loc) · 3.19 KB
/
test_ParticleRigidityCalculationTools.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
import numpy as np
import pandas as pd
import ParticleRigidityCalculationTools as PRCT
def test_getAtomicMass():
assert PRCT.getAtomicMass(12) == 24.3
def test_rigidityConversion():
particleKineticEnergyInMeV = [250.0, 578.5, 1056.8, 5123.9]
outputValues = PRCT.convertParticleEnergyToRigidity(particleKineticEnergyInMeV, particleMassAU = 1.0, particleChargeAU = 1.0)
roundedOutputValues = outputValues.apply(lambda x:round(x,2))
assert list(roundedOutputValues) == [0.73, 1.19,1.76, 5.99]
def oneDPround(inputVal):
return round(inputVal,1)
def test_rigidityAndEnergyConversion():
particleKineticEnergyInMeV = [250.0, 578.5, 1056.8, 5123.9]
outputRigidityValues = PRCT.convertParticleEnergyToRigidity(particleKineticEnergyInMeV, particleMassAU = 1.0, particleChargeAU = 1.0)
outputEnergyValues = PRCT.convertParticleRigidityToEnergy(outputRigidityValues, particleMassAU = 1.0, particleChargeAU = 1.0)
assert list(outputEnergyValues.apply(oneDPround)) == particleKineticEnergyInMeV
#######################################################
def test_EnergySpecToRigiditySpec():
energyValuesInMeV = [1000, 2000, 3000, 4000, 5000]
energyDistributionValues = [1, 0.5, 0.2, 0.1, 0.01]
rigiditySpec = PRCT.convertParticleEnergySpecToRigiditySpec(energyValuesInMeV,energyDistributionValues,particleMassAU = 1,particleChargeAU = 1)
assert rigiditySpec["Rigidity"].round(2).iloc[2] == 3.82
assert rigiditySpec["Rigidity distribution values"].round(2).iloc[2] == 194.24
def test_RigiditySpecToEnergySpec():
rigidityValuesInGV = np.linspace(0.0,10.0,19)
rigidityDistributionValues = np.linspace(0.0,10.0,19)
energySpec = PRCT.convertParticleRigiditySpecToEnergySpec(rigidityValuesInGV,rigidityDistributionValues,particleMassAU = 1,particleChargeAU = 1)
def test_BothSpectralConversions():
energyValuesInMeV = [1000, 2000, 3000, 4000, 5000]
energyDistributionValues = [1, 0.5, 0.2, 0.1, 0.01]
rigiditySpec = PRCT.convertParticleEnergySpecToRigiditySpec(energyValuesInMeV,energyDistributionValues,particleMassAU = 1,particleChargeAU = 1)
energySpec = PRCT.convertParticleRigiditySpecToEnergySpec(rigiditySpec["Rigidity"],rigiditySpec["Rigidity distribution values"],particleMassAU = 1,particleChargeAU = 1)
assert energySpec["Energy"].round(2).array == pd.Series(energyValuesInMeV).apply(float).round(2).array
assert energySpec["Energy distribution values"].round(2).array == pd.Series(energyDistributionValues).apply(float).round(2).array
def test_BothSpectralConversionsAlpha():
energyValuesInMeV = [1000, 2000, 3000, 4000, 5000]
energyDistributionValues = [1, 0.5, 0.2, 0.1, 0.01]
rigiditySpec = PRCT.convertParticleEnergySpecToRigiditySpec(energyValuesInMeV,energyDistributionValues,particleMassAU = 4,particleChargeAU = 2)
energySpec = PRCT.convertParticleRigiditySpecToEnergySpec(rigiditySpec["Rigidity"],rigiditySpec["Rigidity distribution values"],particleMassAU = 4,particleChargeAU = 2)
assert energySpec["Energy"].round(2).array == pd.Series(energyValuesInMeV).apply(float).round(2).array
assert energySpec["Energy distribution values"].round(2).array == pd.Series(energyDistributionValues).apply(float).round(2).array