9pure subroutine rschrodint(sol,l,e,nr,r,vr,nn,p0,p1,q0,q1)
48real(8),
intent(in) :: sol
49integer,
intent(in) :: l
50real(8),
intent(in) :: e
51integer,
intent(in) :: nr
52real(8),
intent(in) :: r(nr),vr(nr)
53integer,
intent(out) :: nn
54real(8),
intent(out) :: p0(nr),p1(nr),q0(nr),q1(nr)
63t4=(t2*ri**2)/t3+vr(1)-e
74 t4=(t2*ri**2)/t3+vr(ir)-e
77 p1(ir)=
poly3(r(ir0),p1(ir0),r(ir))
78 q1(ir)=
poly3(r(ir0),q1(ir0),r(ir))
81 p0(ir)=
poly4i(r(ir0),p1(ir0),r(ir))+p0(ir0)
82 q0(ir)=
poly4i(r(ir0),q1(ir0),r(ir))+q0(ir0)
84 p1(ir)=t3*q0(ir)+p0(ir)*ri
85 q1(ir)=t4*p0(ir)-q0(ir)*ri
88 if (abs(p0(ir)) > 1.d100)
then
89 p0(ir+1:nr)=p0(ir); p1(ir+1:nr)=p1(ir)
90 q0(ir+1:nr)=q0(ir); q1(ir+1:nr)=q1(ir)
94 if (p0(ir-1)*p0(ir) < 0.d0) nn=nn+1
103real(8),
intent(in) :: xa(3),ya(3),x
105real(8) x0,x1,x2,y0,y1,y2
106real(8) c1,c2,t0,t1,t2
109x1=xa(2)-x0; x2=xa(3)-x0
111y1=ya(2)-y0; y2=ya(3)-y0
112t0=1.d0/(x1*x2*(x2-x1))
118poly3=y0+t0*t1*(c1+c2*t1)
124real(8),
intent(in) :: xa(4),ya(4),x
126real(8) x0,x1,x2,x3,y0,y1,y2,y3
127real(8) c1,c2,c3,t0,t1,t2,t3,t4,t5,t6
130x1=xa(2)-x0; x2=xa(3)-x0; x3=xa(4)-x0
132y1=ya(2)-y0; y2=ya(3)-y0; y3=ya(4)-y0
133t4=x1-x2; t5=x1-x3; t6=x2-x3
134t1=x1*x2*y3; t2=x2*x3*y1; t3=x1*x3
135t0=1.d0/(x2*t3*t4*t5*t6)
138t4=x1**2; t5=x2**2; t6=x3**2
139c2=t1*(t5-t4)+t2*(t6-t5)+t3*(t4-t6)
140c1=t1*(x2*t4-x1*t5)+t2*(x3*t5-x2*t6)+t3*(x1*t6-x3*t4)
143poly4i=t1*(y0+t0*t1*(0.5d0*c1+t1*(0.3333333333333333333d0*c2+0.25d0*c3*t1)))
pure subroutine rschrodint(sol, l, e, nr, r, vr, nn, p0, p1, q0, q1)