MIMOΒΆ

Out:

['Sub(Symc, Sub(Add(Symc, x_0), Mul(x_0, Symc)))', 'Div(x_0, Symc)'] (0.3377858084573795,)
['Sub(Symc, Sub(Add(Symc, x_0), Mul(x_0, Symc)))', 'Div(x_0, Symc)'] (0.3377858084573795,)
['Sub(Symc, Sub(Add(Symc, x_0), Mul(x_0, Symc)))', 'Div(x_0, Symc)'] (0.3377858084573795,)
['Mul(x_0, x_0)', 'Mul(x_0, Symc)'] (0.0,)

from functools import partial, partialmethod

import numpy as np
from deap.tools import selBest, selNSGA2

from glyph.gp.algorithms import AgeFitness
from glyph.gp.breeding import cxonepoint, mutuniform, nd_crossover, nd_mutation
from glyph.gp.individual import Individual, NDIndividual, nd_phenotype, numpy_phenotype, numpy_primitive_set
from glyph.utils.numeric import rmse

pset = numpy_primitive_set(1, categories=("algebraic", "symc"))
MyTree = Individual(pset=pset, name="MyTree")
MyNDTree = NDIndividual(base=MyTree, name="MyNDTree")
MyNDTree.create_population = partialmethod(MyNDTree.create_population, ndim=2)


def target(x):
    return np.array([f(x) for f in [lambda x: x ** 2, lambda x: x]])


x = np.linspace(-1, 1, 30)
y = target(x)


def evaluate_(individual, x, y):
    func = nd_phenotype(individual, backend=numpy_phenotype)
    yhat = func(x)
    for i in range(len(yhat)):
        if np.isscalar(yhat[i]):
            yhat[i] = np.ones_like(y[i]) * yhat[i]
    yhat = np.array(yhat)
    return (rmse(yhat, y),)


evaluate = partial(evaluate_, x=x, y=y)


def update_fitness(population):
    invalid = [p for p in population if not p.fitness.valid]
    fitnesses = map(evaluate, invalid)
    for ind, fit in zip(invalid, fitnesses):
        ind.fitness.values = fit
    return population


def main():
    pop_size = 100
    mutate = partial(nd_mutation, mut1d=mutuniform(pset=pset))
    mate = partial(nd_crossover, cx1d=cxonepoint())

    algorithm = AgeFitness(mate, mutate, selNSGA2, MyNDTree.create_population)

    pop = update_fitness(MyNDTree.create_population(pop_size))

    for gen in range(20):
        pop = algorithm.evolve(pop)
        pop = update_fitness(pop)
        best = selBest(pop, 1)[0]
        print(best, best.fitness.values)

        if best.fitness.values[0] <= 1e-3:
            break


if __name__ == "__main__":
    main()

Total running time of the script: ( 0 minutes 2.267 seconds)

Gallery generated by Sphinx-Gallery