Prev Next a_fun_property_xam.pm Headings

@(@\newcommand{\B}[1]{ {\bf #1} } \newcommand{\R}[1]{ {\rm #1} }@)@
Perl: a_fun Properties: Example and Test
package a_fun_property_xam;
sub a_fun_property_xam() {
     # check for standard perl programming conventions
     use strict;
     use warnings;
     #
     # load the Cppad Swig library
     use pm_cppad;
     #
     # initilaize return variable
     my $ok = 1;
     # ---------------------------------------------------------------------
     my $n_ind = 1; # number of independent variables
     my $n_dep = 2; # number of dependent variables
     my $n_var = 1; # phantom variable at address 0
     my $n_op = 1;  # special operator at beginning
     #
     # dimension some vectors
     my $x = new pm_cppad::vec_double($n_ind);
     my $ay = new pm_cppad::vec_a_double($n_dep);
     #
     # independent variables
     $x->set(0, 1.0);
     my $ax = pm_cppad::independent($x);
     $n_var = $n_var + $n_ind; # one for each indpendent
     $n_op = $n_op + $n_ind;
     #
     # first dependent variable
     $ay->set(0, $ax->get(0) + $ax->get(0));
     $n_var = $n_var + 1; # one variable and operator
     $n_op = $n_op + 1;
     #
     # second dependent variable
     my $ax0 = $ax->get(0);
     $ay->set(1, $ax0->sin());
     $n_var = $n_var + 2; # two varialbes, one operator
     $n_op = $n_op + 1;
     #
     # define f(x) = y
     my $af = new pm_cppad::a_fun($ax, $ay);
     $n_op = $n_op + 1; # speical operator at end
     #
     # check af properties
     $ok = $ok && $af->size_ind() == $n_ind;
     $ok = $ok && $af->size_dep() == $n_dep;
     $ok = $ok && $af->size_var() == $n_var;
     $ok = $ok && $af->size_op() == $n_op;
     #
     return( $ok  );
}

Input File: build/lib/example/perl/a_fun_property_xam.pm