-
Notifications
You must be signed in to change notification settings - Fork 125
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add constexpr consteval tests for forward mode
- Loading branch information
1 parent
cb9a8fe
commit c15ec08
Showing
2 changed files
with
119 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
// RUN: %cladclang %s -I%S/../../include -std=c++23 -oConstevalTest.out | %filecheck %s | ||
// RUN: ./ConstevalTest.out | %filecheck_exec %s | ||
|
||
#include <limits> | ||
|
||
#include "clad/Differentiator/Differentiator.h" | ||
|
||
#include "../TestUtils.h" | ||
|
||
|
||
consteval double fn(double a, double b) { | ||
return (a+b)/2; | ||
} | ||
|
||
//CHECK: consteval double fn_darg0(double a, double b) { | ||
//CHECK-NEXT: double _d_a = 1; | ||
//CHECK-NEXT: double _d_b = 0; | ||
//CHECK-NEXT: double _t0 = (a + b); | ||
//CHECK-NEXT: return ((_d_a + _d_b) * 2 - _t0 * 0) / (2 * 2); | ||
//CHECK-NEXT:} | ||
|
||
consteval double mul(double a, double b, double c) { | ||
double val = 99.00; | ||
double result = val * a + 100 - b + c; | ||
return result; | ||
} | ||
|
||
//CHECK: consteval double mul_darg0(double a, double b, double c) { | ||
//CHECK-NEXT: double _d_a = 1; | ||
//CHECK-NEXT: double _d_b = 0; | ||
//CHECK-NEXT: double _d_c = 0; | ||
//CHECK-NEXT: double _d_val = 0.; | ||
//CHECK-NEXT: double val = 99.; | ||
//CHECK-NEXT: double _d_result = _d_val * a + val * _d_a + 0 - _d_b + _d_c; | ||
//CHECK-NEXT: double result = val * a + 100 - b + c; | ||
//CHECK-NEXT: return _d_result; | ||
//CHECK-NEXT:} | ||
|
||
consteval double fn_test() { | ||
auto dx = clad::differentiate(fn, "a"); | ||
|
||
return dx.execute(4, 7); | ||
} | ||
|
||
consteval double mul_test() { | ||
auto dx = clad::differentiate(mul, "a"); | ||
|
||
return dx.execute(5, 6, 10); | ||
} | ||
|
||
int main() { | ||
constexpr double fn_result = fn_test(); | ||
printf("%.2f\n", fn_result); // CHECK-EXEC: 0.50 | ||
|
||
constexpr double mul_result = mul_test(); | ||
printf("%.2f\n", mul_result); // CHECK-EXEC: 99.00 | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
// RUN: %cladclang %s -I%S/../../include -std=c++23 -oConstexprTest.out | %filecheck %s | ||
// RUN: ./ConstexprTest.out | %filecheck_exec %s | ||
|
||
#include "clad/Differentiator/Differentiator.h" | ||
|
||
constexpr double fn(double a, double b) { | ||
return (a+b)/2; | ||
} | ||
|
||
//CHECK: constexpr double fn_darg0(double a, double b) { | ||
//CHECK-NEXT: double _d_a = 1; | ||
//CHECK-NEXT: double _d_b = 0; | ||
//CHECK-NEXT: double _t0 = (a + b); | ||
//CHECK-NEXT: return ((_d_a + _d_b) * 2 - _t0 * 0) / (2 * 2); | ||
//CHECK-NEXT:} | ||
|
||
constexpr double mul(double a, double b, double c) { | ||
double val = 99.00; | ||
double result = val * a + 100 - b + c; | ||
return result; | ||
} | ||
|
||
//CHECK: constexpr double mul_darg0(double a, double b, double c) { | ||
//CHECK-NEXT: double _d_a = 1; | ||
//CHECK-NEXT: double _d_b = 0; | ||
//CHECK-NEXT: double _d_c = 0; | ||
//CHECK-NEXT: double _d_val = 0.; | ||
//CHECK-NEXT: double val = 99.; | ||
//CHECK-NEXT: double _d_result = _d_val * a + val * _d_a + 0 - _d_b + _d_c; | ||
//CHECK-NEXT: double result = val * a + 100 - b + c; | ||
//CHECK-NEXT: return _d_result; | ||
//CHECK-NEXT:} | ||
|
||
constexpr double fn_test() { | ||
if consteval { | ||
auto dx = clad::differentiate(fn, "a"); | ||
|
||
return dx.execute(4, 7); | ||
} else { | ||
assert(false && "fn non-consteval context"); | ||
return -42.; | ||
} | ||
} | ||
|
||
constexpr double mul_test() { | ||
if consteval { | ||
auto dx = clad::differentiate(mul, "a"); | ||
|
||
return dx.execute(5, 6, 10); | ||
} else { | ||
assert(false && "mul non-immediate context"); | ||
return -42.; | ||
} | ||
} | ||
|
||
int main() { | ||
constexpr double fn_result = fn_test(); | ||
printf("%.2f\n", fn_result); // CHECK-EXEC: 0.50 | ||
|
||
constexpr double mul_result = mul_test(); | ||
printf("%.2f\n", mul_result); // CHECK-EXEC: 99.0 | ||
} |