Sha256: 4b5ca088aaf130982d4b03ac5cd2f82055bb104ceb75307eae2b99569d6885d2

Contents?: true

Size: 1.46 KB

Versions: 9

Compression:

Stored size: 1.46 KB

Contents

static void
<%=c_iter%>(na_loop_t *const lp)
{
    size_t   i, n;
    char    *p1, *p2, *p3, *p4;
    ssize_t  s1, s2, s3, s4;
    dtype    x, y, a, b;
    INIT_COUNTER(lp, n);
    INIT_PTR(lp, 0, p1, s1);
    INIT_PTR(lp, 1, p2, s2);
    INIT_PTR(lp, 2, p3, s3);
    INIT_PTR(lp, 3, p4, s4);
    for (i=n; i--;) {
        GET_DATA_STRIDE(p1,s1,dtype,x);
        GET_DATA_STRIDE(p2,s2,dtype,y);
<% if is_int and %w[divmod].include? name %>
        if (y==0) {
            lp->err_type = rb_eZeroDivError;
            return;
        }
<% end %>
        m_<%=name%>(x,y,a,b);
        SET_DATA_STRIDE(p3,s3,dtype,a);
        SET_DATA_STRIDE(p4,s4,dtype,b);
    }
}

static VALUE
<%=c_func%>_self(VALUE self, VALUE other)
{
    ndfunc_arg_in_t ain[2] = {{cT,0},{cT,0}};
    ndfunc_arg_out_t aout[2] = {{cT,0},{cT,0}};
    ndfunc_t ndf = { <%=c_iter%>, STRIDE_LOOP, 2, 2, ain, aout };

    return na_ndloop(&ndf, 2, self, other);
}

/*
  Binary <%=name%>.
  @overload <%=op_map%> other
  @param [Numo::NArray,Numeric] other
  @return [Numo::NArray] <%=name%> of self and other.
*/
static VALUE
<%=c_func(1)%>(VALUE self, VALUE other)
{
    <% if is_object %>
    return <%=c_func%>_self(self, other);
    <% else %>
    VALUE klass, v;
    klass = na_upcast(rb_obj_class(self),rb_obj_class(other));
    if (klass==cT) {
        return <%=c_func%>_self(self, other);
    } else {
        v = rb_funcall(klass, id_cast, 1, self);
        return rb_funcall(v, <%=id_op%>, 1, other);
    }
    <% end %>
}

Version data entries

9 entries across 9 versions & 1 rubygems

Version Path
numo-narray-0.9.2.1 ext/numo/narray/gen/tmpl/binary2.c
numo-narray-0.9.2.0 ext/numo/narray/gen/tmpl/binary2.c
numo-narray-0.9.1.9 ext/numo/narray/gen/tmpl/binary2.c
numo-narray-0.9.1.8 ext/numo/narray/gen/tmpl/binary2.c
numo-narray-0.9.1.7 ext/numo/narray/gen/tmpl/binary2.c
numo-narray-0.9.1.6 ext/numo/narray/gen/tmpl/binary2.c
numo-narray-0.9.1.5 ext/numo/narray/gen/tmpl/binary2.c
numo-narray-0.9.1.4 ext/numo/narray/gen/tmpl/binary2.c
numo-narray-0.9.1.3 ext/numo/narray/gen/tmpl/binary2.c