Sha256: 903984ddee026b297059786bcd5e35dae5ee6f0b0d139dfac0eb13d3f0dc46a8

Contents?: true

Size: 1.49 KB

Versions: 7

Compression:

Stored size: 1.49 KB

Contents

static void
<%=c_iter%>(na_loop_t *const lp)
{
    size_t  i;
    char   *p1, *p2;
    ssize_t s1, s2;
    size_t *idx1, *idx2;
    dtype   x;
    <%=dtype%> y;
    INIT_COUNTER(lp, i);
    INIT_PTR_IDX(lp, 0, p1, s1, idx1);
    INIT_PTR_IDX(lp, 1, p2, s2, idx2);
    if (idx1) {
        if (idx2) {
            for (; i--;) {
                GET_DATA_INDEX(p1,idx1,dtype,x);
                GET_DATA_INDEX(p2,idx2,<%=dtype%>,y);
                x = m_<%=method%>(x,y);
                SET_DATA_INDEX(p1,idx1,dtype,x);
            }
        } else {
            for (; i--;) {
                GET_DATA_INDEX(p1,idx1,dtype,x);
                GET_DATA_STRIDE(p2,s2,<%=dtype%>,y);
                x = m_<%=method%>(x,y);
                SET_DATA_INDEX(p1,idx1,dtype,x);
            }
        }
    } else {
        if (idx2) {
            for (; i--;) {
                GET_DATA(p1,dtype,x);
                GET_DATA_INDEX(p2,idx2,<%=dtype%>,y);
                x = m_<%=method%>(x,y);
                SET_DATA_STRIDE(p1,s1,dtype,x);
            }
        } else {
            for (; i--;) {
                GET_DATA(p1,dtype,x);
                GET_DATA_STRIDE(p2,s2,<%=dtype%>,y);
                x = m_<%=method%>(x,y);
                SET_DATA_STRIDE(p1,s1,dtype,x);
            }
        }
    }
}

static VALUE
<%=c_func%>(VALUE self, VALUE a1)
{
    ndfunc_arg_in_t ain[2] = {{OVERWRITE,0},{<%=tpclass%>,0}};
    ndfunc_t ndf = { <%=c_iter%>, FULL_LOOP, 2, 0, ain, 0 };

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

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
numo-narray-0.9.0.4 ext/numo/narray/gen/tmpl/set2.c
numo-narray-0.9.0.3-x86-mingw32 ext/numo/narray/gen/tmpl/set2.c
numo-narray-0.9.0.3-x64-mingw32 ext/numo/narray/gen/tmpl/set2.c
numo-narray-0.9.0.3 ext/numo/narray/gen/tmpl/set2.c
numo-narray-0.9.0.1-x64-mingw32 ext/numo/narray/gen/tmpl/set2.c
numo-narray-0.9.0.1 ext/numo/narray/gen/tmpl/set2.c
numo-narray-0.9.0.1-x86-mingw32 ext/numo/narray/gen/tmpl/set2.c