GeneticSharp is a fast, extensible, multi-platform and multithreading C# Genetic Algorithm library that simplifies the development of applications using Genetic Algorithms (GAs).
Can be used in any kind of .NET Core and .NET Framework apps, like ASP .NET MVC, ASP .NET Core, Blazor, Web Forms, UWP, Windows Forms, GTK#, Xamarin and Unity3D games.
- AeroVision: aircraft trajectories optimization and visualization (paper)
- Artificial Intelligence course in French engineering schools (course)
- Analysis and comparison between Black-Scholes and Merton and Corrado-Su for options pricing (paper)
- Context-Sensitive Code Completion: improving predictions with genetic algorithms (paper) (Github)
- Deriving Functions for Pareto Optimal Fronts Using Genetic Programming (paper/book)
- Designing and creating a self managing distributed file system (paper)
- Design of a warehouse order picking policy using genetic algorithm (paper)
- Developing trading strategies with genetic algorithms (forum) (paper)
- Fabrication of Adiabatic Quantum-Flux-Parametron Integrated Circuits Using an Automatic Placement Tool Based on Genetic Algorithms (paper)
- Frixel: 2D framing / pixel structural optimization (project)
- Function optimization with GeneticSharp (tutorial)
- GeneticSharp Car2D (sample)
- GeneticSharp Unity3d Samples (Android app)
- Genetic Scheduler: a genetic algorithm for scheduling tasks with temporal restriction in distributed systems (paper)
- Lean Optimization: genetic optimization using LEAN (GitHub)
- OpenFMSL: simulate stationary chemical processes using mass and energy balances (project)
- Modelling and Simulation Analysis of Goal-Oriented Business Process (paper)
- Optimization of patient flow in emergency departments using Genetic Algorithms (paper)
- Optimization by genetic algorithm of lattices structures for the media generation in additive manufacturing (paper)
- Overload journal 142: Evolutionary computing frameworks for optimisation (journal)
- Path Finding with Genetic Algorithms (project)
- SurvivorAI: some experiments of survival scenarios (project)
- ThermalDesign (project)
- TrussOptimization (project)
- TSP with GeneticSharp and Unity3D (tutorial)
- VetMedData.NET: a .NET Core class library for obtaining structured data on UK-licensed Veterinary Medicines (project)
- Are you using GeneticSharp in your project? Please, let me know!
- FloatingPointChromosome
- IntegerChromosome
- Add your own chromosome representation implementing IChromosome / IBinaryChromosome interfaces or extending ChromosomeBase / BinaryChromosomeBase.
Add your own fitness evaluation, implementing IFitness interface.
- Population
- TplPopulation
- Others populations can be added implementing IPopulation interface or extending Population.
- Generation
- Generation strategy
- Performance strategy
- Tracking strategy
- Others generation strategies can be added implementing IGenerationStrategy.cs interface.
- DefaultOperatorsStrategy
- TplOperatorsStrategy
- Others operators strategies can be added implementing IOperatorsStrategy interface.
- Elite (also know as Truncate or Truncation)
- Roulette Wheel
- Stochastic Universal Sampling
- Tournament
- Others selections can be added implementing ISelection interface or extending SelectionBase.
- Alternating-position (AP)
- Cut and Splice
- Cycle (CX)
- One-Point (C1)
- Order-based (OX2)
- Ordered (OX1)
- Partially Mapped (PMX)
- Position-based (POS)
- Three parent
- Two-Point (C2)
- Uniform
- Voting Recombination (VR)
- Others crossovers can be added implementing ICrossover interface or extending CrossoverBase.
- Displacement
- Flip Bit
- Insertion
- Partial Shuffle (PSM)
- Reverse Sequence (RSM)
- Twors
- Uniform
- Others mutations can be added implementing IMutation interface or extending MutationBase / SequenceMutationBase.
- Elitist
- Fitness Based
- Pure
- Uniform
- Others reinsertions can be added implementing IReinsertion interface or extending ReinsertionBase.
- Generation number
- Time evolving
- Fitness stagnation
- Fitness threshold
- And e Or (allows combine others terminations)
- Others terminations can be added implementing ITermination interface or extending TerminationBase.
- Basic randomization (using System.Random)
- Fast random
- If you need a special kind of randomization for your GA, just implement the IRandomization interface.
- LinearTaskExecutor
- ParallelTaskExecutor
- TplTaskExecutor
- Others task executors can be added implementing ITaskExecutor interface.
- AutoConfig
- Bitmap equality
- Equality equation
- Equation solver
- Function builder
- Ghostwriter
- TSP (Travelling Salesman Problem)
- Bitmap equality
- Function optimization
- Sudoku
- TSP (Travelling Salesman Problem)
- Car2D
- TSP (Travelling Salesman Problem)
- Wall Builder
- Mono, .NET Standard 2.0 and .NET Framework 4.6.2 support
- Fully tested on Windows and MacOS
- 100% unit test code coverage
- 100% code documentation
- SonarCloud validated
- Performance benchmarks
Only GeneticSharp:
install-package GeneticSharp
GeneticSharp and extensions (TSP, AutoConfig, Bitmap equality, Equality equation, Equation solver, Function builder, etc):
install-package GeneticSharp.Extensions
You should use the UnityNuGet to install GeneticSharp directly from NuGet.
Or you can use the latest GeneticSharp.unitypackage available on our release page.
To install previous version that support .NET Framework 3.5:
install-package GeneticSharp -Version 1.2.0
If you want to run the console, GTK# and Unity samples, just fork this repository and follow the instruction from our setup page wiki.
An easy way to run the Unity Samples, if you have a Android device, is download it from Google Play.
public class MyProblemFitness : IFitness
{
public double Evaluate (IChromosome chromosome)
{
// Evaluate the fitness of chromosome.
}
}
public class MyProblemChromosome : ChromosomeBase
{
// Change the argument value passed to base constructor to change the length
// of your chromosome.
public MyProblemChromosome() : base(10)
{
CreateGenes();
}
public override Gene GenerateGene (int geneIndex)
{
// Generate a gene base on my problem chromosome representation.
}
public override IChromosome CreateNew ()
{
return new MyProblemChromosome();
}
}
var selection = new EliteSelection();
var crossover = new OrderedCrossover();
var mutation = new ReverseSequenceMutation();
var fitness = new MyProblemFitness();
var chromosome = new MyProblemChromosome();
var population = new Population (50, 70, chromosome);
var ga = new GeneticAlgorithm(population, fitness, selection, crossover, mutation);
ga.Termination = new GenerationNumberTermination(100);
Console.WriteLine("GA running...");
ga.Start();
Console.WriteLine("Best solution found has {0} fitness.", ga.BestChromosome.Fitness);
If you're using .NET Core, you can install GeneticSharp.Templates:
dotnet new -i GeneticSharp.Templates
There are 4 templates in GeneticSharp.Templates:
A Blazor client application template with GeneticSharp ready to run a Travelling Salesman Problem (TSP).
dotnet new GeneticSharpTspBlazorApp -n MyNamespace -o MyOutoputFolder
A console application template with GeneticSharp, you just need to implement the chromosome and fitness function.
dotnet new GeneticSharpConsoleApp -n MyNamespace -o MyOutoputFolder
A console application template with GeneticSharp ready to run a Travelling Salesman Problem (TSP).
dotnet new GeneticSharpTspConsoleApp -n MyNamespace -o MyOutoputFolder
A Unity3D template with GeneticSharp ready to run a Travelling Salesman Problem (TSP).
dotnet new GeneticSharpTspUnity3d -n MyNamespace -o MyOutoputFolder
Having troubles?
- Read our wiki.
- Tutorials
- Ask on Stack Overflow using the tag GeneticSharp.
- Open an issue.
Create a fork of GeneticSharp.
Did you change it? Submit a pull request.
Licensed under the The MIT License (MIT). In others words, you can use this library for developement any kind of software: open source, commercial, proprietary, etc.
- AppVeyor: open source license for continuous integration.
- JetBrains: open source license for all products pack.
- SMASHINGLOGO: GeneticSharp's logo.
- SonarCloud: open source license for online inspection.