File Coverage

pp-_xyz_to_rgb.c
Criterion Covered Total %
statement 48 50 96.0
branch 73 138 52.9
condition n/a
subroutine n/a
pod n/a
total 121 188 64.3


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 color_space.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_Graphics_ColorSpace
21             extern Core* PDL; /* Structure hold core C functions */
22             #line 23 "pp-_xyz_to_rgb.c"
23              
24             #include
25             #include "color_space.h" /* Local decs */
26              
27             #line 1857 "lib/PDL/PP.pm"
28             pdl_error pdl__xyz_to_rgb_redodims(pdl_trans *__privtrans) {
29             pdl_error PDL_err = {0, NULL, 0};
30             #line 31 "pp-_xyz_to_rgb.c"
31 5           __privtrans->ind_sizes[0] = 3;
32 5           __privtrans->ind_sizes[1] = 3;
33 5           __privtrans->ind_sizes[2] = 3;
34 5 50         PDL_RETERROR(PDL_err, PDL->redodims_default(__privtrans));
35 5           return PDL_err;
36             }
37              
38              
39             #line 1857 "lib/PDL/PP.pm"
40             pdl_error pdl__xyz_to_rgb_readdata(pdl_trans *__privtrans) {
41             pdl_error PDL_err = {0, NULL, 0};
42             #line 43 "pp-_xyz_to_rgb.c"
43 5           register PDL_Indx __c_size = __privtrans->ind_sizes[0];
44 5 50         if (!__privtrans->broadcast.incs) return PDL->make_error(PDL_EUSERERROR, "Error in _xyz_to_rgb:" "broadcast.incs NULL");
45             /* broadcastloop declarations */
46             int __brcloopval;
47             register PDL_Indx __tind0,__tind1; /* counters along dim */
48 5           register PDL_Indx __tnpdls = __privtrans->broadcast.npdls;
49             /* dims here are how many steps along those dims */
50 5           register PDL_Indx __tinc0_xyz = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,0,0);
51 5           register PDL_Indx __tinc0_gamma = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,1,0);
52 5           register PDL_Indx __tinc0_mstar = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,2,0);
53 5           register PDL_Indx __tinc0_rgb = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,3,0);
54 5           register PDL_Indx __tinc1_xyz = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,0,1);
55 5           register PDL_Indx __tinc1_gamma = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,1,1);
56 5           register PDL_Indx __tinc1_mstar = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,2,1);
57 5           register PDL_Indx __tinc1_rgb = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,3,1);
58             #define PDL_BROADCASTLOOP_START__xyz_to_rgb_readdata PDL_BROADCASTLOOP_START( \
59             readdata, \
60             __privtrans->broadcast, \
61             __privtrans->vtable, \
62             xyz_datap += __offsp[0]; \
63             gamma_datap += __offsp[1]; \
64             mstar_datap += __offsp[2]; \
65             rgb_datap += __offsp[3]; \
66             , \
67             ( ,xyz_datap += __tinc1_xyz - __tinc0_xyz * __tdims0 \
68             ,gamma_datap += __tinc1_gamma - __tinc0_gamma * __tdims0 \
69             ,mstar_datap += __tinc1_mstar - __tinc0_mstar * __tdims0 \
70             ,rgb_datap += __tinc1_rgb - __tinc0_rgb * __tdims0 \
71             ), \
72             ( ,xyz_datap += __tinc0_xyz \
73             ,gamma_datap += __tinc0_gamma \
74             ,mstar_datap += __tinc0_mstar \
75             ,rgb_datap += __tinc0_rgb \
76             ) \
77             )
78             #define PDL_BROADCASTLOOP_END__xyz_to_rgb_readdata PDL_BROADCASTLOOP_END( \
79             __privtrans->broadcast, \
80             xyz_datap -= __tinc1_xyz * __tdims1 + __offsp[0]; \
81             gamma_datap -= __tinc1_gamma * __tdims1 + __offsp[1]; \
82             mstar_datap -= __tinc1_mstar * __tdims1 + __offsp[2]; \
83             rgb_datap -= __tinc1_rgb * __tdims1 + __offsp[3]; \
84             )
85 5           register PDL_Indx __inc_mstar_i = __privtrans->inc_sizes[PDL_INC_ID(__privtrans->vtable,2,0)]; (void)__inc_mstar_i;register PDL_Indx __inc_mstar_rows = __privtrans->inc_sizes[PDL_INC_ID(__privtrans->vtable,2,1)]; (void)__inc_mstar_rows;
86 5           register PDL_Indx __inc_rgb_c = __privtrans->inc_sizes[PDL_INC_ID(__privtrans->vtable,3,0)]; (void)__inc_rgb_c;
87 5           register PDL_Indx __inc_xyz_c = __privtrans->inc_sizes[PDL_INC_ID(__privtrans->vtable,0,0)]; (void)__inc_xyz_c;
88             #ifndef PDL_DECLARE_PARAMS__xyz_to_rgb_1
89             #define PDL_DECLARE_PARAMS__xyz_to_rgb_1(PDL_TYPE_OP,PDL_PPSYM_OP) \
90             PDL_DECLARE_PARAMETER_BADVAL(PDL_TYPE_OP, xyz, (__privtrans->pdls[0]), 1, PDL_PPSYM_OP) \
91             PDL_DECLARE_PARAMETER_BADVAL(PDL_TYPE_OP, gamma, (__privtrans->pdls[1]), 1, PDL_PPSYM_OP) \
92             PDL_DECLARE_PARAMETER_BADVAL(PDL_TYPE_OP, mstar, (__privtrans->pdls[2]), 1, PDL_PPSYM_OP) \
93             PDL_DECLARE_PARAMETER_BADVAL(PDL_TYPE_OP, rgb, (__privtrans->pdls[3]), 1, PDL_PPSYM_OP)
94             #endif
95 5 100         if ( __privtrans->bvalflag ) { /* ** do 'bad' Code ** */
96             #define PDL_BAD_CODE
97             #define PDL_IF_BAD(t,f) t
98 2 50         switch (__privtrans->__datatype) { /* Start generic switch */
99 2           case PDL_D: {
100 2 50         PDL_DECLARE_PARAMS__xyz_to_rgb_1(PDL_Double,D)
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
101 10 50         PDL_BROADCASTLOOP_START__xyz_to_rgb_readdata {
    50          
    50          
    50          
    50          
    100          
    100          
102             /* First check for bad values */
103 10 50         PDL_IF_BAD(if (PDL_ISBAD2((xyz_datap)[0+(__inc_xyz_c*(0))],xyz_badval,D,xyz_badval_isnan) || PDL_ISBAD2((xyz_datap)[0+(__inc_xyz_c*(1))],xyz_badval,D,xyz_badval_isnan) || PDL_ISBAD2((xyz_datap)[0+(__inc_xyz_c*(2))],xyz_badval,D,xyz_badval_isnan)) {
    0          
    100          
    50          
    0          
    50          
    50          
    0          
    50          
    100          
104             {/* Open c */ PDL_EXPAND2(register PDL_Indx c=0, __c_stop=(__c_size)); for(; c<__c_stop; c+=1) {
105             (rgb_datap)[0+(__inc_rgb_c*(c))]=rgb_badval;
106             }} /* Close c */
107             /* skip to the next rgb triple */
108             }
109             else,) {
110 2           xyz2rgb(xyz_datap, (gamma_datap)[0], &(mstar_datap)[0+(__inc_mstar_i*(0))+(__inc_mstar_rows*(0))], &(mstar_datap)[0+(__inc_mstar_i*(0))+(__inc_mstar_rows*(1))], &(mstar_datap)[0+(__inc_mstar_i*(0))+(__inc_mstar_rows*(2))], rgb_datap);
111             }
112 2 50         }PDL_BROADCASTLOOP_END__xyz_to_rgb_readdata
    50          
113 2           } break;
114 0           default: return PDL->make_error(PDL_EUSERERROR, "PP INTERNAL ERROR in _xyz_to_rgb: unhandled datatype(%d), only handles (D)! PLEASE MAKE A BUG REPORT\n", __privtrans->__datatype);
115             }
116             #undef PDL_BAD_CODE
117             #undef PDL_IF_BAD
118             } else { /* ** else do 'good' Code ** */
119             #define PDL_IF_BAD(t,f) f
120 3 50         switch (__privtrans->__datatype) { /* Start generic switch */
121 3           case PDL_D: {
122 3 50         PDL_DECLARE_PARAMS__xyz_to_rgb_1(PDL_Double,D)
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
123 17 50         PDL_BROADCASTLOOP_START__xyz_to_rgb_readdata {
    50          
    50          
    50          
    50          
    100          
    100          
124             /* First check for bad values */
125             PDL_IF_BAD(if (PDL_ISBAD2((xyz_datap)[0+(__inc_xyz_c*(0))],xyz_badval,D,xyz_badval_isnan) || PDL_ISBAD2((xyz_datap)[0+(__inc_xyz_c*(1))],xyz_badval,D,xyz_badval_isnan) || PDL_ISBAD2((xyz_datap)[0+(__inc_xyz_c*(2))],xyz_badval,D,xyz_badval_isnan)) {
126             {/* Open c */ PDL_EXPAND2(register PDL_Indx c=0, __c_stop=(__c_size)); for(; c<__c_stop; c+=1) {
127             (rgb_datap)[0+(__inc_rgb_c*(c))]=rgb_badval;
128             }} /* Close c */
129             /* skip to the next rgb triple */
130             }
131             else,) {
132 8           xyz2rgb(xyz_datap, (gamma_datap)[0], &(mstar_datap)[0+(__inc_mstar_i*(0))+(__inc_mstar_rows*(0))], &(mstar_datap)[0+(__inc_mstar_i*(0))+(__inc_mstar_rows*(1))], &(mstar_datap)[0+(__inc_mstar_i*(0))+(__inc_mstar_rows*(2))], rgb_datap);
133             }
134 3 50         }PDL_BROADCASTLOOP_END__xyz_to_rgb_readdata
    50          
135 3           } break;
136 0           default: return PDL->make_error(PDL_EUSERERROR, "PP INTERNAL ERROR in _xyz_to_rgb: unhandled datatype(%d), only handles (D)! PLEASE MAKE A BUG REPORT\n", __privtrans->__datatype);
137             }
138             #undef PDL_IF_BAD
139             }
140 5           return PDL_err;
141             }
142              
143             static pdl_datatypes pdl__xyz_to_rgb_vtable_gentypes[] = { PDL_D, -1 };
144             static PDL_Indx pdl__xyz_to_rgb_vtable_realdims[] = { 1, 0, 2, 1 };
145             static char *pdl__xyz_to_rgb_vtable_parnames[] = { "xyz","gamma","mstar","rgb" };
146             static short pdl__xyz_to_rgb_vtable_parflags[] = {
147             PDL_PARAM_ISPHYS,
148             0,
149             0,
150             PDL_PARAM_ISCREAT|PDL_PARAM_ISOUT|PDL_PARAM_ISPHYS|PDL_PARAM_ISWRITE
151             };
152             static pdl_datatypes pdl__xyz_to_rgb_vtable_partypes[] = { -1, -1, -1, -1 };
153             static PDL_Indx pdl__xyz_to_rgb_vtable_realdims_starts[] = { 0, 1, 1, 3 };
154             static PDL_Indx pdl__xyz_to_rgb_vtable_realdims_ind_ids[] = { 0, 1, 2, 0 };
155             static char *pdl__xyz_to_rgb_vtable_indnames[] = { "c","i","rows" };
156             pdl_transvtable pdl__xyz_to_rgb_vtable = {
157             PDL_TRANS_DO_BROADCAST|PDL_TRANS_BADPROCESS, 0, pdl__xyz_to_rgb_vtable_gentypes, 3, 4, NULL /*CORE21*/,
158             pdl__xyz_to_rgb_vtable_realdims, pdl__xyz_to_rgb_vtable_parnames,
159             pdl__xyz_to_rgb_vtable_parflags, pdl__xyz_to_rgb_vtable_partypes,
160             pdl__xyz_to_rgb_vtable_realdims_starts, pdl__xyz_to_rgb_vtable_realdims_ind_ids, 4,
161             3, pdl__xyz_to_rgb_vtable_indnames,
162             pdl__xyz_to_rgb_redodims, pdl__xyz_to_rgb_readdata, NULL,
163             NULL,
164             0,"PDL::Graphics::ColorSpace::_xyz_to_rgb"
165             };
166              
167              
168 5           pdl_error pdl_run__xyz_to_rgb(pdl *xyz,pdl *gamma,pdl *mstar,pdl *rgb) {
169 5           pdl_error PDL_err = {0, NULL, 0};
170 5 50         if (!PDL) return (pdl_error){PDL_EFATAL, "PDL core struct is NULL, can't continue",0};
171 5           pdl_trans *__privtrans = PDL->create_trans(&pdl__xyz_to_rgb_vtable);
172 5 50         if (!__privtrans) return PDL->make_error_simple(PDL_EFATAL, "Couldn't create trans");
173 5           __privtrans->pdls[0] = xyz;
174 5           __privtrans->pdls[1] = gamma;
175 5           __privtrans->pdls[2] = mstar;
176 5           __privtrans->pdls[3] = rgb;
177 5 50         PDL_RETERROR(PDL_err, PDL->type_coerce(__privtrans));
178 5 50         PDL_RETERROR(PDL_err, PDL->make_trans_mutual(__privtrans));
179 5           return PDL_err;
180             }