Go to the documentation of this file.00001
00002 DOUBLE PRECISION FUNCTION DLBETA (A, B)
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 DOUBLE PRECISION A, B, P, Q, CORR, SQ2PIL, D9LGMC, DGAMMA, DLNGAM,
00029 1 DLNREL
00030 EXTERNAL DGAMMA
00031 SAVE SQ2PIL
00032 DATA SQ2PIL / 0.9189385332 0467274178 0329736405 62 D0 /
00033
00034 P = MIN (A, B)
00035 Q = MAX (A, B)
00036
00037 IF (P .LE. 0.D0) CALL XERMSG ('SLATEC', 'DLBETA',
00038 + 'BOTH ARGUMENTS MUST BE GT ZERO', 1, 2)
00039
00040 IF (P.GE.10.D0) GO TO 30
00041 IF (Q.GE.10.D0) GO TO 20
00042
00043
00044
00045 DLBETA = LOG (DGAMMA(P) * (DGAMMA(Q)/DGAMMA(P+Q)) )
00046 RETURN
00047
00048
00049
00050 20 CORR = D9LGMC(Q) - D9LGMC(P+Q)
00051 DLBETA = DLNGAM(P) + CORR + P - P*LOG(P+Q)
00052 1 + (Q-0.5D0)*DLNREL(-P/(P+Q))
00053 RETURN
00054
00055
00056
00057 30 CORR = D9LGMC(P) + D9LGMC(Q) - D9LGMC(P+Q)
00058 DLBETA = -0.5D0*LOG(Q) + SQ2PIL + CORR + (P-0.5D0)*LOG(P/(P+Q))
00059 1 + Q*DLNREL(-P/(P+Q))
00060 RETURN
00061
00062 END