1 // eval_rational_series().
7 #include "cl_LF_tran.h"
12 #include "cl_lfloat.h"
13 #include "cl_integer.h"
17 static void eval_pqb_series_aux (uintL N1, uintL N2,
18 cl_pqb_series_stream& args,
19 cl_I* P, cl_I* Q, cl_I* B, cl_I* T)
25 var cl_pqb_series_term v0 = args.next(); // [N1]
33 var cl_pqb_series_term v0 = args.next(); // [N1]
34 var cl_pqb_series_term v1 = args.next(); // [N1+1]
35 var cl_I p01 = v0.p * v1.p;
39 *T = v1.b * v1.q * v0.p
44 var cl_pqb_series_term v0 = args.next(); // [N1]
45 var cl_pqb_series_term v1 = args.next(); // [N1+1]
46 var cl_pqb_series_term v2 = args.next(); // [N1+2]
47 var cl_I p01 = v0.p * v1.p;
48 var cl_I p012 = p01 * v2.p;
50 var cl_I q12 = v1.q * v2.q;
52 var cl_I b12 = v1.b * v2.b;
55 + v0.b * (v2.b * v2.q * p01
60 var cl_pqb_series_term v0 = args.next(); // [N1]
61 var cl_pqb_series_term v1 = args.next(); // [N1+1]
62 var cl_pqb_series_term v2 = args.next(); // [N1+2]
63 var cl_pqb_series_term v3 = args.next(); // [N1+3]
64 var cl_I p01 = v0.p * v1.p;
65 var cl_I p012 = p01 * v2.p;
66 var cl_I p0123 = p012 * v3.p;
67 if (P) { *P = p0123; }
68 var cl_I q23 = v2.q * v3.q;
69 var cl_I q123 = v1.q * q23;
71 var cl_I b01 = v0.b * v1.b;
72 var cl_I b23 = v2.b * v3.b;
74 *T = b23 * (v1.b * q123 * v0.p
76 + b01 * (v3.b * v3.q * p012
81 var uintL Nm = (N1+N2)/2; // midpoint
83 var cl_I LP, LQ, LB, LT;
84 eval_pqb_series_aux(N1,Nm,args,&LP,&LQ,&LB,<);
85 // Compute right part.
86 var cl_I RP, RQ, RB, RT;
87 eval_pqb_series_aux(Nm,N2,args,(P?&RP:(cl_I*)0),&RQ,&RB,&RT);
88 // Put together partial results.
89 if (P) { *P = LP*RP; }
92 // S = LS + LP/LQ * RS, so T = RB*RQ*LT + LB*LP*RT.
93 *T = RB*RQ*LT + LB*LP*RT;
99 const cl_LF eval_rational_series (uintL N, cl_pqb_series_stream& args, uintC len)
102 return cl_I_to_LF(0,len);
104 eval_pqb_series_aux(0,N,args,NULL,&Q,&B,&T);
105 return cl_I_to_LF(T,len) / cl_I_to_LF(B*Q,len);