12#ifndef RANLUXPP_HELPERS_H
13#define RANLUXPP_HELPERS_H
18static inline uint64_t
add_overflow(uint64_t
a, uint64_t
b,
unsigned &overflow)
26static inline uint64_t
add_carry(uint64_t
a, uint64_t
b,
unsigned &carry)
37static inline uint64_t
sub_overflow(uint64_t
a, uint64_t
b,
unsigned &overflow)
45static inline uint64_t
sub_carry(uint64_t
a, uint64_t
b,
unsigned &carry)
66 for (
int i = 0; i < 9; i++) {
74 int64_t
c = -((int64_t)carry);
78 for (
int i = 0; i < 9; i++) {
107 for (
int i = 0; i < 3; i++) {
108 uint64_t
r_i =
r[i + 4];
148 bool greater_m =
r[0] |
r[1] |
r[2] | (
r[3] & 0x0000ffffffffffff);
150 for (
int i = 4; i < 9; i++) {
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t r
static uint64_t sub_overflow(uint64_t a, uint64_t b, unsigned &overflow)
Compute a - b and set overflow accordingly.
static uint64_t sub_carry(uint64_t a, uint64_t b, unsigned &carry)
Compute a - b and increment carry if there was an overflow.
static uint64_t add_carry(uint64_t a, uint64_t b, unsigned &carry)
Compute a + b and increment carry if there was an overflow.
static int64_t compute_r(const uint64_t *upper, uint64_t *r)
Update r = r - (t1 + t2) + (t3 + t2) * b ** 10.
static uint64_t add_overflow(uint64_t a, uint64_t b, unsigned &overflow)
Compute a + b and set overflow accordingly.