Genetic Algorithm
finding extrema of a functions of two variables
Photo by Alexander Popov on Unsplash
This is my final project for Artificial Intelligence course from 4th semester (Summer Semester 2018/19), conducted in cooperation with Pawel.
For function parsing we used SymPy symbols and lambdify function which results then were computed using NumPy ndarrays.
PyQt5 as a GUI, Matplotlib as a data visualisation.
Features
- Defining function of two variables, its domain and range
- Parsing function
- Function visualization in 3D with possibility to manipulate angles of a 3D object
- Defining crossover, mutation probability, number of individuals and epochs in GA
- Plot of each generation
- Summary with chromosome which values will give the best solution
- Plot of best, median and mean value in each epoch
Screenshots
Functions visualization, setting function domain and range
\[x^2 + y^2; x \in \langle -2, 2 \rangle y \in \langle -2, 2 \rangle\]data:image/s3,"s3://crabby-images/5569c/5569caa73f3d91bba048d5aa73b7428af0d3a4a7" alt=""
data:image/s3,"s3://crabby-images/10b06/10b0615555bc71a64d85a77fd92a29de1c5464e0" alt=""
data:image/s3,"s3://crabby-images/7aa2f/7aa2ff25d4c6b25d91d95e68f4c907abec6bc4d7" alt=""
Solving genetic algorithm
data:image/s3,"s3://crabby-images/a4507/a450703277f645cdfaa81ab05d55ebdbbae6e7d4" alt=""
Generation plots
data:image/s3,"s3://crabby-images/90d60/90d60ae1e1e6364d08a356ed98d55701c3f047bf" alt=""
data:image/s3,"s3://crabby-images/78f64/78f64c6163691769d5a27c8f57ada6655a9c818c" alt=""
Summary
data:image/s3,"s3://crabby-images/c6380/c6380071333e44a6de9cf11d7c47ba43b58571e1" alt=""
Remaster
In 2019 Pawel and I decided to update this project further and with our colleague Daniel we created a new version for Building Desktop Applications using WPF course from 6th Semester (Summer Semester 2019/20). We rewrite whole project to C# and add additional featues such as:
- now many functions with various algorithm parameters can be computed at the same time
- results can be exported to PDF file
data:image/s3,"s3://crabby-images/b0adb/b0adbffab24392cedded1146c765332f0b153a02" alt=""
data:image/s3,"s3://crabby-images/4229b/4229bd500d3122171466607efb5eeb2bbfca3c03" alt=""
data:image/s3,"s3://crabby-images/eaeff/eaeff2c2e2058780a67048f7769185eb4d4042d8" alt=""
data:image/s3,"s3://crabby-images/0639a/0639a38d5f88239a8ed235590428328766738489" alt=""
data:image/s3,"s3://crabby-images/decce/decce17781247b9dd9fe02597323da201aef8da2" alt=""
data:image/s3,"s3://crabby-images/a2a7f/a2a7f97c04d6528e1732cb39980353204be20688" alt=""
data:image/s3,"s3://crabby-images/07acd/07acd941492dd471d8a054c8909bfa8e3fa27993" alt=""
data:image/s3,"s3://crabby-images/7bb3e/7bb3e230e3b7584ca90e7f79094882bfaf3fcc3e" alt=""
data:image/s3,"s3://crabby-images/f55b8/f55b80cd32263a390b9f83c0c5a417787e6ba8fe" alt=""
data:image/s3,"s3://crabby-images/c19b2/c19b2642ec5a42ab3dee3566ea4a73d93d5279dc" alt=""
data:image/s3,"s3://crabby-images/c4b37/c4b37c2be992d54bbed5f486453688fdf7a24e81" alt=""