The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
#                              -*- Mode: Perl -*- 
# Before `make install' is performed this script should be runnable with
# `make test'. After `make install' it should work as `perl test.pl'

######################### We start with some black magic to print on failure.

# Change 1..1 below to 1..last_test_to_print .
# (It may become useful if the test is moved to ./t subdirectory.)

BEGIN { $| = 1; print "1..10\n"; }
END {print "not ok 1\n" unless $loaded;}
use Math::Matrix;
$loaded = 1;
print "ok 1\n";

######################### End of black magic.

# Insert your test code below (better if it prints "ok 13"
# (correspondingly "not ok 13") depending on the success of chunk 13
# of the test code):

srand(time);
$A = new Math::Matrix ([rand,rand,rand],
                       [rand,rand,rand],
                       [rand,rand,rand]);
$A->print("A random Matrix A");
print "ok 2\n";
$v = new Math::Matrix ([rand,rand,rand]);
$v->print("A random vector v");
print "ok 3\n";
$M = $A->concat($v->transpose);
$M->print('The equation system A*x=v');
print "ok 4\n";
$x = $M->solve;
$x->print("The solution x");
print "ok 5\n";
$u = $A->multiply($x)->transpose;
$u->print("The proof that A*x yields v?");
print "ok 6\n";

for (0..2) {
  if (equal($v->[0]->[$_],$u->[0]->[$_])) {
    printf "ok %d\n", $_ + 7;
  } else {
    printf "not ok %d\n", $_ + 7;
  }
}

# operator overloading
eval {
$b = ~($A * $x);
$b->print("transpose(A*x) overloaded");
$c = $b - $v;
$c->print("=v (transpose(A*x) - v   ");
};
if ($@) {
  print "not ok 10\n";
} else {
  print "ok 10\n";
}


sub equal {
  my ($a,$b) = @_;

  if ($a > $b) {
    $a - $b < $Math::Matrix::eps;
  } else {
    $b - $a < $Math::Matrix::eps;
  }
}