Course: 2022/2023

Genetic and evolutionary algorithms

(15755)

Requirements (Subjects that are assumed to be known)

Programming. First year, first semester
Statistics. Second year, second semester

KNOWLEDGE:
- To adquire the fundamentals of problem solving techniques based on populations
- To learn the fundamental techniques that allow the resolution of problems by using biologically inspired techniques
- To know which techniques are appropriate for each problem domain
- To know the differences of each technique and their appropriate parameterization
- To get the knowledge about each technique and the reason for its implementation
UNDERSTANDING:
- To understand the application of population-based learning systems
- To understand the mathematical foundations of evolutionary techniques described in the course
- Understand the variants of each technique, motivation and practical justification
- Understand the usefulness of the proposed techniques in problem solving
APPLICATION:
- Be able to select the appropriate technique to the specific characteristics of the problem domains
- Evaluate the performance and efficiency of different methods
- Working on specific problems and solve them efficiently adjusting techniques and their parameters
- Organize experimental environments to validate different alternatives and be able to evaluate and analyze results
- Hability to work cooperatively and creatively in a team
- Hability to communicate effectively by oral and writtng
CRITICISM OR VALUATION:
- To adquire the ability to validate alternative techniques to solve specific problems
- Criticizing a given proposal (eg in the selected bibliography)
- Consider the relationship between computational cost and marginal improvement in different Solutions
- To decide reasonable solutions to the features of a given problem

Skills and learning outcomes

Description of contents: programme

1. Introduction to evolutionary computation algorithms
2. General concepts of evolutionary algorithms
2.1 Generating the initial population
2.2 Stopping criteria
2.3 Selection methods
2.4 Reproduction
2.5 Insertion and replacement policies
2.6 Example of an evolutionary system
3. Evolutionary computation techniques
3.1 Genetic algorithms
3.2 Evolutionary Strategies
3.3 Diferential evolution
3.4 Genetic Programming
3.5 Gene Expressions
3.6 Grammatical evolution
4. Troubleshooting using evolutionary techniques
4.1 Problems with multiple solutions
4.2 Problems with multiple conflicting objectives
4.3 Constrained optimization
4.4 Coevolutionary algorithms
4.5 Application to real-life problems
4.6 Mathematical Foundations

Learning activities and methodology

1. Lectures. To learn the basic concepts of problem solving by means of population-based techniques.
2. Development of a homework project. The student, as part of a work team must develop a project to give a complete solution to a problem, proposing techniques, parameters and the steps required for its realization. This project are divided into three sections that will be evaluated separately and the complexity will grow incrementally. The project will require the completion of a test environment as well as an analysis and assessment of results. 3 ECTS.
3. Work teams will make public presentations of results in each project. After each presentation there will be an open discussion of the works submitted.

Assessment System

- % end-of-term-examination 0
- % of continuous assessment (assigments, laboratory, practicals...) 100

Basic Bibliography

- El-Ghazali Talbi. Metaheuristics: From Design to Implementation. Wiley and Sons. 2009
- M. Mitchell. An introduction to Genetic Algorithms. MIT Press.

The course syllabus may change due academic events or other reasons.