Computational Intelligence

Slides:



Advertisements
Similar presentations
Population-based metaheuristics Nature-inspired Initialize a population A new population of solutions is generated Integrate the new population into the.
Advertisements

Computational Intelligence Winter Term 2009/10 Prof. Dr. Günter Rudolph Lehrstuhl für Algorithm Engineering (LS 11) Fakultät für Informatik TU Dortmund.
Computational Intelligence Winter Term 2013/14 Prof. Dr. Günter Rudolph Lehrstuhl für Algorithm Engineering (LS 11) Fakultät für Informatik TU Dortmund.
Incremental Linear Programming Linear programming involves finding a solution to the constraints, one that maximizes the given linear function of variables.
Biologically Inspired Computing: Operators for Evolutionary Algorithms
Genetic Algorithms Contents 1. Basic Concepts 2. Algorithm
Computational Intelligence Winter Term 2011/12 Prof. Dr. Günter Rudolph Lehrstuhl für Algorithm Engineering (LS 11) Fakultät für Informatik TU Dortmund.
COMP305. Part II. Genetic Algorithms. Genetic Algorithms.
Evolutionary Computational Intelligence
An Introduction to Black-Box Complexity
Chapter 6: Transform and Conquer Genetic Algorithms The Design and Analysis of Algorithms.
Computational Intelligence Winter Term 2011/12 Prof. Dr. Günter Rudolph Lehrstuhl für Algorithm Engineering (LS 11) Fakultät für Informatik TU Dortmund.
Prepared by Barış GÖKÇE 1.  Search Methods  Evolutionary Algorithms (EA)  Characteristics of EAs  Genetic Programming (GP)  Evolutionary Programming.
Genetic Algorithm.
Genetic Algorithms and Ant Colony Optimisation
Genetic algorithms Prof Kang Li
CS 484 – Artificial Intelligence1 Announcements Lab 3 due Tuesday, November 6 Homework 6 due Tuesday, November 6 Lab 4 due Thursday, November 8 Current.
Zorica Stanimirović Faculty of Mathematics, University of Belgrade
Neural and Evolutionary Computing - Lecture 5 1 Evolutionary Computing. Genetic Algorithms Basic notions The general structure of an evolutionary algorithm.
1 Combinatorial Problem. 2 Graph Partition Undirected graph G=(V,E) V=V1  V2, V1  V2=  minimize the number of edges connect V1 and V2.
2005MEE Software Engineering Lecture 11 – Optimisation Techniques.
Exact and heuristics algorithms
1 Genetic Algorithms and Ant Colony Optimisation.
Genetic Algorithms Genetic algorithms provide an approach to learning that is based loosely on simulated evolution. Hypotheses are often described by bit.
Genetic Algorithms What is a GA Terms and definitions Basic algorithm.
METAHEURISTICS Genetic Algorithm Jacques A. Ferland Department of Informatique and Recherche Opérationnelle Université de Montréal
EE749 I ntroduction to Artificial I ntelligence Genetic Algorithms The Simple GA.
CS621: Artificial Intelligence Pushpak Bhattacharyya CSE Dept., IIT Bombay Lecture 5: Power of Heuristic; non- conventional search.
D Nagesh Kumar, IIScOptimization Methods: M8L5 1 Advanced Topics in Optimization Evolutionary Algorithms for Optimization and Search.
Selection and Recombination Temi avanzati di Intelligenza Artificiale - Lecture 4 Prof. Vincenzo Cutello Department of Mathematics and Computer Science.
1 Combinatorial Problem. 2 Graph Partition Undirected graph G=(V,E) V=V1  V2, V1  V2=  minimize the number of edges connect V1 and V2.
Computational Intelligence Winter Term 2015/16 Prof. Dr. Günter Rudolph Lehrstuhl für Algorithm Engineering (LS 11) Fakultät für Informatik TU Dortmund.
Genetic Algorithms And other approaches for similar applications Optimization Techniques.
Genetic Algorithm. Outline Motivation Genetic algorithms An illustrative example Hypothesis space search.
Power Magnetic Devices: A Multi-Objective Design Approach
Chapter 14 Genetic Algorithms.
Genetic Algorithms.
Computational Intelligence
Evolutionary Algorithms Jim Whitehead
School of Computer Science & Engineering
Introduction to Genetic Algorithm (GA)
Example: Applying EC to the TSP Problem
CSC 380: Design and Analysis of Algorithms
Artificial Intelligence (CS 370D)
Subject Name: Operation Research Subject Code: 10CS661 Prepared By:Mrs
Comparing Genetic Algorithm and Guided Local Search Methods
CS621: Artificial Intelligence
Dr. Arslan Ornek IMPROVING SEARCH
Computational Intelligence
Meta-Heuristic Algorithms 16B1NCI637
Introduction to Operators
Example: Applying EC to the TSP Problem
Multi-Objective Optimization
Computational Intelligence
Genetic Algorithms Chapter 3.
EE368 Soft Computing Genetic Algorithms.
Boltzmann Machine (BM) (§6.4)
Searching for solutions: Genetic Algorithms
Machine Learning: UNIT-4 CHAPTER-2
Genetic Algorithms & Simulated Evolution
Biologically Inspired Computing: Operators for Evolutionary Algorithms
Genetic Algorithm Soft Computing: use of inexact t solution to compute hard task problems. Soft computing tolerant of imprecision, uncertainty, partial.
Computational Intelligence
Beyond Classical Search
Population Based Metaheuristics
Computational Intelligence
CSC 380: Design and Analysis of Algorithms
Population Methods.
Presentation transcript:

