1 // eval_rational_series().
7 #include "cl_LF_tran.h"
12 #include "cln/lfloat.h"
13 #include "cln/integer.h"
14 #include "cln/abort.h"
19 static void eval_pq_series_aux (uintL N1, uintL N2,
20 cl_pq_series_stream& args,
21 cl_I* P, cl_I* Q, cl_I* T)
27 var cl_pq_series_term v0 = args.next(); // [N1]
34 var cl_pq_series_term v0 = args.next(); // [N1]
35 var cl_pq_series_term v1 = args.next(); // [N1+1]
36 var cl_I p01 = v0.p * v1.p;
44 var cl_pq_series_term v0 = args.next(); // [N1]
45 var cl_pq_series_term v1 = args.next(); // [N1+1]
46 var cl_pq_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;
58 var cl_pq_series_term v0 = args.next(); // [N1]
59 var cl_pq_series_term v1 = args.next(); // [N1+1]
60 var cl_pq_series_term v2 = args.next(); // [N1+2]
61 var cl_pq_series_term v3 = args.next(); // [N1+3]
62 var cl_I p01 = v0.p * v1.p;
63 var cl_I p012 = p01 * v2.p;
64 var cl_I p0123 = p012 * v3.p;
65 if (P) { *P = p0123; }
66 var cl_I q23 = v2.q * v3.q;
67 var cl_I q123 = v1.q * q23;
76 var uintL Nm = (N1+N2)/2; // midpoint
79 eval_pq_series_aux(N1,Nm,args,&LP,&LQ,<);
80 // Compute right part.
82 eval_pq_series_aux(Nm,N2,args,(P?&RP:(cl_I*)0),&RQ,&RT);
83 // Put together partial results.
84 if (P) { *P = LP*RP; }
86 // S = LS + LP/LQ * RS, so T = RQ*LT + LP*RT.
93 const cl_LF eval_rational_series (uintL N, cl_pq_series_stream& args, uintC len)
96 return cl_I_to_LF(0,len);
98 eval_pq_series_aux(0,N,args,NULL,&Q,&T);
99 return cl_I_to_LF(T,len) / cl_I_to_LF(Q,len);