3#if _MSC_VER >= 1900 && defined(_M_X64)
5#include "ComputationalGraph.h"
12 class FL_EXPORT CComputationalGraphNormalRandom :
public CComputationalGraph<T>
15 CComputationalGraphNormalRandom();
18 CComputationalGraphNormalRandom(
const CComputationalGraphNormalRandom<T>& cg);
22 CComputationalGraphNormalRandom(
const CComputationalBase<T>& cbOperand1,
double f64Mean = 0.,
double f64Stdev = 1);
23 CComputationalGraphNormalRandom(
const CTensor<T>& tsrOperand1,
double f64Mean = 0.,
double f64Stdev = 1);
24 virtual ~CComputationalGraphNormalRandom();
26 virtual CTensor<T>& Forward()
override;
27 virtual CTensor<T>* Backward()
override;
28 virtual CComputationalBase<T>* Clone()
const override;
29 virtual const CResult PrintNodeParamInfo()
const override;
31 virtual const CResult GetBinaryData(Base::CFLData& fldBinary,
bool bSuperClass =
false, int32_t i32Version = -1,
bool bDumpMode =
false)
const override;
32 virtual const CResult GetBinaryData(Base::CFLData* pFldBinary,
bool bSuperClass =
false, int32_t i32Version = -1,
bool bDumpMode =
false)
const override;
34 virtual const CResult SetBinaryData(
const Base::CFLData& fldBinary, int64_t* pI64Offset =
nullptr)
override;
35 virtual const CResult SetBinaryData(
const Base::CFLData* pFldBinary, int64_t* pI64Offset =
nullptr)
override;
37 virtual const std::vector<int64_t>& GetEstimatedShape(
bool bRecursive =
true)
const override;
39 virtual const CResult SetDistribution(
double f64Mean = 0.,
double f64Stdev = 1.);
40 virtual const CResult GetDistribution(
double& f64Mean,
double& f64Stdev)
const;
43 DeclareGetClassType();
44 SupportToDuplicateObjectWithoutCreateNewObject(CComputationalGraphNormalRandom, *
this);
50 DeclareGetSignletonObject(CComputationalGraphNormalRandom);
53 #define CCGFNormalRandom(...) (*(new CComputationalGraphNormalRandom<float>(__VA_ARGS__)))
54 #define CCGDNormalRandom(...) (*(new CComputationalGraphNormalRandom<double>(__VA_ARGS__)))
56 #define CCGTNoramlRandom(T, ...) (*(new CComputationalGraphNormalRandom<T>(__VA_ARGS__)))