Skip to content

Python based project involving Technique based Multi-objective optimisation.

Notifications You must be signed in to change notification settings

zencodess/genetic-algorithms-optimization

Repository files navigation

Steps to Run

Genetic Algorithms Optimisation Project

Python based project involving Technique based Multi-objective optimisation.

  • Clone the repository to your local workspace using git clone https://github.com/zencodess/genetic-algorithms-optimization.git

  • The main executable file is ./run.py, this is the only file to be run. It has all the commands to invoke and execute all remaining files too.

  • The pygen module generates first generation of files with different Wn, Wp, Ln, Lp values.

  • The mutation module introduces random error in the values of Wn, Wp, Ln, Lp of the files maintaining them in results.

  • The modules crossover and crossover_child perform crossover and produce children.

  • fitness module, runs hspice on files having different values of Wn, Wp, Ln, Lp , takes values of leakagepower and delays , assigns fitness value to each file in the generation.

  • Once you run the file , run.py , directories to hold 20 generations are created. In each generation's directory (genXX), we have mutation, delay, leakage, crossover directories, byproduct text files stats.txt and next_gen.txt.

    • In the text file, next_gen.txt, we have files of that generation in decreasing order of their fitness values.
    • In the stats.txt, file, the leakages and delays are put in the order from the best file to the worst ones in the generation.
  • The change in delays and leakage powers can be known by , observing the delays and leakages of file with index number same as that of last number in the stats file of the initial generation (stats file in gen0 directory) and the delays and leakages of file with index number same as that of first number in the stats file (stats file in gen19 directory) of the final generation.

  • In mutation directory (genXX/mutation), we get delay and leakage directories , which have delay.mt0 and leakage.ms0 files (of different indices) which can be looked up for getting the values of delay and leakages of best files in that generation.

Commands to run the file

  1. python run.py - The maxdelay and average leakage are displayed on the screen for all the 100 files in each genertion
  2. Let k be the last generation cat genk/next_gen.txt
  3. The first number indicates the best child let it be i, cat genk/mutation/delay/i_delay.mt0 and cat genk/mutation/leakage/i_leakage.ms0 gives the leakage and delay results on the screen
  4. To get the delay and leakage of all population also gives the file with best heuristic, run python fitness.py give no.of generations as input

About

Python based project involving Technique based Multi-objective optimisation.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published