File Coverage

lib/PDL/Primitive-pp-vsearch_match.c
Criterion Covered Total %
statement 75 105 71.4
branch 89 202 44.0
condition n/a
subroutine n/a
pod n/a
total 164 307 53.4


line stmt bran cond sub pod time code
1              
2             #line 453 "lib/PDL/PP.pm"
3             /*
4             * THIS FILE WAS GENERATED BY PDL::PP from lib/PDL/Primitive.pd! Do not modify!
5             */
6              
7             #define PDL_FREE_CODE(trans, destroy, comp_free_code, ntpriv_free_code) \
8             if (destroy) { \
9             comp_free_code \
10             } \
11             if ((trans)->dims_redone) { \
12             ntpriv_free_code \
13             }
14              
15             #include "EXTERN.h"
16             #include "perl.h"
17             #include "XSUB.h"
18             #include "pdl.h"
19             #include "pdlcore.h"
20             #define PDL PDL_Primitive
21             extern Core* PDL; /* Structure hold core C functions */
22             #line 23 "lib/PDL/Primitive-pp-vsearch_match.c"
23             extern int pdl_srand_threads;
24             extern uint64_t *pdl_rand_state;
25             void pdl_srand(uint64_t **s, uint64_t seed, int n);
26             double pdl_drand(uint64_t *s);
27             #define PDL_MAYBE_SRAND \
28             if (pdl_srand_threads < 0) \
29             pdl_srand(&pdl_rand_state, PDL->pdl_seed(), PDL->online_cpus());
30             #define PDL_RAND_SET_OFFSET(v, thr, pdl) \
31             if (v < 0) { \
32             if (thr.mag_nthr >= 0) { \
33             int thr_no = PDL->magic_get_thread(pdl); \
34             if (thr_no < 0) return PDL->make_error_simple(PDL_EFATAL, "Invalid pdl_magic_get_thread!"); \
35             v = thr_no == 0 ? thr_no : thr_no % PDL->online_cpus(); \
36             } else { \
37             v = 0; \
38             } \
39             }
40              
41             #line 1857 "lib/PDL/PP.pm"
42             pdl_error pdl_vsearch_match_readdata(pdl_trans *__privtrans) {
43             pdl_error PDL_err = {0, NULL, 0};
44             #line 45 "lib/PDL/Primitive-pp-vsearch_match.c"
45 27           register PDL_Indx __n_size = __privtrans->ind_sizes[0];
46 27 50         if (!__privtrans->broadcast.incs) return PDL->make_error(PDL_EUSERERROR, "Error in vsearch_match:" "broadcast.incs NULL");
47             /* broadcastloop declarations */
48             int __brcloopval;
49             register PDL_Indx __tind0,__tind1; /* counters along dim */
50 27           register PDL_Indx __tnpdls = __privtrans->broadcast.npdls;
51             /* dims here are how many steps along those dims */
52 27           register PDL_Indx __tinc0_vals = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,0,0);
53 27           register PDL_Indx __tinc0_x = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,1,0);
54 27           register PDL_Indx __tinc0_idx = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,2,0);
55 27           register PDL_Indx __tinc1_vals = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,0,1);
56 27           register PDL_Indx __tinc1_x = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,1,1);
57 27           register PDL_Indx __tinc1_idx = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,2,1);
58             #define PDL_BROADCASTLOOP_START_vsearch_match_readdata PDL_BROADCASTLOOP_START( \
59             readdata, \
60             __privtrans->broadcast, \
61             __privtrans->vtable, \
62             vals_datap += __offsp[0]; \
63             x_datap += __offsp[1]; \
64             idx_datap += __offsp[2]; \
65             , \
66             ( ,vals_datap += __tinc1_vals - __tinc0_vals * __tdims0 \
67             ,x_datap += __tinc1_x - __tinc0_x * __tdims0 \
68             ,idx_datap += __tinc1_idx - __tinc0_idx * __tdims0 \
69             ), \
70             ( ,vals_datap += __tinc0_vals \
71             ,x_datap += __tinc0_x \
72             ,idx_datap += __tinc0_idx \
73             ) \
74             )
75             #define PDL_BROADCASTLOOP_END_vsearch_match_readdata PDL_BROADCASTLOOP_END( \
76             __privtrans->broadcast, \
77             vals_datap -= __tinc1_vals * __tdims1 + __offsp[0]; \
78             x_datap -= __tinc1_x * __tdims1 + __offsp[1]; \
79             idx_datap -= __tinc1_idx * __tdims1 + __offsp[2]; \
80             )
81 27           register PDL_Indx __inc_x_n = __privtrans->inc_sizes[PDL_INC_ID(__privtrans->vtable,1,0)]; (void)__inc_x_n;
82             #ifndef PDL_DECLARE_PARAMS_vsearch_match_1
83             #define PDL_DECLARE_PARAMS_vsearch_match_1(PDL_TYPE_OP,PDL_PPSYM_OP,PDL_TYPE_PARAM_idx,PDL_PPSYM_PARAM_idx) \
84             PDL_DECLARE_PARAMETER_BADVAL(PDL_TYPE_OP, vals, (__privtrans->pdls[0]), 1, PDL_PPSYM_OP) \
85             PDL_DECLARE_PARAMETER_BADVAL(PDL_TYPE_OP, x, (__privtrans->pdls[1]), 1, PDL_PPSYM_OP) \
86             PDL_DECLARE_PARAMETER_BADVAL(PDL_TYPE_PARAM_idx, idx, (__privtrans->pdls[2]), 1, PDL_PPSYM_PARAM_idx)
87             #endif
88             #define PDL_IF_BAD(t,f) f
89 27           switch (__privtrans->__datatype) { /* Start generic switch */
90 0           case PDL_F: {
91 0 0         PDL_DECLARE_PARAMS_vsearch_match_1(PDL_Float,F,PDL_Indx,N)
    0          
    0          
    0          
    0          
    0          
    0          
    0          
    0          
    0          
    0          
    0          
92 0 0         PDL_BROADCASTLOOP_START_vsearch_match_readdata {
    0          
    0          
    0          
    0          
    0          
    0          
93 0 0         {/* Open n */ PDL_EXPAND2(register PDL_Indx n=0, __n_stop=(__n_size)); for(; n<__n_stop; n+=1) {
94 0 0         if ( !PDL_ISBAD2((vals_datap)[0],vals_badval,F,vals_badval_isnan) ) {
    0          
95 0           PDL_Indx n1 = __privtrans->ind_sizes[0]-1;
96 0           PDL_Indx low = 0;
97 0           PDL_Indx high = n1;
98             PDL_Indx mid;
99              
100 0           PDL_Float value = (vals_datap)[0];
101              
102             /* determine sort order of data */
103 0           int up = (x_datap)[0+(__inc_x_n*(n1))] >= (x_datap)[0+(__inc_x_n*(0))];
104            
105 0           int done = 0;
106              
107 0 0         while (low <= high ) {
108             PDL_Float mid_value;
109              
110 0           mid = low + (( high - low )>> 1);;
111              
112 0           mid_value = (x_datap)[0+(__inc_x_n*(mid))];
113              
114 0 0         if ( up ) {
115 0 0         if ( mid_value > value ) { high = mid - 1; }
116 0 0         else if ( mid_value < value ) { low = mid + 1; }
117 0           else { done = 1; break; }
118             }
119             else {
120 0 0         if ( mid_value < value ) { high = mid - 1; }
121 0 0         else if ( mid_value > value ) { low = mid + 1; }
122 0           else { done = 1; break; }
123             }
124             }
125 0           (idx_datap)[0] = done ? mid
126 0 0         : up ? - ( low + 1 )
127 0 0         : - ( high + 1 );
128            
129             }
130              
131             else {
132 0           (idx_datap)[0]=idx_badval;
133             }
134             }} /* Close n */
135              
136 0 0         }PDL_BROADCASTLOOP_END_vsearch_match_readdata
    0          
137 0           } break;
138 3           case PDL_D: {
139 3 50         PDL_DECLARE_PARAMS_vsearch_match_1(PDL_Double,D,PDL_Indx,N)
    50          
    50          
    50          
    100          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
140 932 50         PDL_BROADCASTLOOP_START_vsearch_match_readdata {
    50          
    50          
    50          
    50          
    100          
    100          
141 663652 100         {/* Open n */ PDL_EXPAND2(register PDL_Indx n=0, __n_stop=(__n_size)); for(; n<__n_stop; n+=1) {
142 662729 50         if ( !PDL_ISBAD2((vals_datap)[0],vals_badval,D,vals_badval_isnan) ) {
    50          
143 662729           PDL_Indx n1 = __privtrans->ind_sizes[0]-1;
144 662729           PDL_Indx low = 0;
145 662729           PDL_Indx high = n1;
146             PDL_Indx mid;
147              
148 662729           PDL_Double value = (vals_datap)[0];
149              
150             /* determine sort order of data */
151 662729           int up = (x_datap)[0+(__inc_x_n*(n1))] >= (x_datap)[0+(__inc_x_n*(0))];
152            
153 662729           int done = 0;
154              
155 1334729 50         while (low <= high ) {
156             PDL_Double mid_value;
157              
158 1334729           mid = low + (( high - low )>> 1);;
159              
160 1334729           mid_value = (x_datap)[0+(__inc_x_n*(mid))];
161              
162 1334729 100         if ( up ) {
163 928729 100         if ( mid_value > value ) { high = mid - 1; }
164 759329 100         else if ( mid_value < value ) { low = mid + 1; }
165 592729           else { done = 1; break; }
166             }
167             else {
168 406000 100         if ( mid_value < value ) { high = mid - 1; }
169 236600 100         else if ( mid_value > value ) { low = mid + 1; }
170 70000           else { done = 1; break; }
171             }
172             }
173 662729           (idx_datap)[0] = done ? mid
174 662729 50         : up ? - ( low + 1 )
175 0 0         : - ( high + 1 );
176            
177             }
178              
179             else {
180 0           (idx_datap)[0]=idx_badval;
181             }
182             }} /* Close n */
183              
184 3 50         }PDL_BROADCASTLOOP_END_vsearch_match_readdata
    50          
185 3           } break;
186 24           case PDL_LD: {
187 24 50         PDL_DECLARE_PARAMS_vsearch_match_1(PDL_LDouble,E,PDL_Indx,N)
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
188 5872 50         PDL_BROADCASTLOOP_START_vsearch_match_readdata {
    50          
    50          
    50          
    50          
    100          
    100          
189 4199200 100         {/* Open n */ PDL_EXPAND2(register PDL_Indx n=0, __n_stop=(__n_size)); for(; n<__n_stop; n+=1) {
190 4193400 50         if ( !PDL_ISBAD2((vals_datap)[0],vals_badval,E,vals_badval_isnan) ) {
    100          
191 3147942           PDL_Indx n1 = __privtrans->ind_sizes[0]-1;
192 3147942           PDL_Indx low = 0;
193 3147942           PDL_Indx high = n1;
194             PDL_Indx mid;
195              
196 3147942           PDL_LDouble value = (vals_datap)[0];
197              
198             /* determine sort order of data */
199 3147942           int up = (x_datap)[0+(__inc_x_n*(n1))] >= (x_datap)[0+(__inc_x_n*(0))];
200            
201 3147942           int done = 0;
202              
203 31240830 100         while (low <= high ) {
204             PDL_LDouble mid_value;
205              
206 29141238           mid = low + (( high - low )>> 1);;
207              
208 29141238           mid_value = (x_datap)[0+(__inc_x_n*(mid))];
209              
210 29141238 100         if ( up ) {
211 14570619 100         if ( mid_value > value ) { high = mid - 1; }
212 7911789 100         else if ( mid_value < value ) { low = mid + 1; }
213 524175           else { done = 1; break; }
214             }
215             else {
216 14570619 100         if ( mid_value < value ) { high = mid - 1; }
217 7912512 100         else if ( mid_value > value ) { low = mid + 1; }
218 524175           else { done = 1; break; }
219             }
220             }
221 3147942           (idx_datap)[0] = done ? mid
222 5247534 100         : up ? - ( low + 1 )
223 2099592 100         : - ( high + 1 );
224            
225             }
226              
227             else {
228 1045458           (idx_datap)[0]=idx_badval;
229             }
230             }} /* Close n */
231              
232 24 50         }PDL_BROADCASTLOOP_END_vsearch_match_readdata
    50          
233 24           } break;
234 0           default: return PDL->make_error(PDL_EUSERERROR, "PP INTERNAL ERROR in vsearch_match: unhandled datatype(%d), only handles (FDE)! PLEASE MAKE A BUG REPORT\n", __privtrans->__datatype);
235             }
236             #undef PDL_IF_BAD
237 27           return PDL_err;
238             }
239              
240             static pdl_datatypes pdl_vsearch_match_vtable_gentypes[] = { PDL_F, PDL_D, PDL_LD, -1 };
241             static PDL_Indx pdl_vsearch_match_vtable_realdims[] = { 0, 1, 0 };
242             static char *pdl_vsearch_match_vtable_parnames[] = { "vals","x","idx" };
243             static short pdl_vsearch_match_vtable_parflags[] = {
244             0,
245             0,
246             PDL_PARAM_ISCREAT|PDL_PARAM_ISOUT|PDL_PARAM_ISTYPED|PDL_PARAM_ISWRITE
247             };
248             static pdl_datatypes pdl_vsearch_match_vtable_partypes[] = { -1, -1, PDL_IND };
249             static PDL_Indx pdl_vsearch_match_vtable_realdims_starts[] = { 0, 0, 1 };
250             static PDL_Indx pdl_vsearch_match_vtable_realdims_ind_ids[] = { 0 };
251             static char *pdl_vsearch_match_vtable_indnames[] = { "n" };
252             pdl_transvtable pdl_vsearch_match_vtable = {
253             PDL_TRANS_DO_BROADCAST|PDL_TRANS_BADPROCESS, 0, pdl_vsearch_match_vtable_gentypes, 2, 3, NULL /*CORE21*/,
254             pdl_vsearch_match_vtable_realdims, pdl_vsearch_match_vtable_parnames,
255             pdl_vsearch_match_vtable_parflags, pdl_vsearch_match_vtable_partypes,
256             pdl_vsearch_match_vtable_realdims_starts, pdl_vsearch_match_vtable_realdims_ind_ids, 1,
257             1, pdl_vsearch_match_vtable_indnames,
258             NULL, pdl_vsearch_match_readdata, NULL,
259             NULL,
260             0,"PDL::Primitive::vsearch_match"
261             };
262              
263              
264 27           pdl_error pdl_run_vsearch_match(pdl *vals,pdl *x,pdl *idx) {
265 27           pdl_error PDL_err = {0, NULL, 0};
266 27 50         if (!PDL) return (pdl_error){PDL_EFATAL, "PDL core struct is NULL, can't continue",0};
267 27           pdl_trans *__privtrans = PDL->create_trans(&pdl_vsearch_match_vtable);
268 27 50         if (!__privtrans) return PDL->make_error_simple(PDL_EFATAL, "Couldn't create trans");
269 27           __privtrans->pdls[0] = vals;
270 27           __privtrans->pdls[1] = x;
271 27           __privtrans->pdls[2] = idx;
272 27 50         PDL_RETERROR(PDL_err, PDL->type_coerce(__privtrans));
273 27 50         PDL_RETERROR(PDL_err, PDL->make_trans_mutual(__privtrans));
274 27           return PDL_err;
275             }