Computational Intelligence Winter Term 2018/19 Prof. Dr. Günter Rudolph Lehrstuhl für Algorithm Engineering (LS 11) Fakultät für Informatik TU Dortmund

Evolutionary Algorithms (EA) Optimization Basics EA Basics Plan for Today Evolutionary Algorithms (EA) Optimization Basics EA Basics G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 2 G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 2

! ? ? ! ? ! Optimization Basics modelling simulation optimization system output input G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 3

Optimization Basics given: objective function f: X → feasible region X (= nonempty set) objective: find solution with minimal or maximal value! x* global solution f(x*) global optimum optimization problem: find x*  X such that f(x*) = min{ f(x) : x  X } note: max{ f(x) : x  X } = – min{ – f(x) : x  X } G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 4

Optimization Basics local solution x*  X : x  N(x*): f(x*) ≤ f(x) if x* local solution then f(x*) local optimum / minimum neighborhood of x* = bounded subset of X example: X = n, N(x*) = { x  X: || x – x*||2 ≤  } remark: evidently, every global solution / optimum is also local solution / optimum; the reverse is wrong in general! a b x* example: f: [a,b] → , global solution at x* G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 5

Optimization Basics What makes optimization difficult? some causes: local optima (is it a global optimum or not?) constraints (ill-shaped feasible region) non-smoothness (weak causality) discontinuities ( nondifferentiability, no gradients) lack of knowledge about problem ( black / gray box optimization) strong causality needed! f(x) = a1 x1 + ... + an xn → max! with xi  {0,1}, ai   xi* = 1 iff ai > 0 add constaint g(x) = b1 x1 + ... + bn xn ≤ b  NP-hard  still harder add capacity constraint to TSP  CVRP G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 6

Optimization Basics When using which optimization method? mathematical algorithms problem explicitly specified problem-specific solver available problem well understood ressources for designing algorithm affordable solution with proven quality required randomized search heuristics problem given by black / gray box no problem-specific solver available problem poorly understood insufficient ressources for designing algorithm solution with satisfactory quality sufficient  don‘t apply EAs  EAs worth a try G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 7

Evolutionary Algorithm Basics idea: using biological evolution as metaphor and as pool of inspiration  interpretation of biological evolution as iterative method of improvement feasible solution x  X = S1 x ... x Sn = chromosome of individual multiset of feasible solutions = population: multiset of individuals = fitness function objective function f: X → often: X = n, X = n = {0,1}n, X = n = {  :  is permutation of {1,2,...,n} } also : combinations like X = n x p x q or non-cartesian sets  structure of feasible region / search space defines representation of individual G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 8

Evolutionary Algorithm Basics algorithmic skeleton initialize population evaluation parent selection variation (yields offspring) evaluation (of offspring) survival selection (yields new population) N stop? Y output: best individual found G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 9

