Skip to content

A genetic algorithm for breaking the Vigenère cipher using the DEAP evolutionary computation framework.

Notifications You must be signed in to change notification settings

zehadialam/Evolutionary-Vigenere-Cipher-Breaker

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

26 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Evolutionary Vigenère Cipher Breaker

Description

This is a program that breaks the Vigenère cipher using a genetic algorithm.

Genetic Algorithm

Genetic algorithms are a kind of search algorithm that seek to find solutions from a problem space by making use of the Darwinian principles of variation, inheritance, and selection. In the context of biological evolution, individuals within a population who harbor traits that are more fit for their environment are more likely to pass on those traits to the next generation, such that there is an increase in that trait in the population over time. Similarly, in genetic algorithms, individuals with good genes according to a fitness function can pass on those genes to the next generation, which can lead to convergence to a solution over successive generations.

Problems that are to be solved using a genetic algorithm must undergo the proper set up and formulation. In this project, the following constitutes the problem formulation:

Representation: Chromosomes consist of genes that are ASCII values 65 – 90 (i.e., uppercase characters of English alphabet).

Initialization: Randomly generate population of 75 individuals.

Fitness Function: The sum of the log probabilities of all quadgrams within a message decrypted with a candidate key.

Mutation: Random resetting (i.e., character at random chromosomal position is replaced with a different character) with a probability of 1 / key length.

Crossover: Uniform crossover with a probability of 0.7

Selection: Ternary tournament selection

Termination condition: Message is fully decrypted.

About

A genetic algorithm for breaking the Vigenère cipher using the DEAP evolutionary computation framework.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages