2017 © Pedro Peláez
 

library gao

PHP framework for performing Genetic Algorithm Optimisation

image

petercoles/gao

PHP framework for performing Genetic Algorithm Optimisation

  • Saturday, July 7, 2018
  • by petercoles
  • Repository
  • 1 Watchers
  • 0 Stars
  • 20 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 2 Versions
  • 0 % Grown

The README.md

Genetic Algorithm Optimiser

Genetic Alorithms are a class of machine learning approaches that use the principles of natural selection, rather than the solving of mathematical formulae to find solutions to optimisation and search type problems. They are especially effective in complex situation that aren't easily "solved" and can often be used as a more-easily understood alternative to neural networks., (*1)

This framework takes care of most of the steps (loops) needed when developing and running a genetic algorithm, leaving you needing only to define the shape of your expected solution and a function to evaluate each candidate faciliating their comparison and thus the march towards an optimum., (*2)

Installation

You can install the package via composer:, (*3)

composer require petercoles/gao

Usage

Framing and Finding Solutions

Firstly create a class that defines a generic solution to the problem to be solved. The class must extend this package's Solution class, which will force the implemetation of two methods: genome() which defines the shape of a valid solution and evaluate(), which will calculate a numerical value that can be used to compare solutions., (*4)

``` php use PeterColes\GAO\Solution;, (*5)

class MySolution extends Solution { public function genome() { return [ ['char', 'ABC'], ['float', 0, 1], ['integer', -100, 100], ]; }, (*6)

public function evaluate($data = null)
{
    $this->fitness = (ord($this->chromosomes[0]) + $this->chromosomes[2]) / $this->chromosomes[1];
}

}, (*7)


Then instantiate and run the optimiser, creating an initial population of possible solutions to start its evaluation. ``` php $optimiser = new Optimiser(new Population(MySolution::class, 100)); $optimiser->run(); foreach ($optimiser->results as $solution) { print_r($solution->summary()); }

Data Manager

Although some use cases may not require much, if any, data against which to evaluate candidate solutions, others may need astronomical amounts. This could be be the case in financial markets where a trading strategy is sought and candidates are evaluated against the evolution of prices for many different securities, or in sports trading markets where possible strategies may be evaluated against changes in odds for thousands of events., (*8)

The DataManager class offers utilities optimised to assist with htese challenges. Here's the sort of thing that it can do:, (*9)

``` php $dm = new DataManager();, (*10)

// loads all files (assumed to be in CSV format) from given directory into an collection $data = $dm->loadCsvDir('path/to/directory');, (*11)

// PHP is really slow importing data into arrays - so once done, save the results (as json) $dm->save('path/to/output/file', $data);, (*12)

// It can be reloaded later from a json file in a tiny fraction of the time taken by the initial import $data = $dm->load('path/to/output/file');, (*13)

// to ensure our solutions works on data not seen during training, we may set aside some data (20% below) just for testing list($trainingData, $testingData) = $dm->split($data, 0.2);, (*14)


PHP is also rather memory hungry when constructing arrays. If you experience out of memory errors, then the following may help: ``` php $dm->setMemoryLimit('1G'); // increases memory for the current process only, accepts values in M or G e.g. 512M or 2Gs

Testing

bash composer test, (*15)

Changelog

Please see CHANGELOG for more information on what has changed recently., (*16)

Contributing

Please see CONTRIBUTING for details., (*17)

Security

If you discover any security related issues, please email peterdcoles@gmail.com instead of using the issue tracker. I take security very seriously and will welcome and respond promptly to your input., (*18)

Credits

License

The MIT License (MIT). Please see License File for more information., (*19)

The Versions

07/07 2018

dev-master

9999999-dev https://github.com/petercoles/gao

PHP framework for performing Genetic Algorithm Optimisation

  Sources   Download

MIT

The Requires

 

The Development Requires

ai gao genetic algorithm optimisation artifical intelligence

04/07 2018

0.1.0

0.1.0.0 https://github.com/petercoles/laraGAO

A Laravel package for performing Genetic Algorithm Optimisation

  Sources   Download

MIT

The Requires

  • php ^7.1

 

The Development Requires

ai gao genetic algorithm optimisation artifical intelligence