The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
#!/usr/bin/perl -w

# Copyright 2012, 2013 Kevin Ryde

# This file is part of Math-PlanePath-Toothpick.
#
# Math-PlanePath-Toothpick is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License as published
# by the Free Software Foundation; either version 3, or (at your option) any
# later version.
#
# Math-PlanePath-Toothpick is distributed in the hope that it will be
# useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General
# Public License for more details.
#
# You should have received a copy of the GNU General Public License along
# with Math-PlanePath-Toothpick.  If not, see <http://www.gnu.org/licenses/>.


use 5.004;
use strict;
use Test;
plan tests => 4;

use lib 't','xt';
use MyTestHelpers;
MyTestHelpers::nowarnings();
use MyOEIS;

use Math::PlanePath::TwoOfEightByCells;

# uncomment this to run the ### lines
#use Smart::Comments '###';

my $path = Math::PlanePath::TwoOfEightByCells->new;

#------------------------------------------------------------------------------
# A151731 - 2of8 total cells

MyOEIS::compare_values
  (anum => 'A151731',
   func => sub {
     my ($count) = @_;
     my $path = Math::PlanePath::TwoOfEightByCells->new;
     my @got;
     my $total = 0;
     for (my $depth = 0; @got < $count; $depth++) {
       push @got, $path->tree_depth_to_n($depth);
     }
     return \@got;
   });

#------------------------------------------------------------------------------
# A151732 - 2of8 cells added

MyOEIS::compare_values
  (anum => 'A151732',
   func => sub {
     my ($count) = @_;
     my @got = (0);
     for (my $depth = 0; @got < $count; $depth++) {
       my $added = ($path->tree_depth_to_n($depth+1)
                    - $path->tree_depth_to_n($depth));
       push @got, $added;
     }
     return \@got;
   });

#------------------------------------------------------------------------------
# A151733 - 2of8 total cells / 2

MyOEIS::compare_values
  (anum => 'A151733',
   func => sub {
     my ($count) = @_;
     my $path = Math::PlanePath::TwoOfEightByCells->new;
     my @got;
     my $total = 0;
     for (my $depth = 0; @got < $count; $depth++) {
       push @got, $path->tree_depth_to_n($depth) / 2;
     }
     return \@got;
   });

#------------------------------------------------------------------------------
# A151734 - 2of8 cells added / 2

MyOEIS::compare_values
  (anum => 'A151734',
   func => sub {
     my ($count) = @_;
     my @got = (0);
     for (my $depth = 0; @got < $count; $depth++) {
       my $added = ($path->tree_depth_to_n($depth+1)
                    - $path->tree_depth_to_n($depth));
       push @got, $added / 2;
     }
     return \@got;
   });

#------------------------------------------------------------------------------
exit 0;