blob: 372f8841a05919101cac59bcbf20d9277e5da9ba [file] [log] [blame] [edit]
// RUN: %clang++ -ffast-math %O0TBAA -fno-vectorize -fno-slp-vectorize -fno-unroll-loops -fno-exceptions %s -S -emit-llvm -o - | %opt - %OPloadEnzyme %enzyme -enzyme-loose-types -S | %lli -
// RUN: %clang++ -ffast-math -O1 -fno-vectorize -fno-slp-vectorize -fno-unroll-loops -fno-exceptions %s -S -emit-llvm -o - | %opt - %OPloadEnzyme %enzyme -S | %lli -
// RUN: %clang++ -ffast-math -O2 -fno-vectorize -fno-slp-vectorize -fno-unroll-loops -fno-exceptions %s -S -emit-llvm -o - | %opt - %OPloadEnzyme %enzyme -S
// RUN: %clang++ -ffast-math -O2 -fno-vectorize -fno-slp-vectorize -fno-unroll-loops -fno-exceptions %s -S -emit-llvm -o - | %opt - %OPloadEnzyme %enzyme -S | %lli -
// RUN: %clang++ -ffast-math -O3 -fno-vectorize -fno-slp-vectorize -fno-unroll-loops -fno-exceptions %s -S -emit-llvm -o - | %opt - %OPloadEnzyme %enzyme -S | %lli -
// RUN: %clang++ -ffast-math %O0TBAA -fno-vectorize -fno-slp-vectorize -fno-unroll-loops -fno-exceptions %s -S -emit-llvm -o - | %opt - %OPloadEnzyme %enzyme -enzyme-inline=1 -S | %lli -
// RUN: %clang++ -ffast-math -O1 -fno-vectorize -fno-slp-vectorize -fno-unroll-loops -fno-exceptions %s -S -emit-llvm -o - | %opt - %OPloadEnzyme %enzyme -enzyme-inline=1 -S | %lli -
// RUN: %clang++ -ffast-math -O2 -fno-vectorize -fno-slp-vectorize -fno-unroll-loops -fno-exceptions %s -S -emit-llvm -o - | %opt - %OPloadEnzyme %enzyme -enzyme-inline=1 -S | %lli -
// RUN: %clang++ -ffast-math -O3 -fno-vectorize -fno-slp-vectorize -fno-unroll-loops -fno-exceptions %s -S -emit-llvm -o - | %opt - %OPloadEnzyme %enzyme -enzyme-inline=1 -S | %lli -
#include <stdio.h>
#include <math.h>
#include <vector>
#include "../test_utils.h"
extern void __enzyme_autodiff(void*, double*, double*, int);
/*double max(double x, double y) {
return (x > y) ? x : y;
}*/
double reduce_max(double* vec, int size) {
double ret = -INFINITY;
std::vector<double> maxes;
for (int i = 0; i < size; i++) {
if (vec[i] > ret) {
maxes.clear();
ret = vec[i];
}
if (vec[i] == ret) {
maxes.push_back(vec[i]);
}
}
ret = 0;
for(auto a : maxes) {
ret += a;
}
ret /= maxes.size();
return ret;
}
int main() {
double vec[] = {-1., 2., -0.2, 2., 1.};
double d_vec[] = {0., 0., 0., 0., 0.};
double max_val = reduce_max(vec, 5);
printf("reduce_max=%f\n", max_val);
__enzyme_autodiff((void*)reduce_max, vec, d_vec, 5);
for(int i=0; i<5; i++) {
printf("d_reduce_max(%i)=%f\n", i, d_vec[i]);
}
fflush(0);
double ans[] = {0, 0.5, 0, 0.5, 0};
for(int i=0; i<5; i++) {
APPROX_EQ(d_vec[i], ans[i], 1e-10);
}
}