Evolutionary Algorithm Basics Specific example: (1+1)-EA in n for minimizing some f: n → population size = 1, number of offspring = 1, selects best from 1+1 individuals parent offspring initialize X(0)  n uniformly at random, set t = 0 evaluate f(X(t)) select parent: Y = X(t) variation: flip each bit of Y independently with probability pm = 1/n evaluate f(Y) selection: if f(Y) ≤ f(X(t)) then X(t+1) = Y else X(t+1) = X(t) if not stopping then t = t+1, continue at (3) no choice, here G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 10

Evolutionary Algorithm Basics Specific example: (1+1)-EA in n for minimizing some f: n → population size = 1, number of offspring = 1, selects best from 1+1 individuals parent offspring compact set = closed & bounded initialize X(0)  C  n uniformly at random, set t = 0 evaluate f(X(t)) select parent: Y = X(t) variation = add random vector: Y = Y + Z, e.g. Z  N(0, In) evaluate f(Y) selection: if f(Y) ≤ f(X(t)) then X(t+1) = Y else X(t+1) = X(t) if not stopping then t = t+1, continue at (3) no choice, here G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 11

Evolutionary Algorithm Basics Selection select parents that generate offspring → selection for reproduction select individuals that proceed to next generation → selection for survival necessary requirements: - selection steps must not favor worse individuals one selection step may be neutral (e.g. select uniformly at random) at least one selection step must favor better individuals typically : selection only based on fitness values f(x) of individuals seldom : additionally based on individuals‘ chromosomes x (→ maintain diversity) G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 12

Evolutionary Algorithm Basics Selection methods population P = (x1, x2, ..., x) with  individuals two approaches: 1. repeatedly select individuals from population with replacement 2. rank individuals somehow and choose those with best ranks (no replacement) uniform / neutral selection choose index i with probability 1/ fitness-proportional selection choose index i with probability si = don‘t use! problems: f(x) > 0 for all x  X required  g(x) = exp( f(x) ) > 0 but already sensitive to additive shifts g(x) = f(x) + c almost deterministic if large differences, almost uniform if small differences G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 13

Evolutionary Algorithm Basics Selection methods population P = (x1, x2, ..., x) with  individuals rank-proportional selection order individuals according to their fitness values assign ranks fitness-proportional selection based on ranks  avoids all problems of fitness-proportional selection but: best individual has only small selection advantage (can be lost!) outdated! k-ary tournament selection draw k individuals uniformly at random (typically with replacement) from P choose individual with best fitness (break ties at random)  has all advantages of rank-based selection and probability that best individual does not survive: G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 14

Evolutionary Algorithm Basics Selection methods without replacement population P = (x1, x2, ..., x) with  parents and population Q = (y1, y2, ..., y) with  offspring (, )-selection or truncation selection on offspring or comma-selection rank  offspring according to their fitness select  offspring with best ranks  best individual may get lost,  ≥  required (+)-selection or truncation selection on parents + offspring or plus-selection merge  offspring and  parents rank them according to their fitness select  individuals with best ranks  best individual survives for sure G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 15

from parents & offspring Evolutionary Algorithm Basics Selection methods: Elitism Elitist selection: best parent is not replaced by worse individual. Intrinsic elitism: method selects from parent and offspring, best survives with probability 1 - Forced elitism: if best individual has not survived then re-injection into population, i.e., replace worst selected individual by previously best parent method P{ select best } from parents & offspring intrinsic elitism neutral < 1 no fitness proportionate rank proportionate k-ary tournament ( + ) = 1 yes ( , ) G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 16

Evolutionary Algorithm Basics Variation operators: depend on representation mutation → alters a single individual recombination → creates single offspring from two or more parents may be applied exclusively (either recombination or mutation) chosen in advance exclusively (either recombination or mutation) in probabilistic manner sequentially (typically, recombination before mutation); for each offspring sequentially (typically, recombination before mutation) with some probability G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 17

Evolutionary Algorithm Basics Variation in n Individuals  { 0, 1 }n ● Mutation local → choose index k  { 1, …, n } uniformly at random, flip bit k, i.e., xk = 1 – xk global → for each index k  { 1, …, n }: flip bit k with probability pm  (0,1) “nonlocal“ → choose K indices at random and flip bits with these indices inversion → choose start index ks and end index ke at random invert order of bits between start and end index 1 0 0 1 1 1 1 0 1 1 a) k=2 0 0 1 0 1 b) 0 0 0 0 1 c) K=2 → 1 1 0 0 1 ks ke d) G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 18

