Sha256: 4c7fcec49e61caf18fe8d59259a7e9d33c3146c5af6ee3436521ed43688e08bd

Contents?: true

Size: 1.55 KB

Versions: 9

Compression:

Stored size: 1.55 KB

Contents

#define args_t <%=name%>_args_t

typedef struct {
    dtype alpha;
} args_t;

#define func_p <%=func_name%>_p
static <%=func_name%>_t func_p = 0;

static void
<%=c_iter%>(na_loop_t *const lp)
{
    char   *p1, *p2;
    size_t  n;
    ssize_t s1, s2;
    dtype  *g;

    INIT_COUNTER(lp,n);
    INIT_PTR(lp,0,p1,s1);
    INIT_PTR(lp,1,p2,s2);
    g = (dtype*)(lp->opt_ptr);

    (*func_p)(n, DP(*g), (dtype*)p1, s1/sizeof(dtype),
                         (dtype*)p2, s2/sizeof(dtype));
}

/*<%
 params = [
   vec("x"),
   vec("y",:inplace),
   opt("alpha"),
 ].select{|x| x}.join("\n  ")
%>
  @overload <%=name%>( x, y, [alpha:1] )
  <%=params%>
  @return [<%=class_name%>] y = alpha * x + y

<%=description%>

*/
static VALUE
<%=c_func(-1)%>(int argc, VALUE const argv[], VALUE UNUSED(mod))
{
    VALUE x, y, alpha;
    narray_t *na1, *na2;
    ndfunc_arg_in_t ain[2] = {{cT,0},{OVERWRITE,0}};
    ndfunc_t ndf = {<%=c_iter%>, STRIDE_LOOP, 2, 0, ain, 0};

    dtype g;
    VALUE kw_hash = Qnil;
    ID kw_table[1] = {id_alpha};
    VALUE opts[1] = {Qundef};

    CHECK_FUNC(func_p,"<%=func_name%>");

    rb_scan_args(argc, argv, "2:", &x, &y, &kw_hash);
    rb_get_kwargs(kw_hash, kw_table, 0, 1, opts);
    alpha = option_value(opts[0],Qnil);
    g     = RTEST(alpha) ? m_num_to_data(alpha) : m_one;

    COPY_OR_CAST_TO(y,cT);
    GetNArray(x,na1);
    GetNArray(y,na2);
    CHECK_DIM_GE(na1,1);
    CHECK_DIM_GE(na2,1);
    CHECK_NON_EMPTY(na1);
    CHECK_NON_EMPTY(na2);
    CHECK_SAME_SHAPE(na1,na2);

    na_ndloop3(&ndf, &g, 2, x, y);
    return y;
}

#undef func_p
#undef args_t

Version data entries

9 entries across 9 versions & 1 rubygems

Version Path
numo-linalg-0.1.7 ext/numo/linalg/blas/tmpl/axpy.c
numo-linalg-0.1.6 ext/numo/linalg/blas/tmpl/axpy.c
numo-linalg-0.1.5 ext/numo/linalg/blas/tmpl/axpy.c
numo-linalg-0.1.4 ext/numo/linalg/blas/tmpl/axpy.c
numo-linalg-0.1.3 ext/numo/linalg/blas/tmpl/axpy.c
numo-linalg-0.1.2 ext/numo/linalg/blas/tmpl/axpy.c
numo-linalg-0.1.1 ext/numo/linalg/blas/tmpl/axpy.c
numo-linalg-0.1.0 ext/numo/linalg/blas/tmpl/axpy.c
numo-linalg-0.0.1 ext/numo/linalg/blas/tmpl/axpy.c