48 lines
1.7 KiB
C++
48 lines
1.7 KiB
C++
#include <iostream>
|
|
#include "backwardad.hpp"
|
|
|
|
// 一阶反向自动微分测试函数
|
|
backwardad::Node f2(backwardad::Node x) {
|
|
return x + x*x + pow(x,3);
|
|
}
|
|
|
|
// 二阶反向自动微分测试函数
|
|
backwardad::Node g2(backwardad::Node x, backwardad::Node y) {
|
|
return exp(x) * log(y);
|
|
}
|
|
|
|
// 高阶反向自动微分测试函数
|
|
backwardad::Node h2(backwardad::Node x, backwardad::Node y, backwardad::Node z) {
|
|
return pow(x, 3) + pow(y, 2) + z + cos(x * y * z);
|
|
}
|
|
|
|
int test_backward_ad() {
|
|
std::cout << "Testing f(x) = x^2 + sin(x) at x=2.0\n";
|
|
auto r = backwardad::diff(f2, 2.0);
|
|
std::cout << "value = " << r.value << "\n";
|
|
std::cout << "grad = " << r.gradient[0] << "\n";
|
|
std::cout << "div = " << r.divergence << "\n";
|
|
std::cout << "curl = " << r.curl[0] << "\n";
|
|
|
|
std::cout << "\nTesting g(x,y) = exp(x)*log(y) at (x,y)=(1.0, 2.0)\n";
|
|
auto r2 = backwardad::diff(g2, 1.0, 2.0);
|
|
std::cout << "value = " << r2.value << "\n";
|
|
std::cout << "grad = (" << r2.gradient[0] << ", " << r2.gradient[1] << ")\n";
|
|
std::cout << "div = " << r2.divergence << "\n";
|
|
std::cout << "curl = (" << r2.curl[0] << ", " << r2.curl[1] << ")\n";
|
|
|
|
std::cout << "\nTesting h(x,y,z) = x^3 + y^2 + z + cos(x*y*z) at (x,y,z)=(1.0, 2.0, 3.0)\n";
|
|
auto r3 = backwardad::diff(h2, 1.0, 2.0, 3.0);
|
|
std::cout << "value = " << r3.value << "\n";
|
|
std::cout << "grad = (" << r3.gradient[0] << ", " << r3.gradient[1] << ", " << r3.gradient[2] << ")\n";
|
|
std::cout << "div = " << r3.divergence << "\n";
|
|
std::cout << "curl = (" << r3.curl[0] << ", " << r3.curl[1] << ", " << r3.curl[2] << ")\n";
|
|
|
|
return 0;
|
|
}
|
|
|
|
int main() {
|
|
std::cout << "\n=== Backward AD Tests ===\n";
|
|
test_backward_ad();
|
|
return 0;
|
|
} |