From 3811bbd69591b07bc94247602eb0f38c2b44cc2e Mon Sep 17 00:00:00 2001 From: "petro.zarytskyi" Date: Thu, 14 Nov 2024 18:21:06 +0100 Subject: [PATCH] Use clad::zero_vector instead of 0 in the vectorized forward mode to ensure type safety. This is necessary to ensure type safety. ``0`` represents a zero vector but is only properly treated as a zero vector when it gets added/subtracted with a ``clad::array``. Initializing a ``clad::array`` with ``0`` will create not a zero vector but an empty array (with zero elements). To fix this, we needed exceptions for all declarations. We would need to make new exceptions when passing parameters to pushforwards. --- .../Differentiator/BaseForwardModeVisitor.h | 4 +- .../Differentiator/VectorForwardModeVisitor.h | 2 + .../VectorForwardModeVisitor.cpp | 48 ++++++--------- test/Arrays/ArrayInputsVectorForwardMode.C | 16 ++--- test/ForwardMode/VectorMode.C | 60 ++++++++----------- test/ForwardMode/VectorModeInterface.C | 6 +- 6 files changed, 59 insertions(+), 77 deletions(-) diff --git a/include/clad/Differentiator/BaseForwardModeVisitor.h b/include/clad/Differentiator/BaseForwardModeVisitor.h index 802db880a..73ed020a0 100644 --- a/include/clad/Differentiator/BaseForwardModeVisitor.h +++ b/include/clad/Differentiator/BaseForwardModeVisitor.h @@ -58,12 +58,12 @@ class BaseForwardModeVisitor StmtDiff VisitCXXDefaultArgExpr(const clang::CXXDefaultArgExpr* DE); StmtDiff VisitDeclRefExpr(const clang::DeclRefExpr* DRE); StmtDiff VisitDeclStmt(const clang::DeclStmt* DS); - StmtDiff VisitFloatingLiteral(const clang::FloatingLiteral* FL); + virtual StmtDiff VisitFloatingLiteral(const clang::FloatingLiteral* FL); StmtDiff VisitForStmt(const clang::ForStmt* FS); StmtDiff VisitIfStmt(const clang::IfStmt* If); StmtDiff VisitImplicitCastExpr(const clang::ImplicitCastExpr* ICE); StmtDiff VisitInitListExpr(const clang::InitListExpr* ILE); - StmtDiff VisitIntegerLiteral(const clang::IntegerLiteral* IL); + virtual StmtDiff VisitIntegerLiteral(const clang::IntegerLiteral* IL); StmtDiff VisitMemberExpr(const clang::MemberExpr* ME); StmtDiff VisitParenExpr(const clang::ParenExpr* PE); virtual StmtDiff VisitReturnStmt(const clang::ReturnStmt* RS); diff --git a/include/clad/Differentiator/VectorForwardModeVisitor.h b/include/clad/Differentiator/VectorForwardModeVisitor.h index f906c6c14..6890b622a 100644 --- a/include/clad/Differentiator/VectorForwardModeVisitor.h +++ b/include/clad/Differentiator/VectorForwardModeVisitor.h @@ -69,6 +69,8 @@ class VectorForwardModeVisitor : public BaseForwardModeVisitor { /// For example: for size = 4, the returned expression is: {0, 0, 0, 0} clang::Expr* getZeroInitListExpr(size_t size, clang::QualType type); + StmtDiff VisitFloatingLiteral(const clang::FloatingLiteral* FL) override; + StmtDiff VisitIntegerLiteral(const clang::IntegerLiteral* IL) override; StmtDiff VisitArraySubscriptExpr(const clang::ArraySubscriptExpr* ASE) override; StmtDiff VisitReturnStmt(const clang::ReturnStmt* RS) override; diff --git a/lib/Differentiator/VectorForwardModeVisitor.cpp b/lib/Differentiator/VectorForwardModeVisitor.cpp index c471c517d..1c9ff820d 100644 --- a/lib/Differentiator/VectorForwardModeVisitor.cpp +++ b/lib/Differentiator/VectorForwardModeVisitor.cpp @@ -506,15 +506,10 @@ StmtDiff VectorForwardModeVisitor::VisitReturnStmt(const ReturnStmt* RS) { Expr* derivedRetValE = retValDiff.getExpr_dx(); // If we are in vector mode, we need to wrap the return value in a // vector. - SourceLocation loc{m_DiffReq->getLocation()}; - llvm::SmallVector args = {m_IndVarCountExpr, derivedRetValE}; QualType cladArrayType = GetCladArrayOfType(utils::GetValueType(retType)); - TypeSourceInfo* TSI = m_Context.getTrivialTypeSourceInfo(cladArrayType, loc); - Expr* constructorCallExpr = - m_Sema.BuildCXXTypeConstructExpr(TSI, loc, args, loc, false).get(); auto dVectorParamDecl = - BuildVarDecl(cladArrayType, "_d_vector_return", constructorCallExpr, - false, nullptr, VarDecl::InitializationStyle::CallInit); + BuildVarDecl(cladArrayType, "_d_vector_return", derivedRetValE, false, + nullptr, VarDecl::InitializationStyle::CallInit); // Create an array of statements to hold the return statement and the // assignments to the derivatives of the parameters. Stmts returnStmts; @@ -591,34 +586,29 @@ VectorForwardModeVisitor::DifferentiateVarDecl(const VarDecl* VD) { VarDecl* VDClone = BuildVarDecl(VD->getType(), VD->getNameAsString(), initDiff.getExpr(), VD->isDirectInit(), nullptr, VD->getInitStyle()); - // Create an expression to initialize the derivative vector of the - // size of the number of parameters to be differentiated and initialize - // the derivative vector to the derivative expression. - // - // For example: - // clad::array _d_vector_y(2, ...); - // - // This will also help in initializing the derivative vector in the - // case when initExprDx is not an array. - // So, for example, if we have: - // clad::array _d_vector_y(2, 1); - // this means that we have to initialize the derivative vector of - // size 2 with all elements equal to 1. - SourceLocation loc{m_DiffReq->getLocation()}; - llvm::SmallVector args = {m_IndVarCountExpr, initDiff.getExpr_dx()}; - QualType cladArrayType = - GetCladArrayOfType(utils::GetValueType(VD->getType())); - TypeSourceInfo* TSI = m_Context.getTrivialTypeSourceInfo(cladArrayType, loc); - Expr* constructorCallExpr = - m_Sema.BuildCXXTypeConstructExpr(TSI, loc, args, loc, false).get(); - VarDecl* VDDerived = BuildVarDecl(GetCladArrayOfType(utils::GetValueType(VD->getType())), - "_d_vector_" + VD->getNameAsString(), constructorCallExpr, + "_d_vector_" + VD->getNameAsString(), initDiff.getExpr_dx(), false, nullptr, VarDecl::InitializationStyle::CallInit); m_Variables.emplace(VDClone, BuildDeclRef(VDDerived)); return DeclDiff(VDClone, VDDerived); } +StmtDiff VectorForwardModeVisitor::VisitFloatingLiteral( + const clang::FloatingLiteral* FL) { + SourceLocation fakeLoc = utils::GetValidSLoc(m_Sema); + auto* zero_vec = BuildCallExprToCladFunction( + "zero_vector", {m_IndVarCountExpr}, {FL->getType()}, fakeLoc); + return StmtDiff(Clone(FL), zero_vec); +} + +StmtDiff +VectorForwardModeVisitor::VisitIntegerLiteral(const clang::IntegerLiteral* IL) { + SourceLocation fakeLoc = utils::GetValidSLoc(m_Sema); + auto* zero_vec = BuildCallExprToCladFunction( + "zero_vector", {m_IndVarCountExpr}, {IL->getType()}, fakeLoc); + return StmtDiff(Clone(IL), zero_vec); +} + } // namespace clad diff --git a/test/Arrays/ArrayInputsVectorForwardMode.C b/test/Arrays/ArrayInputsVectorForwardMode.C index 4068d91e6..74ede1eb4 100644 --- a/test/Arrays/ArrayInputsVectorForwardMode.C +++ b/test/Arrays/ArrayInputsVectorForwardMode.C @@ -11,7 +11,7 @@ double multiply(const double *arr) { // CHECK-NEXT: unsigned {{int|long|long long}} indepVarCount = _d_arr.size(); // CHECK-NEXT: clad::matrix _d_vector_arr = clad::identity_matrix(_d_arr.size(), indepVarCount, {{0U|0UL|0ULL}}); // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_return(clad::array(indepVarCount, (_d_vector_arr[0]) * arr[1] + arr[0] * (_d_vector_arr[1]))); +// CHECK-NEXT: clad::array _d_vector_return((_d_vector_arr[0]) * arr[1] + arr[0] * (_d_vector_arr[1])); // CHECK-NEXT: _d_arr = _d_vector_return.slice({{0U|0UL|0ULL}}, _d_arr.size()); // CHECK-NEXT: return; // CHECK-NEXT: } @@ -25,7 +25,7 @@ double divide(double *arr) { // CHECK-NEXT: unsigned {{int|long|long long}} indepVarCount = _d_arr.size(); // CHECK-NEXT: clad::matrix _d_vector_arr = clad::identity_matrix(_d_arr.size(), indepVarCount, {{0U|0UL|0ULL}}); // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_return(clad::array(indepVarCount, ((_d_vector_arr[0]) * arr[1] - arr[0] * (_d_vector_arr[1])) / (arr[1] * arr[1]))); +// CHECK-NEXT: _d_vector_return(((_d_vector_arr[0]) * arr[1] - arr[0] * (_d_vector_arr[1])) / (arr[1] * arr[1])); // CHECK-NEXT: _d_arr = _d_vector_return.slice({{0U|0UL|0ULL}}, _d_arr.size()); // CHECK-NEXT: return; // CHECK-NEXT: } @@ -43,17 +43,17 @@ double addArr(const double *arr, int n) { // CHECK-NEXT: unsigned {{int|long|long long}} indepVarCount = _d_arr.size(); // CHECK-NEXT: clad::matrix _d_vector_arr = clad::identity_matrix(_d_arr.size(), indepVarCount, {{0U|0UL|0ULL}}); // CHECK-NEXT: clad::array _d_vector_n = clad::zero_vector(indepVarCount); -// CHECK-NEXT: clad::array _d_vector_ret(clad::array(indepVarCount, 0)); +// CHECK-NEXT: clad::array _d_vector_ret(clad::zero_vector(indepVarCount)); // CHECK-NEXT: double ret = 0; // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_i(clad::array(indepVarCount, 0)); +// CHECK-NEXT: clad::array _d_vector_i(clad::zero_vector(indepVarCount)); // CHECK-NEXT: for (int i = 0; i < n; i++) { // CHECK-NEXT: _d_vector_ret += _d_vector_arr[i]; // CHECK-NEXT: ret += arr[i]; // CHECK-NEXT: } // CHECK-NEXT: } // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_return(clad::array(indepVarCount, _d_vector_ret)); +// CHECK-NEXT: clad::array _d_vector_return(_d_vector_ret); // CHECK-NEXT: _d_arr = _d_vector_return.slice({{0U|0UL|0ULL}}, _d_arr.size()); // CHECK-NEXT: return; // CHECK-NEXT: } @@ -77,10 +77,10 @@ double maskedSum(const double *arr, int n, int *signedMask, double alpha, double // CHECK-NEXT: clad::array _d_vector_n = clad::zero_vector(indepVarCount); // CHECK-NEXT: clad::array _d_vector_alpha = clad::one_hot_vector(indepVarCount, _d_arr.size()); // CHECK-NEXT: clad::array _d_vector_beta = clad::one_hot_vector(indepVarCount, _d_arr.size() + {{1U|1UL|1ULL}}); -// CHECK-NEXT: clad::array _d_vector_ret(clad::array(indepVarCount, 0)); +// CHECK-NEXT: clad::array _d_vector_ret(clad::zero_vector(indepVarCount)); // CHECK-NEXT: double ret = 0; // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_i(clad::array(indepVarCount, 0)); +// CHECK-NEXT: clad::array _d_vector_i(clad::zero_vector(indepVarCount)); // CHECK-NEXT: for (int i = 0; i < n; i++) { // CHECK-NEXT: if (signedMask[i] > 0) { // CHECK-NEXT: _d_vector_ret += _d_vector_alpha * arr[i] + alpha * (_d_vector_arr[i]); @@ -92,7 +92,7 @@ double maskedSum(const double *arr, int n, int *signedMask, double alpha, double // CHECK-NEXT: } // CHECK-NEXT: } // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_return(clad::array(indepVarCount, _d_vector_ret)); +// CHECK-NEXT: clad::array _d_vector_return(_d_vector_ret); // CHECK-NEXT: _d_arr = _d_vector_return.slice({{0U|0UL|0ULL}}, _d_arr.size()); // CHECK-NEXT: *_d_alpha = _d_vector_return[_d_arr.size()]; // CHECK-NEXT: *_d_beta = _d_vector_return[_d_arr.size() + {{1U|1UL|1ULL}}]; diff --git a/test/ForwardMode/VectorMode.C b/test/ForwardMode/VectorMode.C index 4978eff71..42a855ddb 100644 --- a/test/ForwardMode/VectorMode.C +++ b/test/ForwardMode/VectorMode.C @@ -7,8 +7,6 @@ double f1(double x, double y) { return x*y*(x+y+1); } -void f1_dvec(double x, double y, double *_d_x, double *_d_y); - // CHECK: void f1_dvec(double x, double y, double *_d_x, double *_d_y) { // CHECK-NEXT: unsigned {{int|long|long long}} indepVarCount = {{2U|2UL|2ULL}}; // CHECK-NEXT: clad::array _d_vector_x = clad::one_hot_vector(indepVarCount, {{0U|0UL|0ULL}}); @@ -16,7 +14,7 @@ void f1_dvec(double x, double y, double *_d_x, double *_d_y); // CHECK-NEXT: double _t0 = x * y; // CHECK-NEXT: double _t1 = (x + y + 1); // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_return(clad::array(indepVarCount, (_d_vector_x * y + x * _d_vector_y) * _t1 + _t0 * (_d_vector_x + _d_vector_y + 0))); +// CHECK-NEXT: clad::array _d_vector_return((_d_vector_x * y + x * _d_vector_y) * _t1 + _t0 * (_d_vector_x + _d_vector_y + clad::zero_vector(indepVarCount))); // CHECK-NEXT: *_d_x = _d_vector_return[{{0U|0UL|0ULL}}]; // CHECK-NEXT: *_d_y = _d_vector_return[{{1U|1UL|1ULL}}]; // CHECK-NEXT: return; @@ -30,18 +28,16 @@ double f2(double x, double y) { return temp1*temp2; } -void f2_dvec(double x, double y, double *_d_x, double *_d_y); - // CHECK: void f2_dvec(double x, double y, double *_d_x, double *_d_y) { // CHECK-NEXT: unsigned {{int|long|long long}} indepVarCount = {{2U|2UL|2ULL}}; // CHECK-NEXT: clad::array _d_vector_x = clad::one_hot_vector(indepVarCount, {{0U|0UL|0ULL}}); // CHECK-NEXT: clad::array _d_vector_y = clad::one_hot_vector(indepVarCount, {{1U|1UL|1ULL}}); -// CHECK-NEXT: clad::array _d_vector_temp1(clad::array(indepVarCount, _d_vector_x * y + x * _d_vector_y)); +// CHECK-NEXT: clad::array _d_vector_temp1(_d_vector_x * y + x * _d_vector_y); // CHECK-NEXT: double temp1 = x * y; -// CHECK-NEXT: clad::array _d_vector_temp2(clad::array(indepVarCount, _d_vector_x + _d_vector_y + 0)); +// CHECK-NEXT: clad::array _d_vector_temp2(_d_vector_x + _d_vector_y + clad::zero_vector(indepVarCount)); // CHECK-NEXT: double temp2 = x + y + 1; // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_return(clad::array(indepVarCount, _d_vector_temp1 * temp2 + temp1 * _d_vector_temp2)); +// CHECK-NEXT: clad::array _d_vector_return(_d_vector_temp1 * temp2 + temp1 * _d_vector_temp2); // CHECK-NEXT: *_d_x = _d_vector_return[{{0U|0UL|0ULL}}]; // CHECK-NEXT: *_d_y = _d_vector_return[{{1U|1UL|1ULL}}]; // CHECK-NEXT: return; @@ -56,8 +52,6 @@ double f3(double x, double y) { return x*y; } -void f3_dvec(double x, double y, double *_d_x, double *_d_y); - // CHECK: void f3_dvec(double x, double y, double *_d_x, double *_d_y) { // CHECK-NEXT: unsigned {{int|long|long long}} indepVarCount = {{2U|2UL|2ULL}}; // CHECK-NEXT: clad::array _d_vector_x = clad::one_hot_vector(indepVarCount, {{0U|0UL|0ULL}}); @@ -66,10 +60,10 @@ void f3_dvec(double x, double y, double *_d_x, double *_d_y); // CHECK-NEXT: _d_vector_y = - _d_vector_y; // CHECK-NEXT: y = -y; // CHECK-NEXT: } -// CHECK-NEXT: _d_vector_y += 0; +// CHECK-NEXT: _d_vector_y += clad::zero_vector(indepVarCount); // CHECK-NEXT: y += 1; // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_return(clad::array(indepVarCount, _d_vector_x * y + x * _d_vector_y)); +// CHECK-NEXT: clad::array _d_vector_return(_d_vector_x * y + x * _d_vector_y); // CHECK-NEXT: *_d_x = _d_vector_return[{{0U|0UL|0ULL}}]; // CHECK-NEXT: *_d_y = _d_vector_return[{{1U|1UL|1ULL}}]; // CHECK-NEXT: return; @@ -87,21 +81,19 @@ double f4(double lower, double upper) { return sum; } -void f4_dvec(double lower, double upper, double *_d_lower, double *_d_upper); - // CHECK: void f4_dvec(double lower, double upper, double *_d_lower, double *_d_upper) { // CHECK-NEXT: unsigned {{int|long|long long}} indepVarCount = {{2U|2UL|2ULL}}; // CHECK-NEXT: clad::array _d_vector_lower = clad::one_hot_vector(indepVarCount, {{0U|0UL|0ULL}}); // CHECK-NEXT: clad::array _d_vector_upper = clad::one_hot_vector(indepVarCount, {{1U|1UL|1ULL}}); -// CHECK-NEXT: clad::array _d_vector_sum(clad::array(indepVarCount, 0)); +// CHECK-NEXT: clad::array _d_vector_sum(clad::zero_vector(indepVarCount)); // CHECK-NEXT: double sum = 0; -// CHECK-NEXT: clad::array _d_vector_num_points(clad::array(indepVarCount, 0)); +// CHECK-NEXT: clad::array _d_vector_num_points(clad::zero_vector(indepVarCount)); // CHECK-NEXT: double num_points = 10000; // CHECK-NEXT: double _t0 = (upper - lower); -// CHECK-NEXT: clad::array _d_vector_interval(clad::array(indepVarCount, ((_d_vector_upper - _d_vector_lower) * num_points - _t0 * _d_vector_num_points) / (num_points * num_points))); +// CHECK-NEXT: clad::array _d_vector_interval(((_d_vector_upper - _d_vector_lower) * num_points - _t0 * _d_vector_num_points) / (num_points * num_points)); // CHECK-NEXT: double interval = _t0 / num_points; // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_x(clad::array(indepVarCount, _d_vector_lower)); +// CHECK-NEXT: clad::array _d_vector_x(_d_vector_lower); // CHECK-NEXT: for (double x = lower; x <= upper; (_d_vector_x += _d_vector_interval) , (x += interval)) { // CHECK-NEXT: double _t1 = x * x; // CHECK-NEXT: _d_vector_sum += (_d_vector_x * x + x * _d_vector_x) * interval + _t1 * _d_vector_interval; @@ -109,7 +101,7 @@ void f4_dvec(double lower, double upper, double *_d_lower, double *_d_upper); // CHECK-NEXT: } // CHECK-NEXT: } // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_return(clad::array(indepVarCount, _d_vector_sum)); +// CHECK-NEXT: clad::array _d_vector_return(_d_vector_sum); // CHECK-NEXT: *_d_lower = _d_vector_return[{{0U|0UL|0ULL}}]; // CHECK-NEXT: *_d_upper = _d_vector_return[{{1U|1UL|1ULL}}]; // CHECK-NEXT: return; @@ -127,7 +119,7 @@ double f5(double x, double y, double z) { // CHECK-NEXT: clad::array _d_vector_y = clad::one_hot_vector(indepVarCount, {{1U|1UL|1ULL}}); // CHECK-NEXT: clad::array _d_vector_z = clad::one_hot_vector(indepVarCount, {{2U|2UL|2ULL}}); // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_return(clad::array(indepVarCount, 0. * x + 1. * _d_vector_x + 0. * y + 2. * _d_vector_y + 0. * z + 3. * _d_vector_z)); +// CHECK-NEXT: clad::array _d_vector_return((clad::zero_vector(indepVarCount)) * x + 1. * _d_vector_x + (clad::zero_vector(indepVarCount)) * y + 2. * _d_vector_y + (clad::zero_vector(indepVarCount)) * z + 3. * _d_vector_z); // CHECK-NEXT: *_d_x = _d_vector_return[{{0U|0UL|0ULL}}]; // CHECK-NEXT: *_d_y = _d_vector_return[{{1U|1UL|1ULL}}]; // CHECK-NEXT: *_d_z = _d_vector_return[{{2U|2UL|2ULL}}]; @@ -142,7 +134,7 @@ double f5(double x, double y, double z) { // CHECK-NEXT: clad::array _d_vector_y = clad::one_hot_vector(indepVarCount, {{1U|1UL|1ULL}}); // CHECK-NEXT: clad::array _d_vector_z = clad::zero_vector(indepVarCount); // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_return(clad::array(indepVarCount, 0. * x + 1. * _d_vector_x + 0. * y + 2. * _d_vector_y + 0. * z + 3. * _d_vector_z)); +// CHECK-NEXT: clad::array _d_vector_return((clad::zero_vector(indepVarCount)) * x + 1. * _d_vector_x + (clad::zero_vector(indepVarCount)) * y + 2. * _d_vector_y + (clad::zero_vector(indepVarCount)) * z + 3. * _d_vector_z); // CHECK-NEXT: *_d_x = _d_vector_return[{{0U|0UL|0ULL}}]; // CHECK-NEXT: *_d_y = _d_vector_return[{{1U|1UL|1ULL}}]; // CHECK-NEXT: return; @@ -156,7 +148,7 @@ double f5(double x, double y, double z) { // CHECK-NEXT: clad::array _d_vector_y = clad::zero_vector(indepVarCount); // CHECK-NEXT: clad::array _d_vector_z = clad::one_hot_vector(indepVarCount, {{1U|1UL|1ULL}}); // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_return(clad::array(indepVarCount, 0. * x + 1. * _d_vector_x + 0. * y + 2. * _d_vector_y + 0. * z + 3. * _d_vector_z)); +// CHECK-NEXT: clad::array _d_vector_return((clad::zero_vector(indepVarCount)) * x + 1. * _d_vector_x + (clad::zero_vector(indepVarCount)) * y + 2. * _d_vector_y + (clad::zero_vector(indepVarCount)) * z + 3. * _d_vector_z); // CHECK-NEXT: *_d_x = _d_vector_return[{{0U|0UL|0ULL}}]; // CHECK-NEXT: *_d_z = _d_vector_return[{{1U|1UL|1ULL}}]; // CHECK-NEXT: return; @@ -170,7 +162,7 @@ double f5(double x, double y, double z) { // CHECK-NEXT: clad::array _d_vector_y = clad::one_hot_vector(indepVarCount, {{0U|0UL|0ULL}}); // CHECK-NEXT: clad::array _d_vector_z = clad::one_hot_vector(indepVarCount, {{1U|1UL|1ULL}}); // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_return(clad::array(indepVarCount, 0. * x + 1. * _d_vector_x + 0. * y + 2. * _d_vector_y + 0. * z + 3. * _d_vector_z)); +// CHECK-NEXT: clad::array _d_vector_return((clad::zero_vector(indepVarCount)) * x + 1. * _d_vector_x + (clad::zero_vector(indepVarCount)) * y + 2. * _d_vector_y + (clad::zero_vector(indepVarCount)) * z + 3. * _d_vector_z); // CHECK-NEXT: *_d_y = _d_vector_return[{{0U|0UL|0ULL}}]; // CHECK-NEXT: *_d_z = _d_vector_return[{{1U|1UL|1ULL}}]; // CHECK-NEXT: return; @@ -184,7 +176,7 @@ double f5(double x, double y, double z) { // CHECK-NEXT: clad::array _d_vector_y = clad::zero_vector(indepVarCount); // CHECK-NEXT: clad::array _d_vector_z = clad::one_hot_vector(indepVarCount, {{0U|0UL|0ULL}}); // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_return(clad::array(indepVarCount, 0. * x + 1. * _d_vector_x + 0. * y + 2. * _d_vector_y + 0. * z + 3. * _d_vector_z)); +// CHECK-NEXT: clad::array _d_vector_return((clad::zero_vector(indepVarCount)) * x + 1. * _d_vector_x + (clad::zero_vector(indepVarCount)) * y + 2. * _d_vector_y + (clad::zero_vector(indepVarCount)) * z + 3. * _d_vector_z); // CHECK-NEXT: *_d_z = _d_vector_return[{{0U|0UL|0ULL}}]; // CHECK-NEXT: return; // CHECK-NEXT: } @@ -208,7 +200,7 @@ double f6(double x, double y) { // CHECK-NEXT: clad::ValueAndPushforward > _t0 = square_vector_pushforward(x, _d_vector_x); // CHECK-NEXT: clad::ValueAndPushforward > _t1 = square_vector_pushforward(y, _d_vector_y); // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_return(clad::array(indepVarCount, _t0.pushforward + _t1.pushforward)); +// CHECK-NEXT: clad::array _d_vector_return(_t0.pushforward + _t1.pushforward); // CHECK-NEXT: *_d_x = _d_vector_return[{{0U|0UL|0ULL}}]; // CHECK-NEXT: *_d_y = _d_vector_return[{{1U|1UL|1ULL}}]; // CHECK-NEXT: return; @@ -235,7 +227,7 @@ double f7(const double* arr, double w, int n) { // CHECK-NEXT: clad::array _d_vector_n = clad::zero_vector(indepVarCount); // CHECK-NEXT: clad::ValueAndPushforward > _t0 = weighted_array_squared_sum_vector_pushforward(arr, w, n, _d_vector_arr, _d_vector_w, _d_vector_n); // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_return(clad::array(indepVarCount, _t0.pushforward)); +// CHECK-NEXT: clad::array _d_vector_return(_t0.pushforward); // CHECK-NEXT: _d_arr = _d_vector_return.slice({{0U|0UL|0ULL}}, _d_arr.size()); // CHECK-NEXT: *_d_w = _d_vector_return[_d_arr.size()]; // CHECK-NEXT: return; @@ -261,11 +253,11 @@ double f8(int n, const double* arr) { // CHECK-NEXT: unsigned {{int|long|long long}} indepVarCount = _d_arr.size(); // CHECK-NEXT: clad::array _d_vector_n = clad::zero_vector(indepVarCount); // CHECK-NEXT: clad::matrix _d_vector_arr = clad::identity_matrix(_d_arr.size(), indepVarCount, {{0U|0UL|0ULL}}); -// CHECK-NEXT: clad::array _d_vector_res(clad::array(indepVarCount, 0)); +// CHECK-NEXT: clad::array _d_vector_res(clad::zero_vector(indepVarCount)); // CHECK-NEXT: double res = 0; // CHECK-NEXT: sum_ref_vector_pushforward(res, n, arr, _d_vector_res, _d_vector_n, _d_vector_arr); // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_return(clad::array(indepVarCount, _d_vector_res)); +// CHECK-NEXT: clad::array _d_vector_return(_d_vector_res); // CHECK-NEXT: _d_arr = _d_vector_return.slice({{0U|0UL|0ULL}}, _d_arr.size()); // CHECK-NEXT: return; // CHECK-NEXT: } @@ -293,8 +285,8 @@ double f9(double x, double y) { { \ result[0] = 0; \ result[1] = 0; \ - clad::differentiate(F); \ - F##_dvec(x, y, &result[0], &result[1]); \ + auto F##dvec = clad::differentiate(F); \ + F##dvec.execute(x, y, &result[0], &result[1]); \ printf("Result is = {%.2f, %.2f}\n", result[0], result[1]); \ } @@ -359,17 +351,17 @@ int main() { // CHECK: clad::ValueAndPushforward > square_vector_pushforward(const double &x, const clad::array &_d_x) { // CHECK-NEXT: unsigned long indepVarCount = _d_x.size(); -// CHECK-NEXT: clad::array _d_vector_z(clad::array(indepVarCount, _d_x * x + x * _d_x)); +// CHECK-NEXT: clad::array _d_vector_z(_d_x * x + x * _d_x); // CHECK-NEXT: double z = x * x; // CHECK-NEXT: return {z, _d_vector_z}; // CHECK-NEXT: } // CHECK: clad::ValueAndPushforward > weighted_array_squared_sum_vector_pushforward(const double *arr, double w, int n, clad::matrix &_d_arr, clad::array _d_w, clad::array _d_n) { // CHECK-NEXT: unsigned long indepVarCount = _d_n.size(); -// CHECK-NEXT: clad::array _d_vector_sum(clad::array(indepVarCount, 0)); +// CHECK-NEXT: clad::array _d_vector_sum(clad::zero_vector(indepVarCount)); // CHECK-NEXT: double sum = 0; // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_i(clad::array(indepVarCount, 0)); +// CHECK-NEXT: clad::array _d_vector_i(clad::zero_vector(indepVarCount)); // CHECK-NEXT: for (int i = 0; i < n; ++i) { // CHECK-NEXT: clad::ValueAndPushforward > _t0 = square_vector_pushforward(arr[i], _d_arr[i]); // CHECK-NEXT: double &_t1 = _t0.value; @@ -383,7 +375,7 @@ int main() { // CHECK: void sum_ref_vector_pushforward(double &res, int n, const double *arr, clad::array &_d_res, clad::array _d_n, clad::matrix &_d_arr) { // CHECK-NEXT: unsigned long indepVarCount = _d_arr[0].size(); // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_i(clad::array(indepVarCount, 0)); +// CHECK-NEXT: clad::array _d_vector_i(clad::zero_vector(indepVarCount)); // CHECK-NEXT: for (int i = 0; i < n; ++i) { // CHECK-NEXT: _d_res += _d_arr[i]; // CHECK-NEXT: res += arr[i]; diff --git a/test/ForwardMode/VectorModeInterface.C b/test/ForwardMode/VectorModeInterface.C index 7163073ab..ea503ed8e 100644 --- a/test/ForwardMode/VectorModeInterface.C +++ b/test/ForwardMode/VectorModeInterface.C @@ -11,7 +11,7 @@ double f1(double x, double y) { // CHECK-NEXT: clad::array _d_vector_x = clad::one_hot_vector(indepVarCount, {{0U|0UL|0ULL}}); // CHECK-NEXT: clad::array _d_vector_y = clad::one_hot_vector(indepVarCount, {{1U|1UL|1ULL}}); // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_return(clad::array(indepVarCount, _d_vector_x * y + x * _d_vector_y)); +// CHECK-NEXT: clad::array _d_vector_return(_d_vector_x * y + x * _d_vector_y); // CHECK-NEXT: *_d_x = _d_vector_return[{{0U|0UL|0ULL}}]; // CHECK-NEXT: *_d_y = _d_vector_return[{{1U|1UL|1ULL}}]; // CHECK-NEXT: return; @@ -22,14 +22,12 @@ double f2(double x, double y) { return x+y; } -void f2_dvec(double x, double y, double *_d_x, double *_d_y); - // CHECK: void f2_dvec(double x, double y, double *_d_x, double *_d_y) { // CHECK-NEXT: unsigned {{int|long|long long}} indepVarCount = {{2U|2UL|2ULL}}; // CHECK-NEXT: clad::array _d_vector_x = clad::one_hot_vector(indepVarCount, {{0U|0UL|0ULL}}); // CHECK-NEXT: clad::array _d_vector_y = clad::one_hot_vector(indepVarCount, {{1U|1UL|1ULL}}); // CHECK-NEXT: { -// CHECK-NEXT: clad::array _d_vector_return(clad::array(indepVarCount, _d_vector_x + _d_vector_y)); +// CHECK-NEXT: clad::array _d_vector_return(_d_vector_x + _d_vector_y); // CHECK-NEXT: *_d_x = _d_vector_return[{{0U|0UL|0ULL}}]; // CHECK-NEXT: *_d_y = _d_vector_return[{{1U|1UL|1ULL}}]; // CHECK-NEXT: return;