2010bEquipe07 Monografia

De Wiki DAINF
(Diferença entre revisões)
(Inclusão da primeira parte da monografia convertida para wiki)
 
(3 edições intermediárias de um usuário não apresentadas)
Linha 1: Linha 1:
 
[[2010bEquipe07]]
 
[[2010bEquipe07]]
  
A primeira versão para a monografia foi finalizada e entregue aos professores da disciplina. Abaixo os links para as versões PDF e LATEX:
+
*NESTA VERSÃO ONLINE FORAM RETIRADAS AS FIGURAS. PARA A VERSÃO COMPLETA LEIA O [http://dl.dropbox.com/u/12362738/monografia_final.pdf PDF].
  
[http://dl.dropbox.com/u/12362738/monografia_final.tex http://dl.dropbox.com/u/12362738/monografia_final.tex]
+
*A primeira versão para a monografia foi finalizada e entregue aos professores da disciplina. Estão disponíveis as versões em [http://dl.dropbox.com/u/12362738/monografia_final.pdf PDF] e [http://dl.dropbox.com/u/12362738/monografia_final.tex LATEX].
  
[http://dl.dropbox.com/u/12362738/monografia_final.pdf http://dl.dropbox.com/u/12362738/monografia_final.pdf]
 
  
 
=Resumo=
 
=Resumo=
Linha 45: Linha 44:
 
==Delimitação do Tema==
 
==Delimitação do Tema==
  
:Softwares simuladores são fortes aliados no avanço da tecnologia. Simular fenômenos da natureza, comportamentos e situações reais sempre foram desafios ao ser humano[[SmartSimSelector]]. Simulações robóticas cada vez mais vêm sendo utilizadas para proporcionar agilidade a eventos experimentais[[JAI2009]].
+
:Softwares simuladores são fortes aliados no avanço da tecnologia. Simular fenômenos da natureza, comportamentos e situações reais sempre foram desafios ao ser humano[http://simvehic.com/admin/rpapers/Smart%20Sim%20Selector.pdf]. Simulações robóticas cada vez mais vêm sendo utilizadas para proporcionar agilidade a eventos experimentais[http://osorio.wait4.org/palestras/JAI2009-Denis.pdf].
  
:O futebol de robôs é uma iniciativa que propõe o desenvolvimento de tecnologia robótica tendo o futebol como motivação[[Kitano]].
+
:O futebol de robôs é uma iniciativa que propõe o desenvolvimento de tecnologia robótica tendo o futebol como motivação[http://www.sonycsl.co.jp/person/kitano/RoboCup/RoboCup-Agent97.ps].
O simulador de futebol de robôs, em especial, é muito usado por professores de cursos de graduação e em testes de algoritmos inteligentes e o tema deste projeto gira em torno dele[[Beard]].
+
O simulador de futebol de robôs, em especial, é muito usado por professores de cursos de graduação e em testes de algoritmos inteligentes e o tema deste projeto gira em torno dele[http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.57.8397&rep=rep1&type=ps].
  
:De maneira genérica o tema a ser tratado é o aperfeiçoamento do software Tewnta[[SiteTewnta]], que é um simulador do futebol de robôs da categoria F-180 da Robocup[[sslrules]].
+
:De maneira genérica o tema a ser tratado é o aperfeiçoamento do software Tewnta[http://code.google.com/p/tewnta/], que é um simulador do futebol de robôs da categoria F-180 da Robocup[http://small-size.informatik.uni-bremen.de/_media/rules:ssl-rules-2010.pdf].
  
 
:Considerando-se particularidades dos modelos matemáticos do robô e da bola, procura-se ajustar o programa para operar de forma mais fidedigna segundo as características de um robô, campo e bola reais disponíveis na UTFPR, ou seja, torná-lo o mais próximo possível da realidade.
 
:Considerando-se particularidades dos modelos matemáticos do robô e da bola, procura-se ajustar o programa para operar de forma mais fidedigna segundo as características de um robô, campo e bola reais disponíveis na UTFPR, ou seja, torná-lo o mais próximo possível da realidade.
Linha 56: Linha 55:
 
==Problema==
 
==Problema==
  
:A dificuldade em reproduzir a realidade é o principal desafio dos desenvolvedores de softwares simuladores. Muitas vezes o problema não é implementar as constantes físicas no programa, mas como calculá-las[[Beard]].
+
:A dificuldade em reproduzir a realidade é o principal desafio dos desenvolvedores de softwares simuladores. Muitas vezes o problema não é implementar as constantes físicas no programa, mas como calculá-las[http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.57.8397&rep=rep1&type=ps].
  
:Softwares simuladores de Futebol de Robôs, de maneira geral, desconsideram detalhes específicos dos robôs e do ambiente presentes numa partida real. Dessa forma, algoritmos tidos como bons em um simulador, podem não obter o mesmo sucesso em um ambiente real[[Beard]].
+
:Softwares simuladores de Futebol de Robôs, de maneira geral, desconsideram detalhes específicos dos robôs e do ambiente presentes numa partida real. Dessa forma, algoritmos tidos como bons em um simulador, podem não obter o mesmo sucesso em um ambiente real[http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.57.8397&rep=rep1&type=ps].
  
 
:Os principais problemas enfrentados para a realização desse projeto estão relacionados à determinação e interpretação de constantes e eventos físicos através de um método experimental válido. Outro problema seria a criação de uma interface em que o usuário pudesse transferir esses dados ao software, e esses dados serem interepretados de maneira correta pelo algoritmo.
 
:Os principais problemas enfrentados para a realização desse projeto estão relacionados à determinação e interpretação de constantes e eventos físicos através de um método experimental válido. Outro problema seria a criação de uma interface em que o usuário pudesse transferir esses dados ao software, e esses dados serem interepretados de maneira correta pelo algoritmo.
Linha 64: Linha 63:
 
==Justificativa==
 
==Justificativa==
  
:Aperfeiçoar um simulador de entes robóticos, independentes de quais sejam, é uma tarefa de grande importância científica e tecnológica. Simular é um desafio enorme, pois envolve a abstração e posterior construção de um modelo elaborado de um evento real. Através das simulações pode-se representar processos reais mais rápida ou lentamente (de acordo com a necessidade específica de cada caso) para obtenção de informações de maneira mais prática do que através de experimentos reais[[SmartSimSelector]].
+
:Aperfeiçoar um simulador de entes robóticos, independentes de quais sejam, é uma tarefa de grande importância científica e tecnológica. Simular é um desafio enorme, pois envolve a abstração e posterior construção de um modelo elaborado de um evento real. Através das simulações pode-se representar processos reais mais rápida ou lentamente (de acordo com a necessidade específica de cada caso) para obtenção de informações de maneira mais prática do que através de experimentos reais[http://simvehic.com/admin/rpapers/Smart%20Sim%20Selector.pdf].
  
 
:A decisão de colaborar com a melhoria do simulador de futebol de robôs baseia-se na possibilidade de, além de exercer contribuições científicas e tecnológicas de forma geral, cooperar com as atividades da UTFPR, visto que esse software é utilizado na disciplina de Sistemas Inteligentes, do Departamento Acadêmico de Informática. Esse trabalho também poderia auxiliar os treinamentos da equipe de futebol de robôs da UTFPR, possibilitando melhores resultados nas participações da RoboCup, já que quanto mais próximo for o comportamento simulado dos robôs, mais adequado será o simulador para desenvolver estratégias de controle dos robôs.
 
:A decisão de colaborar com a melhoria do simulador de futebol de robôs baseia-se na possibilidade de, além de exercer contribuições científicas e tecnológicas de forma geral, cooperar com as atividades da UTFPR, visto que esse software é utilizado na disciplina de Sistemas Inteligentes, do Departamento Acadêmico de Informática. Esse trabalho também poderia auxiliar os treinamentos da equipe de futebol de robôs da UTFPR, possibilitando melhores resultados nas participações da RoboCup, já que quanto mais próximo for o comportamento simulado dos robôs, mais adequado será o simulador para desenvolver estratégias de controle dos robôs.
Linha 90: Linha 89:
 
==História==
 
==História==
  
:A ideia de robôs competindo numa partida de futebol vem de longa data. No ano de 1992 [[RoboCup1]] este assunto foi comentado pela primeira vez no artigo ''On Seeing Robots''  do Professor Alan Mackworth (''University of British Columbia'' , Canadá), publicado no ano seguinte no livro ''Computer Vision: System, Theory, and Applications'' , páginas 1-13, ''World Scientific Press'' , Singapura, 1993.
+
:A ideia de robôs competindo numa partida de futebol vem de longa data. No ano de 1992 [http://www.robocup.org/about-robocup/a-brief-history-of-robocup] este assunto foi comentado pela primeira vez no artigo ''On Seeing Robots''  do Professor Alan Mackworth (''University of British Columbia'' , Canadá), publicado no ano seguinte no livro ''Computer Vision: System, Theory, and Applications'' , páginas 1-13, ''World Scientific Press'' , Singapura, 1993.
  
:Em Outubro de 1992 em Tóquio [[RoboCup1]], um grupo de pesquisadores japoneses organizou um workshop sobre Grandes desafios em Inteligência Artificial. Durante este evento as discussões guiaram as atenções para o uso de jogos como forma de promover tecnologia e ciência. Em 1993, idealizada por Minoru Asada, Yasuo Kuniyoshi, e Hiroaki Kitano, teve início a primeira competição de futebol de robôs [[RoboCup1]].  
+
:Em Outubro de 1992 em Tóquio [http://www.robocup.org/about-robocup/a-brief-history-of-robocup], um grupo de pesquisadores japoneses organizou um workshop sobre Grandes desafios em Inteligência Artificial. Durante este evento as discussões guiaram as atenções para o uso de jogos como forma de promover tecnologia e ciência. Em 1993, idealizada por Minoru Asada, Yasuo Kuniyoshi, e Hiroaki Kitano, teve início a primeira competição de futebol de robôs [http://www.robocup.org/about-robocup/a-brief-history-of-robocup/].  
  
 
:Inicialmente chamada de ''Robot J-League'' , este evento imediatamente chamou a atenção de pesquisadores do mundo todo que propuseram estender esta iniciativa a um projeto colaborativo internacional. Assim, o evento foi renomeado para ''Robot World Cup Initiative'', também conhecido como RoboCup. No mesmo ano foi feito o primeiro anúncio público sobre esta iniciativa, definidas as primeiras regras e lançada a primeira versão do ''Soccer Server Version 0'' , primeiro simulador aberto que permitiu o desenvolvimento de pesquisas  com sistemas multi-agentes, construído em linguagem LISP, seguido pela versão 1.0 construída em C++.
 
:Inicialmente chamada de ''Robot J-League'' , este evento imediatamente chamou a atenção de pesquisadores do mundo todo que propuseram estender esta iniciativa a um projeto colaborativo internacional. Assim, o evento foi renomeado para ''Robot World Cup Initiative'', também conhecido como RoboCup. No mesmo ano foi feito o primeiro anúncio público sobre esta iniciativa, definidas as primeiras regras e lançada a primeira versão do ''Soccer Server Version 0'' , primeiro simulador aberto que permitiu o desenvolvimento de pesquisas  com sistemas multi-agentes, construído em linguagem LISP, seguido pela versão 1.0 construída em C++.
Linha 105: Linha 104:
 
:O principal foco da RoboCup é promover pesquisas em robótica e inteligência artificial de uma maneira mais amigável e com certo apelo publicitário. Por entender que estabelecer metas é uma maneira eficaz de desenvolver estas pesquisas, é tido como objetivo à longo prazo:
 
:O principal foco da RoboCup é promover pesquisas em robótica e inteligência artificial de uma maneira mais amigável e com certo apelo publicitário. Por entender que estabelecer metas é uma maneira eficaz de desenvolver estas pesquisas, é tido como objetivo à longo prazo:
  
:<cite>“By mid-21st century, a team of fully autonomous humanoid robot soccer players shall win the soccer game, comply with the official rule of the FIFA, against the winner of the most recent World Cup.”[[RoboCup2]]</cite>
+
:<cite>“By mid-21st century, a team of fully autonomous humanoid robot soccer players shall win the soccer game, comply with the official rule of the FIFA, against the winner of the most recent World Cup.”[http://www.robocup.org/about-robocup/objective/]</cite>
  
 
==As Modalidades da RoboCup==
 
==As Modalidades da RoboCup==
  
:A RoboCup é um tipo de problema padrão que permite que várias teorias, algoritmos e arquiteturas sejam testadas, combinando as complexidades do mundo real dentro de um mundo limitado. Diversas áreas de pesquisa sobre Inteligência Artificial (IA) e robótica [[Kitano]], tais como sensores de tempo real, comportamento reativo, sistemas multi-agentes, reconhecimento de contexto, visão e controle de robôs inteligentes, entre outras, estão envolvidas e para isso existem várias modalidades de campeonato, cada uma com suas particularidades e regulamentação própria. São elas:
+
:A RoboCup é um tipo de problema padrão que permite que várias teorias, algoritmos e arquiteturas sejam testadas, combinando as complexidades do mundo real dentro de um mundo limitado. Diversas áreas de pesquisa sobre Inteligência Artificial (IA) e robótica [http://www.sonycsl.co.jp/person/kitano/RoboCup/RoboCup-Agent97.ps], tais como sensores de tempo real, comportamento reativo, sistemas multi-agentes, reconhecimento de contexto, visão e controle de robôs inteligentes, entre outras, estão envolvidas e para isso existem várias modalidades de campeonato, cada uma com suas particularidades e regulamentação própria. São elas:
  
 
===RoboCup Rescue===
 
===RoboCup Rescue===
  
 
:A robocup rescue é dividida em  duas categorias principais: a ''RoboCup Simulation Project''  e a ''Real Robots Project'' ;  
 
:A robocup rescue é dividida em  duas categorias principais: a ''RoboCup Simulation Project''  e a ''Real Robots Project'' ;  
que atuam como um padrão para pesquisadores na área de desastres[[Rescue]].
+
que atuam como um padrão para pesquisadores na área de desastres[http://www.robocuprescue.org/].
  
:Tem como objetivo principal realizar pesquisa e desenvolvimento envolvendo agentes diversos em áreas hostis em vários níveis de interação[[Rescueoficial]]. Coordenação de equipes de trabalho multi-agentes, busca e salvamento, agentes robóticos físicos e estratégias de salvamento, são alguns exemplos das pesquisas realizadas. Esta competição que segue os moldes da ''RoboCup Soccer''  e provome fóruns técnicos e testes competitivos para pesquisadores e praticantes, foi idealizada após o terremoto Hanshi-Awaji que atingiu a cidade de Kobe no Japão em 1995 [[Rescue]].
+
:Tem como objetivo principal realizar pesquisa e desenvolvimento envolvendo agentes diversos em áreas hostis em vários níveis de interação[http://www.rescuesystem.org/robocuprescue/]. Coordenação de equipes de trabalho multi-agentes, busca e salvamento, agentes robóticos físicos e estratégias de salvamento, são alguns exemplos das pesquisas realizadas. Esta competição que segue os moldes da ''RoboCup Soccer''  e provome fóruns técnicos e testes competitivos para pesquisadores e praticantes, foi idealizada após o terremoto Hanshi-Awaji que atingiu a cidade de Kobe no Japão em 1995 [http://www.robocuprescue.org/].
  
 
===RoboCup @Home===
 
===RoboCup @Home===
  
:Considerada a maior competição internacional anual de robôs autônomos [[AtHome]] a Robocup @Home teve início em 2006 e está voltada para o ambiente humano diário [[AtHome2]]. Esta modalidade tem como objetivo principal desenvolver tecnologias para robôs assistenciais para aplicações domésticas.
+
:Considerada a maior competição internacional anual de robôs autônomos [http://www.ai.rug.nl/robocupathome/documents/rulebook2010_FINAL_VERSION.pdf] a Robocup @Home teve início em 2006 e está voltada para o ambiente humano diário [[AtHome2]]. Esta modalidade tem como objetivo principal desenvolver tecnologias para robôs assistenciais para aplicações domésticas.
  
:A competição testa a habilidade dos robôs em ambientes domésticos desconhecidos [[AtHome3]] em quesitos que envolvem entre outras coisas:
+
:A competição testa a habilidade dos robôs em ambientes domésticos desconhecidos [http://www.ai.rug.nl/robocupathome/index.php] em quesitos que envolvem entre outras coisas:
 
      
 
      
 
:*interação cooperativa entre humanos e robôs;     
 
:*interação cooperativa entre humanos e robôs;     
Linha 133: Linha 132:
 
===RoboCup Soccer===
 
===RoboCup Soccer===
  
:As competições de futebol são a principal atividade da RoboCup [[Soccer]] e permitem que os pesquisadores troquem informações técnicas sobre robótica e inteligência artificial. Esta modalidade envolve as ligas ''Humanoid'' , ''Middle Size Robot'' , ''Simulation'' , ''Standard Plataform'' e a ''Small Size Robot'', também conhecida como SSL, a qual é a base de estudo deste trabalho.
+
:As competições de futebol são a principal atividade da RoboCup [http://www.robocup.org/robocup-soccer/] e permitem que os pesquisadores troquem informações técnicas sobre robótica e inteligência artificial. Esta modalidade envolve as ligas ''Humanoid'' , ''Middle Size Robot'' , ''Simulation'' , ''Standard Plataform'' e a ''Small Size Robot'', também conhecida como SSL, a qual é a base de estudo deste trabalho.
 
 
 
====Humanoid League====
 
====Humanoid League====
  
:Nesta liga, robôs autônomos bípides com corpo e sentidos parecidos com humanos, competem entre si [[Humanoid]]. Eles devem ter a habilidade de correr, andar e chutar a bola ao mesmo tempo em que mantém o equilíbrio e percebem a posição da bola e dos outros jogadores no campo, além de reconhecerem sua própria posição. A ''Humanoid League''  é divida em três subgrupos:
+
:Nesta liga, robôs autônomos bípides com corpo e sentidos parecidos com humanos, competem entre si [http://www.tzi.de/humanoid/bin/view/Website/WebHome]. Eles devem ter a habilidade de correr, andar e chutar a bola ao mesmo tempo em que mantém o equilíbrio e percebem a posição da bola e dos outros jogadores no campo, além de reconhecerem sua própria posição. A ''Humanoid League''  é divida em três subgrupos:
  
 
:*KidSize (altura: 30-60cm);     
 
:*KidSize (altura: 30-60cm);     
Linha 145: Linha 144:
 
====Middle Size Robot League (MSL)====
 
====Middle Size Robot League (MSL)====
  
:Utiliza robôs com até 50 cm de diâmetro em equipes de até seis jogadores [[msl]]. Os robôs devem ter todos os sensores ''onboard''  e utilizar rede sem fio para comunicação.
+
:Utiliza robôs com até 50 cm de diâmetro em equipes de até seis jogadores [http://www.robocup.org/robocup-soccer/middle-size/]. Os robôs devem ter todos os sensores ''onboard''  e utilizar rede sem fio para comunicação.
  
 
====Soccer Simulation League====
 
====Soccer Simulation League====
  
:São utilizados softwares para simular os robôs que jogam uma partida num campo virtual. Esta categoria está divida em quatro sub-ligas [[Simulador]]. São elas: 2D, 3D, desenvolvimento 3D e realidade mista onde são utilizados robôs em miniatura fazendo uma ligação entre robôs reais e simulados.
+
:São utilizados softwares para simular os robôs que jogam uma partida num campo virtual. Esta categoria está divida em quatro sub-ligas [http://www.robocup.org/robocup-soccer/simulation/]. São elas: 2D, 3D, desenvolvimento 3D e realidade mista onde são utilizados robôs em miniatura fazendo uma ligação entre robôs reais e simulados.
  
 
====Standard Plataform====
 
====Standard Plataform====
  
:É uma liga de futebol onde todas as equipes utilizam o mesmo modelo de robô [[spl]]. Este robô é totalmente autônomo,  
+
:É uma liga de futebol onde todas as equipes utilizam o mesmo modelo de robô [http://www.tzi.de/spl/bin/view/Website/WebHome]. Este robô é totalmente autônomo,  
devendo ser previamente programado e não pode ser controlado externamente nem por humanos nem por computador. Atualmente são utilizados os robôs '''NAO'''  desenvolvidos pela empresa Aldebaran Robotics. Estes robôs são totalmente programáveis através do software ''Coregraphe'' , também desenvolvido pela Aldebaran Robotics[[NAO]]. O software é multi-plataforma e aceita as linguagens C, C++, URBI e Python[[NAO2]].
+
devendo ser previamente programado e não pode ser controlado externamente nem por humanos nem por computador. Atualmente são utilizados os robôs '''NAO'''  desenvolvidos pela empresa Aldebaran Robotics. Estes robôs são totalmente programáveis através do software ''Coregraphe'' , também desenvolvido pela Aldebaran Robotics[http://www.aldebaran-robotics.com/en/programmable]. O software é multi-plataforma e aceita as linguagens C, C++, URBI e Python[http://www.aldebaran-robotics.com/Files/DSV3_En.pdf].
  
 
====Small Size Robot League (SSL ou F180)====
 
====Small Size Robot League (SSL ou F180)====
  
:Liga formada por robôs pequenos, tem como objetivo estudar problemas de cooperação entre multi-agentes inteligentes e cooperação em ambientes dinâmicos através de um sistema híbrido (centralizado/distribuído) [[ssl]].
+
:Liga formada por robôs pequenos, tem como objetivo estudar problemas de cooperação entre multi-agentes inteligentes e cooperação em ambientes dinâmicos através de um sistema híbrido (centralizado/distribuído) [http://small-size.informatik.uni-bremen.de/].
  
:De acordo com as regras [[sslrules]], um robô deve ser cilíndrico, ter no máximo 180 mm de diâmetro e 150 mm de altura. A comunicação com o computador é feita por wireless e cada robô deve seguir um padrão de cores no topo identificando equipe e numero do robô. Esta identificação servirá como padrão de reconhecimento para o sistema de visão compartilhada (''SSL-Vision'' ).
+
:De acordo com as regras [http://small-size.informatik.uni-bremen.de/_media/rules:ssl-rules-2010.pdf], um robô deve ser cilíndrico, ter no máximo 180 mm de diâmetro e 150 mm de altura. A comunicação com o computador é feita por wireless e cada robô deve seguir um padrão de cores no topo identificando equipe e numero do robô. Esta identificação servirá como padrão de reconhecimento para o sistema de visão compartilhada (''SSL-Vision'' ).
  
 
:Cada equipe é formada por até cinco robôs, já incluído o goleiro. A identificação deve ser clara o suficiente para que o robô possa ser facilmente reconhecido pelo juiz e o goleiro deve ser identificado antes do início da partida. Os robôs devem jogar de forma totalmente autônoma.
 
:Cada equipe é formada por até cinco robôs, já incluído o goleiro. A identificação deve ser clara o suficiente para que o robô possa ser facilmente reconhecido pelo juiz e o goleiro deve ser identificado antes do início da partida. Os robôs devem jogar de forma totalmente autônoma.
 
;\begin{figure}
 
;  \center
 
;  \includegraphics[scale=0.5]{campo.jpg}
 
;  \caption{Campo oficial da liga SSL.}
 
;  (1)
 
;\end{figure}
 
  
 
:Uma partida é composta de dois tempos com duração de dez minutos cada, com um intervalo de no máximo cinco minutos entre eles. O campo, conforme visto na figura 1, deve ser retangular e medir entre as linhas, 6050 mm de comprimento por 4050 mm de largura, a superfície deve ser recoberta com um carpete verde e é utilizada uma bola de golfe de cor laranja.
 
:Uma partida é composta de dois tempos com duração de dez minutos cada, com um intervalo de no máximo cinco minutos entre eles. O campo, conforme visto na figura 1, deve ser retangular e medir entre as linhas, 6050 mm de comprimento por 4050 mm de largura, a superfície deve ser recoberta com um carpete verde e é utilizada uma bola de golfe de cor laranja.
  
;\begin{figure}
 
;  \center
 
;  \includegraphics[scale=0.65]{posicao.jpg}
 
;  \caption{Disposição padrão de identificação dos robôs na liga SSL.}
 
;  (2)
 
;\end{figure}
 
 
   
 
 
:*'''Matriz de Cores Padrão:''' Antes do início da partida cada equipe recebe uma cor que pode ser azul ou amarela. As figuras 2 e 3 mostram o padrão que deve ser seguido para que o SSL-Vision reconheça cada robô. Um adesivo com a cor da equipe deve ser colada no centro do topo de cada robô. Além deste, mais quatro adesivos são dispostos no topo de cada robô informando a identificação numérica de cada um.
 
:*'''Matriz de Cores Padrão:''' Antes do início da partida cada equipe recebe uma cor que pode ser azul ou amarela. As figuras 2 e 3 mostram o padrão que deve ser seguido para que o SSL-Vision reconheça cada robô. Um adesivo com a cor da equipe deve ser colada no centro do topo de cada robô. Além deste, mais quatro adesivos são dispostos no topo de cada robô informando a identificação numérica de cada um.
  
;\begin{figure}
+
:*'''SSL-Vision:''' Até a RoboCup 2009 era permitido, e a maior parte das equipes preferia, utilizar câmeras de vídeo em cima ou perto do campo. Normalmente eram utilizadas duas câmeras, uma em cada metade do campo, Isto ocasionava um longo tempo gasto para configurar corretamente as câmeras  antes e até durante o jogo -- se em cada campo disputassem cinco equipes, era necessário instalar e calibrar dez câmeras.    O comitê organizador resolveu então adotar a partir da RoboCup 2010 um sistema de visão compartilhada chamado SSL-Vision [http://szickler.net/download.php?session=715d8e45e634b347025b48bf3d7cd6cd&param=url_pdf&id=263]. Este sistema é implementado em linguagem C++ e desenvolvido por integrantes das equipes competidoras.  Ele consiste em um único conjunto de câmeras conectadas em um servidor de processamento de imagens que identifica as posiões da bola e dos jogadores, e redistribui estas informações para as equipes participantes, conforme figura 4.
;    \center
+
;    \includegraphics[scale=0.5]{cores.jpg}
+
;    \caption{Cores padrão para identificação dos robôs na liga SSL.}
+
;    (3)
+
;  \end{figure}
+
 
+
:*'''SSL-Vision:''' Até a RoboCup 2009 era permitido, e a maior parte das equipes preferia, utilizar câmeras de vídeo em cima ou perto do campo. Normalmente eram utilizadas duas câmeras, uma em cada metade do campo, Isto ocasionava um longo tempo gasto para configurar corretamente as câmeras  antes e até durante o jogo -- se em cada campo disputassem cinco equipes, era necessário instalar e calibrar dez câmeras.    O comitê organizador resolveu então adotar a partir da RoboCup 2010 um sistema de visão compartilhada chamado SSL-Vision [[Vision]]. Este sistema é implementado em linguagem C++ e desenvolvido por integrantes das equipes competidoras.  Ele consiste em um único conjunto de câmeras conectadas em um servidor de processamento de imagens que identifica as posiões da bola e dos jogadores, e redistribui estas informações para as equipes participantes, conforme figura 4.
+
 
+
;\begin{figure}
+
;    \center
+
;    \includegraphics[scale=0.65]{dataflow.png}
+
;    \caption{Diagrama resumido SSL-Vision.}
+
;    (4)
+
;  \end{figure}   
+
  
 
=Ambientes de Simulação Robótica}=
 
=Ambientes de Simulação Robótica}=
Linha 206: Linha 176:
  
 
:O Sistema Estrategista para Futebol de Robôs foi desenvolvido por Hugo Goveia com o objetivo de tratar assuntos relacionados ao futebol robótico,
 
:O Sistema Estrategista para Futebol de Robôs foi desenvolvido por Hugo Goveia com o objetivo de tratar assuntos relacionados ao futebol robótico,
dando continuidade à pesquisa iniciada na Faculdade de Informática de Presidente Prudente (FIPP)[[Goveia]].
+
dando continuidade à pesquisa iniciada na Faculdade de Informática de Presidente Prudente (FIPP)[http://www2.unoeste.br/~chico/FIPP/projetos/projeto2006/Monografia_Hugo_2006.pdf].
  
 
:Em seu trabalho, Goveia desenvolveu um ambiente virtual que simula uma disputa entre um time controlado pelo usuário e outro que obedece às decisões  
 
:Em seu trabalho, Goveia desenvolveu um ambiente virtual que simula uma disputa entre um time controlado pelo usuário e outro que obedece às decisões  
tomadas pelo Sistema Estrategista[[Goveia]].
+
tomadas pelo Sistema Estrategista[http://www2.unoeste.br/~chico/FIPP/projetos/projeto2006/Monografia_Hugo_2006.pdf].
  
: O software foi desenvolvido em ''Borland C++ Builder''. Este está organizado de maneira a permitir o controle dos robôs de um dos times por um usuário humano, que recebe comandos via teclado, enquanto o outro time obedece aos comandos definidos por estratégias implementadas[[Goveia]]. As informações de localização dos robôs ficam armazenadas em um vetor de oito posições, cada qual referente a um robô[[Goveia]].
+
: O software foi desenvolvido em ''Borland C++ Builder''. Este está organizado de maneira a permitir o controle dos robôs de um dos times por um usuário humano, que recebe comandos via teclado, enquanto o outro time obedece aos comandos definidos por estratégias implementadas[http://www2.unoeste.br/~chico/FIPP/projetos/projeto2006/Monografia_Hugo_2006.pdf]. As informações de localização dos robôs ficam armazenadas em um vetor de oito posições, cada qual referente a um robô[http://www2.unoeste.br/~chico/FIPP/projetos/projeto2006/Monografia_Hugo_2006.pdf].
  
 
:A Figura 5 representa a tela da simulação das estratégias. O campo é constituído por uma escala para as medidas reais da categoria MiroSot, onde são feitos os tratamentos de colisão entre os robôs, bolas e laterais, de maneira que os elementos não saiam do campo.
 
:A Figura 5 representa a tela da simulação das estratégias. O campo é constituído por uma escala para as medidas reais da categoria MiroSot, onde são feitos os tratamentos de colisão entre os robôs, bolas e laterais, de maneira que os elementos não saiam do campo.
 
;\begin{figure}
 
;  \center
 
;  \includegraphics[height=9.32cm]{SoftwareSimulacaoFig01.jpg}
 
;  \caption{Tela do aplicativo de simulação de Sistema Estrategista para Futebol Robótico.}
 
;  (5)
 
;\end{figure}
 
  
 
:Em seu trabalho, Goveia focou o desenvolvimento do Sistema Estrategista. Dessa forma, seu software de simulação é limitado em relação ao Tewnta, objeto de estudo deste trabalho.  
 
:Em seu trabalho, Goveia focou o desenvolvimento do Sistema Estrategista. Dessa forma, seu software de simulação é limitado em relação ao Tewnta, objeto de estudo deste trabalho.  
Linha 226: Linha 189:
 
==Webots==
 
==Webots==
  
:Iniciado em 1996, pelo Dr. Olivier Michel no Instituto Federal Suíço de Tecnologia, Webots é um software de prototipagem e de simulação robótica profissional utilizado para fins educativos[[FerreiraJunior]].
+
:Iniciado em 1996, pelo Dr. Olivier Michel no Instituto Federal Suíço de Tecnologia, Webots é um software de prototipagem e de simulação robótica profissional utilizado para fins educativos[http://www.do.ufgd.edu.br/valguimaodakura/aulas-trm/seminarios-final/Webots-Jonathas-Diego.pdf].
  
:Esse software utiliza o ODE (''Open Dynamics Engine'' ), cuja biblioteca permite simular com precisão as propriedades físicas dos objetos, para detecção de colisões e simulação dinâmica de corpos rígidos[[Webots]].
+
:Esse software utiliza o ODE (''Open Dynamics Engine'' ), cuja biblioteca permite simular com precisão as propriedades físicas dos objetos, para detecção de colisões e simulação dinâmica de corpos rígidos[http://www.cyberbotics.com/cyberbotics/reference/].
  
:O programa apresenta uma coleção de robôs modificáveis e, além disso, há a possibilidade de criação de novos modelos. Para a projeção de um novo modelo de robô, o usuário especifica os anúncios gráficos, como forma, dimensões, posição e cores do objeto e propriedades físicas, que abrangem massa, coeficiente de atrito, mola e amortecimento[[FerreiraJunior]].
+
:O programa apresenta uma coleção de robôs modificáveis e, além disso, há a possibilidade de criação de novos modelos. Para a projeção de um novo modelo de robô, o usuário especifica os anúncios gráficos, como forma, dimensões, posição e cores do objeto e propriedades físicas, que abrangem massa, coeficiente de atrito, mola e amortecimento[http://www.do.ufgd.edu.br/valguimaodakura/aulas-trm/seminarios-final/Webots-Jonathas-Diego.pdf].
  
:O uso de uma prototipagem rápida e software de simulação é muito útil para o desenvolvimento de projeto de robótica mais avançada. Ele realmente permite visualizar previamente o controle inteligente de robôs para, eventualmente, transferir os resultados da simulação em um robô real. Por isso, tanto o tempo de desenvolvimento e a qualidade dos resultados são melhores usando uma prototipagem rápida e software de simulação[[Webots]].
+
:O uso de uma prototipagem rápida e software de simulação é muito útil para o desenvolvimento de projeto de robótica mais avançada. Ele realmente permite visualizar previamente o controle inteligente de robôs para, eventualmente, transferir os resultados da simulação em um robô real. Por isso, tanto o tempo de desenvolvimento e a qualidade dos resultados são melhores usando uma prototipagem rápida e software de simulação[http://www.cyberbotics.com/cyberbotics/reference/].
  
 
:Outra vantagem da Webots é a compatibilidade com diversas linguagens de programação, os programas de controle do robô podem ser escrito em C, C++, Java,  
 
:Outra vantagem da Webots é a compatibilidade com diversas linguagens de programação, os programas de controle do robô podem ser escrito em C, C++, Java,  
Python e MATLAB[[FerreiraJunior]]. As Figuras 6 e 7 são um exemplo de simulação feita pela Webots.
+
Python e MATLAB[http://www.do.ufgd.edu.br/valguimaodakura/aulas-trm/seminarios-final/Webots-Jonathas-Diego.pdf]. As Figuras 6 e 7 são um exemplo de simulação feita pela Webots.
  
;\begin{figure}
+
:Webots é um simulador de cunho genérico. Dessa forma, a representação dos eventos físicos é robusta. No entanto, não é seu intuito simular uma partida de Futebol de Robôs. Outra limitação em relação ao Webots é o seu custo. Por se tratar de um software profissional, possui apenas uma versão demo livre, que não pode ser modificada[http://www.cyberbotics.com/cyberbotics/reference/].
;  \center
+
;  \includegraphics[height=7.68cm]{SoftwareSimulacaoFig02.jpg}
+
;  \caption{Simulação de futebol de robôs da categoria humanóide - Webots.}
+
;  (6)
+
;\end{figure}
+
 
+
;\begin{figure}
+
;  \center
+
;  \includegraphics[height=7.68cm]{SoftwareSimulacaoFig03.jpg}
+
;  \caption{Simulação de modelos diferentes de robôs em situações diversas - Webots.} 
+
; (7)
+
;\end{figure}
+
 
+
:Webots é um simulador de cunho genérico. Dessa forma, a representação dos eventos físicos é robusta. No entanto, não é seu intuito simular uma partida de Futebol de Robôs. Outra limitação em relação ao Webots é o seu custo. Por se tratar de um software profissional, possui apenas uma versão demo livre, que não pode ser modificada[[Webots]].
+
  
 
==The Robocup Soccer Simulator==
 
==The Robocup Soccer Simulator==
Linha 260: Linha 209:
 
não há restrições quanto à forma como as equipes são construídas. A única exigência é que as ferramentas de suporte de comunicação cliente-servidor  
 
não há restrições quanto à forma como as equipes são construídas. A única exigência é que as ferramentas de suporte de comunicação cliente-servidor  
 
sejam via UDP/IP (''User Datagram Protocol / Internet Protocol'' ) pois todas as comunicações entre o servidor e cada cliente são feitas via sockets UDP/IP.
 
sejam via UDP/IP (''User Datagram Protocol / Internet Protocol'' ) pois todas as comunicações entre o servidor e cada cliente são feitas via sockets UDP/IP.
Cada cliente é um processo separado e se conecta ao servidor através de uma porta especificada. Depois que um jogador se conecta ao servidor, todas as mensagens são transferidas através desta porta. Uma equipe pode ter até 12 clientes, ou seja, 11 jogadores e um treinador[[RoboCupSoccerSimulator]].
+
Cada cliente é um processo separado e se conecta ao servidor através de uma porta especificada. Depois que um jogador se conecta ao servidor, todas as mensagens são transferidas através desta porta. Uma equipe pode ter até 12 clientes, ou seja, 11 jogadores e um treinador[http://sourceforge.net/apps/mediawiki/sserver].
  
 
:Os jogadores enviam pedidos para o servidor quanto às ações que desejam realizar, como por exemplo, chutar a bola, girar ou correr. O servidor recebe estas mensagens, processa os pedidos, e atualiza o ambiente em conformidade. Além disso, o servidor fornece a todos os jogadores as informações sensoriais  
 
:Os jogadores enviam pedidos para o servidor quanto às ações que desejam realizar, como por exemplo, chutar a bola, girar ou correr. O servidor recebe estas mensagens, processa os pedidos, e atualiza o ambiente em conformidade. Além disso, o servidor fornece a todos os jogadores as informações sensoriais  
(por exemplo, informações visuais sobre a posição dos objetos no campo, ou dados sobre os recursos do jogador, como resistência ou velocidade) [[JanPereira]].
+
(por exemplo, informações visuais sobre a posição dos objetos no campo, ou dados sobre os recursos do jogador, como resistência ou velocidade) [http://projetos.inf.ufsc.br/arquivos_projetos/projeto_82/Monografia.pdf].
  
:É importante mencionar que o servidor é um sistema em tempo real, trabalhando com intervalos de tempo discretos. Cada ciclo tem uma duração específica, e as ações que precisam ser executadas em um determinado ciclo, têm de chegar ao servidor durante o intervalo de direito. Portanto, o desempenho de um jogador lento, que resulta em perda de oportunidades de ação tem um impacto importante sobre o desempenho da equipe como um todo[[JanPereira]].
+
:É importante mencionar que o servidor é um sistema em tempo real, trabalhando com intervalos de tempo discretos. Cada ciclo tem uma duração específica, e as ações que precisam ser executadas em um determinado ciclo, têm de chegar ao servidor durante o intervalo de direito. Portanto, o desempenho de um jogador lento, que resulta em perda de oportunidades de ação tem um impacto importante sobre o desempenho da equipe como um todo[http://projetos.inf.ufsc.br/arquivos_projetos/projeto_82/Monografia.pdf].
  
:A tela de visualização apresenta informações de pontuação, nomes de equipe e as posições de todos os jogadores e da bola. A interface é simples para o servidor e possui diversas conveniências. Como pode ser vista nas Figuras 8 e 9. Há a possibilidade de zoom em áreas de campo, para fins de depuração, de mover os jogadores e a bola com o mouse e de imprimir as posições e velocidades atuais dos jogadores e da bola em qualquer momento[[RoboCupSoccerSimulator]].
+
:A tela de visualização apresenta informações de pontuação, nomes de equipe e as posições de todos os jogadores e da bola. A interface é simples para o servidor e possui diversas conveniências. Como pode ser vista nas Figuras 8 e 9. Há a possibilidade de zoom em áreas de campo, para fins de depuração, de mover os jogadores e a bola com o mouse e de imprimir as posições e velocidades atuais dos jogadores e da bola em qualquer momento[http://sourceforge.net/apps/mediawiki/sserver].
  
 
:Para executar um jogo no servidor, não é necessário um monitor. No entanto, em um mesmo servidor, pode haver vários monitores conectados,  
 
:Para executar um jogo no servidor, não é necessário um monitor. No entanto, em um mesmo servidor, pode haver vários monitores conectados,  
caso haja a necessidade de mostrar o mesmo jogo em terminais diferentes[[RoboCupSoccerSimulator]].
+
caso haja a necessidade de mostrar o mesmo jogo em terminais diferentes[http://sourceforge.net/apps/mediawiki/sserver].
 
+
;\begin{figure}
+
; \center
+
;  \includegraphics[height=7.16cm]{SoftwareSimulacaoFig04.jpg}
+
;  \caption{Interface do Robocup Soccer Simulator - 2D}
+
;  (8)
+
;\end{figure}
+
 
+
;\begin{figure}
+
; \center
+
;  \includegraphics[height=7.16cm]{sim3d.png}
+
;  \caption{Interface do Robocup Soccer Simulator - 3D}
+
;  (9)
+
;\end{figure}
+
  
 
=Tewnta=
 
=Tewnta=
  
 
:Tewnta é um software de simulação de futebol de robôs, baseados nos parâmetros da modalidade Small Size League (SSL),  
 
:Tewnta é um software de simulação de futebol de robôs, baseados nos parâmetros da modalidade Small Size League (SSL),  
também conhecida como F180. Projeto originário da UFRGS, foi desenvolvido por Gabriel Detoni, em 2008, em linguagem Java com o objetivo de simular uma partida de futebol de robôs pequenos nos moldes de RoboCup. É um programa de código aberto e de componente gráfico bem desenvolvido[[SiteTewnta]].
+
também conhecida como F180. Projeto originário da UFRGS, foi desenvolvido por Gabriel Detoni, em 2008, em linguagem Java com o objetivo de simular uma partida de futebol de robôs pequenos nos moldes de RoboCup. É um programa de código aberto e de componente gráfico bem desenvolvido[http://code.google.com/p/tewnta/].
  
 
:O Tewnta é utilizado na UTFPR na disciplina de Sistemas Inteligentes I do Curso de Engenharia da Computação, como ferramenta de ensino de algoritmos
 
:O Tewnta é utilizado na UTFPR na disciplina de Sistemas Inteligentes I do Curso de Engenharia da Computação, como ferramenta de ensino de algoritmos
Linha 299: Linha 234:
 
:Tewnta se destaca dos demais simuladores englobar características como código fonte aberto, sob a licença ''GNU Lesser General Public License'' ,
 
:Tewnta se destaca dos demais simuladores englobar características como código fonte aberto, sob a licença ''GNU Lesser General Public License'' ,
 
simulação muito próxima da realidade de uma partida de futebol, simplicidade no uso, funcionabilidade e adaptabilidade. Sua interface pode ser visualizada na Figura 10
 
simulação muito próxima da realidade de uma partida de futebol, simplicidade no uso, funcionabilidade e adaptabilidade. Sua interface pode ser visualizada na Figura 10
 
;\begin{figure}
 
; \center
 
;  \includegraphics[height=9.00cm]{SoftwareSimulacaoFig05.jpg}
 
;  \caption{Interface do Tewnta}
 
;  (10)
 
;\end{figure}
 
  
 
=Estudo do Código Fonte=
 
=Estudo do Código Fonte=
  
:O estudo apresentado a seguir foi elaborado pelos integrantes da equipe para melhor compreensão do código fonte, baseando-se principalmente na documentação oficial do Tewnta [[JavaDocTewnta]] e no Livro ''Java Como Programar'' [[JavaComoProgramar]].
+
:O estudo apresentado a seguir foi elaborado pelos integrantes da equipe para melhor compreensão do código fonte, baseando-se principalmente na documentação oficial do Tewnta [http://tewnta.googlecode.com/svn/trunk/tewnta/javadoc/index.html] e no Livro ''Java Como Programar'' [[JavaComoProgramar]].
  
 
==Visão Geral==
 
==Visão Geral==
Linha 316: Linha 244:
  
 
:O Tewnta trabalha em duas camadas, a primeira atua como ''Servidor'' ,e é responsável pela simulação física e interpretação das regras do Futebol de Robôs. Uma segunda camada atua como ''Cliente'' , nela estão definidas as ações que devem ser tomadas pelos robôs. Para cada um dos times há uma aplicação cliente sendo executada. (Como pode ser visto na Figura 12). Essas duas camadas são executadas em aplicações diferentes que se comunicam através de protocolo IP (Internet Protocol).
 
:O Tewnta trabalha em duas camadas, a primeira atua como ''Servidor'' ,e é responsável pela simulação física e interpretação das regras do Futebol de Robôs. Uma segunda camada atua como ''Cliente'' , nela estão definidas as ações que devem ser tomadas pelos robôs. Para cada um dos times há uma aplicação cliente sendo executada. (Como pode ser visto na Figura 12). Essas duas camadas são executadas em aplicações diferentes que se comunicam através de protocolo IP (Internet Protocol).
 
;\begin{figure}
 
;  \center
 
;  \includegraphics[height=4.98cm]{EstudoFonteFig01.jpg}
 
;  \caption{Diagrama de Comunicação - Tewnta}
 
;  (12)
 
;\end{figure}
 
  
 
:O fluxo básico da aplicação consiste em:
 
:O fluxo básico da aplicação consiste em:
Linha 336: Linha 257:
  
 
:Um modelo em diagrama de blocos do fluxograma do programa pode ser visualizado na Figura 14.
 
:Um modelo em diagrama de blocos do fluxograma do programa pode ser visualizado na Figura 14.
 
;\begin{figure}
 
;  \center
 
;  \includegraphics[height=9.79cm]{EstudoFonteFig02.jpg}
 
;  \caption{Diagrama de fluxo - Tewnta}
 
;  (14)
 
;\end{figure}
 
  
 
:A Linguagem de Programação Java trabalha com o conceito de ''Máquinas Virtuais'' [[JavaComoProgramar]]. As Máquinas Virtuais trabalham como intermediários entre a aplicação e o Sistema Operacional, interpretando os comandos dentro da aplicação e os convertendo para os respectivos comandos do Sistema Operacional. Devido a esse fato, o Tewnta pode ser executado em qualquer Sistema Operacional que possua uma JVM (''Java Virtual Machine'' ).
 
:A Linguagem de Programação Java trabalha com o conceito de ''Máquinas Virtuais'' [[JavaComoProgramar]]. As Máquinas Virtuais trabalham como intermediários entre a aplicação e o Sistema Operacional, interpretando os comandos dentro da aplicação e os convertendo para os respectivos comandos do Sistema Operacional. Devido a esse fato, o Tewnta pode ser executado em qualquer Sistema Operacional que possua uma JVM (''Java Virtual Machine'' ).
Linha 501: Linha 415:
  
 
:Diagrama de Classes elaborado pela equipe para o programa Tewnta. Nessa versão do diagrama, apresentamos cada pacote Java como um diagrama, para uma versão completa do diagrama [[http://www.dainf.ct.utfpr.edu.br/wiki/index.php/Imagem:Twenta.jpg acesse]].
 
:Diagrama de Classes elaborado pela equipe para o programa Tewnta. Nessa versão do diagrama, apresentamos cada pacote Java como um diagrama, para uma versão completa do diagrama [[http://www.dainf.ct.utfpr.edu.br/wiki/index.php/Imagem:Twenta.jpg acesse]].
 +
 +
=Modificações Executadas=
 +
:Durante o trabalho, buscou-se aperfeiçoar algumas limitações do Tewnta.
 +
:A seguir são apresentadas as correções feitas.
 +
 +
 +
==Validação do Gol==
 +
:A versão 1.3 do Tewnta apresentava uma limitação em relação à validação do gol. Nessa versão, caso a bola passasse atrás do gol -- entre a trave do fundo e o fundo do campo -- , o algoritmo interpretava esse evento como gol.
 +
:Essa imperfeição poderia causar problemas na simulação, uma vez que algumas equipes poderiam ser beneficiadas com gols que não fizeram.
 +
 +
===Arquivos modificados===
 +
   
 +
:*/br/ufrgs/f180/server/Game.java   
 +
:*/br/ufrgs/f180/elements/GameField.java 
 +
 +
====Função modificada====
 +
   
 +
:*''public ScoredGoal goalScored()'' 
 +
 +
====Função criada====
 +
   
 +
:*''public static double getGoalDepth()'' 
 +
 +
====Descrição====
 +
 +
:A condição para validação do gol no código original era que a bola estivesse no retângulo imaginário entre os dois gols no meio do campo e estivesse fora da linha de fundo. A contribuição do trabalho consistiu em incluir a condição de a bola estar entre a linha de fundo e a barra de fundo do gol, em vez de o fundo do campo, como na versão original, como pode ser verificado no código 23.
 +
 +
:Para executar essa correção, é necessária a informação da profundidade da trave do gol na classe ''server.Game'', essa informação era visível apenas na classe ''elements.GameField'' , então criou-se uma função ''getter''  pública que retorna essa informação, como pode ser verificado no código 24.
 +
 +
 +
CODIGO {codigo01a.java}
 +
 +
 +
CODIGO{codigo01b.java}
 +
 +
==Função ''fast-foward'' ==
 +
:Durante os testes dos algoritmos inteligentes no simulador os programadores precisam aguardar os 20 minutos de uma partida para obter os resultados. Um acréscimo interessante ao Tewnta seria acelerar o tempo da simulação. Na versão 1.3, foi implementado um método para desacelerar a simulação e vê-la em câmera lenta, dessa forma, o arcabouço necessário para uma simulação mais rápida já estava pronto nessa versão.
 +
 +
===Arquivo modificado===
 +
   
 +
:*/br/ufrgs/f180/gui/MainWindow.java 
 +
 +
====Função modificada====
 +
   
 +
:*''private void initGUI()'' 
 +
 +
====Descrição====
 +
:Para executar a função de desaceleração do jogo, o Tewnta utilizava uma variável de valor real chamada ''elapsedTimePerCycle''  definida na classe ''gui.MainWindow'' , que representa quanto tempo se passa em um ciclo de jogo. O usuário controla o valor dessa variável através de uma barra de rolagem presente na tela principal do Tewnta, como pode ser visto na figura 25. O valor dessa barra rolagem varia entre 1 e 100, onde 100 representa um segundo por um segundo, isso é, um segundo na simulação significa um segundo no mundo real.
 +
 +
:A contribuição do trabalho ao Tewnta consistiu em modificar o alcance dessa barra de rolagem, como mostra o código 26, mudando de 1-100 para 1-500. Dessa forma, o usuário pode definir uma simulação até cinco vezes mais rápida.
 +
 +
CODIGO{codigo02.java}
 +
 +
 +
==Jogadores voltarem a posição inicial após o gol==
 +
:Uma regra do Futebol de Robôs que não havia sido implementada no Tewnta era a volta dos robôs a seu campo de origem após um gol, como acontece no futebol humano. O posicionamento inadequado dos robôs após um gol pode favorecer ou prejudicar algum time durante uma partida.
 +
 +
===Arquivo modificado===
 +
   
 +
:*/br/ufrgs/f180/server/Game.java 
 +
 +
====Função modificada====
 +
   
 +
:*''public void updateState(double d)'' 
 +
 +
====Funções criadas====
 +
   
 +
:*''private void setUpRobot()''   
 +
:*''private double [ ][ ][ ] initialPositions()'' 
 +
 +
====Descrição====
 +
:Para implementar essa correção, era necessário inicialmente definir quais seriam as posições inicias dos jogadores após um gol. Essas posições foram definidas em termos relativos às dimensões do campo, de forma que cada time tivesse um robô goleiro, dois robôs em posição de defesa e dois robôs avançados.
 +
 +
:Para facilitar a implementação, foi criada a função ''private double [ ][ ][ ] initialPositions'' , que define uma matriz de três dimensões de valores reais, onde a primeira dimensão representa o time ao qual pertence o robô (0-1); a segunda dimensão define o índice daquele jogador dentro do time (0-4); e a terceira dimensão representa a coordenada (X ou Y) do valor real (0-1). Para que as posições dos jogadores não sejam sempre as mesmas a cada gol, foi incluído um fator aleatório na determinação das posições que pode
 +
variar a posição definida em até 10. A implementação da função ''initialPositions()''  pode ser vista no código 27.
 +
 +
CODIGO{codigo03a.java}
 +
 +
:Implementada a definição das posições dos jogadores, o proximo passo foi criar uma função que alterasse as posições dos jogadores. Então, definiu-se a função ''setUpRobot''  que pode ser vista no código 28. Essa função obtém e percorre o vetor de ''MovingElement''  da classe ''MainWindow''  e verifica quais são robôs, e a qual time eles pertencem, então seta a posição de acordo com a definição feita na função ''initialPositions()'' .
 +
 +
 +
CODIGO{codigo03b.java}
 +
 +
:Depois de implementadas as duas funções anteriores era necessário invocá-las no momento certo do código, então alterou-se a função ''updateState'' , que já estava definida desde a versão 1.2 do Tewnta. Essa função, entre outras coisas, define o que deve ser feito após um gol, então foi chamada a função ''setUpRobot()''  dentro do bloco de código que é executado após um gol, como pode ser visto no código 29.
 +
 +
CODIGO{codigo03c.java}
 +
 +
==Dimensões atualizadas do campo==
 +
:No Futebol de Robôs, as dimensões do campo podem ser modificadas a cada ano. Prevendo isso, o Tewnta possui um arquivo texto (''game.properties'' ) que fica no diretório ''/src''  do código fonte onde são definidos os parâmetros do campo.
 +
 +
===Arquivo modificado===
 +
   
 +
:*/src/game.properties 
 +
 +
====Descrição====
 +
 +
:Para adequar o Tewnta às regras 2010 do futebol de robôs foi necessário modificar os seguintes campos no arquivo ''game.properties'' , como
 +
pode ser verificado no código 30:
 +
   
 +
:*''field.height''  -- altura do campo;   
 +
:*''field.width''  -- largura do campo;   
 +
:*''field.border''  -- borda do campo, entre as paredes e as linhas. 
 +
 +
 +
CODIGO{codigo04.properties}
 +
 +
=Modificações implementadas na versão 1.3=
 +
 +
==Colisão==
 +
 +
:Uma das correções propostas pela equipe no início do trabalho foi o tratamento adequado da colisão entre robôs. No entanto, essa correção foi implementada na versão 1.3 do Tewnta.
 +
 +
:Para cálculo da colisão, primeiramente foi implementada uma função booleana na classe ''elements.MovingElement''  para definir se dois objetos estão em vias de se colidir, como mostra o código 31, através do cálculo da distância entre esses dois objetos.
 +
 +
 +
CODIGO{codigo06a.java}
 +
 +
:Caso a função definida no código 31 detecte a colisão entre dois elementos, o cálculo da colisão é feito através de uma colisão não elástica, como mostra o código 32.
 +
 +
CODIGO{codigo06b.java}
 +
 +
==Aceleração==
 +
:Para o cálculo de posição de um elemento, método ''public void calculatePosition(double timeElapsed)'' , no código 33, da classe ''elements.Movingelement'' , o algoritmo calcula primeiro a velocidade em função da aceleração (código 34) no Movimento Linear e então define a nova posição. Para o Movimento Rotacional, a aceleração rotacional é calculada (código 35) e então a velocidade rotacional é calculada, e só depois o novo ângulo é calculado.
 +
 +
CODIGO{codigo07a.java}
 +
 +
CODIGO{codigo07b.java}
 +
 +
CODIGO{codigo07c.java}
 +
 +
:No entanto, a implementação da Aceleração Linear utilizada no Tewnta não considera particularidades de robôs e solo, o cálculo é baseado na equação 36: onde <math>F</math> é a força exercida pelos motores dos robôs, e <math>m</math> é a massa dos robôs. Apesar desses parâmetros serem definidos através do arquivo ''game.properties'', através dos experimentos, pode-se observar que a relação expressa em 36 não expressa adequadamente a relação, porque desconsidera dissipações de energia inerentes ao movimento. Uma possível solução é apresentada em 38.
 +
 +
<center><math>
 +
a = \frac{F}{m}
 +
  (36)
 +
</math></center>
 +
 +
:A implementação utilizada para cálculo da aceleração rotacional (código 35) se baseia na equação 37 onde <math>F</math> é a força de rotação e <math>m</math> a massa do robô. No entanto, essa equação não considera o Momento de Inércia do corpo em rotação, o que afasta da realidade a simulação desse evento físico. Uma alternativa para essa implementação é apresentada em 39.
 +
 +
<center><math>
 +
a = \frac{F}{m}
 +
(37)
 +
</math></center>
 +
 +
 +
=Modificações a serem implementadas=
 +
 +
==Aceleração Linear==
 +
 +
:A potência exercida pelos motores dos robôs é constante, portanto, enquanto aceleram, a variação da velocidade é uniforme. Essa aceleração é influenciada por fatores como atrito entre as rodas e o campo, potência do motor e é melhor definida através de experimentos. Sendo assim, uma melhor implementação desse conceito seria definí-lo experimentalmente e
 +
então incluir seu valor no Tewnta.
 +
 +
:Para incluir a aceleração como um parâmetro definido pelo usuário, algumas modificações no código são necessárias:
 +
 +
   
 +
:*Incluir no arquivo ''game.properties''  o parâmetro ''robot.linearAcceleration'' ;   
 +
:*Na classe ''elements.Robot''  criar uma variável ''linearAcceleration'' ;   
 +
:*Na classe ''elements.Robot''  sobreescrever o método ''getAcceleration()''  definido em ''elements.MovingElement'' ; 
 +
 +
==Aceleração Rotacional==
 +
 +
:Assim como a Aceleração Linear (38), é possível obter a Aceleração Rotacional a partir de experimentos, e esta também é constante em módulo durante o regime de aceleração do movimento de rotação. Assim, os passos para implementação desse parâmetro físico são semelhantes aos apresentados em 38.
 +
 +
:*Incluir no arquivo ''game.properties''  o parâmetro ''robot.rotationalAcceleration'' ;   
 +
:*Na classe ''elements.Robot''  criar uma variável ''rotationalAcceleration'' ;   
 +
:*Na classe ''elements.Robot''  sobreescrever o método ''getRotationAcceleration()'' definido em ''elements.MovingElement'' ; 
 +
 +
==Desacelaração==
 +
 +
:Um movimento de um robô num Futebol de Robôs pode ser definido em três regimes:
 +
 +
:*Aceleração: fase em que o módulo da velocidade aumenta;   
 +
:*Uniforme: fase em que o módulo da velocidade não varia;   
 +
:*Desaceleração: fase em que o módulo da velocidade diminui. 
 +
 +
:A implementação do cálculo de posição utilizada no Tewnta 1.3, Código 33, considera apenas os dois primeiros regimes, uma vez que as funções ''getAcceleration()''  e ''getRotationAcceleration()'' não consideram valores negativos para as acelerações. Para incluir a faixa de valores negativos no cálculo é necessário, antes, determinar no código fonte o momento em que o robô inicia sua desaceleração, e então calcular o decréscimo da velocidade. No mundo real, isso acontece quando os motores param de exercer força sobre as rodas. No ambiente simulado, isso acontecerá quando o método ''setForce()''  da classe ''elements.MovingElement''  receber um parâmetro negativo.
 +
 +
=Tracker como ferramenta para o Futebol de Robôs=
 +
 +
:O Tracker é um software de código aberto destinado à análise de experimentos físicos. Para utilizar o programa, é necessário um vídeo com o movimento a ser analisado, que será decomposto em vários frames, para obtenção de resultados mais precisos e em curtos espaços de tempo[[ManualTracker]].
 +
 +
:A seguir, apresenta-se um breve tutorial descrevendo os passos de utilização do software Tracker como ferramenta para calcular as constantes físicas envolvidas no ambiente do futebol da categoria F180. Com essas constantes calculadas, e as devidas correções implementadas, os valores poderão ser inseridos no software Tewnta.
 +
 +
:Primeiramente serão necessários alguns itens.
 +
 +
:#Um robô, categoria F180, e o piso no qual se darão os experimentos;
 +
:#Uma câmera digital com função de gravação de vídeos em alta resolução;
 +
:#Software Tracker -- Link para download: ''http://www.cabrillo.edu/~dbrown/tracker/'' .
 +
:#Software Tewnta. -- Link para download: ''http://code.google.com/p/tewnta/'' .
 +
 +
==Filmagem==
 +
 +
:A filmagem deve ser feita de cima. A câmera deve focalizar a parte superior do robô. A câmera deve ficar imóvel enquanto grava o vídeo.
 +
 +
==Movimento Linear==
 +
 +
:Após a câmera posicionada, inicia-se o movimento retilíneo. É importante que apareça o início do movimento na gravação e, preferencialmente, o fim do movimento na mesma filmagem. O robô não deve rotacionar, deve apenas locomover-se para frente até estabilizar -- quando atinge módulo de velocidade constante, ou seja, entra em Movimento Retilíneo Uniforme (MRU) -- e, em seguida, parar.
 +
 +
==Movimento Rotacional==
 +
 +
:Após a câmera posicionada, coloca-se o robô para girar. O robô não deve locomover-se para frente ou para trás, deve apenas girar.
 +
 +
==Tracker - Funções Gerais==
 +
 +
:O manual oficial dos desenvolvedores do Tracker contém todas as informações gerais para utilizar o programa e pode ser encontrado no site dos desenvolvedores ou diretamente através do [http://www.cabrillo.edu/~dbrown/tracker/tracker_help_pt_BR.pdf link].
 +
 +
==Tracker e sua utilização nos testes lineares com robôs==
 +
 +
===Ajustando o Tracker===
 +
 +
:Abra o vídeo do movimento linear de sua escolha através do menu ''Arquivo <math>></math> Abrir <math>></math> ...''; selecione, na barra de duração, a parte do vídeo em que o robô está na eminência de começar o movimento até a parte imediatamente posterior ao término do movimento. Após isso, selecione o botão ''Eixos'' , logo abaixo do menu ''Trajetórias'', e posicione a origem do eixo o mais precisamente possível no centro do robô; ajuste o ângulo dos eixos, caso não estejam alinhados com o movimento.
 +
 +
:Após setado o eixo, clique no menu ''Trajetórias <math>></math> Novo <math>></math> Centro de massa''; clique em ''Aceitar''  na janela que irá aparecer. Na janela ''Controle de Trajetórias'' clique ao lado direito do ponto verde (em uma situação padrão estará escrito ''cm'' ) e renomeie o centro de massa como quiser (caso não queira, não é necessário).
 +
Novamente entre no menu ''Trajetórias <math>></math> Novo'' , porém agora clique em ''Ponto de Massa''; na janela que abrir clique em ''Sim'' . Segure a tecla ''Shift''  e com o botão esquerdo do mouse clique no centro do robô, onde deve estar a origem, como na Figura 41.
 +
 +
:Feito isso, clique no seu ponto de massa na janela ''Controle de Trajetórias''  e selecione ''autotrack'' , como na Figura 42.
 +
 +
:Na parte ''1.Mask''  pede-se para selecionar o ponto a ser acompanhado no movimento, por isso selecione, novamente, o centro do robô, como na figura 43.
 +
 +
:Clique em ''Next'' . Depois em ''2.Target'' , é onde ficarão as marcas do movimento. Pode deixá-lo do jeito que está; clique em ''Next''. No passo ''3.Accept''  clique em ''Next''. No último passo, chamado ''4.Search'', clique no botão ''Start''  para o vídeo rodar e o robô começar o movimento, como mostra a figura 44.
 +
 +
===Calculando a velocidade e aceleração instantâneas===
 +
 +
:A velocidade instantânea é definida [[Tipler1]] como o limite da razão <math>\Delta x/\Delta t</math> quando <math>\Delta t</math> tende a zero. Este valor, como será visto a seguir, é igual ao coeficiente angular da reta tangente à curva de <math>x</math> para um determinado ponto. Na notação do cálculo esta equação pode ser escrita como em 45.
 +
 +
<center><math>
 +
  v(t)=\lim_{\Delta t \to 0} \frac{\Delta x}{\Delta t}=\frac{dx}{dt}
 +
  (45)
 +
</math></center>
 +
 +
:Outra forma de encontrar esta velocidade é fazendo uma análise de um gráfico da posição <math>x</math> ''versus''  o tempo <math>t</math>. Tornando cada vez menor o intervalo de tempo <math>t</math> em relação a um ponto <math>t_p</math>, as velocidades médias desses intervalos se aproximam cada vez mais do coeficiente angular da reta tangente naquele ponto. A esta inclinação dá-se o nome de velocidade instantânea [[Halliday1]].
 +
 +
:Após realizados todos os passos de 40, clique no menu \textit{Janela <math>></math> Vista Direita}. Com isso, serão apresentados, ao lado do vídeo, o gráfico da posição <math>x</math> ''versus''  <math>t</math>. Para saber velocidade instantânea e aceleração instantânea em cada tempo <math>t</math>, clique em ''Dados'', no canto direito da tela e selecione ''''v'' : intensidade da velocidade''  e ''''a'' : intensidade da aceleração''.
 +
 +
:De posse dos dados coletados anteriormente, é possível traçar um gráfico de <math>v</math> ''versus''  <math>t</math> que descreve o movimento linear completo do robô,
 +
partindo do repouso até atingir velocidade constante e retornando ao repouso, conforme mostra a figura 46. Desmembrando este gráfico em outros três, cada um representando um estágio do movimento, podemos definir analiticamente os valores corretos para calibração do software simulador Tewnta.
 +
 +
:No primeiro estágio do movimento, o robô descreve Movimento Retilíneo Uniformemente Variado (MRUV), então derivando novamente a equação 45 obtemos o valor da aceleração do robô até ele atingir velocidade constante, como em 47.
 +
 +
<center><math>
 +
  a(t)=\frac{dv}{dt}=\frac{d^2x}{dt^2}
 +
  (47)
 +
</math></center>
 +
 +
:De outra forma, analisando graficamente, após linearizar o gráfico 48 o coeficiente angular (<math>a</math>) da reta é o valor da aceleração.
 +
 +
:No segundo estágio do movimento, o gráfico 49 mostra que o robô atinge velocidade máxima e está em MRU, ou seja, a velocidade é constante e portanto a aceleração é zero. A partir do gráfico 49 é possivel extrair diretamente o valor da velocidade máxima atingida pelo robô.
 +
 +
:De forma análoga ao primeiro estágio, no terceiro o robô novamente descreve MRUV, porém com aceleração negativa, então utilizando os mesmos métodos é possível determinar o valor da desaceleração do robô até que ele atinga o repouso.
 +
 +
==Tracker e sua utilização nos testes rotacionais com robôs==
 +
 +
===Ajustando o Tracker===
 +
 +
:Abra o vídeo da rotação de sua escolha no menu ''Arquivo <math>></math> Abrir <math>></math> ...''; selecione, na barra de duração, a parte do vídeo em que o robô está na
 +
eminência de começar a rotação até a parte posterior ao fim da rotação. Feito isso, selecione o botão ''Eixos'' , logo abaixo do menu ''Trajetórias'' , e posicione a origem do plano o mais precisamente possível no centro do robô; ajuste o ângulo dos eixos, caso não esteja alinhado.
 +
 +
:Após setado o eixo, clique no menu \textit{Trajetórias <math>></math> Novo <math>></math> Centro de massa}; clique em ''Aceitar''  na janela que irá aparecer; na janela ''Controle de Trajetórias'' clique ao lado direito do ponto verde (em uma situação padrão, estará escrito ''cm'' ) e renomeie o centro de massa como quiser (caso não queira, não é necessário). Novamente entre no menu ''Trajetórias <math>></math> Novo'' , porém agora clique em \textit{Ponto de Massa}; na janela que abrir clique em ''Sim'' . Segure a tecla ''Shift''  e com o botão esquerdo do mouse clique no centro do robô, onde deve estar a origem, como na Figura 41. Feito isso, clique no seu ponto de massa na janela ''Controle de Trajetórias''  e selecione ''autotrack'' , como na Figura 42.
 +
 +
:Na parte ''1.Mask''  pede-se para selecionar o ponto a ser acompanhado no movimento, por isso selecione uma das extremidades laterais do robô, como na Figura 51.
 +
 +
:Clique em ''Next'' . Em ''2.Target'' , é onde ficarão as marcas do movimento. Pode deixá-lo do jeito que está; clique em ''Next'' . No passo ''3.Accept''  clique
 +
em ''Next'' . No último passo, chamado ''4.Search'' , clique no botão ''Start''  para que o vídeo inicie e o robô inicie o movimento, ficando como na Figura 52.
 +
 +
===Calculando intensidades de velocidade e aceleração instantâneas===
 +
 +
:A velocidade angular instantânea é definada como o limite da razão <math>\Delta\Theta/\Delta t</math> quando <math>\Delta t</math> tende a zero [[Halliday1]], ou seja,
 +
é a derivada de <math>d\Theta</math> em relação a <math>dt</math>, como mostrado em 53
 +
 +
<center><math>
 +
  \omega=\lim_{\Delta t \to 0} \frac{\Delta\Theta}{\Delta t}=\frac{d\Theta}{dt}
 +
  (53)
 +
</math></center>
 +
 +
:Fazendo a derivada de segunda ordem da equação 53, é possível determinar a aceleração angular instantânea do robô, conforme mostrado na equação 54.
 +
 +
<center><math>
 +
  \alpha=\frac{d^2\Theta}{dt^2}=\frac{d\omega}{dt}
 +
  (54)
 +
</math></center>
 +
 +
:Também é possível determinar velocidade e aceleração angular através da velocidade e aceleração linear, respectivamente, multiplicando-as pelo raio do robô (medida do eixo de rotação até a extremidade)[[Tipler1]].
 +
 +
:Após realizados todos os passos de 50, clique no menu \textit{Janela <math>></math> Vista Direita}. Com isso, serão apresentados, ao lado do vídeo, o gráfico da posição <math>x</math> ''versus''  <math>t</math>. Para saber velocidade instantânea e aceleração instantânea em cada tempo <math>t</math>, clique em ''Dados'' ,
 +
no canto direito da tela e selecione ''''v'' : intensidade da velocidade''  e ''''a'' : intensidade da aceleração''.
 +
 +
:Com os dados da velocidade e tempo, constrói-se o gráfico 55 que descreve o movimento completo da rotação do robô em termos de velocidade linear do ponto analisado. Este movimento também está divido em três estágios: aceleração, velocidade máxima (constante) e desaceleração. Desmembrando este gráfico nos três estagios conseguimos determinar estes valores na forma linear, para em seguida convertê-los para a forma angular.
 +
 +
:A aceleração linear do ponto analisado é obtida através do coeficiente angular do gráfico 56.
 +
 +
:A partir do gráfico 57 é possível extrair diretamente a velocidade máxima linear do ponto analisado.
 +
 +
:E o coeficiente angular do gráfico 58 é igual à desaceleração linear do ponto analisado.
 +
 +
===Calculando velocidade e aceleração angulares a partir da velocidade e aceleração instantâneas lineares===
 +
 +
:Para determinar a velocidade angular instantânea, utiliza-se o valor de <math>v</math> encontrado no gráfico 57 e o raio do robô na equação 59.
 +
 +
<center><math>
 +
  \omega=\frac{v}{r}
 +
  (59)
 +
</math></center>
 +
 +
:De forma análoga, para determinar a aceleração e a desaceleração angulares instantâneas do robô substitui-se os coeficientes angulares encontrados nos gráficos 56 e 58 na equação 60, determinando assim respectivamente os valores da aceleração e a desaceleração angulares.
 +
 +
<center><math>
 +
\alpha = \frac{a}{r}
 +
  (60)
 +
</math></center>
 +
 +
:Ou seja, as acelerações angulares podem ser encontradas dividindo a intensidade de aceleração linear da extremidade pelo raio do robô e a velocidade angular divindindo-se a intesidade da velocidade linear também pelo raio do robô.
 +
 +
=Conclusão=
 +
 +
:O estudo e a elaboração de ambientes de simulação é importante pois contribui para pesquisas na área de robótica e melhorias de sistemas robóticos atuantes em diversas áreas. O futebol de robôs possibilita experimentar e validar diferentes técnicas da robótica, contudo, a implementação real dos robôs envolvidos pode ser complexa e trabalhosa.
 +
 +
:Como a UTFPR mantém atividades referentes à Robocup é necessária a existência de um simulador eficiente de partidas, permitindo a experimentação de situações variadas sem a necessidade do uso dos robôs físicos para tais experiências. Devido a isso, o foco deste trabalho foi a adaptação do simulador Tewnta, já em uso pela UTFPR, para seu melhor aproveitamento.
 +
 +
:Os demais simuladores de Robocup estudados não se encaixam em um perfil esperado para a UTFPR. Espera-se de um simulador: uma representação próxima da realidade; fácil entendimento; adaptabilidade; interpretação dos mesmos algoritmos usados nos robôs reais; e baixo custo.
 +
 +
:Tewnta é um simulador que se aproxima dessas características: é de uso livre, logo, não incide custos diretos. Possui código aberto, portanto adaptável. Interpreta os mesmos algoritmos usados nos robôs reais. Dentro de um contexto em que se conhece a linguagem Java e a comunicação entre aplicações, é fácil de ser usado. Possui um algoritmo de simulação funcional, apesar de alguns comportamentos físicos e interpretações das regras do futebol de robôs não coincidirem completamente com a realidade.
 +
 +
:Durante o trabalho, tentou-se aproximar a simulação do Tewnta de uma situação real. Para isso, foi feito um estudo do código fonte do programa em que procurou-se identificar onde e como eram definidas as diversas situações de jogo. Durante esse estudo pode-se perceber a dificuldade existente em analisar e interpretar um código feito por outra pessoa. A partir do momento em que a estrutura do programa foi compreendida, foi possível identificar com certa facilidade os pontos que precisavam ser alterados para atingir os objetivos propostos.
 +
 +
:Durante o estudo, percebeu-se que a variedade de características de cada equipe de futebol de robôs impede que um simulador preveja todas as peculiaridades de um time, dessa forma, concluiu-se que seria mais adequado a personalização de parâmetros físicos. Então buscou-se métodos experimentais eficientes que determinassem esses parâmetros, fazendo a integração entre a Física e a Computação.
 +
 +
:Apesar de não terem sido implementados todos os objetivos, percebeu-se que a estrutura do Tewnta permite que esses objetivos sejam codificados sem maiores dificuldades. Uma mudança considerável seria a implementação correta das constantes e limites físicos que podem ser obtidos a partir das técnicas e ferramentas de experimentos que foram usados, entre elas o software Tracker. Incluindo, assim, dados fenomenológicos na simulação do Tewnta.
 +
 +
=Anexos=
 +
 +
==Tewnta - Iniciando==
 +
 +
:O Tewnta é hospedado no ''Google Code'' , um serviço Google para hospedagem de código aberto. O link do [http://code.google.com/p/tewnta/ projeto]. Na guia ''Project Home'' , além de um sumário sobre a aplicação, pode-se acompanhar as diversas atualizações do sofrware e nome das pessoas que contribuem para o projeto.
 +
 +
:Na guia ''Downloads'' , pode-se fazer o download das diversas compilações do Tewnta, a saber:
 +
   
 +
:*Tewnta 1.3 for Linux x86   
 +
:*Tewnta 1.3 for Linux x64   
 +
:*Tewnta 1.3 for Windows x86   
 +
:*Tewnta 1.3 for Windows x64
 +
 +
:Na guia ''Wiki'' , há uma página Wiki sobre a aplicação, com uma breve explicação sobre o licenciamento, como instalar e rodar a aplicação.
 +
 +
:Na guia ''Issues'' , há um espaço para questões ao desenvolvedor do software, Gabriel Detoni, e as respostas que ele pode dar.
 +
 +
:E finalmente na guia ''Source'' , há a explicação sobre como fazer download do código fonte.
 +
 +
:Para baixar o Tewnta, é necessário possuir um cliente SVN (''SubVersioN'' ) instalado na máquina. Comumente um cliente SVN é instalado nas distribuições Linux, em Windows há diversas opções para download:
 +
   
 +
:*[http://www.collab.net/subversion CollabNet]
 +
:*[http://www.sliksvn.com/en/download SlikSVN]
 +
:*[http://www.visualsvn.com/server VisualSVN]
 +
 +
:Tendo instaldo o cliente SVN, é necessário dar o seguinte comando no prompt de comando:
 +
 +
:;svn checkout http://tewnta.googlecode.com/svn/trunk/ tewnta-read-only
 +
 +
:Após o comando, o programa fará download do código fonte do Tewnta. Tendo sido feito o download, é necessário criar o projeto no Eclipse. Para executá-lo, é necessário rodar a classe ''br.ufrgs.f180.gui.MainWindows'' . Então aparecerá a tela do Tewnta.
 +
 +
:Agora é necessário executar o time, o time de demonstração que acompanha a versão baixada do site do Tewnta está na classe ''br.ufrgs.f180.team.DemoTeam'' . Quando o time for executado, aparecerão na tela do Tewnta os jogadores. Para dar início à simulação basta clicar no botão ''Play''  no canto superior esquerdo da tela.

Edição atual tal como 23h44min de 11 de novembro de 2010

2010bEquipe07

  • NESTA VERSÃO ONLINE FORAM RETIRADAS AS FIGURAS. PARA A VERSÃO COMPLETA LEIA O PDF.
  • A primeira versão para a monografia foi finalizada e entregue aos professores da disciplina. Estão disponíveis as versões em PDF e LATEX.


Tabela de conteúdo

Resumo

Este trabalho tem como objetivo o aperfeiçoamento do simulador de futebol de robôs Tewnta, baseado nas regras da RoboCup SSL. Foram acrescentados ajustes e novas funcionalidades, que possibilitaram ao software uma melhor simulação do futebol e mais praticidade em seu uso. Além disso, desenvolveu-se um método experimental para obtenção de dados físicos no universo do futebol de robôs, utilizando o analisador de vídeos Tracker.
palavras-chave: Simulação. Futebol de Robôs. RoboCup. SSL. Tewnta. Tracker.

Abstract

This work aims to improve the robot soccer simulator Tewnta, based on RoboCup SSL rules. Tweaks and new features, that enabled a better simulation of soccer and more practical use, were added to the software. Furthermore, it has developed an experimental method for obtaining data on the physical world of robot soccer, using the video analyzer Tracker.
keywords: Simulation. Robot Soccer. RoboCup. SSL. Tewnta. Tracker.

Licenciamento

Este trabalho está licenciado sob uma Licença GNU Lesser General Public License . Para ver uma cópia dessa Licença visite www.gnu.org ou envie uma carta para 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA.

Glossário

  • API - Application Programming Interface
  • IDE - Integrated Development Environment
  • GNU - GNU is Not Unix
  • GPL - General Public License
  • IA - Inteligência Artificial
  • IP - Internet Protocol
  • JVM - Java Virtual Machine
  • MRU - Movimento Retilíneo Uniforme
  • MRUV - Movimento Retilíneo Uniformemente Variado
  • ODE - Open Dynamics Engine
  • POO - Programação Orientada a Objetos
  • SSL - Small Size League
  • SWT - Standard Widget Toolkit
  • UDP - User Datagram Protocol

Introdução

Delimitação do Tema

Softwares simuladores são fortes aliados no avanço da tecnologia. Simular fenômenos da natureza, comportamentos e situações reais sempre foram desafios ao ser humano[1]. Simulações robóticas cada vez mais vêm sendo utilizadas para proporcionar agilidade a eventos experimentais[2].
O futebol de robôs é uma iniciativa que propõe o desenvolvimento de tecnologia robótica tendo o futebol como motivação[3].

O simulador de futebol de robôs, em especial, é muito usado por professores de cursos de graduação e em testes de algoritmos inteligentes e o tema deste projeto gira em torno dele[4].

De maneira genérica o tema a ser tratado é o aperfeiçoamento do software Tewnta[5], que é um simulador do futebol de robôs da categoria F-180 da Robocup[6].
Considerando-se particularidades dos modelos matemáticos do robô e da bola, procura-se ajustar o programa para operar de forma mais fidedigna segundo as características de um robô, campo e bola reais disponíveis na UTFPR, ou seja, torná-lo o mais próximo possível da realidade.

Problema

A dificuldade em reproduzir a realidade é o principal desafio dos desenvolvedores de softwares simuladores. Muitas vezes o problema não é implementar as constantes físicas no programa, mas como calculá-las[7].
Softwares simuladores de Futebol de Robôs, de maneira geral, desconsideram detalhes específicos dos robôs e do ambiente presentes numa partida real. Dessa forma, algoritmos tidos como bons em um simulador, podem não obter o mesmo sucesso em um ambiente real[8].
Os principais problemas enfrentados para a realização desse projeto estão relacionados à determinação e interpretação de constantes e eventos físicos através de um método experimental válido. Outro problema seria a criação de uma interface em que o usuário pudesse transferir esses dados ao software, e esses dados serem interepretados de maneira correta pelo algoritmo.

Justificativa

Aperfeiçoar um simulador de entes robóticos, independentes de quais sejam, é uma tarefa de grande importância científica e tecnológica. Simular é um desafio enorme, pois envolve a abstração e posterior construção de um modelo elaborado de um evento real. Através das simulações pode-se representar processos reais mais rápida ou lentamente (de acordo com a necessidade específica de cada caso) para obtenção de informações de maneira mais prática do que através de experimentos reais[9].
A decisão de colaborar com a melhoria do simulador de futebol de robôs baseia-se na possibilidade de, além de exercer contribuições científicas e tecnológicas de forma geral, cooperar com as atividades da UTFPR, visto que esse software é utilizado na disciplina de Sistemas Inteligentes, do Departamento Acadêmico de Informática. Esse trabalho também poderia auxiliar os treinamentos da equipe de futebol de robôs da UTFPR, possibilitando melhores resultados nas participações da RoboCup, já que quanto mais próximo for o comportamento simulado dos robôs, mais adequado será o simulador para desenvolver estratégias de controle dos robôs.

Objetivos

Objetivo Geral

O objetivo geral do projeto é aperfeiçoar o software Tewnta, tornando sua simulação mais coerente com uma partida real de futebol de robôs. E também a determinação de uma metodologia adequada para obtenção de parâmetros físicos dos robôs e da bola em uma partida de futebol de robôs.

Objetivos Específicos

Os objetivos específicos do projeto incluem:


  • Corrigir a validação do gol no simulador;
  • Incluir o cálculo das acelerações linear e angular no movimento dos robôs;
  • Tornar parâmetros físicos do software manipuláveis pelo usuário, para que sejam consideradas peculiaridades de diferentes campos e robôs;
  • Implementar uma função fast-forward para facilitar os testes com algoritmos inteligentes, de maneira que as simulações possam ser aceleradas;
  • Criar um manual de introdução ao Tewnta;
  • Elaborar um guia para os experimentos físicos, utilizando o Tracker como ferramenta.

Robocup

História

A ideia de robôs competindo numa partida de futebol vem de longa data. No ano de 1992 [10] este assunto foi comentado pela primeira vez no artigo On Seeing Robots do Professor Alan Mackworth (University of British Columbia , Canadá), publicado no ano seguinte no livro Computer Vision: System, Theory, and Applications , páginas 1-13, World Scientific Press , Singapura, 1993.
Em Outubro de 1992 em Tóquio [11], um grupo de pesquisadores japoneses organizou um workshop sobre Grandes desafios em Inteligência Artificial. Durante este evento as discussões guiaram as atenções para o uso de jogos como forma de promover tecnologia e ciência. Em 1993, idealizada por Minoru Asada, Yasuo Kuniyoshi, e Hiroaki Kitano, teve início a primeira competição de futebol de robôs [12].
Inicialmente chamada de Robot J-League , este evento imediatamente chamou a atenção de pesquisadores do mundo todo que propuseram estender esta iniciativa a um projeto colaborativo internacional. Assim, o evento foi renomeado para Robot World Cup Initiative, também conhecido como RoboCup. No mesmo ano foi feito o primeiro anúncio público sobre esta iniciativa, definidas as primeiras regras e lançada a primeira versão do Soccer Server Version 0 , primeiro simulador aberto que permitiu o desenvolvimento de pesquisas com sistemas multi-agentes, construído em linguagem LISP, seguido pela versão 1.0 construída em C++.
Em 1996, foi realizada a Pre-RoboCup, durante a International Conference on Intelligence Robotics and Systems (IROS-96), realizada de 4 a 8 de novembro em Osaka. Participaram deste evento oito equipes com simuladores e demonstração de robôs médios.
E finalmente, após muitos anos de pesquisas e aperfeiçoamentos nos moldes do campeonato, foi realizado em 1997 o primeiro

RoboCup Games and Conference .

Objetivos

O principal foco da RoboCup é promover pesquisas em robótica e inteligência artificial de uma maneira mais amigável e com certo apelo publicitário. Por entender que estabelecer metas é uma maneira eficaz de desenvolver estas pesquisas, é tido como objetivo à longo prazo:
“By mid-21st century, a team of fully autonomous humanoid robot soccer players shall win the soccer game, comply with the official rule of the FIFA, against the winner of the most recent World Cup.”[13]

As Modalidades da RoboCup

A RoboCup é um tipo de problema padrão que permite que várias teorias, algoritmos e arquiteturas sejam testadas, combinando as complexidades do mundo real dentro de um mundo limitado. Diversas áreas de pesquisa sobre Inteligência Artificial (IA) e robótica [14], tais como sensores de tempo real, comportamento reativo, sistemas multi-agentes, reconhecimento de contexto, visão e controle de robôs inteligentes, entre outras, estão envolvidas e para isso existem várias modalidades de campeonato, cada uma com suas particularidades e regulamentação própria. São elas:

RoboCup Rescue

A robocup rescue é dividida em duas categorias principais: a RoboCup Simulation Project e a Real Robots Project ;

que atuam como um padrão para pesquisadores na área de desastres[15].

Tem como objetivo principal realizar pesquisa e desenvolvimento envolvendo agentes diversos em áreas hostis em vários níveis de interação[16]. Coordenação de equipes de trabalho multi-agentes, busca e salvamento, agentes robóticos físicos e estratégias de salvamento, são alguns exemplos das pesquisas realizadas. Esta competição que segue os moldes da RoboCup Soccer e provome fóruns técnicos e testes competitivos para pesquisadores e praticantes, foi idealizada após o terremoto Hanshi-Awaji que atingiu a cidade de Kobe no Japão em 1995 [17].

RoboCup @Home

Considerada a maior competição internacional anual de robôs autônomos [18] a Robocup @Home teve início em 2006 e está voltada para o ambiente humano diário AtHome2. Esta modalidade tem como objetivo principal desenvolver tecnologias para robôs assistenciais para aplicações domésticas.
A competição testa a habilidade dos robôs em ambientes domésticos desconhecidos [19] em quesitos que envolvem entre outras coisas:
  • interação cooperativa entre humanos e robôs;
  • manipulação de objetos (portas, utensílios de cozinha, copos, etc.);
  • Navegação em ambientes domésticos dinâmicos;
  • visão computacional e reconhecimento de objetos sob luz natural;
  • comportamento adaptativo.


RoboCup Soccer

As competições de futebol são a principal atividade da RoboCup [20] e permitem que os pesquisadores troquem informações técnicas sobre robótica e inteligência artificial. Esta modalidade envolve as ligas Humanoid , Middle Size Robot , Simulation , Standard Plataform e a Small Size Robot, também conhecida como SSL, a qual é a base de estudo deste trabalho.

Humanoid League

Nesta liga, robôs autônomos bípides com corpo e sentidos parecidos com humanos, competem entre si [21]. Eles devem ter a habilidade de correr, andar e chutar a bola ao mesmo tempo em que mantém o equilíbrio e percebem a posição da bola e dos outros jogadores no campo, além de reconhecerem sua própria posição. A Humanoid League é divida em três subgrupos:
  • KidSize (altura: 30-60cm);
  • TeenSize (altura: 100-120cm);
  • AdultSize (altura: 130cm ou mais).

Middle Size Robot League (MSL)

Utiliza robôs com até 50 cm de diâmetro em equipes de até seis jogadores [22]. Os robôs devem ter todos os sensores onboard e utilizar rede sem fio para comunicação.

Soccer Simulation League

São utilizados softwares para simular os robôs que jogam uma partida num campo virtual. Esta categoria está divida em quatro sub-ligas [23]. São elas: 2D, 3D, desenvolvimento 3D e realidade mista onde são utilizados robôs em miniatura fazendo uma ligação entre robôs reais e simulados.

Standard Plataform

É uma liga de futebol onde todas as equipes utilizam o mesmo modelo de robô [24]. Este robô é totalmente autônomo,

devendo ser previamente programado e não pode ser controlado externamente nem por humanos nem por computador. Atualmente são utilizados os robôs NAO desenvolvidos pela empresa Aldebaran Robotics. Estes robôs são totalmente programáveis através do software Coregraphe , também desenvolvido pela Aldebaran Robotics[25]. O software é multi-plataforma e aceita as linguagens C, C++, URBI e Python[26].

Small Size Robot League (SSL ou F180)

Liga formada por robôs pequenos, tem como objetivo estudar problemas de cooperação entre multi-agentes inteligentes e cooperação em ambientes dinâmicos através de um sistema híbrido (centralizado/distribuído) [27].
De acordo com as regras [28], um robô deve ser cilíndrico, ter no máximo 180 mm de diâmetro e 150 mm de altura. A comunicação com o computador é feita por wireless e cada robô deve seguir um padrão de cores no topo identificando equipe e numero do robô. Esta identificação servirá como padrão de reconhecimento para o sistema de visão compartilhada (SSL-Vision ).
Cada equipe é formada por até cinco robôs, já incluído o goleiro. A identificação deve ser clara o suficiente para que o robô possa ser facilmente reconhecido pelo juiz e o goleiro deve ser identificado antes do início da partida. Os robôs devem jogar de forma totalmente autônoma.
Uma partida é composta de dois tempos com duração de dez minutos cada, com um intervalo de no máximo cinco minutos entre eles. O campo, conforme visto na figura 1, deve ser retangular e medir entre as linhas, 6050 mm de comprimento por 4050 mm de largura, a superfície deve ser recoberta com um carpete verde e é utilizada uma bola de golfe de cor laranja.
  • Matriz de Cores Padrão: Antes do início da partida cada equipe recebe uma cor que pode ser azul ou amarela. As figuras 2 e 3 mostram o padrão que deve ser seguido para que o SSL-Vision reconheça cada robô. Um adesivo com a cor da equipe deve ser colada no centro do topo de cada robô. Além deste, mais quatro adesivos são dispostos no topo de cada robô informando a identificação numérica de cada um.
  • SSL-Vision: Até a RoboCup 2009 era permitido, e a maior parte das equipes preferia, utilizar câmeras de vídeo em cima ou perto do campo. Normalmente eram utilizadas duas câmeras, uma em cada metade do campo, Isto ocasionava um longo tempo gasto para configurar corretamente as câmeras antes e até durante o jogo -- se em cada campo disputassem cinco equipes, era necessário instalar e calibrar dez câmeras. O comitê organizador resolveu então adotar a partir da RoboCup 2010 um sistema de visão compartilhada chamado SSL-Vision [29]. Este sistema é implementado em linguagem C++ e desenvolvido por integrantes das equipes competidoras. Ele consiste em um único conjunto de câmeras conectadas em um servidor de processamento de imagens que identifica as posiões da bola e dos jogadores, e redistribui estas informações para as equipes participantes, conforme figura 4.

Ambientes de Simulação Robótica}

Durante o desenvolvimento deste projeto, foram analizados alguns sistemas de simulação de robôs utilizados para a RoboCup. A seguir é apresentado um estudo elaborado sobre estes sistemas.

Sistema Estrategista para Futebol de Robôs

O Sistema Estrategista para Futebol de Robôs foi desenvolvido por Hugo Goveia com o objetivo de tratar assuntos relacionados ao futebol robótico,

dando continuidade à pesquisa iniciada na Faculdade de Informática de Presidente Prudente (FIPP)[30].

Em seu trabalho, Goveia desenvolveu um ambiente virtual que simula uma disputa entre um time controlado pelo usuário e outro que obedece às decisões

tomadas pelo Sistema Estrategista[31].

O software foi desenvolvido em Borland C++ Builder. Este está organizado de maneira a permitir o controle dos robôs de um dos times por um usuário humano, que recebe comandos via teclado, enquanto o outro time obedece aos comandos definidos por estratégias implementadas[32]. As informações de localização dos robôs ficam armazenadas em um vetor de oito posições, cada qual referente a um robô[33].
A Figura 5 representa a tela da simulação das estratégias. O campo é constituído por uma escala para as medidas reais da categoria MiroSot, onde são feitos os tratamentos de colisão entre os robôs, bolas e laterais, de maneira que os elementos não saiam do campo.
Em seu trabalho, Goveia focou o desenvolvimento do Sistema Estrategista. Dessa forma, seu software de simulação é limitado em relação ao Tewnta, objeto de estudo deste trabalho.

Webots

Iniciado em 1996, pelo Dr. Olivier Michel no Instituto Federal Suíço de Tecnologia, Webots é um software de prototipagem e de simulação robótica profissional utilizado para fins educativos[34].
Esse software utiliza o ODE (Open Dynamics Engine ), cuja biblioteca permite simular com precisão as propriedades físicas dos objetos, para detecção de colisões e simulação dinâmica de corpos rígidos[35].
O programa apresenta uma coleção de robôs modificáveis e, além disso, há a possibilidade de criação de novos modelos. Para a projeção de um novo modelo de robô, o usuário especifica os anúncios gráficos, como forma, dimensões, posição e cores do objeto e propriedades físicas, que abrangem massa, coeficiente de atrito, mola e amortecimento[36].
O uso de uma prototipagem rápida e software de simulação é muito útil para o desenvolvimento de projeto de robótica mais avançada. Ele realmente permite visualizar previamente o controle inteligente de robôs para, eventualmente, transferir os resultados da simulação em um robô real. Por isso, tanto o tempo de desenvolvimento e a qualidade dos resultados são melhores usando uma prototipagem rápida e software de simulação[37].
Outra vantagem da Webots é a compatibilidade com diversas linguagens de programação, os programas de controle do robô podem ser escrito em C, C++, Java,

Python e MATLAB[38]. As Figuras 6 e 7 são um exemplo de simulação feita pela Webots.

Webots é um simulador de cunho genérico. Dessa forma, a representação dos eventos físicos é robusta. No entanto, não é seu intuito simular uma partida de Futebol de Robôs. Outra limitação em relação ao Webots é o seu custo. Por se tratar de um software profissional, possui apenas uma versão demo livre, que não pode ser modificada[39].

The Robocup Soccer Simulator

The Robocup Soccer Simulator é simulador oficial da RoboCup, dessa forma é o software mais completo e funcional de todos estudados. É composto por um servidor e por um monitor.
O servidor é um sistema que permite a várias equipes competir em um jogo de futebol. Como o jogo é realizado em um estilo cliente-servidor,

não há restrições quanto à forma como as equipes são construídas. A única exigência é que as ferramentas de suporte de comunicação cliente-servidor sejam via UDP/IP (User Datagram Protocol / Internet Protocol ) pois todas as comunicações entre o servidor e cada cliente são feitas via sockets UDP/IP. Cada cliente é um processo separado e se conecta ao servidor através de uma porta especificada. Depois que um jogador se conecta ao servidor, todas as mensagens são transferidas através desta porta. Uma equipe pode ter até 12 clientes, ou seja, 11 jogadores e um treinador[40].

Os jogadores enviam pedidos para o servidor quanto às ações que desejam realizar, como por exemplo, chutar a bola, girar ou correr. O servidor recebe estas mensagens, processa os pedidos, e atualiza o ambiente em conformidade. Além disso, o servidor fornece a todos os jogadores as informações sensoriais

(por exemplo, informações visuais sobre a posição dos objetos no campo, ou dados sobre os recursos do jogador, como resistência ou velocidade) [41].

É importante mencionar que o servidor é um sistema em tempo real, trabalhando com intervalos de tempo discretos. Cada ciclo tem uma duração específica, e as ações que precisam ser executadas em um determinado ciclo, têm de chegar ao servidor durante o intervalo de direito. Portanto, o desempenho de um jogador lento, que resulta em perda de oportunidades de ação tem um impacto importante sobre o desempenho da equipe como um todo[42].
A tela de visualização apresenta informações de pontuação, nomes de equipe e as posições de todos os jogadores e da bola. A interface é simples para o servidor e possui diversas conveniências. Como pode ser vista nas Figuras 8 e 9. Há a possibilidade de zoom em áreas de campo, para fins de depuração, de mover os jogadores e a bola com o mouse e de imprimir as posições e velocidades atuais dos jogadores e da bola em qualquer momento[43].
Para executar um jogo no servidor, não é necessário um monitor. No entanto, em um mesmo servidor, pode haver vários monitores conectados,

caso haja a necessidade de mostrar o mesmo jogo em terminais diferentes[44].

Tewnta

Tewnta é um software de simulação de futebol de robôs, baseados nos parâmetros da modalidade Small Size League (SSL),

também conhecida como F180. Projeto originário da UFRGS, foi desenvolvido por Gabriel Detoni, em 2008, em linguagem Java com o objetivo de simular uma partida de futebol de robôs pequenos nos moldes de RoboCup. É um programa de código aberto e de componente gráfico bem desenvolvido[45].

O Tewnta é utilizado na UTFPR na disciplina de Sistemas Inteligentes I do Curso de Engenharia da Computação, como ferramenta de ensino de algoritmos

de Inteligência Artificial. E também é usado pela equipe de Futebol de Robôs da UTFPR para testes dos algoritmos de controle dos robôs.

Quando o estudo foi iniciado, a versão então disponível do Tewnta\footnote{Versão 1.2 de 2 de Dezembro de 2009} no site oficial

possuia algumas limitações com relação à simulação física e à interpretação de algumas regras do Futebol de Robôs. No entanto, durante o trabalho, uma nova versão do Tewnta foi lançada. A versão 1.3 apresentava algumas melhorias em relação à anterior, como o tratamento adequado das colisões entre robôs e bola; melhor implementação da aceleração dos robôs. Ainda assim, problemas como a validação correta do gol, volta dos jogadores à posição inicial após um gol não foram corrigidos.

Tewnta se destaca dos demais simuladores englobar características como código fonte aberto, sob a licença GNU Lesser General Public License ,

simulação muito próxima da realidade de uma partida de futebol, simplicidade no uso, funcionabilidade e adaptabilidade. Sua interface pode ser visualizada na Figura 10

Estudo do Código Fonte

O estudo apresentado a seguir foi elaborado pelos integrantes da equipe para melhor compreensão do código fonte, baseando-se principalmente na documentação oficial do Tewnta [46] e no Livro Java Como Programar JavaComoProgramar.

Visão Geral

Tewnta é um software simulador de Futebol de Robôs desenvolvido em Linguagem de Programação Java. Java é uma Linguagem de Programação que trabalha com o paradigma Orientado a Objetos desenvolvido originalmente pela Sun Microsystems, em 1991JavaComoProgramar. Programas Java estão divididos em Pacotes (Packages ), estes estão divididos em Classes (Class ), e as Classes por sua vez, estão divididas em métodosJavaComoProgramar.
O Tewnta trabalha em duas camadas, a primeira atua como Servidor ,e é responsável pela simulação física e interpretação das regras do Futebol de Robôs. Uma segunda camada atua como Cliente , nela estão definidas as ações que devem ser tomadas pelos robôs. Para cada um dos times há uma aplicação cliente sendo executada. (Como pode ser visto na Figura 12). Essas duas camadas são executadas em aplicações diferentes que se comunicam através de protocolo IP (Internet Protocol).
O fluxo básico da aplicação consiste em:


  1. Iniciar Servidor;
  2. Iniciar Cliente;
  3. Conexão entre Servidor-Cliente;
  4. Início da Partida;
  5. Servidor computa o estado da partida e o transmite para o cliente(13);
  6. Cliente determina a próxima ação a ser tomada e a passa para o servidor; volta a 13


Um modelo em diagrama de blocos do fluxograma do programa pode ser visualizado na Figura 14.
A Linguagem de Programação Java trabalha com o conceito de Máquinas Virtuais JavaComoProgramar. As Máquinas Virtuais trabalham como intermediários entre a aplicação e o Sistema Operacional, interpretando os comandos dentro da aplicação e os convertendo para os respectivos comandos do Sistema Operacional. Devido a esse fato, o Tewnta pode ser executado em qualquer Sistema Operacional que possua uma JVM (Java Virtual Machine ).

Pacotes e Classes

A seguir apresentamos a relação dos pacotes e classes em que está dividida a versão original\footnote{Versão 1.3, disponível no site oficial em (28/09/2010} do software Tewnta.

br.ufrgs.f180.math

Pacote de bibliotecas matemáticas comuns utilizadas em todo o programa.

Point

Representa um ponto no plano com coordenadas X e Y (valores reais). Inclui também operações elementares como distância até um ponto, subtração de pontos

Line

Representa uma linha no plano com dois pontos P1 e P2. Inclui operações como distância até um ponto e projeção perpendicular de um ponto

Circle

Representa um círculo no plano com um centro (Classe Point ) e um raio de valor real.

Matrix

Representa uma matriz 2x2, inclui a operação de multiplicação por um ponto (Classe Point ).

Vector

Representa um vetor. É uma especialização da classe Point e implementa a interface Cloneable. Inclui operações matemáticas como cosseno e seno entre dois vetores; rotação de um vetor, soma, subtração e mutiplicação vetores.
Durante a simulação, grandezas físicas como Velocidade, Aceleração e Força são representadas como objetos da classe Vector.

MathUtils

Funções auxiliares úteis genéricas: como normalização de um valor entre 0 e 1 e subtração de radianos.

br.ufrgs.f180.api

Pacote com a API (Application Programming Interface, Interface de Programação de Aplicações ) fornecida aos jogadores para se comunicar com o simulador.

Player

Principal API fornecida aos jogadores (Equipes de Futebol de Robôs) para se conectar e comunicar com o simulador. Seu objetivo é fornecer a mesma visão que se tem em um jogo de futebol de robôs real. As APIs são publicadas como serviço Web e estão disponíveis assim que o sistema é iniciado.
A classe Player é uma Interface Java.
Um fluxo normal de jogo consiste em:


  1. Login da equipe;
  2. Registro de até cinco jogadores;
  3. Fornecimento do movimento (ação) dos jogadores(15);
  4. Ler a posição dos jogadores e informações;volta a 15
  5. Desconectar.


PlayerImpl

Por se tratar de uma Interface, a classe Player necessita de uma Implementação, esse é o papel da classe PlayerImpl .

br.ufrgs.f180.api.model

Pacote com um conjunto de informações sobre os elementos do jogo. As classes desse pacote apenas armazenam informações, não executando ações.

ElementInformation

Classe genérica dentro do pacote, representa qualquer elemento do jogo. Possui informações como posição, velocidade, ângulo.

BallInformation

Especialização da classe ElementInformation para representar informações sobre a bola.

RobotInformation

Especialização da classe ElementInformation para representar informações sobre os robôs. Acrescenta à classe ElementInformation informações acerca das ações dos robôs, como se ele está chutando ou driblando.

GameInformation

Especialização da classe ElementInformation para representar informações sobre o jogo. Contém informações como nomes dos times em campo, listas de objetos da classe RobotInformation .

br.ufrgs.f180.elements

Pacote com os elementos físicos visuais do jogo.

VisualElement

Interface que representa um elemento visual qualquer do jogo, é uma classe genérica especializada pelas demais.

MovingElement

Classe abstrata que representa um elemento que se movimenta no jogo, implementação de VisualElement . Por representar objetos que se movem, possui parâmetros como velocidade, aceleração, força e métodos como calcular velocidade, calcular rotação, calcular colisão.

GameField

Classe responsável por representar tanto a simulação física quanto a apresentação visual do campo de jogo, com origem cartesiana no canto esquerdo inferior da tela. Nessa classe estão contidos todos os elementos do jogo, como a bola, os robôs, as paredes.

Wall

Classe que representa uma parede, implementa VisualElement . Uma parede é representada pela semi-reta entre dois pontos.

WallCollisionPoint

Classe para simular um ponto da parede com massa infinita, especializa MovingElement. É utilizada para melhor simulação da colisão entre a bola e os robôs com as paredes.

Ball

Classe para representar a bola, especializa MovingElement .

Robot

Classe para representar o robô, especializa MovingElement . Contém métodos relativos ao robô, como a instrução para chutar, driblar, andar para frente, rotacionar.

br.ufrgs.f180.gui

Pacote com a GUI (Graphical User Interface ).

AboutDialog

Janela Sobre .

MainWindow

Janela principal do programa, contém o método main do programa e os métodos da atualização da interface. Nela estão contidos todos os métodos responsáveis por desenhar o campo, a bola e os robôs na tela e informar graficamente dados como posição e velocidade dos jogadores.

TrailAnalyserWidget

Janela que exibe um histórico das posições dos jogadores em campo. Pode ser acessada a partir da Janela Principal.

br.ufrgs.f180.resources

Pacote com recursos necessários para o jogo.

GameProperties

Classe responsável por importar do arquivo parâmetros da simulação, como dimensões do campo, velocidade máxima do robôs.

Especializa a classe Properties, genérica do Java.

br.ufrgs.f180.server

Pacote com informações do servidor e do jogo.

Game

Classe que representa o jogo. Nesta classe estão contidos os métodos que controlam o fluxo e as regras jogo. Por conter os métodos de controle da dinâmica do jogo, pode ser considerada uma das classes mais importantes do software.

Server

Classe responsável por implementar o servidor do jogo para comunicação com os clientes. Através dos métodos dessa classe, os algoritmos que controlam os times se comunicam com o Tewnta.

br.ufrgs.f180.team

Pacote para um time de demonstração.

DemoTeam

Representa um time de demonstração.

com.cloudgarden.resource

Pacote para manipulação dos parâmetros do toolkit SWT, Standard Widget Toolkit .

SWTResourceManager

Classe única do pacote para manipulação de recursos gráficos como Fonte, Cor, Imagem e Cursor.

Diagrama de Classes

Diagrama de Classes elaborado pela equipe para o programa Tewnta. Nessa versão do diagrama, apresentamos cada pacote Java como um diagrama, para uma versão completa do diagrama [acesse].

Modificações Executadas

Durante o trabalho, buscou-se aperfeiçoar algumas limitações do Tewnta.
A seguir são apresentadas as correções feitas.


Validação do Gol

A versão 1.3 do Tewnta apresentava uma limitação em relação à validação do gol. Nessa versão, caso a bola passasse atrás do gol -- entre a trave do fundo e o fundo do campo -- , o algoritmo interpretava esse evento como gol.
Essa imperfeição poderia causar problemas na simulação, uma vez que algumas equipes poderiam ser beneficiadas com gols que não fizeram.

Arquivos modificados

  • /br/ufrgs/f180/server/Game.java
  • /br/ufrgs/f180/elements/GameField.java

Função modificada

  • public ScoredGoal goalScored()

Função criada

  • public static double getGoalDepth()

Descrição

A condição para validação do gol no código original era que a bola estivesse no retângulo imaginário entre os dois gols no meio do campo e estivesse fora da linha de fundo. A contribuição do trabalho consistiu em incluir a condição de a bola estar entre a linha de fundo e a barra de fundo do gol, em vez de o fundo do campo, como na versão original, como pode ser verificado no código 23.
Para executar essa correção, é necessária a informação da profundidade da trave do gol na classe server.Game, essa informação era visível apenas na classe elements.GameField , então criou-se uma função getter pública que retorna essa informação, como pode ser verificado no código 24.


CODIGO {codigo01a.java}


CODIGO{codigo01b.java}

Função fast-foward

Durante os testes dos algoritmos inteligentes no simulador os programadores precisam aguardar os 20 minutos de uma partida para obter os resultados. Um acréscimo interessante ao Tewnta seria acelerar o tempo da simulação. Na versão 1.3, foi implementado um método para desacelerar a simulação e vê-la em câmera lenta, dessa forma, o arcabouço necessário para uma simulação mais rápida já estava pronto nessa versão.

Arquivo modificado

  • /br/ufrgs/f180/gui/MainWindow.java

Função modificada

  • private void initGUI()

Descrição

Para executar a função de desaceleração do jogo, o Tewnta utilizava uma variável de valor real chamada elapsedTimePerCycle definida na classe gui.MainWindow , que representa quanto tempo se passa em um ciclo de jogo. O usuário controla o valor dessa variável através de uma barra de rolagem presente na tela principal do Tewnta, como pode ser visto na figura 25. O valor dessa barra rolagem varia entre 1 e 100, onde 100 representa um segundo por um segundo, isso é, um segundo na simulação significa um segundo no mundo real.
A contribuição do trabalho ao Tewnta consistiu em modificar o alcance dessa barra de rolagem, como mostra o código 26, mudando de 1-100 para 1-500. Dessa forma, o usuário pode definir uma simulação até cinco vezes mais rápida.

CODIGO{codigo02.java}


Jogadores voltarem a posição inicial após o gol

Uma regra do Futebol de Robôs que não havia sido implementada no Tewnta era a volta dos robôs a seu campo de origem após um gol, como acontece no futebol humano. O posicionamento inadequado dos robôs após um gol pode favorecer ou prejudicar algum time durante uma partida.

Arquivo modificado

  • /br/ufrgs/f180/server/Game.java

Função modificada

  • public void updateState(double d)

Funções criadas

  • private void setUpRobot()
  • private double [ ][ ][ ] initialPositions()

Descrição

Para implementar essa correção, era necessário inicialmente definir quais seriam as posições inicias dos jogadores após um gol. Essas posições foram definidas em termos relativos às dimensões do campo, de forma que cada time tivesse um robô goleiro, dois robôs em posição de defesa e dois robôs avançados.
Para facilitar a implementação, foi criada a função private double [ ][ ][ ] initialPositions , que define uma matriz de três dimensões de valores reais, onde a primeira dimensão representa o time ao qual pertence o robô (0-1); a segunda dimensão define o índice daquele jogador dentro do time (0-4); e a terceira dimensão representa a coordenada (X ou Y) do valor real (0-1). Para que as posições dos jogadores não sejam sempre as mesmas a cada gol, foi incluído um fator aleatório na determinação das posições que pode

variar a posição definida em até 10. A implementação da função initialPositions() pode ser vista no código 27.

CODIGO{codigo03a.java}

Implementada a definição das posições dos jogadores, o proximo passo foi criar uma função que alterasse as posições dos jogadores. Então, definiu-se a função setUpRobot que pode ser vista no código 28. Essa função obtém e percorre o vetor de MovingElement da classe MainWindow e verifica quais são robôs, e a qual time eles pertencem, então seta a posição de acordo com a definição feita na função initialPositions() .


CODIGO{codigo03b.java}

Depois de implementadas as duas funções anteriores era necessário invocá-las no momento certo do código, então alterou-se a função updateState , que já estava definida desde a versão 1.2 do Tewnta. Essa função, entre outras coisas, define o que deve ser feito após um gol, então foi chamada a função setUpRobot() dentro do bloco de código que é executado após um gol, como pode ser visto no código 29.

CODIGO{codigo03c.java}

Dimensões atualizadas do campo

No Futebol de Robôs, as dimensões do campo podem ser modificadas a cada ano. Prevendo isso, o Tewnta possui um arquivo texto (game.properties ) que fica no diretório /src do código fonte onde são definidos os parâmetros do campo.

Arquivo modificado

  • /src/game.properties

Descrição

Para adequar o Tewnta às regras 2010 do futebol de robôs foi necessário modificar os seguintes campos no arquivo game.properties , como

pode ser verificado no código 30:

  • field.height -- altura do campo;
  • field.width -- largura do campo;
  • field.border -- borda do campo, entre as paredes e as linhas.


CODIGO{codigo04.properties}

Modificações implementadas na versão 1.3

Colisão

Uma das correções propostas pela equipe no início do trabalho foi o tratamento adequado da colisão entre robôs. No entanto, essa correção foi implementada na versão 1.3 do Tewnta.
Para cálculo da colisão, primeiramente foi implementada uma função booleana na classe elements.MovingElement para definir se dois objetos estão em vias de se colidir, como mostra o código 31, através do cálculo da distância entre esses dois objetos.


CODIGO{codigo06a.java}

Caso a função definida no código 31 detecte a colisão entre dois elementos, o cálculo da colisão é feito através de uma colisão não elástica, como mostra o código 32.

CODIGO{codigo06b.java}

Aceleração

Para o cálculo de posição de um elemento, método public void calculatePosition(double timeElapsed) , no código 33, da classe elements.Movingelement , o algoritmo calcula primeiro a velocidade em função da aceleração (código 34) no Movimento Linear e então define a nova posição. Para o Movimento Rotacional, a aceleração rotacional é calculada (código 35) e então a velocidade rotacional é calculada, e só depois o novo ângulo é calculado.

CODIGO{codigo07a.java}

CODIGO{codigo07b.java}

CODIGO{codigo07c.java}

No entanto, a implementação da Aceleração Linear utilizada no Tewnta não considera particularidades de robôs e solo, o cálculo é baseado na equação 36: onde <math>F</math> é a força exercida pelos motores dos robôs, e <math>m</math> é a massa dos robôs. Apesar desses parâmetros serem definidos através do arquivo game.properties, através dos experimentos, pode-se observar que a relação expressa em 36 não expressa adequadamente a relação, porque desconsidera dissipações de energia inerentes ao movimento. Uma possível solução é apresentada em 38.
<math>
a = \frac{F}{m}
 (36)
</math>
A implementação utilizada para cálculo da aceleração rotacional (código 35) se baseia na equação 37 onde <math>F</math> é a força de rotação e <math>m</math> a massa do robô. No entanto, essa equação não considera o Momento de Inércia do corpo em rotação, o que afasta da realidade a simulação desse evento físico. Uma alternativa para essa implementação é apresentada em 39.
<math>
a = \frac{F}{m}
(37) 
</math>


Modificações a serem implementadas

Aceleração Linear

A potência exercida pelos motores dos robôs é constante, portanto, enquanto aceleram, a variação da velocidade é uniforme. Essa aceleração é influenciada por fatores como atrito entre as rodas e o campo, potência do motor e é melhor definida através de experimentos. Sendo assim, uma melhor implementação desse conceito seria definí-lo experimentalmente e

então incluir seu valor no Tewnta.

Para incluir a aceleração como um parâmetro definido pelo usuário, algumas modificações no código são necessárias:


  • Incluir no arquivo game.properties o parâmetro robot.linearAcceleration ;
  • Na classe elements.Robot criar uma variável linearAcceleration ;
  • Na classe elements.Robot sobreescrever o método getAcceleration() definido em elements.MovingElement ;

Aceleração Rotacional

Assim como a Aceleração Linear (38), é possível obter a Aceleração Rotacional a partir de experimentos, e esta também é constante em módulo durante o regime de aceleração do movimento de rotação. Assim, os passos para implementação desse parâmetro físico são semelhantes aos apresentados em 38.
  • Incluir no arquivo game.properties o parâmetro robot.rotationalAcceleration ;
  • Na classe elements.Robot criar uma variável rotationalAcceleration ;
  • Na classe elements.Robot sobreescrever o método getRotationAcceleration() definido em elements.MovingElement ;

Desacelaração

Um movimento de um robô num Futebol de Robôs pode ser definido em três regimes:
  • Aceleração: fase em que o módulo da velocidade aumenta;
  • Uniforme: fase em que o módulo da velocidade não varia;
  • Desaceleração: fase em que o módulo da velocidade diminui.
A implementação do cálculo de posição utilizada no Tewnta 1.3, Código 33, considera apenas os dois primeiros regimes, uma vez que as funções getAcceleration() e getRotationAcceleration() não consideram valores negativos para as acelerações. Para incluir a faixa de valores negativos no cálculo é necessário, antes, determinar no código fonte o momento em que o robô inicia sua desaceleração, e então calcular o decréscimo da velocidade. No mundo real, isso acontece quando os motores param de exercer força sobre as rodas. No ambiente simulado, isso acontecerá quando o método setForce() da classe elements.MovingElement receber um parâmetro negativo.

Tracker como ferramenta para o Futebol de Robôs

O Tracker é um software de código aberto destinado à análise de experimentos físicos. Para utilizar o programa, é necessário um vídeo com o movimento a ser analisado, que será decomposto em vários frames, para obtenção de resultados mais precisos e em curtos espaços de tempoManualTracker.
A seguir, apresenta-se um breve tutorial descrevendo os passos de utilização do software Tracker como ferramenta para calcular as constantes físicas envolvidas no ambiente do futebol da categoria F180. Com essas constantes calculadas, e as devidas correções implementadas, os valores poderão ser inseridos no software Tewnta.
Primeiramente serão necessários alguns itens.
  1. Um robô, categoria F180, e o piso no qual se darão os experimentos;
  2. Uma câmera digital com função de gravação de vídeos em alta resolução;
  3. Software Tracker -- Link para download: http://www.cabrillo.edu/~dbrown/tracker/ .
  4. Software Tewnta. -- Link para download: http://code.google.com/p/tewnta/ .

Filmagem

A filmagem deve ser feita de cima. A câmera deve focalizar a parte superior do robô. A câmera deve ficar imóvel enquanto grava o vídeo.

Movimento Linear

Após a câmera posicionada, inicia-se o movimento retilíneo. É importante que apareça o início do movimento na gravação e, preferencialmente, o fim do movimento na mesma filmagem. O robô não deve rotacionar, deve apenas locomover-se para frente até estabilizar -- quando atinge módulo de velocidade constante, ou seja, entra em Movimento Retilíneo Uniforme (MRU) -- e, em seguida, parar.

Movimento Rotacional

Após a câmera posicionada, coloca-se o robô para girar. O robô não deve locomover-se para frente ou para trás, deve apenas girar.

Tracker - Funções Gerais

O manual oficial dos desenvolvedores do Tracker contém todas as informações gerais para utilizar o programa e pode ser encontrado no site dos desenvolvedores ou diretamente através do link.

Tracker e sua utilização nos testes lineares com robôs

Ajustando o Tracker

Abra o vídeo do movimento linear de sua escolha através do menu Arquivo <math>></math> Abrir <math>></math> ...; selecione, na barra de duração, a parte do vídeo em que o robô está na eminência de começar o movimento até a parte imediatamente posterior ao término do movimento. Após isso, selecione o botão Eixos , logo abaixo do menu Trajetórias, e posicione a origem do eixo o mais precisamente possível no centro do robô; ajuste o ângulo dos eixos, caso não estejam alinhados com o movimento.
Após setado o eixo, clique no menu Trajetórias <math>></math> Novo <math>></math> Centro de massa; clique em Aceitar na janela que irá aparecer. Na janela Controle de Trajetórias clique ao lado direito do ponto verde (em uma situação padrão estará escrito cm ) e renomeie o centro de massa como quiser (caso não queira, não é necessário).

Novamente entre no menu Trajetórias <math>></math> Novo , porém agora clique em Ponto de Massa; na janela que abrir clique em Sim . Segure a tecla Shift e com o botão esquerdo do mouse clique no centro do robô, onde deve estar a origem, como na Figura 41.

Feito isso, clique no seu ponto de massa na janela Controle de Trajetórias e selecione autotrack , como na Figura 42.
Na parte 1.Mask pede-se para selecionar o ponto a ser acompanhado no movimento, por isso selecione, novamente, o centro do robô, como na figura 43.
Clique em Next . Depois em 2.Target , é onde ficarão as marcas do movimento. Pode deixá-lo do jeito que está; clique em Next. No passo 3.Accept clique em Next. No último passo, chamado 4.Search, clique no botão Start para o vídeo rodar e o robô começar o movimento, como mostra a figura 44.

Calculando a velocidade e aceleração instantâneas

A velocidade instantânea é definida Tipler1 como o limite da razão <math>\Delta x/\Delta t</math> quando <math>\Delta t</math> tende a zero. Este valor, como será visto a seguir, é igual ao coeficiente angular da reta tangente à curva de <math>x</math> para um determinado ponto. Na notação do cálculo esta equação pode ser escrita como em 45.
<math>
 v(t)=\lim_{\Delta t \to 0} \frac{\Delta x}{\Delta t}=\frac{dx}{dt}
 (45)
</math>
Outra forma de encontrar esta velocidade é fazendo uma análise de um gráfico da posição <math>x</math> versus o tempo <math>t</math>. Tornando cada vez menor o intervalo de tempo <math>t</math> em relação a um ponto <math>t_p</math>, as velocidades médias desses intervalos se aproximam cada vez mais do coeficiente angular da reta tangente naquele ponto. A esta inclinação dá-se o nome de velocidade instantânea Halliday1.
Após realizados todos os passos de 40, clique no menu \textit{Janela <math>></math> Vista Direita}. Com isso, serão apresentados, ao lado do vídeo, o gráfico da posição <math>x</math> versus <math>t</math>. Para saber velocidade instantânea e aceleração instantânea em cada tempo <math>t</math>, clique em Dados, no canto direito da tela e selecione 'v : intensidade da velocidade e 'a : intensidade da aceleração.
De posse dos dados coletados anteriormente, é possível traçar um gráfico de <math>v</math> versus <math>t</math> que descreve o movimento linear completo do robô,

partindo do repouso até atingir velocidade constante e retornando ao repouso, conforme mostra a figura 46. Desmembrando este gráfico em outros três, cada um representando um estágio do movimento, podemos definir analiticamente os valores corretos para calibração do software simulador Tewnta.

No primeiro estágio do movimento, o robô descreve Movimento Retilíneo Uniformemente Variado (MRUV), então derivando novamente a equação 45 obtemos o valor da aceleração do robô até ele atingir velocidade constante, como em 47.
<math>
 a(t)=\frac{dv}{dt}=\frac{d^2x}{dt^2}
 (47)
</math>
De outra forma, analisando graficamente, após linearizar o gráfico 48 o coeficiente angular (<math>a</math>) da reta é o valor da aceleração.
No segundo estágio do movimento, o gráfico 49 mostra que o robô atinge velocidade máxima e está em MRU, ou seja, a velocidade é constante e portanto a aceleração é zero. A partir do gráfico 49 é possivel extrair diretamente o valor da velocidade máxima atingida pelo robô.
De forma análoga ao primeiro estágio, no terceiro o robô novamente descreve MRUV, porém com aceleração negativa, então utilizando os mesmos métodos é possível determinar o valor da desaceleração do robô até que ele atinga o repouso.

Tracker e sua utilização nos testes rotacionais com robôs

Ajustando o Tracker

Abra o vídeo da rotação de sua escolha no menu Arquivo <math>></math> Abrir <math>></math> ...; selecione, na barra de duração, a parte do vídeo em que o robô está na

eminência de começar a rotação até a parte posterior ao fim da rotação. Feito isso, selecione o botão Eixos , logo abaixo do menu Trajetórias , e posicione a origem do plano o mais precisamente possível no centro do robô; ajuste o ângulo dos eixos, caso não esteja alinhado.

Após setado o eixo, clique no menu \textit{Trajetórias <math>></math> Novo <math>></math> Centro de massa}; clique em Aceitar na janela que irá aparecer; na janela Controle de Trajetórias clique ao lado direito do ponto verde (em uma situação padrão, estará escrito cm ) e renomeie o centro de massa como quiser (caso não queira, não é necessário). Novamente entre no menu Trajetórias <math>></math> Novo , porém agora clique em \textit{Ponto de Massa}; na janela que abrir clique em Sim . Segure a tecla Shift e com o botão esquerdo do mouse clique no centro do robô, onde deve estar a origem, como na Figura 41. Feito isso, clique no seu ponto de massa na janela Controle de Trajetórias e selecione autotrack , como na Figura 42.
Na parte 1.Mask pede-se para selecionar o ponto a ser acompanhado no movimento, por isso selecione uma das extremidades laterais do robô, como na Figura 51.
Clique em Next . Em 2.Target , é onde ficarão as marcas do movimento. Pode deixá-lo do jeito que está; clique em Next . No passo 3.Accept clique

em Next . No último passo, chamado 4.Search , clique no botão Start para que o vídeo inicie e o robô inicie o movimento, ficando como na Figura 52.

Calculando intensidades de velocidade e aceleração instantâneas

A velocidade angular instantânea é definada como o limite da razão <math>\Delta\Theta/\Delta t</math> quando <math>\Delta t</math> tende a zero Halliday1, ou seja,

é a derivada de <math>d\Theta</math> em relação a <math>dt</math>, como mostrado em 53

<math>
 \omega=\lim_{\Delta t \to 0} \frac{\Delta\Theta}{\Delta t}=\frac{d\Theta}{dt}
 (53)
</math>
Fazendo a derivada de segunda ordem da equação 53, é possível determinar a aceleração angular instantânea do robô, conforme mostrado na equação 54.
<math>
 \alpha=\frac{d^2\Theta}{dt^2}=\frac{d\omega}{dt}
 (54)
</math>
Também é possível determinar velocidade e aceleração angular através da velocidade e aceleração linear, respectivamente, multiplicando-as pelo raio do robô (medida do eixo de rotação até a extremidade)Tipler1.
Após realizados todos os passos de 50, clique no menu \textit{Janela <math>></math> Vista Direita}. Com isso, serão apresentados, ao lado do vídeo, o gráfico da posição <math>x</math> versus <math>t</math>. Para saber velocidade instantânea e aceleração instantânea em cada tempo <math>t</math>, clique em Dados ,

no canto direito da tela e selecione 'v : intensidade da velocidade e 'a : intensidade da aceleração.

Com os dados da velocidade e tempo, constrói-se o gráfico 55 que descreve o movimento completo da rotação do robô em termos de velocidade linear do ponto analisado. Este movimento também está divido em três estágios: aceleração, velocidade máxima (constante) e desaceleração. Desmembrando este gráfico nos três estagios conseguimos determinar estes valores na forma linear, para em seguida convertê-los para a forma angular.
A aceleração linear do ponto analisado é obtida através do coeficiente angular do gráfico 56.
A partir do gráfico 57 é possível extrair diretamente a velocidade máxima linear do ponto analisado.
E o coeficiente angular do gráfico 58 é igual à desaceleração linear do ponto analisado.

Calculando velocidade e aceleração angulares a partir da velocidade e aceleração instantâneas lineares

Para determinar a velocidade angular instantânea, utiliza-se o valor de <math>v</math> encontrado no gráfico 57 e o raio do robô na equação 59.
<math>
 \omega=\frac{v}{r}
 (59)
</math>
De forma análoga, para determinar a aceleração e a desaceleração angulares instantâneas do robô substitui-se os coeficientes angulares encontrados nos gráficos 56 e 58 na equação 60, determinando assim respectivamente os valores da aceleração e a desaceleração angulares.
<math>
\alpha = \frac{a}{r}
 (60)
</math>
Ou seja, as acelerações angulares podem ser encontradas dividindo a intensidade de aceleração linear da extremidade pelo raio do robô e a velocidade angular divindindo-se a intesidade da velocidade linear também pelo raio do robô.

Conclusão

O estudo e a elaboração de ambientes de simulação é importante pois contribui para pesquisas na área de robótica e melhorias de sistemas robóticos atuantes em diversas áreas. O futebol de robôs possibilita experimentar e validar diferentes técnicas da robótica, contudo, a implementação real dos robôs envolvidos pode ser complexa e trabalhosa.
Como a UTFPR mantém atividades referentes à Robocup é necessária a existência de um simulador eficiente de partidas, permitindo a experimentação de situações variadas sem a necessidade do uso dos robôs físicos para tais experiências. Devido a isso, o foco deste trabalho foi a adaptação do simulador Tewnta, já em uso pela UTFPR, para seu melhor aproveitamento.
Os demais simuladores de Robocup estudados não se encaixam em um perfil esperado para a UTFPR. Espera-se de um simulador: uma representação próxima da realidade; fácil entendimento; adaptabilidade; interpretação dos mesmos algoritmos usados nos robôs reais; e baixo custo.
Tewnta é um simulador que se aproxima dessas características: é de uso livre, logo, não incide custos diretos. Possui código aberto, portanto adaptável. Interpreta os mesmos algoritmos usados nos robôs reais. Dentro de um contexto em que se conhece a linguagem Java e a comunicação entre aplicações, é fácil de ser usado. Possui um algoritmo de simulação funcional, apesar de alguns comportamentos físicos e interpretações das regras do futebol de robôs não coincidirem completamente com a realidade.
Durante o trabalho, tentou-se aproximar a simulação do Tewnta de uma situação real. Para isso, foi feito um estudo do código fonte do programa em que procurou-se identificar onde e como eram definidas as diversas situações de jogo. Durante esse estudo pode-se perceber a dificuldade existente em analisar e interpretar um código feito por outra pessoa. A partir do momento em que a estrutura do programa foi compreendida, foi possível identificar com certa facilidade os pontos que precisavam ser alterados para atingir os objetivos propostos.
Durante o estudo, percebeu-se que a variedade de características de cada equipe de futebol de robôs impede que um simulador preveja todas as peculiaridades de um time, dessa forma, concluiu-se que seria mais adequado a personalização de parâmetros físicos. Então buscou-se métodos experimentais eficientes que determinassem esses parâmetros, fazendo a integração entre a Física e a Computação.
Apesar de não terem sido implementados todos os objetivos, percebeu-se que a estrutura do Tewnta permite que esses objetivos sejam codificados sem maiores dificuldades. Uma mudança considerável seria a implementação correta das constantes e limites físicos que podem ser obtidos a partir das técnicas e ferramentas de experimentos que foram usados, entre elas o software Tracker. Incluindo, assim, dados fenomenológicos na simulação do Tewnta.

Anexos

Tewnta - Iniciando

O Tewnta é hospedado no Google Code , um serviço Google para hospedagem de código aberto. O link do projeto. Na guia Project Home , além de um sumário sobre a aplicação, pode-se acompanhar as diversas atualizações do sofrware e nome das pessoas que contribuem para o projeto.
Na guia Downloads , pode-se fazer o download das diversas compilações do Tewnta, a saber:
  • Tewnta 1.3 for Linux x86
  • Tewnta 1.3 for Linux x64
  • Tewnta 1.3 for Windows x86
  • Tewnta 1.3 for Windows x64
Na guia Wiki , há uma página Wiki sobre a aplicação, com uma breve explicação sobre o licenciamento, como instalar e rodar a aplicação.
Na guia Issues , há um espaço para questões ao desenvolvedor do software, Gabriel Detoni, e as respostas que ele pode dar.
E finalmente na guia Source , há a explicação sobre como fazer download do código fonte.
Para baixar o Tewnta, é necessário possuir um cliente SVN (SubVersioN ) instalado na máquina. Comumente um cliente SVN é instalado nas distribuições Linux, em Windows há diversas opções para download:
Tendo instaldo o cliente SVN, é necessário dar o seguinte comando no prompt de comando:
svn checkout http://tewnta.googlecode.com/svn/trunk/ tewnta-read-only
Após o comando, o programa fará download do código fonte do Tewnta. Tendo sido feito o download, é necessário criar o projeto no Eclipse. Para executá-lo, é necessário rodar a classe br.ufrgs.f180.gui.MainWindows . Então aparecerá a tela do Tewnta.
Agora é necessário executar o time, o time de demonstração que acompanha a versão baixada do site do Tewnta está na classe br.ufrgs.f180.team.DemoTeam . Quando o time for executado, aparecerão na tela do Tewnta os jogadores. Para dar início à simulação basta clicar no botão Play no canto superior esquerdo da tela.
Ferramentas pessoais