AI-Categorizer

 view release on metacpan or  search on metacpan

t/11-feature_vector.t  view on Meta::CPAN

#!/usr/bin/perl -w

# Before `make install' is performed this script should be runnable with
# `make test'. After `make install' it should work as `perl test.pl'

#########################

use strict;
use Test;
BEGIN { 
  plan tests => 18;
}

use AI::Categorizer::FeatureVector;
ok(1);

my $f1 = new AI::Categorizer::FeatureVector(features => {sports => 2, finance => 3});
ok $f1;
ok $f1->includes('sports');
ok $f1->value('sports'), 2;

my $f2 = new AI::Categorizer::FeatureVector;
ok $f2;

$f2->set({sports => 5, hockey => 7});
ok $f2->value('sports'), 5;
ok $f2->value('hockey'), 7;

my $h = $f2->as_hash;
ok keys(%$h), 2;


ok $f1->dot($f2), 10;
ok $f2->dot($f1), 10;

my $pkg = 'AI::Categorizer::FeatureVector::FastDot';
if (eval "use $pkg; 1") {
  my $f1 = $pkg->new(features => {sports => 2, finance => 3});
  my $f2 = $pkg->new(features => {sports => 5, hockey  => 7});
  ok $f1;
  ok $f2;

  $pkg->all_features([qw(sports finance hockey)]);
  ok keys(%{$pkg->all_features}), 3;

  ok $f1->dot($f2), 10;
  ok $f2->dot($f1), 10;
} else {
  skip "skip $pkg is not available", 1 for 1..5;
}

{
  # Call normalize() on an empty vector
  my $f = AI::Categorizer::FeatureVector->new(features => {});
  ok $f->euclidean_length, 0;
  eval {$f->normalize};
  ok $@, '';
  ok $f->normalize, $f;
}



( run in 1.172 second using v1.01-cache-2.11-cpan-39bf76dae61 )