2022-04-07 20:30:22 -07:00
|
|
|
#ifndef COSMOPOLITAN_TOOL_PLINKO_LIB_HISTO_H_
|
|
|
|
#define COSMOPOLITAN_TOOL_PLINKO_LIB_HISTO_H_
|
2022-09-12 23:10:38 -07:00
|
|
|
#include "libc/intrin/bsr.h"
|
2022-04-07 20:30:22 -07:00
|
|
|
#include "libc/macros.internal.h"
|
|
|
|
#if !(__ASSEMBLER__ + __LINKER__ + 0)
|
|
|
|
COSMOPOLITAN_C_START_
|
|
|
|
|
|
|
|
#define HISTO(H, X) \
|
|
|
|
do { \
|
|
|
|
uint64_t x_ = X; \
|
2022-09-12 23:10:38 -07:00
|
|
|
x_ = x_ ? _bsrl(x_) + 1 : x_; \
|
2022-04-07 20:30:22 -07:00
|
|
|
++H[MIN(x_, ARRAYLEN(H) - 1)]; \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
void PrintHistogram(int, const char *, const long *, size_t);
|
|
|
|
long GetLongSum(const long *, size_t);
|
|
|
|
|
|
|
|
COSMOPOLITAN_C_END_
|
|
|
|
#endif /* !(__ASSEMBLER__ + __LINKER__ + 0) */
|
|
|
|
#endif /* COSMOPOLITAN_TOOL_PLINKO_LIB_HISTO_H_ */
|