3. ALGORITMOS GENÉTICOS
|
|
|
- Maria Clara Tomé Brunelli
- 9 Há anos
- Visualizações:
Transcrição
1 1 3. ALGORITMOS GENÉTICOS PARTE Analogia Física: a evolução das espécies 3.2 A Tradução Matemática: o algoritmo básico 3.3 Codificação dos Indivíduos 3.4 Avaliação da Aptidão de um Indivíduo 3.5 Operador Cruzamento 3.6 Operador Mutação
2 2 3. ALGORITMOS GENÉTICOS 3.1. Analogia Física: a evolução das espécies Até meados do século 19, os naturalistas acreditavam que cada espécie havia sido criada separadamente por um ser supremo ou através de geração espontânea. O trabalho do naturalista Carolus Linnaeus sobre a classificação biológica de organismos despertou o interesse pela similaridade entre certas espécies, levando a acreditar na existência de uma certa relação entre elas. Outros trabalhos influenciaram os naturalistas em direção à teoria da seleção natural, tais como os de Jean Baptiste Lamark, que sugeriu uma teoria evolucionária no "uso e desuso" de órgãos; e de Thomas Robert Malthus, que propôs que fatores ambientais tais como doenças e carência de alimentos, limitavam o crescimento de uma população. Depois de mais de 20 anos de observações e experimentos, Charles Darwin apresentou em 1858 sua teoria de evolução através de seleção natural, simultaneamente com outro naturalista inglês Alfred Russel Wallace. No ano seguinte, Darwin publica o seu On the Origin of Species by Means of Natural Selection com a sua teoria completa, sustentada por muitas evidências colhidas durante suas viagens a bordo do Beagle. Este trabalho influenciou muito o futuro não apenas da Biologia, Botânica e Zoologia, mas também teve grande influência sobre o pensamento religioso, filosófico, político e econômico da época. A teoria da evolução e a computação nasceram praticamente na mesma época: Charles Babbage, um dos fundadores da computação moderna e amigo pessoal de Darwin desenvolveu sua máquina analítica em Ambos provavelmente estariam surpresos e orgulhosos com a ligação entre estas duas áreas. Por volta de 1900, o trabalho de Gregor Mendel, desenvolvido em 1865, sobre os princípios básicos de herança genética, foi redescoberto pelos cientistas e teve grande influência sobre os futuros trabalhos relacionados à evolução. A moderna teoria da evolução combina a genética e as idéias de Darwin e Wallace sobre a seleção natural, criando o princípio básico de Genética Populacional: a variabilidade entre indivíduos em uma população de organismos que se reproduzem sexualmente é produzida pela mutação e pela recombinação genética. Este princípio foi desenvolvido durante os anos 30 e 40, por biólogos e matemáticos de importantes centros de pesquisa. Nos anos 50 e 60, muitos biólogos começaram a desenvolver simulações computacionais de sistemas genéticos. Entretanto, foi John Holland quem começou, seriamente, a desenvolver as primeiras pesquisas no tema. A idéia inicial de Holland foi tentar imitar algumas etapas do processo de evolução natural das espécies incorporando-as a um algoritmo computacional. Holland foi gradualmente refinando suas idéias e em 1975 publicou o seu livro Adaptation in Natural and Artificial Systems, hoje considerado a Bíblia de Algoritmos Genéticos. Desde então, estes algoritmos vêm sendo aplicados com sucesso nos mais diversos problemas de otimização e aprendizado de máquina. ( )
3 A Tradução Matemática: o algoritmo básico Um modelo simplificado do processo de seleção natural poderia ser expresso por: (i) as características (boas ou ruins) dos indivíduos estão registradas nos seus genes, de forma codificada; (ii) cada geração de indivíduos em uma população é formada pela combinação do material genético dos indivíduos da geração anterior; (iii) ocasionalmente, ocorrem mutações aleatórias no material genético de um indivíduo, que podem torná-lo mais ou menos apto a sobreviver em seu meio; (iv) os indivíduos mais aptos têm maior chance de sobreviverem e conseguirem passar seus genes para a próxima geração, ou seja, têm maior chance de se reproduzirem; (v) qualquer indivíduo - mais ou menos apto - tem a mesma probabilidade de sofrer mutação. Com inspiração nestas premissas simples, é possível formular algoritmos para efetuar a otimização de uma função objetivo arbitrária, os chamados Algoritmos Genéticos (AGs). Na analogia matemática, a aptidão está relacionada ao valor da função objetivo. Cada indivíduo corresponde a uma possível solução do problema de otimização e cada geração é uma iteração do algoritmo. Os AGs operam sobre um conjunto de possíveis soluções do problema, e não apenas uma (como métodos determinísticos ou o método de Recozimento Simulado, vistos nas aulas anteriores). Em cada iteração, operadores são aplicados aos indivíduos para simular os fenômenos de seleção natural, de geração de novos indivíduos pela reprodução sexuada e de mutação aleatória dos indivíduos. A figura ao lado mostra as principais etapas do algoritmo genético básico. A cada iteração do algoritmo as soluções mais promissoras do problema (os indivíduos mais aptos) têm maior probabilidade de serem selecionadas para gerarem novas soluções tentativa (descendentes). Em seguida, alguns indivíduos são selecionados aleatoriamente, independente de sua aptidão, para sofrerem uma mudança arbitrária (mutação). O valor da função objetivo é então calculado para cada elemento deste novo conjunto de soluções tentativa. Os métodos de seleção são projetados para escolher preferencialmente indivíduos com maiores notas de aptidão, embora não exclusivamente, a fim de manter a diversidade da população. Os passos 2 a 5 são continuamente repetidos até que um critério de parada seja satisfeito. Estes critérios são dependentes do problema, mas geralmente correspondem a ter sido encontrada
4 4 uma resposta suficientemente boa para o problema ou ter sido executado um certo número de iterações do algoritmo (gerações). Assim como a natureza caminha no sentido de maximizar a aptidão dos indivíduos, os algoritmos genéticos caminham no sentido de otimizar o valor da função objetivo. Estes algoritmos, apesar de serem computacionalmente muito simples, são bastante poderosos. Não há provas matemáticas rigorosas da convergência do algoritmo, mas as aplicações do algoritmo vêm crescendo nos últimos anos, principalmente devido às vantagens que este apresenta quando comparado a outros métodos de otimização. Podem-se destacar as seguintes: i) O algoritmo não requer o cálculo de derivadas da função objetivo; ii) Descontinuidades na função objetivo não afetam o desempenho do algoritmo; iii) A presença de mínimos locais não reduz a eficiência do algoritmo; iv) O algoritmo se aplica a problemas em que a função objetivo não pode ser representada por uma função matemática. Nas próximas seções, cada etapa dos Algoritmos Genéticos será detalhada Codificação dos Indivíduos Na natureza, todas as características do indivíduo, responsáveis por seu grau de aptidão, estão codificadas nos genes que constituem os cromossomos. Analogamente, os Algoritmos Genéticos otimizam o valor da função objetivo (o fenótipo da solução, a sua característica observável) atuando sobre a representação codificada dos genes dos indivíduos (o genótipo da solução). Assim, o primeiro passo ao se empregar um Algoritmo Genético é definir que codificação será empregada. Há várias maneiras de representar um indivíduo de forma codificada. Tradicionalmente, os indivíduos são representados por vetores binários, isto é, cada elemento do vetor pode ser preenchido de 2 maneiras apenas: 1 ou 0. Se há 2 maneiras de preencher um dígito, há 4 maneiras de preencher uma seqüência de 2 dígitos (00, 01, 10 e 11), 8 maneiras de preencher uma seqüência de 3 dígitos (000, 001, 010, 100, 011, 101, 110 e 111), etc... Generalizando, há 2 n maneiras de preencher uma seqüência de n dígitos. A grande vantagem desta representação é o fato de ela ser independente do problema. Uma vez encontrada a representação em vetores binários de um conjunto de indivíduos, os operadores genéticos padrão podem ser utilizados, o que facilita a utilização dos AGs em diferentes classes de problemas. Como um exemplo, analisemos o problema do caixeiro viajante que precisa passar pelas 4 capitais da Região Sudeste do Brasil. Será necessário empregar 2 dígitos na representação de cada cidade, pois este é o número mínimo de dígitos capaz de representar 4 diferentes números. Podemos representar um determinado roteiro através da concatenação dos códigos associados às cidades vi-
5 sitadas. Por exemplo, usando a associação mostrada na tabela abaixo, podemos codificar as rotas mostradas nos esquemas em seguida como seqüências de 8 dígitos. 5 CIDADE CÓDIGO Rio de Janeiro 00 São Paulo 01 Belo Horizonte 10 Vitória 11 Obviamente não existe sentido em codificar um problema do caixeiro viajante com 4 cidades, pois só há três possíveis rotas, mostradas abaixo. Mas, para o problema com 15 cidades, já há a necessidade de um método de otimização para auxiliar na tarefa de encontrar a melhor rota. Neste problema, são necessários 4 dígitos para codificar as cidades, e cada rota será identificada por uma seqüência de 15*4=60 dígitos. codificação codificação codificação Se uma variável real estiver sendo codificada, é necessário primeiro discretizar o domínio. Apenas como um exemplo imagine que uma das variáveis a otimizar em um problema seja uma fração molar. Esta variável encontra-se entre 0 e 1, e a depender da precisão requerida para representá-la, um número diferente de dígitos é necessário. Para representá-la com uma precisão de 0,1 já haverá 11 possíveis valores para esta variável, e serão necessários 4 dígitos para representá-la. Observe que serão ocupadas (associadas a um valor numérico da variável) apenas 11 das 16 possíveis seqüências binárias formadas com 4 dígitos. Isto significa que 5 seqüências de dígitos não estarão associadas a qualquer valor da variável x. Indivíduos que possuem uma destas codificações para representar a variável x são chamados de espúrios. A codificação binária, apesar de ser a mais tradicional e conferir generalidade aos operadores, não é a mais adequada para qualquer tipo de problema. Apenas para ilustrar, veja que há apenas 3 rotas possíveis no PCV com 4 cidades, mas é possível codificar 2 8 = 256 rotas com 8 dígitos!
6 6 Outras formas de codificação adaptadas a cada tipo de problema serão apresentadas na próxima aula e durante os exemplos Avaliação da Aptidão de um indivíduo Avaliar um indivíduo num AG significa determinar o seu nível de aptidão de sobrevivência. Ou seja, num AG sobrevivem prioritariamente os indivíduo mais aptos. Em problemas de otimização, o critério de sobrevivência é determinado pelo valor da função objetivo. A depender do problema, avaliar o valor da função objetivo pode envolver a avaliação de uma expressão algébrica, a resolução de um sistema algébrico não linear ou mesmo a integração de um conjunto de equações diferenciais. Qualquer que seja o procedimento numérico, nesta etapa é preciso decodificar a variável binária e avaliar a qualidade da solução representada. No problema do caixeiro viajante, o objetivo é minimizar o trajeto percorrido para visitar todas as cidades. Cada indivíduo corresponde a uma possível rota, e o valor da aptidão de um indivíduo é a distância percorrida nesta rota. Um outro detalhe importante para a implementação do método: é possível (e até bastante provável) que indivíduos espúrios sejam gerados ao longo da execução do algoritmo genético. A maneira mais tradicional de lidar com este problema é, no momento de avaliar a aptidão do indivíduo, detectar que ele não é válido e atribuir um valor muito ruim de aptidão. Assim, ele não conseguirá se reproduzir e estes genes defeituosos vão eventualmente ser eliminados da população pelo processo de seleção natural. Uma das muitas alterações feitas no algoritmo básico para torná-lo competitivo frente a outras técnicas de otimização foi adaptar os operadores para que estes indivíduos espúrios não sejam gerados. Desta forma reduz-se o custo computacional do algoritmo, já que apenas soluções válidas são consideradas. Estas particularidades serão discutidas com mais detalhe na próxima aula, onde os Algoritmos Genéticos modificados serão discutidos Operador Cruzamento O operador cruzamento consiste em gerar um ou dois cromossomos filhos a partir das informações dos dois cromossomos pais. Suponha que, por algum mecanismo, tenham sido escolhidos os dois cromossomos pais P1 e P2, representados abaixo como cadeias de 32 bits: P P
7 7 No operador mais clássico, chamado de operador cruzamento simples, inicialmente seleciona-se de forma aleatória uma posição, onde se efetua um corte entre dois genes adjacentes em cada cromossomo pai. No nosso exemplo, o corte foi feito entre o 12 o e o 13 o bit. É possível gerar até dois filhos (F1 e F2) pela concatenação dos cromossomos dos pais, mas não é incomum que apenas um destes filhos seja introduzido na nova população. O número de filhos por cruzamento (1 ou 2) é uma parâmetro a ser definido pelo usuário. P P F F Há um número infinito de variações deste algoritmo básico. Talvez a mais simples seja o cruzamento simples em múltiplos pontos, onde não um mais vários pontos de corte são determinados aleatoriamente. Abaixo está representado o cruzamento com 2 pontos de corte (7 o / 8 o bit e o 24 o / 25 o bit). P P F F Outra variação bastante freqüente é o chamado cruzamento uniforme, onde determina-se a percentagem de genes que vão ser trocados, procede-se o sorteio destes genes, e efetua-se a troca do material genético dos pais nestas posições. P P F F
8 8 No exemplo acima, um parâmetro do algoritmo seria 25% de substituição de genes no cruzamento. Para os dois pais selecionados, foram aleatoriamente sorteadas as posições de troca de material genético como 2, 3, 6, 12, 13, 14, 19 e 29. Observe que há 50% de chance de a troca de um gene não modificar o indivíduo (como por exemplo para os genes 2, 3 e 29). Em uma população real, nem todos os casais têm filhos ao mesmo tempo, e há a coexistência de indivíduos mais novos e mais velhos, possivelmente trocando material genético. Da mesma forma, nos Algoritmos Genéticos, nem todos os indivíduos passam pelo operador cruzamento em todas as iterações, e muitas vezes os indivíduos (especialmente os bons) são mantidos na população por várias gerações. O procedimento implementado em um Algoritmo Genético padrão é detalhado a seguir. Se há Nind indivíduos na população, e deseja-se obter 1 filho por cruzamento, são selecionados por um sorteio especial Nind pares de indivíduos. Este sorteio favorece os indivíduos mais aptos, mas não exclui a possibilidade de os menos aptos serem sorteados. Existe uma certa probabilidade p de o operador cruzamento ser aplicado, tipicamente da ordem de 70%. Para cada um dos pares formado, é sorteado um número aleatório r uniformemente distribuído no intervalo [0,1]. Se r p, então o operador cruzamento é aplicado a este casal, gerando um indivíduo na nova população. Se r>p então não haverá um filho, e um dos pais deverá ser introduzido na nova população. Após a avaliação dos Nind casais, Nind indivíduos (novos ou antigos) terão sido introduzidos na nova geração de indivíduos Operador Mutação O operador mutação altera aleatoriamente um ou mais bits de um cromossomo. Este operador é utilizado para permitir uma diversificação no processo de busca e introduzir diversidade. Há pesquisadores que defendem a tese de que este é o verdadeiro operador genético, o responsável por toda a evolução. Assim como o operador cruzamento, o operador mutação não é aplicado a todos os indivíduos. Existe uma probabilidade p (tipicamente da ordem de 5%) de o operador ser aplicado a um indivíduo. Para cada indivíduo da população, sorteia-se um número randômico r uniformemente distribuído no intervalo [0,1]. Se r p, então o operador mutação é aplicado a este indivíduo, gerando um indivíduo diferente na nova população. Se r>p então não haverá mutação, e o indivíduo é deixado inalterado. Observe que todos os indivíduos estão igualmente sujeitos a sofrer mutação. Para aplicar o operador mutação, normalmente sorteia-se aleatoriamente um bit, e este é alterado. No exemplo abaixo, o 11 o bit do indivíduo foi sorteado, e consequentemente foi alterado de 1 para
Algoritmos Genéticos. Princípio de Seleção Natural. Sub-áreas da Computação Evolutiva. Idéias básicas da CE. Computação Evolutiva
Computação Evolutiva Algoritmos Genéticos A computação evolutiva (CE) é uma área da ciência da computação que abrange modelos computacionais inspirados na Teoria da Evolução das Espécies, essencialmente
Inteligência Artificial. Algoritmos Genéticos. Aula I Introdução
Universidade Estadual do Oeste do Paraná Curso de Bacharelado em Ciência da Computação Inteligência Artificial Algoritmos Genéticos Aula I Introdução Roteiro Introdução Computação Evolutiva Algoritmos
Introdução aos Algoritmos Genéticos
Introdução aos Algoritmos Genéticos Prof. Matheus Giovanni Pires EXA 868 Inteligência Artificial Não-Simbólica B Universidade Estadual de Feira de Santana 2 Algoritmos Genéticos: Introdução Introduzidos
Algoritmos Genéticos. Estéfane G. M. de Lacerda DCA/UFRN Outubro/2008
Estéfane G. M. de Lacerda DCA/UFRN Outubro/2008 Introdução São técnicas de busca e otimização. É a metáfora da teoria da evolução das espécies iniciada pelo Fisiologista e Naturalista inglês Charles Darwin.
3. Resolução de problemas por meio de busca
Inteligência Artificial - IBM1024 3. Resolução de problemas por meio de busca Prof. Renato Tinós Local: Depto. de Computação e Matemática (FFCLRP/USP) 1 Principais Tópicos 3. Resolução de problemas por
Algoritmo Genético. Inteligência Artificial. Professor: Rosalvo Ferreira de Oliveira Neto
Algoritmo Genético Inteligência Artificial Professor: Rosalvo Ferreira de Oliveira Neto Estrutura 1. Introdução 2. Conceitos Básicos 3. Aplicações 4. Algoritmo 5. Exemplo Introdução São técnicas de busca
Técnicas de Inteligência Artificial
Universidade do Sul de Santa Catarina Ciência da Computação Técnicas de Inteligência Artificial Aula 9 Algoritmos Genéticos Max Pereira Algoritmos Genéticos Algoritmos Genéticos São técnicas de busca e
Algoritmos Genéticos. Pontos fracos dos métodos tradicionais. Características de alguns problemas. Tamanho do espaço de busca- Ex. caixeiro viajante:
Algoritmos Genéticos Prof. Luis Otavio Alvares INE/UFSC Características de alguns problemas Tamanho do espaço de busca- Ex. caixeiro viajante: 10 cidades: 181.000 soluções 20 cidades: 10.000.000.000.000
Técnicas de Inteligência Artificial
Universidade do Sul de Santa Catarina Ciência da Computação Técnicas de Inteligência Artificial Aula 9 Algoritmos Genéticos Max Pereira Algoritmos Genéticos São técnicas de busca e otimização. Uma metáfora
Introdução a Algoritmos Genéticos
Introdução a Algoritmos Genéticos Tiago da Conceição Mota Laboratório de Inteligência Computacional Núcleo de Computação Eletrônica Universidade Federal do Rio de Janeiro Outubro de 2007 O Que São? Busca
3 Algoritmos Genéticos
Técnicas de Inteligência Computacional 33 3 Algoritmos Genéticos Este capítulo resume os principais conceitos sobre o algoritmo evolucionário empregado nesta dissertação. É apresentada uma breve explicação
Algoritmos Genéticos
Universidade de São Paulo Instituto de Ciências Matemáticas e de Computação Algoritmos Genéticos Aluno: Fabricio Aparecido Breve Prof.: Dr. André Ponce de Leon F. de Carvalho São Carlos São Paulo Maio
Pós-Graduação em Engenharia de Automação Industrial SISTEMAS INTELIGENTES PARA AUTOMAÇÃO
Pós-Graduação em Engenharia de Automação Industrial SISTEMAS INTELIGENTES PARA AUTOMAÇÃO AULA 06 Algoritmos Genéticos Sumário Introdução Inteligência Artificial (IA) Algoritmos Genéticos Aplicações de
Algoritmos Genéticos
Algoritmos Genéticos Roteiro Introdução Algoritmos Genéticos Otimização Representação Seleção Operadores Genéticos Aplicação Caixeiro Viajante Introdução Algoritmos Genéticos (AGs), são métodos de otimização
Inteligência Artificial
Inteligência Artificial Aula 6 Algoritmos Genéticos M.e Guylerme Velasco Roteiro Introdução Otimização Algoritmos Genéticos Representação Seleção Operadores Geneticos Aplicação Caixeiro Viajante Introdução
Inteligência Artificial
Inteligência Artificial Prof. Kléber de Oliveira Andrade [email protected] Algoritmos Genéticos Conteúdo Introdução O Algoritmo Genético Binário Noções de Otimização O Algoritmo Genético com Parâmetros
1. Computação Evolutiva
Computação Bioinspirada - 5955010-1 1. Computação Evolutiva Prof. Renato Tinós Programa de Pós-Graduação Em Computação Aplicada Depto. de Computação e Matemática (FFCLRP/USP) 2 Computação Bioinspirada
Aprendizado Evolutivo: Introdução aos Algoritmos Genéticos
Aprendizado Evolutivo: Introdução aos Algoritmos Genéticos SCC-230 Inteligência Artificial Thiago A. S. Pardo Solange O. Rezende 1 Computação Evolutiva (CE) Trata de sistemas para a resolução de problemas
Computação Evolutiva Eduardo do Valle Simões Renato Tinós ICMC - USP
Computação Evolutiva Eduardo do Valle Simões Renato Tinós ICMC - USP 1 Principais Tópicos Introdução Evolução Natural Algoritmos Genéticos Aplicações Conclusão 2 Introdução http://www.formula-um.com/ Como
Computação Evolutiva. Computação Evolutiva. Principais Tópicos. Evolução natural. Introdução. Evolução natural
Computação Evolutiva Eduardo do Valle Simões Renato Tinós ICMC - USP Principais Tópicos Introdução Evolução Natural Algoritmos Genéticos Aplicações Conclusão 1 2 Introdução Evolução natural http://www.formula-um.com/
Proposta de Algoritmo Genético Seqüencial e Paralelo para o Problema da Mochila
Proposta de Algoritmo Genético Seqüencial e Paralelo para o Problema da Mochila Ricardo de Jesus Carvalho, Gustavo Andrade Lemos, Adenevaldo da Silva Machado Junior, Lairton Reis, Wilton Oliveira Ferreira,
Algoritmos Genéticos
Algoritmos Genéticos Introdução Um Algoritmo Genético (AG), conceitualmente, segue passos inspirados no processo biológico de evolução natural segundo a teoria de Darwin Algoritmos Genéticos seguem a idéia
ALGORITMOS GENÉTICOS. Adair Santa Catarina Curso de Ciência da Computação Unioeste Campus de Cascavel PR
ALGORITMOS GENÉTICOS Adair Santa Catarina Curso de Ciência da Computação Unioeste Campus de Cascavel PR Fev/2018 Introdução Algoritmos Genéticos são algoritmos heurísticos de busca, que utilizam regras
Codificação das variáveis: binária Iniciação da população: aleatória Avaliação: função aptidão Operadores. Critério de parada: número de gerações
AG Simples/Canônico (AGS) AG introduzido por Holland Funciona bem para problemas de otimização simples e/ou de pequenas dimensões A maior parte da teoria dos AGs está baseada no AGS Utilidade didática
Algoritmos genéticos Abordagem unificada de algoritmos evolutivos simples
Introdução Inspiração biológica Histórico da computação evolutiva Algoritmo evolutivo simples Programação evolutiva Estratégias evolutivas Algoritmos genéticos Abordagem unificada de algoritmos evolutivos
3 Algoritmos Genéticos
Algoritmos Genéticos Algoritmos Genéticos (AGs) constituem um mecanismo de busca adaptativa que se baseia no princípio Darwiniano de seleção natural e reprodução genética [101]. AGs são tipicamente empregados
Metahuerísticas: Algoritmos Genéticos. Sistemas de Informação/Ciências da Computação UNISUL Aran Bey Tcholakian Morales, Dr. Eng.
Metahuerísticas: Algoritmos Genéticos Sistemas de Informação/Ciências da Computação UNISUL Aran Bey Tcholakian Morales, Dr. Eng. (Apostila 8) Meta-heurísticas Classificação de métodos heurísticos: os métodos
Computação Evolutiva. Prof. Eduardo R. Hruschka (Slides baseados nos originais do Prof. André C. P. L. F. de Carvalho)
Computação Evolutiva Prof. Eduardo R. Hruschka (Slides baseados nos originais do Prof. André C. P. L. F. de Carvalho) Principais Tópicos Computação Evolutiva Algoritmos Genéticos Codificação Função de
Algoritmos Genéticos. 1 Semestre de Cleber Zanchettin UFPE - Universidade Federal de Pernambuco CIn - Centro de Informática
Algoritmos Genéticos 1 Semestre de 2015 Cleber Zanchettin UFPE - Universidade Federal de Pernambuco CIn - Centro de Informática 1 2 Introdução Darwin Naturalistas: cada espécie havia sido criada separadamente
Exemplo de Aplicação de Algoritmos Genéticos. Prof. Juan Moisés Mauricio Villanueva cear.ufpb.br/juan
Exemplo de Aplicação de Algoritmos Genéticos Prof. Juan Moisés Mauricio Villanueva [email protected] cear.ufpb.br/juan Estrutura do Algoritmo Genético Algoritmo genético Inicio t = 0 inicializar P(t)
Otimização. Unidade 6: Algoritmo Genético. Jaime Arturo Ramírez. 7. Teoria do processo evolutivo num GA. 8. Aspectos avançados
Otimização Jaime Arturo Ramírez Conteúdo 1. Introdução 2. Analogia de mecanismos de seleção natural com sistemas artificiais 3. Algoritmo genético modelo 4. Um GA simples 5. Representação, genes e cromossomos
Métodos de Busca. Inteligência Artificial. Algoritmos Genéticos. Algoritmos Evolucionários. Prof. Ms. Luiz Alberto Contato:
Inteligência Artificial Prof. Ms. Luiz Alberto Contato: [email protected] Métodos de Busca Busca Cega ou Exaustiva: Não sabe qual o melhor nó da fronteira a ser expandido. Apenas distingue o estado objetivo
Algoritmos Genéticos. Texto base: Stuart Russel e Peter Norving - Inteligência Artificial
Algoritmos Genéticos Texto base: Stuart Russel e Peter Norving - Inteligência Artificial junho/2007 Algoritmo Genético Uma variante da busca em feixe estocástica Estado sucessor gerado pela combinação
Modelos Evolucionários e Tratamento de Incertezas
Ciência da Computação Modelos Evolucionários e Tratamento de Incertezas Aula 01 Computação Evolucionária Max Pereira Motivação Se há uma multiplicidade impressionante de algoritmos para solução de problemas,
Sistemas Inteligentes if684. Germano Vasconcelos Página da Disciplina:
Sistemas Inteligentes if684 Germano Vasconcelos [email protected] Página da Disciplina: www.cin.ufpe.br/~îf684/ec 1 1 Algoritmos Genéticos 2 Algoritmos Genéticos n Técnicas de busca e otimização n Metáfora
OTIMIZAÇÃO FUNÇÕES UTILIZANDO ALGORITMOS GENÉTICOS NO APLICATIVO MS EXCEL RESUMO INTRODUÇÃO
OTIMIZAÇÃO FUNÇÕES UTILIZANDO ALGORITMOS GENÉTICOS NO APLICATIVO MS EXCEL Miquéias Augusto Ferreira Nantes 1, Douglas Peixoto de Carvalho 1 (Alunos do Curso de Matemática da Universidade Anhanguera - Uniderp)
GT-JeDi - Curso de Desenv. de Jogos IA para Jogos. Gustavo Pessin 2007
GT-JeDi - Curso de Desenv. de Jogos IA para Jogos Gustavo Pessin 2007 Cronograma Base conceitual Exemplo: Achando o máximo de uma função... Como criar uma pequena aplicação: Exercício-Exemplo [Animal selvagem...]
Agentes Adaptativos. Introdução
Agentes Adaptativos Capítulo 6: Costa, E. e Simões, A. (2015). Inteligência Artificial Fundamentos e Aplicações, 3.ª edição, FCA. AGENTES ADAPTATIVOS 1 Introdução Os seres vivos que não se adaptam ao seu
Introdução ao Algoritmo Genético
Introdução ao Algoritmo Genético Sadao Massago Agosto de 2013 1 Introdução O algoritmo genético é um método de otimização bio insperado, desenvolvida por John Henry Holland em 1975. Segundo a teoria evolucionária
4 Implementação Computacional
4 Implementação Computacional 4.1. Introdução Neste capítulo é apresentada a formulação matemática do problema de otimização da disposição das linhas de ancoragem para minimizar os deslocamentos (offsets)
APLICAÇÃO DE ALGORITMOS BIO-INSPIRADOS EM CONTROLE ÓTIMO
APLICAÇÃO DE ALGORITMOS BIO-INSPIRADOS EM CONTROLE ÓTIMO Profa. Mariana Cavalca Baseado em: Material didático do Prof. Dr. Carlos Henrique V. Moraes da UNIFEI Curso de verão da Profa. Gisele L. Pappa Material
3 Otimização Evolucionária de Problemas com Restrição
3 Otimização Evolucionária de Problemas com Restrição 3.1. Introdução Este capítulo resume os principais conceitos sobre os algoritmos evolucionários empregados nesta dissertação. Primeiramente, se fornece
Implementação De Um Algoritmo Genético Codificado Para A Solução do Problema do Caixeiro Viajante
Implementação De Um Algoritmo Genético Codificado Para A Solução do Problema do Caixeiro Viajante 1 Resumo Neste trabalho será realizada a codificação do algoritmo genético para a solução do problema do
4 Métodos Existentes. 4.1 Algoritmo Genético
61 4 Métodos Existentes A hibridização de diferentes métodos é em geral utilizada para resolver problemas de escalonamento, por fornecer empiricamente maior eficiência na busca de soluções. Ela pode ser
Algoritmos Genéticos 1
Algoritmos Genéticos 1 Esquema de um GA Algoritmos Genéticos são um ramo da computação evolucionária Seu funcionamento pode ser resumido algoritimicamente através dos seguintes passos: Inicialize a população
Neodarwinismo ou Teoria sintética de evolução
Neodarwinismo ou Teoria sintética de evolução O desenvolvimento dos conhecimentos de genética e as novas descobertas sobre hereditariedade, permitiram fazer uma nova interpretação da teoria da evolução
IDÉIAS EVOLUCIONISTAS DE DARWIN
IDÉIAS EVOLUCIONISTAS DE DARWIN A história entre Darwin (1809-1882) e a biologia começou quando o mesmo foi convidado a embarcar numa expedição de estudo promovida pela Inglaterra. Então, com 22 anos de
Estratégias Evolutivas EEs. Prof. Juan Moisés Mauricio Villanueva
Estratégias Evolutivas EEs Prof. Juan Moisés Mauricio Villanueva [email protected] www.cear.ufpb.br/juan Estratégias Evolutivas Desenvolvidas por Rechenberg e Schwefel, e estendida por Herdy, Kursawe
O USO DE ALGORITMOS GENÉTICOS PARA DETERMINAR ZEROS DE FUNÇÕES NÃO LINEARES
O USO DE ALGORITMOS GENÉTICOS PARA DETERMINAR ZEROS DE FUNÇÕES NÃO LINEARES RESUMO Ediany Batista Silva Universidade Católica de Brasília Curso de Matemática Os algoritmos genéticos utilizam conceitos
GA Conceitos Básicos. Capítulo 3 Prof. Ricardo Linden
GA Conceitos Básicos Capítulo 3 Prof. Ricardo Linden Algoritmos Evolucionários Algoritmos evolucionários usam modelos computacionais dos processos naturais de evolução como uma ferramenta para resolver
C o m p u t a ç ã o M ó v e l. André Siqueira Ruela
C o m p u t a ç ã o M ó v e l André Siqueira Ruela Sumário Revisão sobre AGs. Codificação de uma Rede Neural. AG em treinamento supervisionado. AG em treinamento não supervisionado. Revisão: Algoritmos
Teorias evolucionistas
Teorias evolucionistas A vida em evolução Se o problema da origem da vida não tem resposta definitiva, há muitos estudos tentando resolver outra questão levantada pela biogênese: se todo ser vivo se origina
Otimização com Algoritmos Genéticos no MATLAB. Prof. Rafael Saraiva Campos CEFET-RJ
Otimização com Algoritmos Genéticos no MATLAB Prof. Rafael Saraiva Campos CEFET-RJ Conteúdo do Mini-Curso PARTE 1 Teoria PARTE 2 Prática Conteúdo do Mini-Curso PARTE 1 Teoria 1.1. Conceitos Básicos de
11/1/2012. Agenda. Classe de problemas de interesse. Busca Local. Busca Local. Exemplo de Espaço de Estados
Agenda PCS / PCS 09 Inteligência Artificial Prof. Dr. Jaime Simão Sichman Profa. Dra. Anna Helena Reali Costa Busca Local e Problemas de Otimização. Introdução. Busca Local I. Subida da Encosta (Hill-Climbing)
INTRODUÇÃO À INTELIGÊNCIA COMPUTACIONAL. Aula 06 Prof. Vitor Hugo Ferreira
Universidade Federal Fluminense Escola de Engenharia Departamento de Engenharia Elétrica INTRODUÇÃO À INTELIGÊNCIA COMPUTACIONAL Aula 06 Prof. Vitor Hugo Ferreira Representação por cromossomos Codificação
Algoritmos Genéticos. Luis Martí LIRA/DEE/PUC-Rio. Algoritmos Genéticos
Luis Martí LIRA/DEE/PUC-Rio Baseado nas transparências dos professores: Teresa B. Ludermir (UFPE) Ricardo Linden (CEPEL) Marco Aurélio Pacheco (PUC-Rio) Conteúdo! Introdução! O Algoritmo Genético Binário!
Inteligência Computacional Aplicada. O que é Inteligência Computacional? Áreas de Aplicação Algoritmos Genéticos
Inteligência Computacional Aplicada Resumo O que é Inteligência Computacional? Áreas de Aplicação Algoritmos Genéticos O que é Inteligência Computacional? Técnicas e sistemas computacionais que imitam
Pesquisa Operacional Aplicada à Mineração
Pesquisa Operacional Aplicada à Mineração Módulo de Otimização Parte II-b Prof. Marcone J. F. Souza Prof. Túlio A. M. Toffolo [email protected] [email protected] Departamento de Computação
Otimização. Algoritmos Genéticos. Teoria da Evolução. Otimização
Algoritmos Genéticos Otimização São técnicas de busca e otimização. É a metáfora da teoria da evolução das espécies iniciada pelo Fisiologista e Naturalista inglês Charles Darwin. Desenvolvido por John
4 Metáforas de Optimização
4 Metáforas de Optimização O gigantesco avanço tecnológico que vem sofrendo os sistemas de computação, mais precisamente as unidades de processamento, criou a base para o uso efetivo da Inteligência Computacional,
UMA INTRODUÇÃO AOS ALGORITMOS GENETICOS
UMA INTRODUÇÃO AOS ALGORITMOS GENETICOS Uma visão geral dos GAs Um algoritmo genético é uma classe de algoritmo de busca. O algoritmo procura uma solução dentro de um espaço para um problema de otimização.
Estatística e Modelos Probabilísticos - COE241
Estatística e Modelos Probabilísticos - COE241 Aula passada Análise da dados através de gráficos Introdução a Simulação Aula de hoje Introdução à simulação Geração de números aleatórios Lei dos Grandes
Problema de Satisfação de Restrições. Problema de Satisfação de Restrições. Grafo de restrições. Exemplo: 4 Rainhas como um PSR
Problema de Satisfação de Restrições Problema de Satisfação de Restrições Exemplos de PSR (CSP, Constraint Satisfaction Problem) Busca genérica aplicada a PSRs Backtracking Verificação forward Heurísticas
