NAME
Algorithm::AdaGrad - AdaGrad learning algorithm.
SYNOPSIS
use Algorithm::AdaGrad;
my $ag = Algorithm::AdaGrad->new(0.1);
$ag->update([
{ "label" => 1, "features" => { "R" => 1.0, "G" => 0.0, "B" => 0.0 } },
]);
$ag->update([
{ "label" => -1, "features" => { "R" => 0.0, "G" => 1.0, "B" => 0.0 } },
{ "label" => -1, "features" => { "R" => 0, "G" => 0, "B" => 1 } },
{ "label" => -1, "features" => { "R" => 0.0, "G" => 1.0, "B" => 1.0 } },
{ "label" => 1, "features" => { "R" => 1.0, "G" => 0.0, "B" => 1.0 } },
{ "label" => 1, "features" => { "R" => 1.0, "G" => 1.0, "B" => 0.0 } }
]);
my $result = $ag->classify({ "R" => 1.0, "G" => 1.0, "B" => 0.0 });
DESCRIPTION
Algorithm::AdaGrad is implementation of AdaGrad(Adaptive Gradient) online learning algorithm. This module can using for binary classification.
METHODS
new($eta)
Constructor. `$eta` is learning ratio.
update($learning_data)
Executes learning.
`$learning_date` is ArrayRef like bellow.
$ag->update([
{ "label" => -1, "features" => { "R" => 0.0, "G" => 1.0, "B" => 0.0 } },
{ "label" => -1, "features" => { "R" => 0, "G" => 0, "B" => 1 } },
{ "label" => -1, "features" => { "R" => 0.0, "G" => 1.0, "B" => 1.0 } },
{ "label" => 1, "features" => { "R" => 1.0, "G" => 0.0, "B" => 1.0 } },
{ "label" => 1, "features" => { "R" => 1.0, "G" => 1.0, "B" => 0.0 } }
]);
`features` is set of feature-string and value(real number) pair. `label` is a expected output label (+1 or -1).
classify($features)
Executes binary classification. Returns 1 or -1.
`$features` is HashRef like bellow.
my $result = $ag->classify({ "R" => 1.0, "G" => 1.0, "B" => 0.0 });
save($filename)
This method dumps the internal data of an object to a file.
load($filename)
This method restores the internal data of object from dumped file.
SEE ALSO
John Duchi, Elad Hazan, Yoram Singer. Adaptive Subgradient Methods for Online Learning and Stochastic Optimization http://www.magicbroom.info/Papers/DuchiHaSi10.pdf
LICENSE
Copyright (C) hideo55.
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
AUTHOR
hideo55 <hide.o.j55@gmail.com>