00001 REAL FUNCTION genbet(aa,bb)
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039 REAL expmax
00040
00041 PARAMETER (expmax=87.49823)
00042
00043 REAL infnty
00044 PARAMETER (infnty=1.0E38)
00045
00046
00047 REAL minlog
00048 PARAMETER (minlog=1.0E-37)
00049
00050
00051 REAL aa,bb
00052
00053
00054 REAL a,alpha,b,beta,delta,gamma,k1,k2,olda,oldb,r,s,t,u1,u2,v,w,y,
00055 + z
00056 LOGICAL qsame
00057
00058
00059 REAL ranf
00060 EXTERNAL ranf
00061
00062
00063 INTRINSIC exp,log,max,min,sqrt
00064
00065
00066
00067 SAVE olda,oldb,alpha,beta,gamma,k1,k2,a,b
00068
00069
00070
00071 DATA olda,oldb/-1.0E37,-1.0E37/
00072
00073
00074 qsame = (olda.EQ.aa) .AND. (oldb.EQ.bb)
00075 IF (qsame) GO TO 20
00076
00077 IF (.NOT. (aa.LT.minlog.OR.bb.LT.minlog)) GO TO 10
00078 WRITE (*,*) ' AA or BB < ',minlog,' in GENBET - Abort!'
00079 WRITE (*,*) ' AA: ',aa,' BB ',bb
00080 CALL XSTOPX (' AA or BB too small in GENBET - Abort!')
00081
00082 10 olda = aa
00083 oldb = bb
00084 20 IF (.NOT. (min(aa,bb).GT.1.0)) GO TO 100
00085
00086
00087
00088
00089
00090
00091
00092 IF (qsame) GO TO 30
00093 a = min(aa,bb)
00094 b = max(aa,bb)
00095 alpha = a + b
00096 beta = sqrt((alpha-2.0)/ (2.0*a*b-alpha))
00097 gamma = a + 1.0/beta
00098 30 CONTINUE
00099 40 u1 = ranf()
00100
00101
00102
00103 u2 = ranf()
00104 v = beta*log(u1/ (1.0-u1))
00105
00106 IF (v.GT.expmax) GO TO 55
00107
00108
00109 50 w = exp(v)
00110 IF (w.GT.infnty/a) GO TO 55
00111 w = a*w
00112 GO TO 60
00113 55 w = infnty
00114
00115 60 z = u1**2*u2
00116 r = gamma*v - 1.3862944
00117 s = a + r - w
00118
00119
00120
00121 IF ((s+2.609438).GE. (5.0*z)) GO TO 70
00122
00123
00124
00125 t = log(z)
00126 IF (s.GT.t) GO TO 70
00127
00128
00129
00130
00131
00132
00133
00134
00135 IF (alpha/(b+w).LT.minlog) GO TO 40
00136
00137 IF ((r+alpha*log(alpha/ (b+w))).LT.t) GO TO 40
00138
00139
00140
00141 70 IF (.NOT. (aa.EQ.a)) GO TO 80
00142 genbet = w/ (b+w)
00143 GO TO 90
00144
00145 80 genbet = b/ (b+w)
00146 90 GO TO 230
00147
00148
00149
00150
00151
00152
00153
00154 100 IF (qsame) GO TO 110
00155 a = max(aa,bb)
00156 b = min(aa,bb)
00157 alpha = a + b
00158 beta = 1.0/b
00159 delta = 1.0 + a - b
00160 k1 = delta* (0.0138889+0.0416667*b)/ (a*beta-0.777778)
00161 k2 = 0.25 + (0.5+0.25/delta)*b
00162 110 CONTINUE
00163 120 u1 = ranf()
00164
00165
00166
00167 u2 = ranf()
00168 IF (u1.GE.0.5) GO TO 130
00169
00170
00171
00172 y = u1*u2
00173 z = u1*y
00174 IF ((0.25*u2+z-y).GE.k1) GO TO 120
00175 GO TO 170
00176
00177
00178
00179 130 z = u1**2*u2
00180 IF (.NOT. (z.LE.0.25)) GO TO 160
00181 v = beta*log(u1/ (1.0-u1))
00182
00183
00184
00185
00186 IF (a.GT.1.0) GO TO 135
00187
00188 IF (v.GT.expmax) GO TO 132
00189 w = a*exp(v)
00190 GO TO 200
00191 132 w = v + log(a)
00192 IF (w.GT.expmax) GO TO 140
00193 w = exp(w)
00194 GO TO 200
00195
00196
00197 135 IF (v.GT.expmax) GO TO 140
00198 w = exp(v)
00199 IF (w.GT.infnty/a) GO TO 140
00200 w = a*w
00201 GO TO 200
00202 140 w = infnty
00203 GO TO 200
00204
00205 160 IF (z.GE.k2) GO TO 120
00206
00207
00208
00209
00210
00211
00212 170 v = beta*log(u1/ (1.0-u1))
00213
00214
00215 IF (a.GT.1.0) GO TO 175
00216
00217 IF (v.GT.expmax) GO TO 172
00218 w = a*exp(v)
00219 GO TO 190
00220 172 w = v + log(a)
00221 IF (w.GT.expmax) GO TO 180
00222 w = exp(w)
00223 GO TO 190
00224
00225
00226 175 IF (v.GT.expmax) GO TO 180
00227 w = exp(v)
00228 IF (w.GT.infnty/a) GO TO 180
00229 w = a*w
00230 GO TO 190
00231
00232 180 w = infnty
00233
00234
00235
00236 190 IF (alpha/(b+w).LT.minlog) GO TO 120
00237 IF ((alpha* (log(alpha/ (b+w))+v)-1.3862944).LT.log(z)) GO TO 120
00238
00239
00240
00241 200 IF (.NOT. (a.EQ.aa)) GO TO 210
00242 genbet = w/ (b+w)
00243 GO TO 220
00244
00245 210 genbet = b/ (b+w)
00246 220 CONTINUE
00247 230 RETURN
00248
00249 END