Evolutionary Algorithm Basics Variation in n Individuals  { 0, 1 }n ● Recombination (two parents) 1-point crossover → draw cut-point k  {1,…,n-1} uniformly at random; choose first k bits from 1st parent, choose last n-k bits from 2nd parent K-point crossover → draw K distinct cut-points uniformly at random; choose bits 1 to k1 from 1st parent, choose bits k1+1 to k2 from 2nd parent, choose bits k2+1 to k3 from 1st parent, and so forth … uniform crossover → for each index i: choose bit i with equal probability from 1st or 2nd parent 1 0 0 1 0 1 1 1 1 1 1 a)  1 0 0 1 0 1 1 1 1 1 1 b)  1 0 0 1 0 1 1 1 0 0 1 c)  G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 19

Evolutionary Algorithm Basics Variation in n Individuals  { 0, 1 }n ● Recombination (multiparent:  = #parents) diagonal crossover (2 <  < n) AAAAAAAAAA BBBBBBBBBB CCCCCCCCCC DDDDDDDDDD → choose  – 1 distinct cut points, select chunks from diagonals ABBBCCDDDD can generate  offspring; otherwise choose initial chunk at random for single offspring BCCCDDAAAA CDDDAABBBB DAAABBCCCC gene pool crossover ( > 2) → for each gene: choose donating parent uniformly at random G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 20

Evolutionary Algorithm Basics Variation in n Individuals  X = (1, …, n) ● Mutation local → 2-swap / 1-translocation 5 3 2 4 1 5 3 2 4 1 5 4 2 3 1 5 2 4 3 1 global → draw number K of 2-swaps, apply 2-swaps K times K is positive random variable; its distribution may be uniform, binomial, geometrical, …; E[K] and V[K] may control mutation strength expectation variance G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 21

Evolutionary Algorithm Basics Variation in n Individuals  X = (1, …, n) ● Recombination (two parents) order-based crossover (OBX) - select two indices k1 and k2 with k1 ≤ k2 uniformly at random copy genes k1 to k2 from 1st parent to offspring (keep positions) copy genes from left to right from 2nd parent, starting after position k2 2 3 5 7 1 6 4 6 4 5 3 7 2 1 x x x 7 1 6 x 5 3 2 7 1 6 4 partially mapped crossover (PMX) - select two indices k1 and k2 with k1 ≤ k2 uniformly at random copy genes k1 to k2 from 1st parent to offspring (keep positions) copy all genes not already contained in offspring from 2nd parent (keep positions) from left to right: fill in remaining genes from 2nd parent 2 3 5 7 1 6 4 6 4 5 3 7 2 1 x x x 7 1 6 x x 4 5 7 1 6 x 3 4 5 7 1 6 2 G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 22

Evolutionary Algorithm Basics Variation in n Individuals X  n ● Mutation additive: Y = X + Z (Z: n-dimensional random vector) offspring = parent + mutation local → Z with bounded support Definition Let fZ: n→ + be p.d.f. of r.v. Z. The set { x  n : fZ(x) > 0 } is termed the support of Z. x fZ nonlocal → Z with unbounded support fZ x most frequently used! G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 23

Evolutionary Algorithm Basics Variation in n Individuals X  n ● Recombination (two parents) all crossover variants adapted from n intermediate intermediate (per dimension) discrete simulated binary crossover (SBX) → for each dimension with probability pc draw from: G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 24

Evolutionary Algorithm Basics Variation in n Individuals X  n ● Recombination (multiparent),  ≥ 3 parents intermediate where and (all points in convex hull) intermediate (per dimension) G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 25

Evolutionary Algorithm Basics Theorem Let f: n → be a strictly quasiconvex function. If f(x) = f(y) for some x ≠ y then every offspring generated by intermediate recombination is better than its parents. Proof: ■ G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 26

Evolutionary Algorithm Basics Theorem Let f: n → be a differentiable function and f(x) < f(y) for some x ≠ y. If (y – x)‘ f(x) < 0 then there is a positive probability that an offspring generated by intermediate recombination is better than both parents. Proof: ■ G. Rudolph: Computational Intelligence ▪ Winter Term 2018/19 27