-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathcomputeCFactors.H
101 lines (86 loc) · 2.77 KB
/
computeCFactors.H
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
//Pre-compute and store Cgix, Cgiy and Cgixy
forAll(flux, energyI)
{
for(int lines=0; lines<klines; lines++)
{
wa=wgta[lines];
List<scalar> xcList=xCCell[lines];
List<scalar> ycList=yCCell[lines];
List<label> indList=cellIndices[lines];
segNum=raySegments[lines];
List<scalar> lengthList=segLengths[lines]; //list of azimuthal ray lengths
label i0=angleInd[lines]; //index of azimuthal angle
//Set trigonometric functions of azimuthal angle
//Should these be strictly positive?
sina=sinInd[i0];
cosa=cosInd[i0];
List<scalar> yIn; //set list of local y-entry co-ords
List<scalar> xIn; //set list of local x-entry co-ords
//List of areas approximated by lines at given angle
List<scalar> approxAreaList=approxArea[angleInd[lines]];
for(int j=0; j<npo; j++)
{
w = wa*wsintheta[j];
sinT=sintheta[j];
List<scalar> g=G2[energyI][lines][j];
for(int d=0; d<2; d++) //are both directions necessary? a/2 index in reference!
{
yIn=yInCell[lines][d];
xIn=xInCell[lines][d];
if (d==0)
{
c1=0;
c2=segNum-1;
m=+1;
}else if (d==1)
{
c1=segNum-1;
c2=0;
m=-1;
sina*=-1;
cosa*=-1;
}
for(int k=c1; k!=c2+m; k+=m)
{
ind=indList[k];
sigT=sigmaT[energyI][ind];
A=area[ind];
scalar s=lengthList[k];
scalar t=s*A/approxAreaList[ind];
scalar fac=w*s*s*g[k]/(A*sigT);
scalar xc=xcList[k];
scalar yc=ycList[k];
//Only sweep through half of angles (accounted by factors of 2)
//Note, even if including both directions, difference in result is minor
//Likely that error exists causing linear contribution to be too small - but where?
if(d==1){continue;}
else{
//remove s in second term for volume balance?
Cxx[energyI][ind]+=fac*cosa*cosa
+2*wa*xc*xc*t/A; //s is replaced with t in second term
Cyy[energyI][ind]+=fac*sina*sina
+2*wa*yc*yc*t/A; //s is replaced with t in second term
Cxy[energyI][ind]+=fac*sina*cosa
+2*wa*xc*yc*t/A; //s is replaced with t in second term
}
//Calculate M factors if first energy iteration
//integral of x^2 etc. along track with weighting factor
// x= xin + cosa*t y= yin + sina*t where cosa and sina can be negative
//int(x^2)=xin^2*t+cosa^2*t^3/3+xin*cosa*t^2
//note division by two only for Mxy
//remember division by sinT for track length!
if(energyI==0)
{
//For calculating M
scalar tm=t/sinT;
scalar xi=xIn[k];
scalar yi=yIn[k];
Mxx[ind] += w*(xi*xi*tm+cosa*cosa*tm*tm*tm/3 + xi*cosa*tm*tm)/A;
Myy[ind] += w*(yi*yi*tm+sina*sina*tm*tm*tm/3 + yi*sina*tm*tm)/A;
Mxy[ind] += w*(xi*yi*tm+sina*cosa*tm*tm*tm/3 + (xi*sina+yi*cosa)*tm*tm/2)/A;
}
}
}
}
}
}