File: odexam.cpp

package info (click to toggle)
adolc 2.5.2-2
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 7,684 kB
  • ctags: 3,333
  • sloc: cpp: 18,988; ansic: 15,599; sh: 11,184; makefile: 483
file content (95 lines) | stat: -rw-r--r-- 3,712 bytes parent folder | download | duplicates (7)
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
/*----------------------------------------------------------------------------
 ADOL-C -- Automatic Differentiation by Overloading in C++
 File:     odexam.cpp
 Revision: $Id: odexam.cpp 171 2010-10-04 13:57:19Z kulshres $
 Contents: Nonlinear ordinary differential equation based on the
           Robertson test problem, described in the manual

 Copyright (c) Andrea Walther, Andreas Griewank, Andreas Kowarz, 
               Hristo Mitev, Sebastian Schlenkrich, Jean Utke, Olaf Vogel 
  
 This file is part of ADOL-C. This software is provided as open source.
 Any use, reproduction, or distribution of the software constitutes 
 recipient's acceptance of the terms of the accompanying license file.
 
---------------------------------------------------------------------------*/

/****************************************************************************/
/*                                                                 INCLUDES */
#include <adolc/adouble.h>            // use of active double
#include <adolc/drivers/odedrivers.h> // use of "Easy To Use" ODE drivers
#include <adolc/adalloc.h>            // use of ADOL-C allocation utilities
#include <adolc/taping.h>             // use of taping

// NOTICE: If one wants to include all ADOL-C interfaces without
//         getting in trouble to find out the right header files
//
//         #include "adolc/adolc.h"
//
//         will do the right work.

#include <iostream>
using namespace std;

/****************************************************************************/
/*                                                          ADOUBLE ROUTINE */
void tracerhs(short int tag, double* py, double* pyprime) {
    adouble y[3];                // we left the parameters passive
    adouble yprime[3];           

    trace_on(tag);
    y[0] <<= py[0]; y[1] <<= py[1];   y[2] <<= py[2];                              // initialize and mark independents
    yprime[0] = -sin(y[2]) + 1.0e8*y[2]*(1.0-1.0/y[0]);
    yprime[1] = -10.0*y[0] + 3.0e7*y[2]*(1-y[1]);
    yprime[2] = -yprime[0] - yprime[1];
    yprime[0] >>= pyprime[0]; yprime[1] >>= pyprime[1];  yprime[2] >>= pyprime[2]; // mark and pass dependents
    trace_off(1);                // write tape array onto a file
} // end tracerhs

/****************************************************************************/
/*                                                             MAIN PROGRAM */
int main() {
    int i,j,deg;
    int n = 3;
    double py[3];
    double pyp[3];

    cout << "MODIFIED ROBERTSON TEST PROBLEM (ADOL-C Documented Example)\n\n";
    cout << "degree of Taylor series =?\n";
    cin >> deg;

    short** nz = new short*[n];
    double  **X;
    double ***Z;
    double ***B;

    X = myalloc2(n,deg+1);
    Z = myalloc3(n,n,deg);
    B = myalloc3(n,n,deg);

    for(i=0; i<n; i++) {
        py[i]   = (i==0) ? 1.0 : 0.0;       // Initialize the base point
        X[i][0] = py[i];                    // and the Taylor coefficient;
        nz[i]   = new short[n];             // set up sparsity array
    } // end for

    tracerhs(1,py,pyp);                   // trace RHS with tag = 1

    forode(1,n,deg,X);                    // compute deg coefficients
    reverse(1,n,n,deg-1,Z,nz);            // U defaults to the identity
    accode(n,deg-1,Z,B,nz);

    cout << "nonzero pattern:\n";
    for(i=0; i<n; i++) {
        for(j=0; j<n; j++)
            cout << nz[i][j]<<"\t";
        cout <<"\n";
    } // end for
    cout << "\n";
    cout << " 4 = transcend , 3 = rational , 2 = polynomial ,"
    << " 1 = linear , 0 = zero \n";
    cout << " negative number k indicate that entries of all"
    << " B_j with j < -k vanish \n";

    return 1;
} // end main