Sha256: ce694de1f083badac9e3596349a5b088f54fd76511742157aab03603220bb3c0

Contents?: true

Size: 1.47 KB

Versions: 3

Compression:

Stored size: 1.47 KB

Contents

static void
iter_<%=c_func%>(na_loop_t *const lp)
{
    int    c0, c1;
    double c2, c3, *c5;
    <%=struct%> *w;
    void **opt = (void**)(lp->opt_ptr);

    w  = (<%=struct%>*)(opt[0]);
    c0 = *(int*)(opt[1]); //<%=args[0][1]%>
    c1 = *(int*)(opt[2]); //<%=args[1][1]%>
    c2 = *(double*)GET_PTR(lp,0); //<%=args[2][1]%>
    c3 = *(double*)GET_PTR(lp,1); //<%=args[3][1]%>
    c5 =  (double*)GET_PTR(lp,2); //<%=args[5][1]%>
    <%=func_name%>(c0,c1,c2,c3,w,c5);
}

/*
  @overload <%=name%>(<%=args[0][1]%>,<%=args[1][1]%>,<%=args[2][1]%>,<%=args[3][1]%>)

  @param [Integer]  <%=args[0][1]%>
  @param [Integer]  <%=args[1][1]%>
  @param [Numo::DFloat]  <%=args[2][1]%>
  @param [Numo::DFloat]  <%=args[3][1]%>
  @return [Numo::DFloat]  returns <%=args[5][1]%>

  <%= description %>
*/
static VALUE
<%=c_func(4)%>(VALUE self, VALUE v0, VALUE v1, VALUE v2, VALUE v3)
{
    <%=struct%> *w;
    int nmin, nmax;
    size_t shape[1];
    ndfunc_arg_in_t ain[2] = {{cDF,0},{cDF,0}};
    ndfunc_arg_out_t aout[1] = {{cDF,1,shape}};
    ndfunc_t ndf = {iter_<%=c_func%>,NO_LOOP|NDF_INPLACE|NDF_EXTRACT,2,1,ain,aout};
    void *opt[3];

    TypedData_Get_Struct(self, <%=struct%>, &<%=data_type_var%>, w);

    nmin = NUM2INT(v0);
    nmax = NUM2INT(v1);
    opt[0] = w;
    opt[1] = &nmin;
    opt[2] = &nmax;
    if (nmin<0 || nmax<0 || nmin>nmax) {
        rb_raise(rb_eArgError,"should be nmin>=0 && nmax>=0 && nmin<=nmax");
    }
    shape[0] = nmax-nmin+1;
    return na_ndloop3(&ndf,opt,2,v2,v3);
}

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
numo-gsl-0.1.2 ext/numo/gsl/sf/tmpl/c_DFloat_f_int_x2_DFloat_x2.c
numo-gsl-0.1.1 ext/numo/gsl/sf/tmpl/c_DFloat_f_int_x2_DFloat_x2.c
numo-gsl-0.1.0 ext/numo/gsl/sf/tmpl/c_DFloat_f_int_x2_DFloat_x2.c