151 lines
12 KiB
C++
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);
|
|
};
|
|
} |