Skip to content

HVisMyLife/rusty_neat

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

rusty_neat

Simple lib for handling Neuroevolution of augmenting topologies. It may not be exact implementation of that alghoritm, but it's simple, fast, and easy to use. Moreover, it just works for my use cases, so that's that. Documentation and lib still in progress

What it does?

In short, you start by creating input and output nodes, without any connections, etc. Then, through randomly evolving, there are added intermediate nodes and connections, which characteristics are randomly changed.

How to use it?

Create large amount of agents, each with each own neural networks. Let simulation run ( or whatever you are using it for ) and after set amount of time choose best of them to be parents of next generation. Alternatively, you can make agents spawn children after, for example, surviving and getting set amount of points ( what are they depends on use case ). Next generation should be created by copying neural network of it's predecessor and mutating it. Here you have example project that uses it to train "cars" ride along random track: https://github.com/HVisMyLife/neat_race

Exaple usage:

    use rusty_neat::NN;

    fn init() {

    // init new network with amount of (input, output) nodes
        let mut net = NN::new(3, 2);

    // set diffrent ( than default ) chances of mutations, sum (eg. 100%) doesn't matter
        net.set_chances(&[20, 20, 20, 0, 0, 0, 0])

    // evolve network, mutations are chosen randomly, according to above settings,
        for _ in 0..32 {
            net.mutate();
        }
    
    // forward inputs through net and return outputs
        let outputs = net.forward(&[0.5, 0.2, 0.8]);

    // access internal structure
        // calculation order, may be used for creating graph
        println!("\nOrder: \n{:?}", net.layer_order);
        // list of connections
        println!("\nConnections: \n{:?}", net.connections);
        // list of nodes
        println!("\nNodes: \n{:?}", net.nodes);

    // save network to file
        net.save("path");

    // load network from file
        net.load("path");
    }

Possible mutations it's order, and default chances:

    35% => modify one of connections weight,
    35% => modify one of nodes bias,
    10% => change one of nodes activation function,
    10% => add new random connection,
    10% => add new random node,
    0% => connection_enable,
    0% => connection_disable,

Struct NN supports serialization and deserialization through serde.

About

NEAT library

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages