mytionbr / FlappIA-Bird

Rede Neural aplicada ao jogo Flappy Bird!

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

FlappIA Bird

Projeto onde várias Redes Neurais competem para aprender a jogar o jogo Flappy Bird.

Preview-Screens

Sobre o Projeto

A ideia consiste em utilizar uma "seleção artificial" para evoluir os pesos de várias redes neurais, com o propósito de encontrar a melhor combinação e assim obter o melhor comportamento para o personagem.

O jogo foi recriado do zero(sem engines) utilizando a biblioteca gráfica Programming Interface Gaming (PIG) que por sua vez é baseada na tradicional Simple DirectMedia Layer (SDL).

A Rede Neural Artificial utilizada foi uma Perceptron Multilayer com 3 camadas!

  • Camada de Entrada com 4 sensores(Distância horizontal, Distância vertical, Velocidade do cano, Abertura dos canos) + 1 Viés, totalizando 5 Neurônios.

  • Camada Escondida com 6 neurônios + 1 Viés, totalizando 7 Neurônios

  • Camada de Saída com 2 neurônios (Pular, Paraquedas)

  • A função de ativação utilizada em todos os neurônios foi a ReLU.

  • O método de aprendizagem é comumente chamado de "Random Mutations".

  • O tamanho da população que utilizei foi de 2000 indivíduos

  • O tempo de aprendizagem variou entre 0 ~ 30 minutos por modo de Jogo.

    Para mais informações e explicações acesse o vídeo demonstrativo.

Por quê?

Desenvolvi esse projeto por curiosidade e diversão :)

Para mais projetos como esse visite o canal.

Observações:

  • O arquivo 'redeNeural.c' contém todas as funções relativas a implementação da Rede Neural (tudo sobre a rede neural está nesse arquivo). Ele está genérico, ou seja, você pode baixar o arquivo e incluir no seu projeto e você conseguirá usar a rede neural facilmente.

    Exemplo:

    RedeNeural* Passaro = RNA_CriarRedeNeural(1,2,3,4);
    

    Nesse exemplo nós estamos criando uma variável chamada 'Passaro' que vai receber a Rede Neural que foi alocada dentro da função RNA_CriarRedeNeural()... Não esqueça de destrui-la após usar, utilizando a função:

    RNA_DestruirRedeNeural(Passaro);
    
  • A função 'ControlarEstadoPassaros' dentro do arquivo 'main.cpp' contém o código que faz a comunicação entre o jogo e a rede neural.

  • O resto dos arquivos são apenas os códigos da implementação do jogo.

Os arquivos "Flappy Bird Treinando.zip" e "Flappy Bird x1.zip" contém o executável para Windows :)

Um grande abraço!

About

Rede Neural aplicada ao jogo Flappy Bird!


Languages

Language:C 80.3%Language:C++ 17.7%Language:Objective-C 2.0%