| 1 |
{ RCSid $Id$ } |
| 2 |
{ |
| 3 |
Calculation of relay directions for prismatic glazing |
| 4 |
|
| 5 |
31 July 1991 Greg Ward |
| 6 |
|
| 7 |
Prism is oriented with flat side in xz plane |
| 8 |
and normal in -y direction. The prism is |
| 9 |
extruded along the x axis. |
| 10 |
|
| 11 |
Reflections are not computed. |
| 12 |
|
| 13 |
Parameters: |
| 14 |
A1 - index of refraction |
| 15 |
A2 - thickness of prism triangle |
| 16 |
A3 - height of upper side (segment 1) |
| 17 |
A4 - height of lower side (segment 2) |
| 18 |
|
| 19 |
Computes: |
| 20 |
coef1 - transmission coefficient for upper side |
| 21 |
dx1, dy1, |
| 22 |
dz1 - transmission direction for upper side |
| 23 |
coef2 - transmission coefficient for lower side |
| 24 |
dx2, dy2, |
| 25 |
dz2 - transmission direction for lower side |
| 26 |
} |
| 27 |
{ required formulae } |
| 28 |
tan2sin(a) = sqrt(a*a/(1+a*a)); |
| 29 |
stb(sta,ca,sa) = ca*sta - sa*sqrt(A1*A1-sta*sta); |
| 30 |
cos_p = Sqrt(1-Dx*Dx); |
| 31 |
dtrans(c1,c2) = dtransb(c1, sqrt(1+(c1*c1-1)/A1/A1), |
| 32 |
c2, sqrt(1+(c2*c2-1)/A1/A1)); |
| 33 |
dtransb(c1o,c1i,c2o,c2i) = 8*A1*A1 * |
| 34 |
( c1o*c1i*c2o*c2i/sq((A1*c1o+c1i)*(A1*c2o+c2i)) + |
| 35 |
1/c1o/c1i/c2o/c2i/sq((A1/c1o+1/c1i)*(A1/c2o+1/c2i)) ); |
| 36 |
|
| 37 |
{************************************************ |
| 38 |
Definitions for Segment 1 |
| 39 |
} |
| 40 |
{ slope angle (always positive) } |
| 41 |
sin_a1 = tan2sin(A2/A3/cos_p); |
| 42 |
cos_a1 = Sqrt(1-sin_a1*sin_a1); |
| 43 |
{ computed coefficeint } |
| 44 |
coef1 = A3/(A3+A4) * if(Dy, |
| 45 |
if(1-abs(sin_tB1o), |
| 46 |
dtrans(cos_tA1i, cos_tB1o), |
| 47 |
0), |
| 48 |
if (Dy*cos_a1 + Dz*sin_a1, |
| 49 |
0, |
| 50 |
if (1-abs(sin_tA1o), |
| 51 |
dtrans(cos_tB1i, cos_tA1o), |
| 52 |
0))); |
| 53 |
{ computed direction } |
| 54 |
dx1 = Dx; |
| 55 |
dy1 = if(Dy, |
| 56 |
(cos_a1*cos_tB1o-sin_a1*sin_tB1o)*cos_p, |
| 57 |
-cos_tA1o*cos_p); |
| 58 |
dz1 = if(Dy, |
| 59 |
(sin_a1*cos_tB1o+cos_a1*sin_tB1o)*cos_p, |
| 60 |
-sin_tA1o*cos_p); |
| 61 |
{ incident angle (flat side) } |
| 62 |
sin_tA1i = Dz/cos_p; |
| 63 |
cos_tA1i = Sqrt(1-sin_tA1i*sin_tA1i); |
| 64 |
{ transmitted angle (steep side) } |
| 65 |
sin_tB1o = stb(sin_tA1i, cos_a1, sin_a1); |
| 66 |
cos_tB1o = Sqrt(1-sin_tB1o*sin_tB1o); |
| 67 |
{ incident angle (steep side) } |
| 68 |
sin_tB1i = -Dz/cos_p*cos_a1 - |
| 69 |
Sqrt(1-sq(Dz/cos_p))*sin_a1; |
| 70 |
cos_tB1i = Sqrt(1-sin_tB1i*sin_tB1i); |
| 71 |
{ transmitted angle (flat side) } |
| 72 |
sin_tA1o = stb(sin_tB1i, cos_a1, -sin_a1); |
| 73 |
cos_tA1o = Sqrt(1-sin_tA1o*sin_tA1o); |
| 74 |
|
| 75 |
{************************************************ |
| 76 |
Definitions for Segment 2 |
| 77 |
} |
| 78 |
{ slope angle (always negative) } |
| 79 |
sin_a2 = -tan2sin(A2/A4/cos_p); |
| 80 |
cos_a2 = Sqrt(1-sin_a2*sin_a2); |
| 81 |
{ computed coefficeint } |
| 82 |
coef2 = A4/(A3+A4) * if(Dy, |
| 83 |
if(1-abs(sin_tB2o), |
| 84 |
dtrans(cos_tA2i, cos_tB2o), |
| 85 |
0), |
| 86 |
if (Dy*cos_a2 + Dz*sin_a2, |
| 87 |
0, |
| 88 |
if (1-abs(sin_tA2o), |
| 89 |
dtrans(cos_tB2i, cos_tA2o), |
| 90 |
0))); |
| 91 |
{ computed direction } |
| 92 |
dx2 = Dx; |
| 93 |
dy2 = if(Dy, |
| 94 |
(cos_a2*cos_tB2o-sin_a2*sin_tB2o)*cos_p, |
| 95 |
-cos_tA2o*cos_p); |
| 96 |
dz2 = if(Dy, |
| 97 |
(sin_a2*cos_tB2o+cos_a2*sin_tB2o)*cos_p, |
| 98 |
-sin_tA2o*cos_p); |
| 99 |
{ incident angle (flat side) } |
| 100 |
sin_tA2i = Dz/cos_p; |
| 101 |
cos_tA2i = Sqrt(1-sin_tA2i*sin_tA2i); |
| 102 |
{ transmitted angle (steep side) } |
| 103 |
sin_tB2o = stb(sin_tA2i, cos_a2, sin_a2); |
| 104 |
cos_tB2o = Sqrt(1-sin_tB2o*sin_tB2o); |
| 105 |
{ incident angle (steep side) } |
| 106 |
sin_tB2i = -Dz/cos_p*cos_a2 - |
| 107 |
Sqrt(1-sq(Dz/cos_p))*sin_a2; |
| 108 |
cos_tB2i = Sqrt(1-sin_tB2i*sin_tB2i); |
| 109 |
{ transmitted angle (flat side) } |
| 110 |
sin_tA2o = stb(sin_tB2i, cos_a2, -sin_a2); |
| 111 |
cos_tA2o = Sqrt(1-sin_tA2o*sin_tA2o); |