blob: 936c433eca7398be2a43a5771c062e6c4fc56c7e [file] [log] [blame] [edit]
// RUN: %clang -O0 %s -S -emit-llvm -o - | %opt - %OPloadEnzyme %enzyme -S | %lli -
// RUN: %clang -O1 %s -S -emit-llvm -o - | %opt - %OPloadEnzyme %enzyme -S | %lli -
// RUN: %clang -O2 %s -S -emit-llvm -o - | %opt - %OPloadEnzyme %enzyme -S | %lli -
// RUN: %clang -O3 %s -S -emit-llvm -o - | %opt - %OPloadEnzyme %enzyme -S | %lli -
// RUN: %clang -O0 %s -S -emit-llvm -o - | %opt - %OPloadEnzyme %enzyme -enzyme-inline=1 -S | %lli -
// RUN: %clang -O1 %s -S -emit-llvm -o - | %opt - %OPloadEnzyme %enzyme -enzyme-inline=1 -S | %lli -
// RUN: %clang -O2 %s -S -emit-llvm -o - | %opt - %OPloadEnzyme %enzyme -enzyme-inline=1 -S | %lli -
// RUN: %clang -O3 %s -S -emit-llvm -o - | %opt - %OPloadEnzyme %enzyme -enzyme-inline=1 -S | %lli -
#include "../test_utils.h"
extern double __enzyme_fwddiff(double (*)(double, double), double,...);
double fun(double x1, double x2) {
double w1 = x1;
double w2 = x2;
double w3 = w1 * w2;
double w4 = 1.0 / w1;
double w5 = w3 + w4;
return w5;
}
double dfun(double x1, double x2) {
return __enzyme_fwddiff(fun, x1, 1.0, x2, 0.0);
}
int main() {
double res[] = {0.0,3.75,8.8888888888888893,15.9375};
for(int i=1; i<5; i++) {
double x = (double) i;
double dfx = dfun(x,x*x);
APPROX_EQ(dfx, res[i-1], 1e-10);
}
}