#!/usr/bin/perl use strict; use warnings; use lib '../lib'; use Data::Dumper; use Math::Symbolic qw/:all/; my $var = Math::Symbolic::Variable->new(); my $a = $var->new( 'x' => 3.14159 ); print "Vars: x=" . $a->value() . " (Value is optional)\n\n"; my $first = $a * 2 + 1; # x*2 + 1 my $second = $a * "2 + 1"; # x*3 my $third = -$a; print "Expression: x * 2 + 1, x * (2+1), -x\n\n"; print "prefix notation and evaluation:\n"; print $first->to_string('prefix') . " = " . $first->value() . "\n\n"; print $second->to_string('prefix') . " = " . $second->value() . "\n\n"; print $third->to_string('prefix') . " = " . $third->value() . "\n\n"; print "Now, we derive this partially to x: (prefix again)\n"; my $n_tree = Math::Symbolic::Operator->new( { type => U_P_DERIVATIVE, operands => [ $first, $a ], } ); my $n_tree2 = Math::Symbolic::Operator->new( { type => U_P_DERIVATIVE, operands => [ $second, $a ], } ); my $n_tree3 = Math::Symbolic::Operator->new( { type => U_P_DERIVATIVE, operands => [ $third, $a ], } ); print $n_tree->to_string('prefix') . " = " . $n_tree->value() . "\n\n"; print $n_tree2->to_string('prefix') . " = " . $n_tree2->value() . "\n\n"; print $n_tree3->to_string('prefix') . " = " . $n_tree3->value() . "\n\n"; print "Now, we apply the derivative to the terms: (infix)\n"; my $derived = $n_tree->apply_derivatives(); my $derived2 = $n_tree2->apply_derivatives(); my $derived3 = $n_tree3->apply_derivatives(); print "$derived" . " = " . $derived->value() . "\n\n"; print "$derived2" . " = " . $derived2->value() . "\n\n"; print "$derived3" . " = " . $derived3->value() . "\n\n"; print "Finally, we simplify the derived term as much as possible:\n"; $derived = $derived->simplify(); print "$derived = " . $derived->value() . "\n\n"; $derived2 = $derived2->simplify(); print "$derived2 = " . $derived2->value() . "\n\n"; $derived3 = $derived3->simplify(); print "$derived3 = " . $derived3->value() . "\n\n";