FUNCTION gammln_s(xx) USE nrtype; USE nrutil, ONLY : arth,assert IMPLICIT NONE REAL(SP), INTENT(IN) :: xx REAL(SP) :: gammln_s REAL(DP) :: tmp,x REAL(DP) :: stp = 2.5066282746310005_dp REAL(DP), DIMENSION(6) :: coef = (/76.18009172947146_dp,& -86.50532032941677_dp,24.01409824083091_dp,& -1.231739572450155_dp,0.1208650973866179e-2_dp,& -0.5395239384953e-5_dp/) call assert(xx > 0.0, 'gammln_s arg') x=xx tmp=x+5.5_dp tmp=(x+0.5_dp)*log(tmp)-tmp gammln_s=tmp+log(stp*(1.000000000190015_dp+& sum(coef(:)/arth(x+1.0_dp,1.0_dp,size(coef))))/x) END FUNCTION gammln_s FUNCTION gammln_v(xx) USE nrtype; USE nrutil, ONLY: assert IMPLICIT NONE INTEGER(I4B) :: i REAL(SP), DIMENSION(:), INTENT(IN) :: xx REAL(SP), DIMENSION(size(xx)) :: gammln_v REAL(DP), DIMENSION(size(xx)) :: ser,tmp,x,y REAL(DP) :: stp = 2.5066282746310005_dp REAL(DP), DIMENSION(6) :: coef = (/76.18009172947146_dp,& -86.50532032941677_dp,24.01409824083091_dp,& -1.231739572450155_dp,0.1208650973866179e-2_dp,& -0.5395239384953e-5_dp/) if (size(xx) == 0) RETURN call assert(all(xx > 0.0), 'gammln_v arg') x=xx tmp=x+5.5_dp tmp=(x+0.5_dp)*log(tmp)-tmp ser=1.000000000190015_dp y=x do i=1,size(coef) y=y+1.0_dp ser=ser+coef(i)/y end do gammln_v=tmp+log(stp*ser/x) END FUNCTION gammln_v