File: diff_autodiff_incl_test.cpp

package info (click to toggle)
boost1.90 1.90.0-1
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 593,120 kB
  • sloc: cpp: 4,190,908; xml: 196,648; python: 34,618; ansic: 23,145; asm: 5,468; sh: 3,774; makefile: 1,161; perl: 1,020; sql: 728; ruby: 676; yacc: 478; java: 77; lisp: 24; csh: 6
file content (30 lines) | stat: -rw-r--r-- 1,053 bytes parent folder | download | duplicates (17)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
//  Copyright Nick Thompson 2017.
//  Use, modification and distribution are subject to the
//  Boost Software License, Version 1.0. (See accompanying file
//  LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
//
// Basic sanity check that header <boost/math/special_functions/gamma.hpp>
// #includes all the files that it needs to.
//
#include <boost/math/differentiation/autodiff.hpp>
//
// Note this header includes no other headers, this is
// important if this test is to be meaningful:
//
#include "test_compile_result.hpp"

template <typename T>
T fourth_power(T const& x) {
   T x4 = x * x;  // retval in operator*() uses x4's memory via NRVO.
   x4 *= x4;      // No copies of x4 are made within operator*=() even when squaring.
   return x4;     // x4 uses y's memory in main() via NRVO.
}

void compile_and_link_test()
{
   using namespace boost::math::differentiation;
   auto const x = make_fvar<double, 5>(2.0);  // Find derivatives at x=2.
   auto const y = fourth_power(x);
   
   check_result<double>(y.derivative(1));
}