AuroraRuntime/Source/RNG/AuRandomDevice.hpp

151 lines
12 KiB
C++

/***
Copyright (C) 2021 J Reece Wilson (a/k/a "Reece"). All rights reserved.
File: AuRandomDevice.hpp
Date: 2021-9-3
Author: Reece
***/
#pragma once
#include "AuWELL.hpp"
#include <Source/IO/Adapters/AuIOAdapterRandom.hpp>
namespace Aurora::RNG
{
struct RandomDevice final :
IRandomDevice,
IO::Adapters::RandomStreamReader
{
RandomDevice();
RandomDevice(const RandomDef & def);
void Read(const AuMemoryViewWrite &view) override;
AuString NextString(AuUInt32 uLength, ERngStringCharacters type) override;
void NextString(const AuMemoryViewWrite &view, ERngStringCharacters type) override;
AuUInt8 NextByte() override;
bool NextBoolean() override;
AuUInt32 NextU32() override;
AuUInt64 NextU64() override;
AuUInt64 NextU64Range(AuUInt64 uMin, AuUInt64 uMax) override;
AuInt64 NextI64Range(AuInt64 iMin, AuInt64 iMax) override;
AuVec2 NextVec2(AuVec2 boundA, AuVec2 boundB) override;
AuVec2 NextVec2Sorted(AuVec2 min, AuVec2 max) override;
AuVec3 NextVec3(AuVec3 boundA, AuVec3 boundB) override;
AuVec3 NextVec3Sorted(AuVec3 min, AuVec3 max) override;
AuVec4 NextVec4(AuVec4 boundA, AuVec4 boundB) override;
AuVec4 NextVec4Sorted(AuVec4 min, AuVec4 max) override;
AuInt32 NextI32Range(AuInt32 iMin, AuInt32 iMax) override;
AuUInt32 NextU32Range(AuUInt32 uMin, AuUInt32 uMax) override;
AuVecD2 NextVecD2(AuVecD2 boundA, AuVecD2 boundB) override;
AuVecD2 NextVecD2Sorted(AuVecD2 min, AuVecD2 max) override;
AuVecD3 NextVecD3(AuVecD3 boundA, AuVecD3 boundB) override;
AuVecD3 NextVecD3Sorted(AuVecD3 min, AuVecD3 max) override;
AuVecD4 NextVecD4(AuVecD4 boundA, AuVecD4 boundB) override;
AuVecD4 NextVecD4Sorted(AuVecD4 min, AuVecD4 max) override;
AuList<AuInt32> NextArrayI32Range(AuUInt32 uCount, AuInt32 iMin, AuInt32 iMax) override;
AuList<AuUInt32> NextArrayU32Range(AuUInt32 uCount, AuUInt32 uMin, AuUInt32 uMax) override;
AuList<AuInt64> NextArrayI64Range(AuUInt32 uCount, AuInt64 uMin, AuInt64 uMax) override;
AuList<AuUInt64> NextArrayU64Range(AuUInt32 uCount, AuUInt64 uMin, AuUInt64 uMax) override;
AuList<AuUInt32> NextArrayU32Mask(AuUInt32 uCount, AuUInt32 uMask) override;
AuList<AuUInt64> NextArrayU64Mask(AuUInt32 uCount, AuUInt64 uMask) override;
AuList<double> NextArrayDoubleRange(AuUInt32 uCount, double dMin, double dMax) override;
AuList<double> NextArrayDoubleRangeFast(AuUInt32 uCount, double dMin, double dMax) override;
AuList<AuInt32> NextArrayI32(AuUInt32 uCount) override;
AuList<AuUInt32> NextArrayU32(AuUInt32 uCount) override;
AuList<AuInt64> NextArrayI64(AuUInt32 uCount) override;
AuList<AuUInt64> NextArrayU64(AuUInt32 uCount) override;
AuList<AuVec2> NextArrayVec2(AuUInt32 uCount, AuVec2 boundA, AuVec2 boundB) override;
AuList<AuVec2> NextArrayVec2Fast(AuUInt32 uCount, AuVec2 boundA, AuVec2 boundB) override;
AuList<AuVec2> NextArrayVec2Sorted(AuUInt32 uCount, AuVec2 min, AuVec2 max) override;
AuList<AuVec2> NextArrayVec2SortedFast(AuUInt32 uCount, AuVec2 min, AuVec2 max) override;
AuList<AuVec3> NextArrayVec3(AuUInt32 uCount, AuVec3 boundA, AuVec3 boundB) override;
AuList<AuVec3> NextArrayVec3Fast(AuUInt32 uCount, AuVec3 boundA, AuVec3 boundB) override;
AuList<AuVec3> NextArrayVec3Sorted(AuUInt32 uCount, AuVec3 min, AuVec3 max) override;
AuList<AuVec3> NextArrayVec3SortedFast(AuUInt32 uCount, AuVec3 min, AuVec3 max) override;
AuList<AuVec4> NextArrayVec4(AuUInt32 uCount, AuVec4 boundA, AuVec4 boundB) override;
AuList<AuVec4> NextArrayVec4Fast(AuUInt32 uCount, AuVec4 boundA, AuVec4 boundB) override;
AuList<AuVec4> NextArrayVec4Sorted(AuUInt32 uCount, AuVec4 min, AuVec4 max) override;
AuList<AuVec4> NextArrayVec4SortedFast(AuUInt32 uCount, AuVec4 min, AuVec4 max) override;
AuList<AuVecD2> NextArrayVecD2(AuUInt32 uCount, AuVecD2 boundA, AuVecD2 boundB) override;
AuList<AuVecD2> NextArrayVecD2Fast(AuUInt32 uCount, AuVecD2 boundA, AuVecD2 boundB) override;
AuList<AuVecD2> NextArrayVecD2Sorted(AuUInt32 uCount, AuVecD2 min, AuVecD2 max) override;
AuList<AuVecD2> NextArrayVecD2SortedFast(AuUInt32 uCount, AuVecD2 min, AuVecD2 max) override;
AuList<AuVecD3> NextArrayVecD3(AuUInt32 uCount, AuVecD3 boundA, AuVecD3 boundB) override;
AuList<AuVecD3> NextArrayVecD3Fast(AuUInt32 uCount, AuVecD3 boundA, AuVecD3 boundB) override;
AuList<AuVecD3> NextArrayVecD3Sorted(AuUInt32 uCount, AuVecD3 min, AuVecD3 max) override;
AuList<AuVecD3> NextArrayVecD3SortedFast(AuUInt32 uCount, AuVecD3 min, AuVecD3 max) override;
AuList<AuVecD4> NextArrayVecD4(AuUInt32 uCount, AuVecD4 boundA, AuVecD4 boundB) override;
AuList<AuVecD4> NextArrayVecD4Fast(AuUInt32 uCount, AuVecD4 boundA, AuVecD4 boundB) override;
AuList<AuVecD4> NextArrayVecD4Sorted(AuUInt32 uCount, AuVecD4 min, AuVecD4 max) override;
AuList<AuVecD4> NextArrayVecD4SortedFast(AuUInt32 uCount, AuVecD4 min, AuVecD4 max) override;
AuList<double> NextArrayDouble(AuUInt32 uCount) override;
AuList<double> NextArrayDecimals(AuUInt32 uCount) override;
AuList<double> NextArrayDecimalsFast(AuUInt32 uCount) override;
AuList<uuids::uuid> NextArrayUUIDs(AuUInt32 uCount) override;
AuList<AuInt32> NextArrayI32RangeFast(AuUInt32 uCount, AuInt32 iMin, AuInt32 iMax) override;
AuList<AuUInt32> NextArrayU32RangeFast(AuUInt32 uCount, AuUInt32 uMin, AuUInt32 uMax) override;
AuList<AuInt64> NextArrayI64RangeFast(AuUInt32 uCount, AuInt64 iMin, AuInt64 iMax) override;
AuList<AuUInt64> NextArrayU64RangeFast(AuUInt32 uCount, AuUInt64 uMin, AuUInt64 uMax) override;
AuUInt NextArrayI32RangeInView(const AuMemoryViewWrite &write, AuInt32 iMin, AuInt32 iMax) override;
AuUInt NextArrayI32RangeFastInView(const AuMemoryViewWrite &write, AuInt32 iMin, AuInt32 iMax) override;
AuUInt NextArrayU32RangeInView(const AuMemoryViewWrite &write, AuUInt32 uMin, AuUInt32 uMax) override;
AuUInt NextArrayU32RangeFastInView(const AuMemoryViewWrite &write, AuUInt32 uMin, AuUInt32 uMax) override;
AuUInt NextArrayI64RangeInView(const AuMemoryViewWrite &write, AuInt64 iMin, AuInt64 iMax) override;
AuUInt NextArrayI64RangeFastInView(const AuMemoryViewWrite &write, AuInt64 iMin, AuInt64 iMax) override;
AuUInt NextArrayU64RangeInView(const AuMemoryViewWrite &write, AuUInt64 uMin, AuUInt64 uMax) override;
AuUInt NextArrayU64RangeFastInView(const AuMemoryViewWrite &write, AuUInt64 uMin, AuUInt64 uMax) override;
AuUInt NextArrayU32MaskInView(const AuMemoryViewWrite &write, AuUInt32 uMask) override;
AuUInt NextArrayU64MaskInView(const AuMemoryViewWrite &write, AuUInt64 uMask) override;
AuUInt NextArrayDoubleRangeInView(const AuMemoryViewWrite &write, double dMin, double dMax) override;
AuUInt NextArrayDoubleRangeFastInView(const AuMemoryViewWrite &write, double dMin, double dMax) override;
AuUInt NextArrayI32InView(const AuMemoryViewWrite &write) override;
AuUInt NextArrayU32InView(const AuMemoryViewWrite &write) override;
AuUInt NextArrayI64InView(const AuMemoryViewWrite &write) override;
AuUInt NextArrayU64InView(const AuMemoryViewWrite &write) override;
AuUInt NextArrayVec2InView(const AuMemoryViewWrite &write, AuVec2 boundA, AuVec2 boundB) override;
AuUInt NextArrayVec2FastInView(const AuMemoryViewWrite &write, AuVec2 boundA, AuVec2 boundB) override;
AuUInt NextArrayVec2SortedInView(const AuMemoryViewWrite &write, AuVec2 min, AuVec2 max) override;
AuUInt NextArrayVec2SortedFastInView(const AuMemoryViewWrite &write, AuVec2 min, AuVec2 max) override;
AuUInt NextArrayVec3InView(const AuMemoryViewWrite &write, AuVec3 boundA, AuVec3 boundB) override;
AuUInt NextArrayVec3FastInView(const AuMemoryViewWrite &write, AuVec3 boundA, AuVec3 boundB) override;
AuUInt NextArrayVec3SortedInView(const AuMemoryViewWrite &write, AuVec3 min, AuVec3 max) override;
AuUInt NextArrayVec3SortedFastInView(const AuMemoryViewWrite &write, AuVec3 min, AuVec3 max) override;
AuUInt NextArrayVec4InView(const AuMemoryViewWrite &write, AuVec4 boundA, AuVec4 boundB) override;
AuUInt NextArrayVec4FastInView(const AuMemoryViewWrite &write, AuVec4 boundA, AuVec4 boundB) override;
AuUInt NextArrayVec4SortedInView(const AuMemoryViewWrite &write, AuVec4 min, AuVec4 max) override;
AuUInt NextArrayVec4SortedFastInView(const AuMemoryViewWrite &write, AuVec4 min, AuVec4 max) override;
AuUInt NextArrayVecD2InView(const AuMemoryViewWrite &write, AuVecD2 boundA, AuVecD2 boundB) override;
AuUInt NextArrayVecD2FastInView(const AuMemoryViewWrite &write, AuVecD2 boundA, AuVecD2 boundB) override;
AuUInt NextArrayVecD2SortedInView(const AuMemoryViewWrite &write, AuVecD2 min, AuVecD2 max) override;
AuUInt NextArrayVecD2SortedFastInView(const AuMemoryViewWrite &write, AuVecD2 min, AuVecD2 max) override;
AuUInt NextArrayVecD3InView(const AuMemoryViewWrite &write, AuVecD3 boundA, AuVecD3 boundB) override;
AuUInt NextArrayVecD3FastInView(const AuMemoryViewWrite &write, AuVecD3 boundA, AuVecD3 boundB) override;
AuUInt NextArrayVecD3SortedInView(const AuMemoryViewWrite &write, AuVecD3 min, AuVecD3 max) override;
AuUInt NextArrayVecD3SortedFastInView(const AuMemoryViewWrite &write, AuVecD3 min, AuVecD3 max) override;
AuUInt NextArrayVecD4InView(const AuMemoryViewWrite &write, AuVecD4 boundA, AuVecD4 boundB) override;
AuUInt NextArrayVecD4FastInView(const AuMemoryViewWrite &write, AuVecD4 boundA, AuVecD4 boundB) override;
AuUInt NextArrayVecD4SortedInView(const AuMemoryViewWrite &write, AuVecD4 min, AuVecD4 max) override;
AuUInt NextArrayVecD4SortedFastInView(const AuMemoryViewWrite &write, AuVecD4 min, AuVecD4 max) override;
AuUInt NextArrayDoubleInView(const AuMemoryViewWrite &write) override;
AuUInt NextArrayDecimalsInView(const AuMemoryViewWrite &write) override;
AuUInt NextArrayDecimalsFastInView(const AuMemoryViewWrite &write) override;
AuUInt NextArrayUUIDsInView(const AuMemoryViewWrite &write) override;
double NextDecimal() override;
double NextNumber(double dMin, double dMax) override;
AuUInt32 NextIndex(AuUInt32 uCount /* = max + 1*/) override;
uuids::uuid NextUUID() override;
IO::IStreamReader *ToStreamReader() override;
AuMemoryViewRead ToSeed() override;
void Init(const RandomDef &def);
private:
RandomDef def_;
WELLRand fast_;
bool DecGeometric(int x);
double UniformFloatInRange(double udMin, double udMax);
};
}