Sha256: 2fd76b841969c2172dd695991b24ee39ff76fcb1f3445ebd8ddc8d2f19477f59

Contents?: true

Size: 979 Bytes

Versions: 20

Compression:

Stored size: 979 Bytes

Contents

#include "xint_macro.h"

#define m_abs(x)     (x)
#define m_sign(x)    (((x)==0) ? 0:1)

static inline dtype int_reciprocal(dtype x) {
    switch (x) {
    case 1:
        return 1;
    case 0:
        rb_raise(rb_eZeroDivError, "divided by 0");
    default:
        return 0;
    }
}

/*
static dtype pow_int(dtype x, int p)
{
    dtype r = m_one;
    switch(p) {
    case 0: return 1;
    case 1: return x;
    case 2: return x*x;
    case 3: return x*x*x;
    }
    while (p) {
        if (p&1) r *= x;
        x *= x;
        p >>= 1;
    }
    return r;
}
*/

static inline u_int64_t f_sum(size_t n, char *p, ssize_t stride)
{
    u_int64_t x,y=0;
    size_t i=n;
    for (; i--;) {
        x = *(dtype*)p;
        y += x;
        p += stride;
    }
    return y;
}

static inline u_int64_t f_prod(size_t n, char *p, ssize_t stride)
{
    u_int64_t x,y=1;
    size_t i=n;
    for (; i--;) {
        x = *(dtype*)p;
        y *= x;
        p += stride;
    }
    return y;
}

Version data entries

20 entries across 20 versions & 1 rubygems

Version Path
cumo-0.4.3 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.4.2 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.4.1 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.4.0 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.3.5 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.3.4 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.3.3 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.3.2 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.3.1 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.3.0 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.3.0.pre1 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.2.5 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.2.4 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.2.3 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.2.2 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.2.1 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.2.0 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.1.2 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.1.1 ext/cumo/include/cumo/types/uint_macro.h
cumo-0.1.0 ext/cumo/include/cumo/types/uint_macro.h