Para visualizar o documento dos anais Clique Aqui!
Transcrição
Para visualizar o documento dos anais Clique Aqui!
ISSN: 2317-3505 Universidade Federal de Sergipe - UFS Departamento de Sistemas de Informação - DSI IV SEMANA DE INFORMÁTICA Itabaiana, Sergipe, Brasil 11-14 Novembro de 2014 Prefácio SEMINFO/UFSITA’2014 A Semana de Informática da Universidade Federal de Sergipe - Campus Itabaiana é um evento Regional, idealizado e organizado por professores e alunos do Departamento de Sistemas de Informação (DSI). Este ano, em sua quarta edição, possui o apoio da Itatech Jr. (empresa formada por alunos do departamento). Através de palestras, minicursos e apresentações de artigos acadêmicos, o evento visa proporcionar aos participantes acesso a novos conhecimentos, conceitos e tecnologias. As palestras e minicursos são ministradas por profissionais referência no mercado de tecnologia regional, proporcionando forte integração entre a comunidade acadêmica e a indústria. A sessão de artigos cientı́ficos, inaugurada em 2012, tem recebido submissões de todo o Brasil, criando um novo fórum de discussões para trabalhos cientı́ficos, que extrapolou as fronteiras regionais, onde o principal objetivo é a publicação de trabalhos cientı́ficos com resultados parciais ou finais, relevantes para a área de computação. Ainda nesta edição, foi iniciada uma nova modalidade para a submissão de trabalhos na forma de resumos, possibilitando também a publicação de trabalhos de conclusão de curso, iniciação cientı́fica ou pesquisas cientı́ficas em estágio inicial ou intermediário, com revisão bibliográfica e objetivos definidos. Foram 23 trabalhos submetidos, entre artigos completos e resumos, dos quais 14 receberam a aceitação do comitê avaliador. Para concluir, sempre colocando temas atuais em foco, em 2014 a Semana de Informática apresentará o tema “Semana Global do Empreendedorismo”. HISTÓRICO A primeira edição do evento ocorreu no perı́odo de 24 à 26 de novembro de 2010, na qual foram promovidas discussões sobre diversos temas, com destaque para o seguinte: “O Uso de Software Livre nas Instituições Públicas e Privadas”, além de minicursos nas áreas de redes e qualidade de software. A segunda edição aconteceu no perı́odo de 17 à 19 de outubro de 2012, sob o tema principal: “Empreendedorismo e Inovação”. Além das palestras e minicursos relacionados ao tema, o evento trouxe diversos casos de sucesso de empresas regionais, com a apresentação de dicas aos futuros empreendedores. Ainda nesse ano foi inaugurada a sessão de artigos cientı́ficos, na qual foram submetidos 17 artigos, sendo 11 aprovados. Os anais do evento foram registrados através do ISSN 2317-3505. A terceira edição ocorreu no perı́odo de 05 à 08 de novembro de 2013, onde abordou-se o tema “Desenvolvimento Móvel e Geoprocessamento: A Nova Tendência” Prof. Msc. Andrés Ignácio Martı́nez Menéndez - Coordenação Geral Prof. Dr. Alcides Xavier Benicasa - Coordenador do Comitê do Programa i Comitê Organizador SEMINFO/UFSITA’2014 Coordenação Geral Prof. Msc. Andrés Ignácio Martı́nez Menéndez Universidade Federal de Sergipe - UFS Departamento de Sistemas de Informação - Itabaiana - SE Comitê Organizador Prof. Dr. Alcides Xavier Benicasa - UFS Prof. Dr. Methanias Colaço Rodrigues Júnior - UFS Prof. Msc. Andrés Ignácio Martı́nez Menéndez - UFS Prof. Msc. Marcos Barbosa Dósea - UFS Anderson dos Santos Farias - UFS Caique Santos Teixeira - UFS Ednilson Messias Castro dos Santos - UFS Euder de Jesus Costa - UFS Everton Mendonça Lima - UFS Flavio da Paixão de Carvalho - UFS Guilherme Bruno Viturino Alves - UFS Luan Lima - UFS Nathanael Oliveira Vasconcelos - UFS Victor Gutemberg Santos Lima - UFS Coordenador do Comitê do Programa Prof. Dr. Alcides Xavier Benicasa - UFS Universidade Federal de Sergipe - UFS Departamento de Sistemas de Informação - Itabaiana - SE ii Comitê do Programa SEMINFO/UFSITA’2014 Universidade Federal de Sergipe - UFS Departamento de Sistemas de Informação - Itabaiana - SE Profa. Msc. Mai-Ly Vanessa Almeida S. Faro Prof. Dr. Alcides Xavier Benicasa Prof. Dr. Eugênio Rubens Cardoso Braz Prof. Dr. Joseval de Melo Santana Prof. Dr. Methanias Colaço Rodrigues Júnior Prof. Msc. Adolfo Pinto Guimarães Prof. Msc. André Luis Meneses Silva Prof. Msc. André Vinicius Rodrigues Passos Nascimento Prof. Msc. Andrés Ignácio Martı́nez Menéndez Prof. Msc. José Aélio Oliveira Junior Prof. Msc. Marcos Barbosa Dosea Universidade Federal de Sergipe - UFS Departamento de Computação - São Cristovão - SE Profa. Dra. Kenia Kodel Cox Prof. Dr. Alberto Costa Neto Prof. Dr. André Britto de Carvalho Prof. Dr. Hendrik Teixeira Macedo Prof. Dr. Leonardo Nogueira Matos Prof. Dr. Ricardo Jose Paiva de Britto Salgueiro Prof. Dr. Rogério Patrı́cio Chagas do Nascimento iii Comitê do Programa SEMINFO/UFSITA’2014 Universidade Tecnológica Federal do Paraná - UTFPR-PG Departamento Acadêmico de Informática - Campus Ponta Grossa - PR Prof. Dr. Daniel Paiva Universidade Federal do Amazonas - UFAM Instituto de Ciências Exatas e Tecnologias - Itacoatiara - AM Prof. Dr. Jorge Yoshio Kanda Instituto Federal de Sergipe - IFS Informática - Aracaju - SE Profa. Msc. Danielle Amaral Menéndez Prof. Msc. Gilson Pereira dos Santos Júnior Instituto Federal de São Paulo - IFSP Tecnologia em Análise e Desenvolvimento de Sistemas - São Carlos - SP Prof. Ms. Giampaolo Luiz Libralon Instituto Nacional de Pesquisas Espaciais - INPE Instituto de Estudos Avançados - São José dos Campos - SP Prof. Ms. Marcelo Módolo iv Índice SEMINFO/UFSITA’2014 Análise Comparativa de Algoritmos de Mineração de Texto Aplicados a Históricos de Contas Públicas 1 Breno Santana Santos and Methanias Colaço Júnior . . . . . . . . . . . . . . . . . . . Proposta para Caracterização da Utilização de Técnicas para Prevenção da Erosão Arquitetural nas Empresas de TI no Brasil. 3 Ythanna Oliveira Gomes, Marcos Barbosa Dósea and Methanias Colaço Júnior . . . . XQPref: Um Sistema para Personalização de Consultas a Dados XML 5 Angélica F. Medeiros and Valéria Gonçalves Soares . . . . . . . . . . . . . . . . . . . . Algoritmos Avançados de Inteligência Artificial Aplicados ao Mapeamento de Ambiente e Controle de Trajetória de Robô 9 Iury Batista De Andrade Santos, Euder De Jesus Costa, Thiago Almeida, Nathanael Oliveira Vasconcelos and Alcides Xavier Benicasa . . . . . . . . . . . . . . . . . . SINTRALIB - Sistema Integrado Tradutor de LIBRAS - Comunicação para todos 11 Maily Faro, Anderson Cunha and Guilherme Alves . . . . . . . . . . . . . . . . . . . . Utilização de Lógica Fuzzy para Roteamento de Sensores Sem Fio - Implementação com JFuzzyLogic e Repast Simphony 15 Daniele Freitas de Jesus, João Henrique Kleinschimdt and Maria Das Graças Bruno Marietto . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Interação Natural Baseado em Inteligência Artificial e Processamento de Imagens: Uma Alternativa ao Uso de Sensores Reais 19 Nathanael Oliveira Vasconcelos, Thiago Almeida and Alcides Xavier Benicasa . . . . . Proposta de Mecanismo de Detecção e Reconhecimento de Semáforos Baseado em Atenção Visual e Inteligência Artificial 21 Thiago Almeida, Nathanael Oliveira Vasconcelos and Alcides Xavier Benicasa . . . . . Sistema Tradutor LIBRAS - Português/Português - LIBRAS Maily Faro, Anderson Cunha and Guilherme Alves . . . . . . . . . . . . . . . . . . . . v 23 Processamento de Imagens e IA aplicado à Apresentação Interativa: Uma Comparação entre um Método Interativo Tradicional e um Método Interativo Fuzzy 25 Nathanael Oliveira Vasconcelos, Thiago Almeida, Ed Charles Nascimento Ferreira, Breno Santana Santos and Alcides Xavier Benicasa . . . . . . . . . . . . . . . . . Planejamento da Melhoria do Processo de Testes do Centro de Processamento da Universidade Federal de Sergipe Baseado no MPT.BR 29 Weverton Dos Santos and Marcos Barbosa Dósea . . . . . . . . . . . . . . . . . . . . . Em Direção à Melhoria do Processo de Aplicação de Surveys em Engenharia de Software 31 Antônio Douglas, Erivan Lima and Marcos Barbosa Dósea . . . . . . . . . . . . . . . . Planeta Saudável, Consumo Consciente em Jogo 33 Ícaro M.R. Oliveira, Isaac Argolo and Kenia Kodel . . . . . . . . . . . . . . . . . . . . Uma Solução de Business Intelligence para Apoio a Decisão à Coordenadoria de Cursos 37 Onezino Gabriel Moreira, Ramon Ramos and André Britto . . . . . . . . . . . . . . . vi Índice de Autores SEMINFO/UFSITA’2014 Almeida, Thiago 9, 19, 21, 25 Alves, Guilherme 11, 23 Argolo, Isaac 33 Benicasa, Alcides Xavier 9, 19, 21, 25 Britto, André 37 Colaço Júnior, Methanias 1, 3 Costa, Euder De Jesus 9 Cunha, Anderson 11, 23 Dos Santos, Weverton 29 Douglas, Antônio 31 Dósea, Marcos Barbosa 3, 29, 31 Faro, Maily 11, 23 Ferreira, Ed Charles Nascimento 25 Gonçalves Soares, Valéria 5 Jesus, Daniele Freitas de 15 Kleinschimdt, João Henrique 15 Kodel, Kenia 33 Lima, Erivan 31 Marietto, Maria Das Graças Bruno 15 Medeiros, Angélica F. 5 Moreira, Onezino Gabriel 37 Oliveira Gomes, Ythanna 3 Oliveira, Ícaro M.R. 33 Ramos, Ramon 37 Santos, Breno Santana 1, 25 Santos, Iury Batista De Andrade 9 Vasconcelos, Nathanael Oliveira 9, 19, 21, 25 vii Índice de Palavras-Chave SEMINFO/UFSITA’2013 Algoritmos de Mineração 1 Apoio a Decisão à Coordenadoria de Curso Aprendizado por Reforço 37 9 Atenção Visual 21 Business Intelligence 37 Comunicação 11, 23 Consumo Consciente 33 Contas Públicas 1 Dados Abertos Governamentais 5 Desenvolvimento de Jogos de Computador 33 Detecção de Semáforo 21 Energetic 15 Engenharia de Software 29, 31 Erosão Arquitetura 3 Ferramenta 31 Imagem Projetada 19, 25 Inclusão social 11, 23 Inteligência Artificial 9, 19, 21, 25 Interação Humano-Computador 19, 25 JFuzzyLogic 15 Jogos Educativos 33 KDT 1 LIBRAS 11, 23 viii Lógica Fuzzy 15, 25 Mapeamento Métrico Probabilı́stico 9 Mineração de Texto 1 MPT.BR 29 Métodos de Busca 9 Métricas 1 OLAP 37 Personalização de Consultas 5 Processamento de Imagens 19, 25 Processo de Testes 29 Reconhecimento de Semáforo 21 Repast Simphony 15 Robôs Móveis Autônomos 9 Simulation 15 Software tradutor 23 Survey 3, 31 Tradutor eletrônico 11 Trânsito 21 Técnicas 3 Wireless Network Sensor 15 XML 5 ix Análise Comparativa de Algoritmos de Mineração de Texto Aplicados a Históricos de Contas Públicas Breno Santana Santos Prof. Dr. Methanias Colaço Rodrigues Júnior Departamento de Sistemas de Informação – DSI Universidade Federal de Sergipe – UFS Itabaiana-SE, Brasil e-mail: [email protected] Departamento de Sistemas de Informação – DSI Universidade Federal de Sergipe – UFS Itabaiana-SE, Brasil e-mail: [email protected] Resumo — Grandes massas de dados são geradas pelas aplicações que apoiam as atividades rotineiras das organizações. Grande parte desses dados estão em formato textual, sendo possível o uso da Mineração de Texto para detector padrões potencialmente úteis e previamente desconhecidos. O objetivo do referido trabalho é avaliar o desempenho e qualidade de algoritmos de mineração de texto aplicados a históricos de contas públicas custodiadas pelo Tribunal de Contas de Sergipe. Para realizar a avaliação, serão definidas a coleta das métricas de Tempo Médio, Acurácia, Precisão e Cobertura, bem como a realização de um estudo de caso. Palavras-chave – Mineração de Texto; KDT; Contas Públicas; Métricas; Algoritmos de Mineração I. INTRODUÇÃO Na era da informação, esta passou a ser um dos maiores bens de uma organização, tendo o poder de influenciar no processo de tomada de decisão. Grandes massas de dados são geradas diariamente pelos sistemas que apoiam as atividades rotineiras das organizações, dificultando a tarefa analítica dos gestores. Diante dessa necessidade, surgiram os Sistemas de Apoio à Decisão (SADs) que, segundo Colaço Júnior [2], permitem apoiar, contribuir e influenciar no processo de tomada de decisão. Os SADs permitem, a partir dos dados transacionais da organização, gerar informações gerenciais que facilitam o referido processo. Como grande parte dos dados manipulados pelas organizações está em formato textual, torna-se fundamental o uso da técnica de Mineração de Texto (também conhecido por Knowledge Discovery in Texts, KDT, em inglês) para identificar padrões e conhecimentos para auxiliar nas decisões. De acordo com Balinski [1], Feldman et al. [3], Magalhães [4], Sá [5] e Souza [6], KDT é o processo de descoberta de conhecimento em bases textuais, sendo esse conhecimento gerado, útil e previamente desconhecido. Para Wives [8], o conhecimento gerado pode ser avaliado para determinar se o mesmo é relevante ou não para o usuário, ou seja, avaliar o desempenho do processo de mineração para a geração do conhecimento. Existem várias métricas, sendo as principais relacionadas ao desempenho, à acurácia, precisão e cobertura. A proposta do trabalho é comparar o desempenho e qualidade de dois algoritmos de mineração de texto aplicados a históricos de contas públicas custodiadas pelo Tribunal de Contas de Sergipe (TCE-SE). O Departamento de Sistemas de Informação, do Campus Alberto Carvalho – UFS, de posse de uma base de dados de teste cedida pelo TCE-SE, desenvolveu uma aplicação que realiza a mineração de texto em qualquer campo descritivo de um sistema. A aplicação permite determinar se os registros são ou não evidências de irregularidades, ou seja, se uma descrição está ou não de acordo com a lei e com o que se espera dos jurisdicionados. Desta forma, a ferramenta tem como objetivo tornar efetivo o trabalho do auditor na identificação de irregularidades. Para classificar os registros, a aplicação utiliza o algoritmo de análise estatística, Naïve Bayes, de forma parametrizada, especificando um limiar mínimo para auxiliar no processo classificatório. O referido algoritmo foi escolhido mediante pesquisa bibliográfica, a qual determina que Naïve Bayes é considerado o melhor classificador para campos descritivos. Este trabalho introduzirá um segundo algoritmo, o qual será determinado por pesquisa bibliográfica sobre o uso do mesmo em campos descritivos, e avaliará métricas de qualidade e desempenho para as duas abordagens. A avaliação dar-se-á por meio da coleta de métricas de tempo médio, acurácia, cobertura e precisão de cada algoritmo, bem como será realizado um estudo de caso para analisar e comparar os resultados das métricas. Sendo assim, os resultados das métricas permitem determinar o melhor algoritmo de mineração e, consequentemente, a qualidade e o desempenho do processo de mineração. Com o melhor algoritmo de mineração, o conhecimento gerado será efetivo e relevante para os auditores na descoberta de irregularidades como, por exemplo, a identificação de uma descrição de motivo de viagem a qual não é permitida o pagamento de diárias. 1 II. OBJETIVOS A. Objetivo Geral Avaliar o desempenho e qualidade de algoritmos de mineração de texto aplicados a históricos de contas públicas custodiadas pelo Tribunal de Contas de Sergipe. B. Objetivos Específicos Analisar a aplicação já desenvolvida e reaproveitar as rotinas de pré-processamento; Implementar um segundo algoritmo de mineração de texto, baseado em revisão bibliográfica sobre o uso do mesmo em campos descritivos; Definir como coletar as métricas de tempo médio, acurácia, precisão e cobertura de cada algoritmo de mineração; Realizar Estudo de Caso para analisar e comparar os resultados das métricas, determinando o melhor algoritmo com base no tempo médio, na acurácia, precisão e cobertura. III. METODOLOGIA No projeto, será utilizada uma metodologia de pesquisa exploratória, na qual será feito um estudo dos temas: Mineração de Texto e Avaliação de Desempenho de Algoritmos de Mineração de Texto. A partir disso, será analisada a aplicação em questão, de modo que haja um reaproveitamento das rotinas de préprocessamento. Depois será feito um estudo de um algoritmo de mineração, baseado em revisão bibliográfica sobre o uso do mesmo em campos descritivos, e após a compreensão do mesmo, será implementado para a aplicação em questão. Serão definidas as formas de coletar as métricas de tempo médio, acurácia, precisão e cobertura de cada algoritmo da aplicação e, por fim, será realizado um estudo de caso para analisar e comparar os resultados obtidos, determinando o melhor algoritmo de acordo com as métricas, sendo a principal questão do trabalho. Os resultados das métricas e a realização do estudo de caso não só determinará o melhor algoritmo de mineração, como também permitirá avaliar se o conhecimento gerado, resultado da mineração, foi efetivo e relevante ao auditor, sendo fundamental a sua participação nessa avaliação. “Um estudo de caso é uma investigação empírica que investiga um fenômeno contemporâneo dentro de seu contexto da vida real, especialmente quando os limites entre o fenômeno e o contexto não estão claramente definidos.” [7]. E ainda conforme Yin [7], estudo de caso não exige controle sobre eventos comportamentais e focaliza em acontecimentos contemporâneos, bem como consiste no tipo de questão de pesquisa “como” e “por que”. feita a elaboração e defesa da proposta do trabalho de conclusão de curso. Na terceira fase, será estudada a aplicação (documentação e código-fonte) em que será implementado mais um algoritmo de mineração, bem como serão reaproveitadas as rotinas de pré-processamento. Na quarta, será realizada a revisão bibliográfica sobre algoritmos de mineração de texto sobre o uso de campos descritivos e, após a escolha do algoritmo, o mesmo será estudado e implementado, bem como será feita a atualização da documentação da aplicação. A quinta fase consiste da realização de um estudo de caso para analisar e avaliar o desempenho e qualidade dos algoritmos, em que serão definidas e coletadas as métricas de cada algoritmo de mineração e, encerrando essa fase, o estudo de caso será realizado e seus resultados obtidos serão analisados. Na sexta, será escrita a monografia de TCC e, finalizando essa fase, a defesa. Finalizando o projeto, temos a elaboração e publicação de artigos em eventos relacionados ao tema. B. Recursos Aplicação TextMining; SQL Server; Visual Studio IDE. IV. [1] [2] [3] [4] [5] [6] [7] [8] A. Fases do Projeto Na primeira fase do projeto, será feito um levantamento bibliográfico sobre técnicas de mineração de texto e avaliação de desempenho de algoritmos de mineração, bem como a escrita do referencial teórico. Na segunda fase, será 2 FONTES DE PESQUISA BALINSKI, Ricardo. Filtragem de Informações no Ambiente do Direito. Dissertação (Mestre em Informática). Porto Alegre: PPGC da UFRGS, 2002. 87 p. COLAÇO JÚNIOR, M. Projetando Sistemas de Apoio à Decisão Baseados em Data Warehouse. Rio de Janeiro: Axcel Books, 2004. FELDMAN, Ronen; DAGAN, Ido. Knowledge Discovery in Textual Databases (KDT). 1995. Disponível em http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.47.7462&r ep=rep1&type=pdf. Acesso em 15 de mai. 2014. MAGALHÃES, Cristiane Costa. MinerJur: Uma ferramenta para mineração de bases de jurisprudência. Dissertação (Mestrado em Sistemas e Computação). Salvador: Universidade Salvador, 2008. 144 p. SÁ, Hially Rodrigues de. Seleção de Características para Classificação de Texto. Recife: UFPE, 2008. 57 p. SOUZA, Janisson Gois de. Uma aplicação de Mineração de Texto para Descoberta de Características Psicológicas de Indivíduos. Itabaiana: UFS, 2011. 62 p. YIN, Robert K. Estudo de caso: planejamento e métodos. Trad. 2ª ed. Porto Alegre: Bookman, 2001. 205 p. WIVES, Leandro Krug. Tecnologias de Descoberta de Conhecimento em Textos Aplicadas à Inteligência Competitiva. Exame de Qualificação EQ-069 (Doutorado). Porto Alegre: PPGC da UFRGS, 2002. 116 p. Caracterização da Utilização de Técnicas para Prevenção da Erosão Arquitetural nas Empresas de TI no Brasil. Ythanna Gomes, Marcos Dósea, Methanias Junior Departamento de Sistemas de Informação Universidade Federal de Sergipe, UFS/ITA Itabaiana, Brasil e-mail: [email protected] Resumo – A evolução do software leva ao distanciamento do código desenvolvido da arquitetura planejada. Muitas vezes, pela falta de conhecimento dos desenvolvedores, requisitos conflitantes, dificuldades técnicas ou pela pressão de prazo. Esse desvio na arquitetura ocasiona o que chamamos de erosão arquitetural. Apesar da variedade de técnicas existentes na literatura para evitar a erosão arquitetural não existe um panorama daquelas que são realmente utilizadas pelas empresas no Brasil. Neste trabalho propomos a realização de um survey para obter resultados que possam ajudar no investimento e aprimoramento das técnicas realmente utilizadas pelas empresas. Estática do Código – Inspeções do código– Linguagem descrição de arquitetura – Documentação Arquitetural – Arquitetura de Conformidade – Extensão ArchJava. As técnicas destacadas podem ser utilizadas para definição e verificação das regras fundamentais da arquitetura de um software que pretendem atender os requisitos de qualidade interna e externa, aumentando a probabilidade de sucesso em termos de custo e prazo. Apesar das várias propostas disponíveis, na literatura não existe uma panorama sobre a utilização prática dessas técnicas nas empresas de TI no Brasil. Isso pode levar ao investimento de pesquisas em técnicas que são rejeitadas pelos desenvolvedores ou ainda deixar de aperfeiçoar ferramentas e técnicas que são bem aceitas e utilizadas pelas equipes de desenvolvimento. Este trabalho tem como objetivo realizar um survey com o propósito de levantar informações sobre as técnicas utilizadas para evitar erosão arquitetural nas empresas de Tecnologia de Informação do Brasil. Palavras Chaves: Survey, Erosão Arquitetura. I. INTRODUÇÃO A arquitetura de Software fornece uma visão holística do sistema a ser construído e os arquitetos de software possuem diversas funções no processo de desenvolvimento de software. Quebrar a complexidade do desenvolvimento em partes mais gerenciáveis; definir funções, interações e dependências para cada componente; e a comunicação entre os componentes e os desenvolvedores são algumas dessas funções. Apesar de sua importância, muitas empresas não utilizam a Arquitetura planejada. Muitas vezes, pela falta de conhecimento dos desenvolvedores, requisitos conflitantes, dificuldades técnicas ou pela pressão de prazo [1]. Esse desvio na arquitetura ocasiona o que chamamos de erosão arquitetural. Erosão arquitetural é a deterioração geral da qualidade de um sistema de software durante a sua evolução [2]. Esse conceito é reforçado pela ideia que a degradação da arquitetura faz com que os benefícios proporcionais por um projeto sejam anulados: Manutenibilidade, Reusabilidade, Escalabilidade, Portabilidade e outros [3]. Para evitar o processo de erosão da arquitetura existem várias técnicas disponíveis na literatura, entre elas destacam-se: Ferramentas de Análise II. METODOLOGIA A escolha do modelo de Survey a ser aplicado deve levar em conta alguns quesitos, tais como o objetivo da pesquisa e o tempo necessário e disponível para aplicação da pesquisa. [4] A metodologia utilizada para a pesquisa será a Survey. A mesma é dividida em algumas etapas. Entre elas: Etapa 1 – Definir o objetivo. Os objetivos determinam quem irá ser entrevistado e as perguntas que irão ser elaboradas. Etapa 2 – Elaboração do plano amostral. É denominado o “público-alvo” da pesquisa. Uma grande amostra representativa irá refletir o resultado do projeto. Quanto maior for à amostra, mais precisos serão os resultados que o grupoalvo reflete. No caso da nossa pesquisa, a amostra será através de um questionario 3 online com a ferramenta surveyMonkey com arquitetos de software. Etapa 3 – Planejamento da amostragem. Os entrevistados serão abordados através de emails e grupos. O questionário será enviado para as empresas de TI do Brasil, com o objetivo de obter o maior número de respostas dos arquitetos de software. Etapa 4 - Elaboração e pré – teste do questionário. É criado o questionário seguindo o tema proposto. Entre as etapas, destacam-se: Os aspectos de interesse na pesquisa, revisão das hipóteses, plano de perguntas e preparação dos elementos que fazem parte do questionário. Além de observar o tempo de duração, a estrutura e o design do questionário. Em seguida é realizado um pré-teste com algumas pessoas que fazem parte do público-alvo, no nosso caso, Engenheiros de Software. O pré-teste serve para treinar e analisar os problemas apresentados pelos entrevistadores. Etapa 5 – Aplicação do questionário nas empresas de tecnologia de informação do Brasil através do envio de e-mails. Será utilizado no projeto a fermenta SurveyMonkey. Etapa 6 – Análise dos Dados. Após aplicação do questionário e o recebimento das respostas, os dados são tratados e analisados. Os resultados obtidos serão analisados seguindo o modelo de estatística descritiva. III. a CodeNose [7]. A mesma é integrada ao ambiente de desenvolvimento Eclipse e tem por objetivo detectar code smells em código Java. Para a linguagem de descrição da arquitetura, [8] propõe uma linguagem para especificação de regras de design para a programação orientada a aspectos que permite programar classes de forma modular. A documentação Arquitetural quando não bem detalhada, pode levar a erosão na arquitetura. Documentações específicas têm que ser ao mesmo tempo suficientemente detalhada para análise e adequadamente abstrata para a compreensão. Outra abordagem utilizada para diminuir a erosão arquitetural é a utilização de processo de conformidade. Essa técnica verifica se a implementação do sistema de software é compatível com a sua visão de módulo na arquitetura [9]. IV. CONCLUSÃO A proposta deste trabalho é realizar um survey, com o propósito de levantar informações sobre as técnicas utilizadas para evitar erosão arquitetural nas empresas de Tecnologia de Informação do Brasil. E essa pesquisa é de fundamental importância, devido à falta de resultados ou de dados concretos a respeito dos melhores usos de técnicas que evitam erosão arquitetural nas empresas de TI do Brasil. [1] Passos, L. et al., 2010. Static architecture-conformance checking: An illustrative overview. IEEE Software, 27, pp.82– 89. [2] De Silva, L. & Balasubramaniam, D., 2012. Controlling software architecture erosion: A survey. Journal of Systems and Software, 85, pp.132–151. [3] Holt, J., 1997. Current practice in software engineering :, (November 1995). [4] Babbie, Earl. Methods of Survey Research. Translation Guilherme Cezarino. Belo Horizonte: Ed UFMG, 1999. [5] Bezerra, Carlos F. Lima. Making decisions desoftware oriented metrics: Metric observations of product and software vulnerabilities via DW and Platform monitoramente source code. Brazilia: University of Brazilia, 2014. [6] Dhami, H.P.S. Analysis of Software Design Erosion Issues. International Journal of Advanced Research in Computer Science and Software Engineering, pp. 1393-1398, 7 jul. 2013. [7] Slinger, S., 2005. Code Smell Detection in Eclipse. Science, pp.1–69. [8] Costa Neto, A. et al., 2013. A design rule language for aspect-oriented programming. Journal of Systems and Software, 86, pp.2333–2356. [9] Passos, L. et al., 2010. Static architecture-conformance checking: An illustrative overview. IEEE Software, 27, pp.82– 89. TRABALHOS RELACIONADOS Um trabalho recente [5] mostra que a melhoria da qualidade de design do código apoia a melhoria contínua do processo oferecendo subsídios para que a equipe de desenvolvimento aumente sua produtividade e implemente novas funcionalidades com maior facilidade. A erosão é causada muitas vezes por problemas associados ao desenvolvimento [6]. Citando como exemplo: o uso inadequado de ferramentas e métodos; Não rastreabilidade de decisões de design; Custo de Manuntenção; Acumulação de decisões do Design; Métodos Iterativos; Falta de documentação; Rapidez na correção; Pressão de Tempo; Falta de experiência com desenvolvimento e Vaporização de decisões de design. E para evitar os problemas citados anteriormente, são importantes as técnicas para evitar a degradação, envelhecimento ou erosão do código. No grupo de técnicas para prevenção da erosão arquitetural destacam-se as ferramentas de análise de código. Uma boa ferramenta para essa análise é 4 XQPref: Um Sistema para Personalização de Consultas a Dados XML Angélica F. Medeiros Valéria G. Soares UFPB: Centro de Informática – Universidade Federal da Paraíba (UFPB) Programa de Pós-Graduação em Informática – PPGI João Pessoa, Brasil [email protected] UFPB: Centro de Informática – Universidade Federal da Paraíba (UFPB) Programa de Pós-Graduação em Informática – PPGI João Pessoa, Brasil [email protected] Resumo — O presente artigo apresenta um sistema para personalização de consultas a documentos XML, com objetivo de tornar transparente para o usuário a execução de consultas escritas na linguagem XQuery. O sistema é responsável pela elicitação de preferências dinâmicas e pelo processamento destas consultas personalizadas. Restringimos o escopo deste trabalho em Dados Abertos Governamentais que, diante da sobrecarga da informação, tem impulsionado a procura de técnicas sensíveis para resolver problemas associados com a consulta em documentos XML. Os dados abertos governamentais consistem na publicação e disseminação de dados e informações públicas na Web em formato aberto, para facilitar sua análise e reutilização. No entanto, a sobrecarga da informação tem despertado a preocupação em personalizar os resultados de consultas de acordo com as necessidades de cada usuário. Palavras-chave: Personalização de Consultas;XML; Dados Abertos Governamentais. I. INTRODUÇÃO O crescimento exponencial de informação disponível em diversos domínios tem chamado atenção dos pesquisadores, surgindo à preocupação em personalizar os resultados de consultas de acordo com o perfil do utilizador [1]. Tal aspecto, desperta possibilidades de pesquisa em áreas como banco de dados, inteligência artificial e recuperação de informação. Dentre destes domínios, o XML é uma tecnologia essencial para a gestão do conhecimento e divulgação de dados pela web, no entanto com a sobrecarga de informações o usuário pode ser confrontado com uma quantidade muito grande de resultados. O que tem impulsionado a procura de técnicas sensíveis para resolver problemas associados com a busca em documentos XML [2]. Um exemplo recente de domínio que possui grande quantidade de informação em formato XML são os Dados Abertos, que constituem a publicação e disseminação de dados e informações públicas na Web, respeitando critérios que possibilitam sua reutilização e o desenvolvimento de aplicativos por toda a sociedade. Como solução para realizar consultas em documentos XML, foram propostas algumas linguagens que devido às diferentes origens, possuem distinções consideráveis em termos de sintaxe e abrangência. Dentre elas, a linguagem XML-QL [3] é baseada numa sintaxe XML textual, já XML Query Language - XQL [4], que foi proposta pela comunidade de processamento de documentos, explora expressões similares às expressões de caminho em diretórios. Enquanto a XQuery [5] é uma linguagem flexível, originada da mistura de ambos os tipos de linguagem e que dentre outras vantagens, possui o diferencial de possibilitar a criação de funções extensíveis. No entanto, mesmo a linguagem mais completa para consulta em XML não possui base para personalização de consultas. E assim, realizar buscas em dados XML tem se tornado maçante devido à sobrecarga da informação, o que tem dificultado ao usuário o acesso a essas informações. O presente trabalho busca personalizar as consultas em documentos XML através do sistema XQPref, que será responsável pela elicitação de preferências dinâmicas e pelo processamento destas consultas personalizadas. Com isso, pode-se reduzir os esforços do usuário na busca por conteúdos específicos. Este trabalho está organizado como a seguir. A Seção 2 descreve alguns trabalhos relacionados a esta proposta, bem como apresenta o estado da arte que envolve esta pesquisa. As Seções 3 e 4 apresentam o sistema XQPref, sua demonstração e estudo de caso, respectivamente. Para finalizar, na Seção 4 são apresentadas as considerações finais. II. TRABALHOS RELACIONADOS A personalização de consultas tem como objetivo fornecer soluções que permitam filtrar o que é mais relevante, ou o que corresponda à expectativa e interesse de cada usuário. Para tanto técnicas de personalização vêm sendo pesquisadas e esta área de estudo vem crescendo e aplicando seus conceitos e em diversas áreas da computação, com o simples objetivo de dinamizar as consultas e produzir respostas personalizadas. Como principais fundamentos desta área de conhecimento, diversos estudos foram tomados como base, a exemplo dos trabalhos [6], [7] e tantos outros que desenvolvem muito bem os conceitos relacionados à personalização de consultas e modelagem de preferências. No entanto, a pesquisa apresentada em [8] merece ressalvas, para diferenciar as contribuições. 5 O trabalho de [8] também possui seu foco na utilização de preferências do usuário ao consultar documentos XML. Esta pesquisa propõe um método de consulta baseado em preferência contextual em documento XML com o objetivo de resolver o problema de respostas vazias ao realizar consultas, para tal ele propõe o relaxamento e pontuação de conteúdo. O modelo proposto é chamado de XCP e tem como objetivo permitir aos usuários expressar seus interesses sobre nós da árvore XML, e então o usuário atribuir pontuações para seus nós interessantes para fornecer as melhores respostas. Comparando a pesquisa realizada em [8] ao presente trabalho, destaca-se que o autor não utiliza uma linguagem de consulta para XML em sua proposta, de modo que o usuário fica preso ao modelo e não consegue realizar buscas envolvendo artifícios disponíveis nestas linguagens (como agrupamento, consultas aninhadas, dentre outros). Outro ponto a ser destacado é que no presente trabalho o processo de elicitação das preferências ocorre de forma bastante simples para o usuário, pois o mesmo necessita apenas selecionar os elementos que lhe são prediletos, enquanto no modelo proposto em [8] um usuário leigo pode ter dificuldade ao se deparar com uma árvore para selecionar seus nodos prediletos. Na outra linha de pesquisa envolvida pela presente pesquisa, estão os Dados Abertos Governamentais, mostrando que, a inclusão digital aliada à informatização dos procedimentos governamentais e a integração entre os diversos repositórios de dados públicos provocam crescentes demandas da população por mais transparência e participação através de meios tecnológicos. Nessa direção o governo brasileiro tem definido políticas e desenvolvido plataformas tecnológicas na intenção de promover a disseminação das informações públicas. Através do site http://dados.gov.br/aplicativos/ é possível ter acesso a essas ferramentas, porém cada uma dessas ferramentas utiliza um conjunto específico de dados abertos governamentais no seu desenvolvimento de modo que, cada ferramenta possibilita o acesso a estes dados especificamente. A exemplo destas ferramentas, o [11] é um aplicativo que utiliza os dados do Cadastro Nacional de Reclamações Fundamentadas para fornecer diversas informações sobre as empresas em formato ilustrativo e intuitivo, sendo de fácil utilização em smartphones e tablets devido ao layout vertical. Tal aplicativo está disponível também através do endereço: http://reputacao-sa.org/. É importante destacar que estas ferramentas são desenvolvidas a partir de um conjunto específico de dados e dessa forma para que fosse possível analisar todos os dados abertos disponíveis pelo governo seria necessário um aplicativo para cada conjunto de dados, o que notoriamente é pouco viável. Sendo assim, este trabalho percebe a demanda de se criar uma ferramenta universal que possibilite a consulta independente desses dados, de modo que qualquer conjunto de dados possa ser analisado através dela. Com isso, é justificado o desenvolvimento do XQPref que além de propiciar a elicitação das preferência necessárias para a extensão XQuery-Pref ainda viabiliza a realização de consultas nestes dados abertos governamentais que estejam em formato XML. Uma importante ressalva em relação à limitação pelo formato exigido do sistema XQPref é que os dados que não estejam disponíveis neste formato no site http://dados.gov.br, podem ser solicitados através do mesmo. III. XQPREF O sistema XQPref tem como objetivo suprir a necessidade de um mecanismo de consulta personalizada baseada em preferências condicionais em base de dados XML. Para tanto, o sistema permite a execução de consultas XQuery em que funções de preferências estão embutidas na linguagem e o uso destas funções possibilitam a otimização da recuperação de informações nessas bases de dados, reduzindo ainda o esforço do usuário para encontrar conteúdo relevante, de acordo com suas necessidades. O XQPref proporciona uma interface de usuário para a biblioteca de execução XQuery. As funções propostas para realizar as consultas respeitando as preferências expressas pelo usuário são disponibilizadas através de um namespace na linguagem XQuery e permitem atender a propósitos de busca variados, simplificando o processo de consulta para o usuário. As funcionalidades incluídas na interface de usuário podem ser vistas na Figura 1, a qual apresenta o diagrama de casos de uso da ferramenta. A primeira funcionalidade do sistema é o upload do documento XML, esta função visa facilitar o processo de consulta para o usuário, para possibilitar que o sistema realize uma varredura sobre as tags, de modo a mapeá-las de forma dinâmica para opções que serão oferecidas para o usuário selecionar suas preferências. Figure 1. Diagrama de casos de uso com as funcionalidades do sistema XQPref As três próximas funcionalidades referem-se à manipulação das preferências, as quais podem ser criadas, salvas em formato XML e recuperadas, assim em um segundo acesso ao sistema, o usuário pode reutilizar 6 preferências já expressas ou expressar novas, de acordo com suas necessidades. Em seguida, a funcionalidade de realizar a consulta permite que usuário busque as informações de seu interesse através da seleção de opções relacionadas ao documento fornecido ao sistema e o resultado é retornado na própria ferramenta. É importante destacar que nesta funcionalidade não é preciso nenhum esforço do usuário para que o sistema retorne suas preferências, uma vez que a extensão com as funções de relevância já estão acopladas a linguagem. Por fim, a última funcionalidade se refere à ajuda disponível para que o usuário possa tirar alguma dúvida que surja na utilização do sistema. Na Figura 2, é apresentada de forma gráfica a arquitetura do sistema XQPref, onde estão ilustrados os módulos necessários para a implementação do sistema e suas relações. Inicialmente, percebeu-se a necessidade de criar um repositório onde serão armazenados os documentos XML e deve ser acessado pelo módulo da inicialização. Figura 2. Arquitetura do sistema XQPref O módulo da inicialização responsabiliza-se em implementar mecanismos de leitura da lista de elementos do documento XML e enviar para o módulo de Interface 1, disponibilizando-as em forma de seleção para que o usuário expresse suas preferências. Quando a interface 1 solicita conteúdo do XML, este módulo deve portanto ser capaz de ler o conteúdo do XML a partir repositório e devolvê-lo a Interface Inicial. Este módulo também interage com o Gerenciador/Tradutor, recebendo as queries, buscando no repositório e retornando o resultado para que o Gerenciador as apresente através da Interface 2 para o usuário. A partir do módulo Interface 1, o usuário fornece o documento no qual quer realizar as consultas e em seguida solicita uma analise deste XML ao módulo de Inicialização, que deve analisar a árvore da estrutura do documento XML para ter a base das queries possíveis. Depois de ter analisado o documento, o módulo de Inicialização deve percorrer o conteúdo do XML como uma árvore de nodo em nodo e a cada nodo é preciso atribuir um elemento selecionável, para uma possível preferência do usuário. O módulo Interface 1 é responsável ainda pela apresentação da listagem de elementos que devem ser selecionados pelo usuário. Assim, este módulo deve solicitar informação ao módulo da Inicialização sempre que o usuário seleciona um elemento. De modo que, quando a seleção é iniciada, o módulo Interface 1 pede a listagem do nome dos elementos descendentes ao de Inicialização e as exibe ao usuário. Quando o usuário selecionar um destes descendentes é então realizado um novo pedido ao módulo Inicialização que devolve dessa vez listagem de todos os descendentes deste novo elemento selecionado, tornando a elicitação de preferências um processo dinâmico. Por fim, quando o usuário tiver finalizado o processo de construção de suas preferências este módulo deverá enviar todas as seleções para que o módulo Gerenciador seja capaz de concluir o processo de construção das funções as adequando as preferências submetidas. Já o módulo Gerenciador / Tradutor, é a parte do sistema responsável por calcular a relevância das preferências, com base nos nodos selecionados pelo usuário. Portanto, é necessário que essa referência, com a ordem de seleção, seja recebida do módulo anteriorl, tornando possível a comparação de relevância entre elas. Este módulo também é responsável pela construção das queries, devendo interpretar as seleções realizadas na Interface 2 e traduzi-las para linguagem XQuery, ou seja, a partir de cada nodo selecionado deve ser construída uma query de acordo com as preferências expressas da Interface 1. Assim, depois de calculada a query, este módulo deve retornar o resultado para o módulo Interface 2. O módulo Interface 2 é responsável por apresentar os elementos presentes no documento XML, fornecidos pelo módulo Inicialização para que o usuário selecione apenas o objeto da sua consulta, e o objeto selecionado será enviado para que o módulo Gerenciador prepare a query, busque no repositório através do módulo Inicialização e retorne para esta Interface o resultado esperado pelo usuário. IV. DEMONSTRAÇÃO E ESTUDO DE CASO A demonstração do sistema XQPref foi realizada utilizando dados XML fictícios, para que viabilizasse a visualização das telas do sistema no presente artigo. O conjunto de telas abaixo, apresentado na figura 3, são os protótipos das principais telas da interface apresentada pelo sistema durante a demonstração. No entanto, o estudo de caso realizado com XQPref, utilizou um conjunto de dados disponibilizados pelo governo brasileiro através do site: http://dados.gov.br/. Com o objetivo de avaliar a acurácia dos resultados. Com o estudo de caso foi possível verificar que os resultados retornados estão respeitando as preferências expressas pelo usuário. Possibilitando que mesmo usuários que não conheçam os comandos da linguagem XQuery, realizem consultadas de modo otimizado. 7 Tela para Selecionar Preferências Tela para Realizar Consultas a) b) Figura 3. Demonstração das Telas do Sistema XQPref. Destaca-se que a ferramenta ainda necessita de maior avaliação antes de ser disponibilizada, tendo em vista que o seu foco são para consultas em grandes quantidades de informações. Tal avaliação está em andamento, através da realização de testes automatizados, ficando assegurada como trabalho futuro. V. CONSIDERAÇÕES FINAIS Este trabalho apresentou o XQPref, sistema desenvolvido para viabilizar a personalização de consultas, ao induzir uma ordem de preferência sobre os elementos de um documento XML. Tal necessidade identificada a partir da sobrecarga de informações em domínios que utilizam este formato. O XQPref é capaz de elicitar preferências dinâmicas e processar estas consultas personalizadas. Tal proposta tem como objetivo suprir a necessidade de um mecanismo de consulta personalizada com suporte a preferências em base de dados XML, tornando transparente para o usuário a execução de consultas escritas na linguagem XQuery. A principal contribuição deste trabalho é, portanto, reduzir o esforço do usuário na busca por conteúdo relevante em bases de dados XML. Esta pesquisa é um trabalho em andamento, e a sequência deste trabalho tem como meta aprimorar as funções implementadas no sistema XQPref, analisando a consistência e acurácia dos resultados na realização de consultas em dados abertos governamentais, para que qualquer interessado possa, ao processar livremente os dados governamentais, criar conteúdo a partir da reutilização dos dados. AGRADECIMENTOS À Coordenação de Aperfeiçoamento de Pessoal de Nível Superior (Capes) pela bolsa de mestrado concedida para realização de um trabalho maior no qual, este artigo está inserido. REFERENCES [1] S. A. Amo, T. M. Ferneda, R. G. Cattelan, V. V. S. Dias, H. M. N. Ferreira, “Contextual Preference Repositories for Personalized Query Answering”. In: XXVII Simpósio Brasileiro de Banco de Dados, 2012, São Paulo. Anais do XXVII Simpósio Brasileiro de Banco de Dados. São Paulo, 2012. p. 17-24 [2] F. G. Santos, R. Pinheiro, V. Braganholo, “Processamento de Consultas XML usando Máquinas de Inferência”. In: Simpósio Brasileiro de Banco de Dados (SBBD), 2012, São Paulo, SP. Simpósio Brasileiro de Banco de Dados (SBBD). Porto Alegre, RS: SBC, 2012. p. 129-136 [3] A. Deutsch,; M. Fernandez, D. Florescu, A. Levy, D. Suciu, “XMLQL: A Query Language for XML. Submission to the World Wide Web Consortium. 1998”. Disponível em: <http://w3.org/TR/1998/NOTE-xml-ql-19980819>. Acesso em Fev.2014. [4] J. Robie, “XQL (XML Query Language): W3C Recommendation. 1999”. Disponível em: <http://www.ibiblio.org/xql/xqlproposal.html>. Acesso em Fev.2014. [5] D. Chamberlin, J. Clark, D. Florescu, J. Robie, J. Siméon, M. Stefanescu, “XQuery 1.0: An Query Language for XML: W3C Working Draft”. 2001. Disponível em: <http://www.w3.org/ TR/xquery>. Acesso em: Mar.2014 [6] N. Wilson, “Extending CP-Nets with Stronger Conditional Preference Statements”. In 19th National Conference on Articial Intelligence (AAAI), 2004, pp.735-741, San Jose, California, USA. [7] C. Boutilier, R. I. Brafman, C. Domshlak, H. H. Hoos, D. Poole, “CPnets: A Tool for Representing and Reasoning with Conditional Ceteris Paribus Preference Statements”. Journal of Articial Intelligence Research 21, 2004. [8] W. Yan, L. Yan, and Z. M. Ma. "Automated Ranking of Relaxing Query Results Based on XML Structure and Content Preferences." International Journal of Systems and Service-Oriented Engineering (IJSSOE) 2.1 (2011): 21-39. [9] C. H. P. Gomes, “Extensão de uma Linguagem de Consulta para Documentos XML com Características de Tempo e de Versão”. 2002. Dissertação - Universidade Federal do Rio Grande do Sul, UFRGS, Brasil. 2002. [10] AMO, S. A. ; Fabiola S.F. Pereira . Evaluation of Conditional Preference Queries.. Journal of Information and Data Management JIDM, v. 1, p. 521-536, 2010. [11] Reputação S.A. 2014. Disponível em: http://reputacao-sa.org/. Acesso em Jun. 2014. 8 Algoritmos Avançados de Inteligência Artificial Aplicados ao Mapeamento de Ambiente e Controle de Trajetória de Robô Iury Batista de Andrade Santos, Euder de Jesus Costa, Thiago da Silva Almeida, Nathanael Oliveira Vasconcelos e Alcides Xavier Benicasa Departamento de Sistemas de Informação – DSI Universidade Federal de Sergipe - UFS Itabaiana - SE, Brasil e-mail: [email protected]; [email protected]; [email protected]; [email protected]; [email protected] Resumo—Este projeto de pesquisa tem como objetivo principal apresentar um método de navegação autônomo para robôs móveis utilizando uma arquitetura híbrida, composta por técnicas probabilísticas de mapeamento e controle de navegação baseado em métodos de busca tradicionais, sendo as seguintes: busca cega, busca heurística e busca por aprendizagem por reforço. De maneira resumida, o robô deverá aprender inicialmente os limites do ambiente e como se locomover de forma inteligente entre dois pontos distintos. Para a simulação do ambiente serão utilizados ambientes de simulação, de modo a tornar possível a análise do comportamento do robô móvel através do ambiente utilizado. Palavras-chave: inteligência artificial; robôs móveis autônomos; mapeamento métrico probabilístico; aprendizado por reforço; métodos de busca. I. INTRODUÇÃO A navegação autônoma de robôs é uma área de grande interesse na computação e na robótica, sendo atual e desafiadora[1][2]. O desenvolvimento de técnicas eficientes de navegação é de grande interesse de estudo desta área, já que é grande o número de aplicações práticas referentes a navegação autônoma de robôs, como o controle de incêndios, acesso a áreas de risco ou de difícil acesso humano, vasculhamento de grandes áreas, limpeza de tubulações e outras. A navegação pode ser então implementada por meio da aplicação de métodos de busca em um determinado ambiente. Na literatura podemos encontrar a definição de métodos de busca como se tratando de um agente que possui uma serie de escolhas imediatas de valor desconhecido e que examina diferentes sequências de ações possíveis levando a estados de valor conhecido escolhendo, em seguida, a sequência de melhor resultado[4]. Estes métodos podem não se utilizar de nenhum tipo de informação, sendo assim chamados de busca cega, ou utilizarem algum tipo de informação (distância de um ponto a outro, por exemplo), sendo chamadas de métodos de busca heurística[9]. Há ainda métodos de busca por aprendizagem por reforço que partem de um modelo de recompensas e punições a depender de cada escolha. São exemplos de busca cega a busca por largura e a busca por profundidade. Métodos heurísticos de busca são a busca de custo uniforme, busca gulosa pela melhor escolha e busca A* (A-Estrela). Dentre as buscas por aprendizado por reforço temos Q-Learning e R-Learning. Os métodos de busca cega e heurísticas foram abordados em Almeida et al. [2]. Neste, o robô realiza a navegação em um ambiente previamente conhecido, tendo como objetivo realizar o percurso de um ponto a outro, valendo-se de um método de busca selecionado e evitando obstáculos ao decorrer do processo. O processo era realizado em um ambiente simulado por meio da aplicação Player e Stage[10]. O Player/Stage funcionam como uma camada de abstração de hardware, comunicando-se com os bits de hardware do robô e reduzindo assim a necessidade de o usuário se preocupar com várias partes do controle do robô[5]. O Stage trata-se um um plugin para o Player responsável por “ouvir” os comandos do Player, bem como simular a leitura dos sensores do robô e o ambiente ao qual este está navegando, enviando-os para o Player que por fim permite que estes sejam utilizados pelo código de controle desenvolvido pelo usuário por meio de bibliotecas. É possível simular diversos robôs simultaneamente por meio do Player/Stage. Os robôs simulados pelo Player/Stage são baseados no modelo Pioneer (fabricado pela MobileRobots). O ambiente simulado apresenta vantagens já demostradas por outros trabalhos[3], como a redução de custos relacionados a construção ou aquisição de um robô, bem como gastos relacionados a danos causado por possíveis colisões, redução do tempo necessário para realização das atividades, dentre outros fatores relacionados a segurança. Além de tais vantagens, o ambiente Player e Stage é amplamente utilizado pela comunidade de pesquisa em robótica. Este projeto se propõe a aumentar a automação destes processos de busca por meio da implementação de mapeamento autônomo, além de adicionar os métodos de busca por aprendizado por reforço Q-Learning e R-Learning, visando chegar a uma solução ótima. Utilizar-se-a então do mapa gerado por meio do mapeamento para a análise dos métodos de busca propostos em Almeida et al. [2], bem como dos modelos de busca por aprendizado por reforço, sendo possível desta forma identificar qual o método mais eficiente de cálculo de uma trajetória de um ponto a outro, 9 além da realização de uma análise das localizações do mapa mais visitadas pelos métodos de busca. II. OBJETIVOS O objetivo desta pesquisa é apresentar maneiras de guiar de forma inteligente um robô móvel. Neste trabalho será utilizado métodos probabilísticos para mapearmos o ambiente em que serão aplicados os algoritmos de busca cega, heurística e por aprendizagem por reforço para o cálculo da trajetória do robô, tendo ao final do processo, como resultado da análise, a melhor trajetória encontrada por meio da comparação entre todos os métodos de busca. Objetivos Específicos: Mapear o ambiente valendo-se de métodos probabilísticos. Analisar e identificar a melhor trajetória a ser percorrida de um ponto a outro por meio de métodos de busca cega, heurística e de aprendizado por reforço, tendo como objetivo alcançar o caminho ótimo. Obter informações sobre regiões mais visitadas de um mapa por tais métodos de busca III. André ponce de leon f. carvalho; tomasz kowaltowski. (org). JAI: Jornada de Atualização em Informática da SBC, Rio de Janeiro, SBC – Editora da PUC Rio 1, p. 279 – 330, 2009. [4] RUSSEL, Stuart e NORVIG, P., “Artificial intelligence: a modern approach, ed. 2, Upper Saddle River, New Jersey: Pretice Hall, 2003. [5] OWEN, J., “How to use Player/Stage 2nd Edition. The Player Manual”, 2010. [6] ELFES, A., “A Sonar-based real-world mapping and navigation”, IEEE Journal of Robotics and Automation, v. 3, p. 249—265, 1987 [7] SOUZA, A., “Mapeamento com sonar usando grade de ocupação baseado em modelagem probabilistica”, Master's thesis, Universidade Federal do Rio Grande do Norte – UFRN, 2008 [8] FARIA, G., ROMERO, R., “Explorando o potencial de algoritmos de aprendizado por reforço em robôs móveis”, Proceedings of the IV Brazilian Conference on Neural Networks, pṕ. 237—242, 1999. [9] FONSECA, F. O., “Algoritmos avançados de inteligência artificial aplicados ao comportamento de robôs móveis”, Universidade Federal de Sergipe, Relatório Final de Programa Especial de Inclusão em Iniciação Científica da UFS, 2012 [10] Brian Gerkey, Kasper Stoy e Richard T. Vaughan, “Player Robot Server”, Technical Report IRIS-00-392, Institute for Robotics and Intelligent Systems, School of Engineering, University of Southern California, Novembro 2000. METODOLOGIA Ao longo de todo o trabalho, mas principalmente e de forma mais intensa durante a fase inicial, será feito um levantamento bibliográfico sobre o mapeamento de ambientes através de métodos de mapeamento métrico probabilístico e grade de ocupação[6][7], bem como dos métodos de busca por aprendizado por reforço Q-Learning e R-Learning[8]. Posteriormente será realizada a integração dos modelos já implementados por Almeida et al.[2] com aquilo desenvolvido referente ao mapeamento métrico probabilístico e grade de ocupação e os métodos de busca por aprendizado por reforço Q-Learning e R-Learning. Na segunda etapa será então aplicado os processos desenvolvidos por meio do ambiente de simulação, iniciando-se pelo mapeamento do ambiente e prosseguindo para a análise de trajetórias valendo-se de todos os métodos de busca aqui já referenciados, desejando-se obter ao final um comparativo entre estes, bem como aquele que alcançou o melhor resultado no cálculo de uma trajetória entre pontos determinados. Também será obtido como resultado dados referentes a métricas de interesse, como eficiência de tais métodos e locais mais visitados no mapa pelos algoritmos de busca. REFERÊNCIAS [1] [2] [3] Benicasa, Alcides Xavier, “Navegação autônoma de robôs baseada em técnicas de mapeamento e aprendizagem de máquina” Revista Brasileira de Computação Aplicada,Passo Fundo, vol. 4, pp. 102-111, Março 2012. Almeida, T. da S., Vasconcelos, N. O., Fonseca, F. O., Benicasa, A. X., “Inteligência Artificial Aplicada à Navegação Autônoma de Robôs, 2º Semana de Informática da UFS Itabaiana , 2012 WOLF, Denis F. and OSÓRIO, F. S. S. E. and O. Trindade Jr., “Robótica inteligente: Da simulação às aplicações no mundo real. in: 10 SINTRALIB - Sistema Integrado Tradutor de LIBRAS Comunicação para todos Anderson de Andrade Cunha Departamento de Sistemas de Informação Universidade Federal de Sergipe Campus Alberto Carvalho Itabaiana - Brasil [email protected] Guilherme Bruno Viturino Alves Mai-Ly Vanessa Almeida Saucedo Faro Departamento de Sistemas de Informação Universidade Federal de Sergipe Campus Alberto Carvalho Itabaiana - Brasil [email protected] Departamento de Sistemas de Informação Universidade Federal de Sergipe Campus Alberto Carvalho Itabaiana - Brasil [email protected] Resumo— De acordo com o censo de 2010, do IBGE, há no Brasil mais de 10.000.000 de pessoas com deficiência auditiva grave. Para muitas destas pessoas LIBRAS (Linguagens Brasileira de Sinais) é considerada a língua materna. Apesar de sua importância e do esforço por parte do governo federal, ao incluir LIBRAS como disciplina obrigatória dos cursos de licenciatura, sua popularização ainda não é realidade em nossa sociedade. Em um mundo de falantes, pessoas que se comunicam em LIBRAS muitas vezes ficam isoladas, restritas a se comunicar apenas com outras pessoas que dominam esta linguagem. Este trabalho versa sobre a primeira etapa do desenvolvimento de um sistema computadorizado que possui como objetivo final permitir a clara comunicação, intermediada por computador, entre falantes de português e usuários de LIBRAS. O referido sistema será composto basicamente por dois módulos. O primeiro módulo escuta a voz, ou recebe o texto, em português e, converte-o para sua representação em LIBRAS, que então é exibida na tela do computador por meio de uma figura, digitalmente criada, que executa os movimentos. O segundo módulo, fazendo uso da tecnologia de dispositivos ópticos capta os movimentos do usuário de LIBRAS e os converte para português, escrito ou falado por meio de um sintetizador de voz. O presente trabalho versa sobre a etapa inicial de desenvolvimento do primeiro módulo do sistema. Palavras chave; LIBRAS; Tradutor eletrônico; Inclusão Social; Comunicação. I. INTRODUÇÃO Segundo o censo realizado em 2010 pelo Instituto Brasileiro de Geografia e Estatística, (IBGE) cerca de 5,1% da população brasileira possui deficiência auditiva. Deste total cerca de 1,12% possui deficiência severa, o que representa um universo de cerca de dois milhões de pessoas [1]. É interessante esclarecer que este número corresponde às pessoas que não conseguem ouvir de modo algum e às pessoas que mesmo com aparelho auditivo possuem grande dificuldade permanente de ouvir. Infelizmente grande parte dos surdos brasileiros não conseguem se comunicar eficientemente em português escrito, entretanto se comunicam fluentemente em linguagem de sinais. Para este universo de pessoas, LIBRAS é considerada a Língua materna, sendo o fato de adquirir capacidade de se comunicar em português escrito um desafio semelhante à aprender um segundo idioma. Mesmo entre aqueles deficientes auditivos biblíngues, ou seja, alfabetizados, vê-se que a comunicação em LIBRAS é muito mais compreensível e confortável como podemos ver no texto de Ana Carolina Siqueira: “...LIBRAS como toda língua materna, é a língua que desperta a subjetividade e a capacidade de compreensão do indivíduo” [2]. Apesar da lei Nº 10.436 de 24 de abril de 2002, que torna LIBRAS parte integrante dos Parâmetros Curriculares Nacionais – PCN, sabemos que apenas uma pequena minoria de pessoas “falantes” podem ser consideradas fluentes neste idioma, a saber, pessoas que lidam diretamente com surdos, como familiares, cuidadores, intérpretes e alguns professores. Consequência disto é o isolamento social de surdos "falantes" de LIBRAS, que na maioria das vezes ficam restritos a se comunicar apenas com outras pessoas que dominam esta língua. A partir deste cenário idealizamos o projeto SINTRALIB (Sistema Integrado Tradutor de LIBRAS) comunicação para todos. A utilização da tecnologia desenvolvida ao longo desse projeto torna-se importante ao permitir interação imediata, mediada por computador, entre os usuários de português e de LIBRAS. Atualmente há dois softwares considerados referência nesta área a saber ProDeaf [3] e Hand Talk [4]. Ambos traduzem texto e voz de português para LIBRAS - com o objetivo de permitir a comunicação entre surdos e ouvintes. O diferencial do nosso projeto é que além de fazer o que os outros dois citados fazem, também faremos o inverso, traduzir frases de LIBRAS para português, permitindo assim que a comunicação seja feita nos dois sentidos. Devido ao fato de que LIBRAS não é apenas um conjunto de sinais e sim um idioma completo, que além de sinais contém separadores, regras sintáticas e semânticas próprias, utilizando não somente movimento de mãos mas também de algumas outras partes do corpo, considerando 11 também à nossa falta de conhecimento inicial a respeito deste idioma, dividimos o desenvolvimento do software em algumas etapas. Nesta primeira etapa nosso objetivo é estudar e selecionar tecnologias que nos podem ser úteis para a construção do sistema, bem como desenvolver um software que seja capaz de traduzir o alfabeto e algumas palavras ou expressões de pouca complexidade, de português para LIBRAS. Tão logo concluamos esta fase faremos a tradução do alfabeto e expressões simples de LIBRAS para português. . II. OBJETIVO O objetivo da atual etapa do projeto, de que trata este trabalho, é desenvolver um software que realize a tradução das letras do alfabeto, bem como de algumas palavras de pouca complexidade, de português para LIBRAS. As entradas podem ser feitas por voz ou de forma escrita. A saída é feita por meio de uma animação 3D executando os sinais de LIBRAS. É interessante observar que o trabalho de que falamos é a etapa inicial de um projeto mais extenso que visa desenvolver um sistema computadorizado que faça a tradução instantânea de português falado para LIBRAS e de LIBRAS para português falado. Adicionalmente serão providos também mecanismos que permitam que tanto a entrada quanto a saída, em ambas as direções, possam ser feitas também em português escrito. III. FUNDAMENTAÇÃO TEÓRICA A. Sobre LIBRAS A língua brasileira de sinais (LIBRAS) é a língua usada pela maioria dos surdos, dos centros urbanos brasileiros, sendo reconhecida pela Lei. É derivada tanto de uma língua de sinais autóctone quanto da língua gestual francesa; por isso, é semelhante a outras línguas de sinais da Europa e da América. LIBRAS não é composta simplesmente de gestos equivalentes a palavras da língua portuguesa, e sim é uma língua à parte. Assim como as diversas línguagens naturais humanas existentes, ela é composta por níveis linguísticos como: fonologia, morfologia, sintaxe e semântica. Da mesma forma que nas línguas orais-auditivas existem palavras, nas línguas de sinais também existem itens lexicais, que recebem o nome de sinais. A diferença é sua modalidade de articulação, a saber visual-espacial, ou cinético-visual, para outros. LIBRAS é comparável tanto em complexidade como em expressividade a qualquer língua oral, pois expressa idéias sutis, complexas e abstratas [5]. Para se comunicar em Libras não basta apenas conhecer os sinais. É necessário conhecer a sua gramática para combinar as frases, estabelecendo comunicação. Os sinais surgem da combinação de configurações de mão, movimentos e de pontos de articulação, locais no espaço ou no corpo onde os sinais são feitos. Há também combinações de expressões faciais e corporais que transmitem os sentimentos que para os ouvintes são transmitidos pela entonação da voz, os quais juntos compõem as unidades básicas dessa língua [6]. Assim, a Libras se apresenta como um sistema linguístico de transmissão de ideias e fatos, oriundos de comunidades de pessoas surdas do Brasil. B. Tecnologias envolvidas na captação e tradução de voz para LIBRAS B.1. Java É uma linguagem de programação de propósito geral, Orientada a Objetos, multiplataforma lançada pela Sun Microsystems em 1995, que desde então tem se firmado como uma das linguagens de desenvolvimento mais usadas do mundo. Esta tecnologia tem sido usada no desenvolvimento de diversos programas da mais alta qualidade, como utilitários, jogos e aplicativos corporativos. Em nosso trabalho preferimos usar java, pelo fato dela ser multiplataforma, oferecer facilidades no desenvolvimento para diferentes tipos de dispositivos e pela facilidade advinda do fato de já existir a conexão entre o Java e os hardwares e softwares que iremos utilizar. B.2. IBM Via Voice É um software que faz reconhecimento de voz em diversas línguas, inclusive em português, filtrando os ruídos o que aumenta a compreensão da voz humana. Este programa consegue escrever o que é dito inclusive usando acentuação. Além disso, o software também pode funcionar como sintetizador de voz. B.3. Java Spech É uma API (Application Programming Interface) que permite que aplicações Java possam incorporar tecnologias de reconhecimento de voz, de comando e controle e sistemas reconhecedores de ditado [7]. Esta API consegue trabalhar tanto com o reconhecimento de fala quanto com a sintetização de fala. Sendo mono-lingual, pode-se trabalhar apenas com uma única língua especificada. Para essa API ser usada é necessária a utilização de um reconhecedor de voz que no caso foi o IBM Via Voice citado acima. C. Tecnologias envolvidas na modelagem 3D do personagem que faz a saída em LIBRAS C.1. Game Engine Game engine, ou "motor de jogo", é uma biblioteca, que permite simplificar e abstrair o desenvolvimento de jogos eletrônicos ou outras aplicações que utilizam animações gráficas em tempo real, impedindo que sua criação tenha que ser feita do zero. 12 A funcionalidade tipicamente fornecida por esse motor gráfico inclui: renderização de gráficos 2D e 3D, suporte a animação, sons, simulação das leis da física, networking, gerência de memória, gerência de arquivos, gerência de linha de execução, suporte a grafos de cena e entidades e, suporte a uma linguagem de script. O cenário de uma imagem pode ser reconstruído graficamente com considerável perfeição. Construir este cenário graficamente com tamanha perfeição a partir do zero demandaria bastante tempo e altos custos seriam gerados. Com a utilização de games engines podemos acelerar o processo de produção de imagens, cenários e qualquer modalidade gráfica, assim como a ilustrado na figura [1]. Figura 1. A imagem da direita foi digitalmente produzida pela CryEngine. C.1. Blender Blender é um software, multiplataforma, de código aberto, desenvolvido pela Blender Foundation, que possui mecanismos para fazer modelagem, animação, texturização, composição, renderização, edição de vídeo e criação de aplicações interativas em 3D, tais como jogos, apresentações, realidades virtuais, auxílio em animação entre outros, através de seu motor de jogo integrado, o Blender Game Engine [8]. O Blender Game Engine usa OpenGL (biblioteca livre para desenvolvimento de aplicativos gráficos) para o desenvolvimento dos gráficos, OpenAl (biblioteca livre para lidar com áudio multicanal tridimensional) para o som 3D e Bullet (motor de física) para características da física e detecção de colisão. Este programa implementa ferramentas similares às de programas proprietários, que incluem avançadas ferramentas de simulação tais como: dinâmica de corpo, dinâmica de fluidos, ferramentas de modelagem baseadas em modificadores, ferramentas de animação de personagens, cenas e imagens, e um editor de imagem e vídeo, com suporte a pós-produção, entre outros conjuntos de produções e auxílios gráficos. IV. DESENVOLVIMENTO DO SOFTWARE O código do software foi escrito em Java utilizando para captação do som da voz o IBM Via Voice. Foi definjido um arquivo de dicionário que foi então ativado para ser usado pela Java Spech. Assim a biblioteca "sabe o que deve procurar" ao receber o som escutado. Uma vez captada a voz do microfone, pelo IBM Via Voice, é feito um tratamento no sinal para retirar ruídos. O sinal, então, é enviado à API Java Spech que efetua testes padrões sobre o espectro de frequência do sinal recebido comparando-o com os testes padrões sobre os espectros de frequência dos padrões das palavras em português definidas no dicionário. Uma vez que seja encontrado o fonema correspondente ao som, é então chamada a animação em LIBRAS, previamente feita, que corresponde à palavra/letra escutada. Adicionalmente o software também pode trabalhar fazendo a tradução de texto para LIBRAS. Neste caso o texto escrito que, por uma questão de compatibilidade com as demais funcionalidades do software, deve ser composto apenas pelas letras ou palavras isoladas definidas no dicionário anteriormente falado, tem suas palavras/letras reconhecidas sendo então feita a chamada da animação em LIBRAS correspondente à palavra. Há diversas Games Engines disponíveis, cada uma com suas características próprias e diferentes tipos de licenças. Para o desenvolvimento das animações do presente projeto optamos por usar o Blender que é um ambiente de desenvolvimento de animações 3D completo, gratuito, de código aberto, baseado no Blender Game Engine. A modelagem da animação foi feita da seguinte forma. Inicialmente desenvolvemos o modelo 3D do personagem que será usado para fazer as animações em LIBRAS. O personagem, batizado como Andy, possui uma aparência simples, com roupas pouco chamativas, conforme visto na figura [2], para que a atenção do deficiente auditivo seja voltada aos movimentos do personagem e não a sua figura em sí. Com o modelo 3D feito iniciamos a preparação para que ele pudesse receber a movimentação necessária à representação dos sinais de LIBRAS. Para isto foi adicionado ao modelo um esqueleto conforme podemos observar na figura [3]. A movimentação do modelo com base na posição de "ossos" consiste em associar um "osso" a um conjunto específico de vértices que se movimentarão para acompanhá-lo quando sua posição for alterada. Com o esqueleto anexado no corpo do modelo 3D, começaremos a movimentar os ossos do esqueleto para agregar movimentação ao corpo. Cada osso é movimentado individualmente mas quando no caso de havere ossos ligados, desejando-se, a movimentação pode ser feita também em conjunto. Utilizamos o conceito de frames 1 para fazer a movimentação do personagem, dividindo a movimentação de cada sinal em LIBRAS, em várias partes e alocando cada parte em uma imagem fixa resultando em imagens contínuas. Na figura [4] podemos observar algumas das posições criadas para a construção da palavra “oi” em LIBRAS. Uma vez que a movimentação relativa a um sinal de LIBRAS esteja pronta a animação pode ser exportada como um objeto XML para assim então poder ser usada pelo Java. O Java então pode usar a animação como se fosse um objeto qualquer. 1 13 Frame - cada quadro ou imagem fixa executada em um espaço curto de tempo. V. CONCLUSÃO O sistema SINTRALIB em sua totalidade foi idealizado para ser um Tradutor de português para LIBRAS e de LIBRAS para português. O objeto do presente trabalho é a etapa inicial do desenvolvimento deste sistema. Foi criado um modelo 3D no qual foi mapeado um esqueleto a partir do qual foi feita a movimentação necessária para realização dos sinais de LIBRAS. O sistema também realizou a tradução de letras e algumas palavras, de pouca complexidade, de português para LIBRAS. VI. Figura 2 - Modelo 3D criado PRÓXIMAS ETAPAS DO DESENVOLVIMENTO DO SISTEMA O próximo passo no desenvolvimento do sistema é a conversão de LIBRAS para português de tudo que já foi convertido, no presente trabalho, de português para LIBRAS. Para esse fim estamos adquirindo o hardware Leap Motion que em conjunto com o Kinect será usado para fazer a captura dos movimentos do usuário. Uma vez que o software esteja fazendo a tradução português - LIBRAS e LIBRAS - português deste conjunto de palavras/letras ora especificado iremos ampliar o dicionário e animações correspondentes para mapeamento das palavras mais usadas da língua portuguesa segundo Antonio Cunha [9]. Após esta etapa iremos implementar a interpretação de frases estruturadas em ambos os sentidos. Ao final, do desenvolvimento do sistema, iremos realizar uma bateria de testes intermediando comunicação real entre surdos usuários de LIBRAS e ouvintes. REFERÊNCIAS BIBLIOGRÁFICAS Figura 3 - Esqueleto adicionado ao modelo 3D Figura 4 - Poses básicas usadas para formar a palavra "Oi" em LIBRAS [1] Disponível em <“http://sulpsurdosusuariosdalinguaportuguesa.blogspot.com.br/2012/05/censo-do-ibge2010-dados-sobre.html”>. Acesso em 10 fev 2014. [2] VELOSO, Ana Carolina Siqueira. Alfabetização do individuo surdo: primeiro em LIBRAS ou em português?.In: XVI Congresso de Leitura do Brasil - Cole: Anais do XVI COLE, Universidade do Rio de Janeiro, 2007. [3] Disponível em < http://www.prodeaf.net/OQueE>. Acessado em 10/11/2014 às 11h. [4] Disponível em < http://handtalk.me/>. Acessado em 10/11/2013 às 10h. [5] ROSA, Andréa da Silva, Entre a visibilidade da linguagem de sinais e a invisibilidade da tarefa do intérprete. 2005. 206 f. Dissertação (Mestrado em Educação) - Faculdade de Educação, Universidade Estadual de Campinas, Campinas, 2005. [6] Damasceno, Rafael H. F., Domingos, Maria C. da S., Leme, Hercilio A. P., Prado, Rogério R. do, Bernardes, Rosiani, C., Araujo, Elaine C., et al. Cartilha LIBRAS - Sinais de Inclusão. Universidade José do Rosário Vellano - UNIFENAS. Alfenas, 2010. Disponível em <" http://www.unifenas.br/extensao/cartilha/CartilhaLibras.pdf">. [7] Marangoni, Josemar B., Precipito, Waldemar B. Revista Científica Eletrônica de Sistemas de Informação. Ano II, Número 4. Garça. 2006. [8] Disponível em <"http://www.blender.org"> [9] CUNHA, Antônio Geraldo da. “A Propósito de um Dicionário de Frequência”. In: Confluência – Revista do Instituto de Língua Portuguesa. N º 8 – 2º semestre de 1994 – Rio de Janeiro; pp 31-35. 1994. 14 Utilização de Lógica Fuzzy para Roteamento de Sensores Sem Fio Implementação com JFuzzyLogic e Repast Simphony Daniele Freitas de Jesus João Henrique Kleinschmidt Maria das Graças B. Marietto Mestrado em Engenharia da Informação Mestrado em Engenharia da Informação Mestrado em Engenharia da Informação Universidade Federal do ABC Universidade Federal do ABC Universidade Federal do ABC Santo André - São Paulo, Brasil Santo André - São Paulo, Brasil Santo André - São Paulo, Brasil [email protected] [email protected] [email protected] Resumo - Esta pesquisa apresenta os principais conceitos sobre Redes de Sensores Sem Fio, Multiagentes e Lógica Fuzzy, para embasar o modelo de Roteamento utilizando lógica Fuzzy na plataforma Repast Simphony e o pacote jFuzzyLogic. Considerando essa necessidade constante de manter a capacidade energética, essa pesquisa busca utilizar a lógica Fuzzy para definir o roteamento de forma inteligente, preservando os nodos com pouca capacidade energética ou potencial de roteamento. A lógica do modelo utiliza três antecedentes e uma consequente. Palavras-Chave: Redes de Sensores Sem Fio. Simulação. Lógica Fuzzy. Repast Simphony. Energia jFuzzyLogic. I. INTRODUÇÃO As Redes de Sensores Sem Fio (RSSF) são formadas por dezenas, ou até centenas de nodos sensores, dispositivos autônomos de baixo custo e tamanho reduzido, com capacidade para realizar sensoriamento, processamento e transmissão de informação. São usualmente utilizadas para aplicações de controle, tráfego, militar, segurança, ambiente e medicina. [1, 2, 4]. As principais características dessas redes é que possuem baixa capacidade energética, pouco processamento e armazenamento. Sua capacidade energética estima a vida útil da rede. Com base nesse conceito energético, vital para a rede, essa pesquisa buscou utilizar os conceitos da lógica Fuzzy e de Sistemas Multiagentes, para que o sensor possa definir o melhor roteamento possível, preservando os nodos com pouca capacidade energética ou alta distância de sua vizinhança, objetivando apoiar os pesquisadores, em mais uma forma de simular o custo energético da rede. As ferramentas utilizadas para implementar o modelo desta pesquisa, foram o JFuzzyLogic, responsável pela geração dos gráficos Fuzzy, e o Repast Shimphony, plataforma onde foi programado os agentes. Existem alguns trabalhos correlatos para a pesquisa proposta, como "Agent-Based, Energy Efficient Routing in Sensor Networks"[17], "Avaliação de Estratégias e Construção de Software para Medição do Nível de Energia em Sensores de RSSF"[3], "Research on energy efficient fusion-driven routing in wireless multimedia sensor networks"[18], "Energy and Mobility Aware Geographical Multipath Routing for WSN"[6] e "A Fuzzy Approach to Energy Optimized Routing for WSN"[7], entretanto nenhuma delas trataram de trabalhar os conceitos de Lógica Fuzzy, Sistemas Multiagente e Capacidade Energética da rede na mesma pesquisa. Este trabalho apresenta em sua primeira parte a teoria geral sobre Lógica Fuzzy e Multiagentes. Já na seção IV e V são expostos o formato do modelo, a lógica e o modelo computacional. Em seguida, na seção dos resultados, são apresentados algumas saídas da simulação do sistema e suas discussões, após, as conclusões alcançadas com essa pesquisa. II. LÓGICA FUZZY De acordo com [9], a Lógica Fuzzy foi introduzida, inicialmente, em 1930 pelo filósofo e lógico polonês Jan Lukasiewicz, propondo o uso do intervalo de valores [0,1], que indica a possibilidade ou não daquela declaração ser verdadeira. Já em 1965, Lofti Zadeh publicou o artigo Fuzzy Sets [8], que ficou conhecido como a origem da Lógica Fuzzy. Devido a falta de critérios bem definidos ou a alta incerteza em alguns problemas do mundo real, fica complicado ou inviável programar utilizando a lógica convencional, conhecida como Crisp, que se baseia na precisão. A lógica Fuzzy trabalha com o grau de pertinência de determinados elementos pertencer ou não a um conjunto com características incertas [8, 9]. 2.1 Conceitos Básicos De acordo com Zadeh [8,] um conjunto Fuzzy é uma classe de objetos de graus de adesão contínua. Tal conjunto é caracterizado por uma função social (característica), que atribui a cada objeto um grau de pertinência que varia entre zero e um. Na Lógica Fuzzy, as variáveis lingüísticas são usadas para descrever variáveis físicas, em vez dos nomes e números utilizados no controle dos sistemas. Se uma variável de entrada é descrita por termos lingüísticos, é referido como um valor linguístico [13]. Para dar intensidade as variáveis linguísticas, são utilizados os chamados modificadores, que podem ser divididos em aumentadores e diminuidores [9, 13]. Para a representação de conjuntos Fuzzy é necessário a escolha da função de pertinência a ser utilizada, que vai depender do problema a ser modelado e também da capacidade computacional disponível para processar o que se deseja [9]. Os formatos mais comuns das funções de pertinência são [13]: trapezoidal, triangular, singleton, irregular, que possuem vantagens e desvantagens que deverão ser estudados pelo pesquisador para acomodar melhor a problemática trabalhada. 2.2 Sistema de Controle Fuzzy O Controlador Fuzzy é baseado em conhecimento de aplicação prática representada pela chamada base de regra linguística, em vez de modelos analíticos (ou empíricas ou teóricas). Pode ser usado quando existe uma experiência que pode ser expressa em seu formalismo. Isso permite ter 15 oportunidade de conhecimento disponível para melhorar os processos e realizar uma variedade de tarefas, como controle, reconhecimento de classificação, tomada de decisão em tempo real, detecção e diagnostico de falhas de sistema [13]. Um controlador Fuzzy é basicamente constituído por três partes: fuzzificação, motor de inferência e defuzzificação [10]. O estilo de inferência Mandami, criado pelo professor Ebrahim Mamdani, da Universidade de Londres em 1975 baseia-se em regras de conjuntos Fuzzy no intuito de representar experiências da vida real. Foi dividido em quatro passos: fuzzyficação, avaliação das regras Fuzzy, agregação das regras Fuzzy e defuzzyficação [9]. A fuzzificação mapeia os valores de entrada crisp ao correspondente no conjunto Fuzzy, ou seja, ele atribui o grau de pertinência para cada conjunto. Os valores fuzzificados são processados no motor de inferência, o que consiste em uma base de regras e vários métodos para inferir elas. Essa base de regras é simplesmente um conjunto de IF-Then, que relacionam as variáveis Fuzzy de entrada com uma implicação. A defuzzificação executa o inverso da entrada, encontrando um valor crisp da solução encontrada no motor, usando técnicas como máximo, centro da área, média de máximos, etc [10]. III. SISTEMAS MULTIAGENTES Apesar de não possuir um consenso sobre a definição de agente, entende-se que ele é um sistema computacional, capaz de receber informações sensoriais do ambiente, executar ações que alteram este ambiente de maneira autônoma, mas sem a intervenção humana. Também são capazes de se comunicarem entre si e perceber o ambiente ao qual está inserido. Eles podem ter comportamento cognitivo ou reativo[5]. O agente reativo busca no ambiente somente o que é válido para si próprio, ou foi pré-definido, sem construir uma representação artificial ou lógica do ambiente. Nesta arquitetura suas ações são diretamente influenciadas por um conjunto de eventos do ambiente [5], já o cognitivo não se limita apenas a influência desses conjuntos, ele é mais complexo e possui mecanismos para tomada de decisão. A interação dos agentes entre si com o ambiente, geram os Sistemas Multiagentes, um modelo de simulação utilizado para simular sistemas distribuídos complexos, como é o caso do sensoriamento das RSSF. Modelo de simulação é uma representação parcial do sistema real, que permite verificar seu comportamento em determinadas situações e suas reações às variadas alterações internas de comportamento do sistema [11]. Modelagem por agentes possui uma ampla variedade de aplicações, que de acordo com [15] vão desde a modelagem de mercado de ações, cadeias de suprimento e de consumo, previsão de epidemias, ameaças, guerras biológicas, ou mesmo para compreensão de algum fator que levou a queda de uma civilização antiga. Simulação com modelo multiagente aprimora a investigação de sistemas que exigem muitos agentes para serem analisados totalmente ou a resposta de um único agente de forma realista [16]. IV. MODELO DE ROTEAMENTO POR MAPA ENERGÉTICO NA RSSF COM LÓGICA FUZZY O modelo desta pesquisa tem a organização dos sensores de forma geográfica (roteamento é baseado na localização dos nós), a mobilidade estacionária (os nós não se movem), a densidade balanceada (quantidade de nós distribuídos), a distribuição é irregular (aleatória), a coleta de informações é reativa (somente quando ocorre o evento), a disseminação dessa informação é sob demanda (dependente do evento), a conexão é simétrica (todos os sensores possuem o mesmo alcance, com exceção do sorvedouro), a transmissão half-duplex (sensores recebem e transmitem informações), a alocação de canal é dinâmica (não existe largura de banda fixa) e o fluxo de informação é do tipo gossiping (o nó seleciona o nó para o qual envia o dado). As configurações básicas iniciais de todos os agentes são: possibilidade de perceber um evento pré-definido, perceber nós vizinhos, perceber o sorvedouro, se estes estiverem próximos de seu raio wireless, solicitar mapa energético do vizinho, e possui quantidade máxima de energia. O mapa de energia neste modelo, é construído individualmente em cada nodo (agente) da rede. Neste mapa contém sua própria informação energética, que é disponibilizada a outro nodo, quando solicitado, para verificar a possibilidade ou não de transmissão de dados. A plataforma multiagente selecionada para programar os agentes, foi o Repast Simponhy [12], por conta de sua generalização e pacotes importantes para a viabilização de Sistemas Multiagentes. Todos os agentes possuem um raio de transmissão limitados no ambiente (grid) onde estão inseridos. Através de sua tabela de vizinhança, onde são incluídos outros agentes iguais próximos a este e o sorvedouro, o nó sensor é capaz de enviar a mensagem de algum evento ocorrido, que foi previamente definido em sua memória, cruzando informações da tabela de vizinhança e o mapa de energia. No modelo, os agentes possuem instruções para garantir rotas inteligentes, utilizando a lógica Fuzzy para definir qual o melhor caminho a seguir. Eles consideram o valor energético de seu nó vizinho, sua própria energia e a distância de seu vizinho, para encaminhar a informação, garantindo que esta mensagem consiga chegar até o sorvedouro, o ponto final do roteamento. O agente sorvedouro possui maior capacidade energética e processamento, ligação com a internet, e usa tanto unicast quanto broadcast. Vários desses nodos podem perceber o evento ao mesmo tempo, pois todos são configurados, por padrão, da mesma forma básica. Portanto, uma transmissão pode ser enviada por várias direções, garantindo que este evento chegue até o nó sorvedouro, independente do trajeto. O evento tem posição aleatória na grid, e pode ocorrer mais de uma vez em uma iteração. Conforme as iterações ocorrem, há um decréscimo de 20% de energia no agente, mudando de cores, conforme a Tabela 1. 16 Tabela 1- Cores possíveis do sensor, conforme estado energético. Percentual Energético Cor 0% - 30% 31% - 49% 50% - 100% Amarela Laranja Azul Para realizar os processos Fuzzy, foi utilizado também um Open Source, Fuzzy Logic library e FCL language implementation [14], um pacote de lógica Fuzzy, escrito em Java. A lógica Fuzzy neste modelo, considera os seguintes passos a seguir para verificar a rota inteligente: a energia do próprio nodo, que irá escolher a rota, considerando que deva ter energia suficiente para repassar a mensagem; a energia do nodo vizinho, que também deve ter energia suficiente para repassar a mensagem; a distância do nodo selecionado para repassar o evento para o nodo vizinho, aonde considera a vizinhança com melhor energia, e menor trajeto possível; com essas considerações, sua implicação será selecionar a melhor rota até o sorvedouro; reconfigurar a rota, caso ocorram problemas aleatórios no percurso, como: nodo apresenta problema físico; nodo removido; sorvedouro removido ou novo evento ocorre. As variáveis linguísticas de entrada nesse modelo são representadas a seguir: Energia_Própria: grau de pertinência da energia atual do próprio nodo; Energia_Vizinho: grau de pertinência da energia atual do nodo vizinho. Distância_Vizinho: grau de pertinência da distância entre um nodo e outro nodo vizinho. A variável linguística de saída é: Rota: implicações de Mandami das três variáveis de entrada. A defuzzificação utiliza a técnica de centro de área, causando uma ação no modelo, que no caso é a rota escolhida. Os valores possíveis das variáveis de entrada são: Energia_Própria = {Baixo, Moderado, Alto} Energia_Vizinho = {Baixo, Moderado, Alto} Distância_Vizinho ={Próximo, Moderado, Distante} Os valores possíveis da variável de saída é: Rota = {Muito Fraco, Fraco, Médio, Forte, Muito Forte} A Tabela 2 apresenta um resumo das regras para a seleção da melhor rota, aonde o antecedente 1 é a energia do próprio nodo, antecedente 2 é a energia do nodo vizinho, antecedente 3 é a distância do nodo vizinho e o consequente é a rota a ser tomada. Já os valores crisp de cada valor das variáveis linguísticas, seguem de acordo com a Tabela 3 a seguir: Tabela 3 - Valores crisp das variáveis linguísticas Energia_Propria Energia_Vizinho Distancia_Vizinho Baixa: de 0 a 3 Baixa: de 0 a 3 Proximo: 0 a 15 Moderada: de 3 a 5 Moderada: de 3 a 5 Moderado: 15 a 25 Alta: de 5 a 10 Alta: de 5 a 10 Distante: 25 a 45 V. MODELO COMPUTACIONAL DA RSSF COM LÓGICA FUZZY Para implementar esse modelo foram utilizadas seis classes: Incendio: Avisar os sensores e sorvedouro sobre o incidente. RedeContextBuilder: Cria o ambiente de simulação e inclui os agentes no ambiente. Sensor: Obtém informação sobre o incidente e se encarrega de avisar os outros sensores e o sorvedouro. Utiliza lógica Fuzzy para enviar a informação sobre o acidente até o sorvedouro. SensorStyle: Altera a cor do sensor, conforme a energia que ele possui. Sorvedouro (Servidor na plataforma): É o sensor responsável pela coleta das informações de incidente. Para criar o ambiente de simulação é inserida uma matriz na qual o usuário define o tamanho. O tamanho padrão inicial é 50 células. É possível, ao usuário, definir a vizinhança que será considerada, o número de sensores que estarão no ambiente de simulação, a quantidade de incidente, e quantidade de sorvedouro. Após definir estes parâmetros a simulação é iniciada. A comunicação entre os sensores e o sorvedouro é estabelecida obedecendo as seguintes regras: 1. Se a energia do próprio sensor estiver acima do definido na variável linguística Médio; 2. Se a energia dos sensores vizinhos estiverem maior que a variável linguística Médio; 3. Se a distância até o próximo sensor/sorvedouro, for menor que a variável linguística Moderado. Todos os sensores e o sorvedouro perdem ou ganham energia, aleatoriamente a cada nova interação do programa. No jFuzzyLogic foram utilizadas a biblioteca FIS e FunctionBlock para geração da lógica Fuzzy e de seus gráficos correspondentes. A classe que gera os gráficos é a MyFuzzyClass, que possui dependência do arquivo Tipper.flc, que tem definidos as regras para fuzzificação, defuzzificação e as regras de saída do modelo Fuzzy. Tabela 2 - Valores Fuzzy possíveis das variáveis linguísticas Regra Antecedente1 Antecedente2 Antecedente3 Conseqüente 1 2 3 10 11 12 19 20 21 Baixo Moderado Alto Baixo Moderado Alto Baixo Moderado Alto Baixo Moderado Alto Baixo Moderado Alto Baixo Moderado Alto Próximo Próximo Próximo Moderado Moderado Moderado Distante Distante Distante Médio Forte Muito Forte Fraco Médio Forte Muito Fraco Fraco Médio Figura 1 - Resultado da variável Energia_Propria Conforme definido nesta pesquisa, é considerado Baixa, os valores crisp entre 0 e 3, Moderada, entre 2 a 5 e 17 Alta, entre 4 e 10, valor máximo de carga definido nas classes Sensor e Sorvedouro, gerando os valores apresentados na Figura 1. Por ser Fuzzy, não existe uma mudança brusca de um valor ao outro, mas sim, áreas de pertinência de cada variável. O conjunto Fuzzy, Energia_Vizinho, são respeitados as mesmas regras do conjunto Energia_Propria, o que levou a similaridade gráfica. Os resultados do gráfico apresentado na Figura 2, respeitaram as regras implementadas na classe RedeContextBuilder, sendo Distante, com os valores de 15 a 45, já que o tamanho máximo da grid padrão é 49, Moderado, com os valores de 5 a 25, e Próximo, com os valores de 0 a 15. Figura 2 - Resultado da variável Distancia_Vizinho O gráfico da variável de saída Rota, Figura 3, apresenta o resultado da implicação de máximo/mínimo de Mamdami dos três conjuntos Fuzzy (Energia_Propria, Energia_Vizinho e Distancia_Vizinho). Figura 3 - Resultado da variável de saída Rota Através desses valores, será possível definir a melhor rota a seguir. A técnica de centro de área definirá a melhor opção de saída do sistema. Na aba de parâmetros, o usuário pode selecionar a quantidade de sensores a ser emulado, o raio de alcance da wireless. As cores dos sensores alteram ao longo de cada iteração, indicando o consumo de energia destes, conforme o estabelecido na Tabela 1. Algumas iterações foram realizadas, e as saídas são apresentadas na seção a seguir. VI. RESULTADOS E DISCUSSÕES Os sensores são lançados aleatoriamente, e a cada iteração a energia é alterada. As cores indicam essa mudança. Figura 4 - Simulação com 25 sensores programação. Como o sorvedouro (formato de estrela) também está próximo do evento, ele recebe essa informação diretamente e dos sensores vizinhos também. Com esses valores, que em Fuzzy seriam: Alta, Moderada e Moderada, respectivamente às variáveis informadas antes, define uma rota com Forte possibilidade de ser utilizada, e com base nessa saída, a informação é roteada até alcançar o sorvedouro e finalizar o processo. A cada iteração, é possível verificar comportamentos diferentes, que vai depender da regra estabelecida naquele momento. VII. CONSIDERAÇÕES FINAIS Através das regras de consequência, uma rota pode ser tomada com maior segurança, já que garante que a informação chegará até o sorvedouro, e não será perdida em algum sensor sem energia ou distante demais de outro sensor vizinho. Além disso, o custo energético dos nodos do restante da rede, ficam preservados, pois somente àqueles que irão participar do roteamento utilizam suas cargas para transmitir a informação. Aprimorar a lógica para otimizar o sistema, é um trabalho futuro interessante, pois em relação a essa área, toda pesquisa que venha reduzir os custos energéticos do sistema, é essencial para desenvolver Redes de Sensores Sem Fio melhores. REFERÊNCIAS [1] Antonio A.F. Loureiro, Et Al. Redes de Sensores Sem Fio. Belo Horizonte. 2003. [2] Luigi Atzori, Antonio Iera, Giacomo Morabito,. The Internet of Things: A survey. 2010. [3] Fábio C. Araújo, Flávius Anderson, Katyusco de F. Santos. Avaliação de Estratégias e Construção de Software para Medição do Nível de Energia em Sensores de Redes de Sensores sem Fio (RSSF). João Pessoa. 2007. [4] Daniele Miorandi, Et Al. Internet of things: Vision, applications and research challenges. 2012. [5] Ivan Alexandre Paiz Tierno. Protocolos de Roteamento para RSSFs. Universidade Federal de Santa Maria. 2008. [6] Liang Qilian, Ren Qingchun. Energy and Mobility Aware Geographical Multipath Routing for Wireless Sensor Networks. 2005. [7] Tarique Haider, Mariam Yusuf. A Fuzzy Approach to Energy Optimized Routing for Wireless Sensor Networks. 2007. [8] L. A. Zadeh. Fuzzy Sets. 1965. [9] Alessandro Assi Marro, Et Al. Lógica Fuzzy: Conceitos e aplicações. 2010. [10] Mariam Yusuf, Tarique Haider. Energy-Aware Fuzzy Routing for Wireless Sensor Networks. 2005. [11] Maria das Graças Bruno Marietto, Bruno David, Jaime Simão Sichman, Helder Coelho. Relatório Técnico n° 2/2002.. Analise de Plataformas de Simulação Multiagentes. USP, São Paulo. 2002. [12] Repast Simphony. http://repast.sourceforge.net/download.html. Acesso em: 05/09/2013. [13] IEC 1131 - PROGRAMMABLE CONTROLLERS. Part 7 - Fuzzy Control Programming. Committee Draft CD 1.0. 1997. [14] jFuzzyLogic. Disponível em: jFuzzylogic.sourceforge.net/html/plugin.html. Acesso em: 18/10/2013. [15] Charles M Macal, Michael J. North. Agent-Based Modeling and Simulation. Winter Simulation Conference: 2009. [16] Michael J. North, Charles M. Macal. Agent Based Modeling and Computer Languages. 2009. [17] Long Gan Liu, Et Al. Agent-Based, Energy Efficient Routing in Sensor Networks.2004. [18] Kai Lin, Min Chen. Research on energy efficient fusion-driven routing in wireless multimedia sensor networks. 2011. Nesse exemplo da Figura 4, o sensor mais próximo do evento, percebe-o e envia a rota estabelecida em sua 18 Interação Natural Baseada em Inteligência Artificial e Processamento de Imagens: Proposta Alternativa ao Uso de Sensores Reais Nathanael Oliveira Vasconcelos, Thiago da Silva Almeida e Alcides Xavier Benicasa Departamento de Sistemas de Informação - DSI Universidade Federal de Sergipe - UFS Itabaiana-SE, Brasil Email: [email protected]; [email protected]; [email protected] Resumo—Este trabalho possui como principal objetivo a proposta de um mecanismo como alternativa ao uso de sensores reais, neste caso, sensores de toque para interação homemmáquina. Como validação do mecanismo proposto será desenvolvida uma aplicação que tornará possı́vel a interação entre o usuário e a imagem projetada por um projetor de imagem (datashow). Para isso, será utilizado técnicas de inteligência artificial (IA) e processamento de imagens, que permitirão identificar informações relevantes da cena (regiões propensas à possı́veis alvos), isolando-os através do uso de segmentação de imagens, para posteriormente serem treinados e reconhecidos. Keywords-Processamento de imagens; inteligência artificial; interação humano-computador; imagem projetada; segmentação de imagens. I. I NTRODUÇ ÃO Nos últimos anos os computadores têm se tornado dispositivos comuns ao cotidiano das pessoas, de acordo com [1], coordenador da 25a Pesquisa Anual do Uso de Tecnologia da Informação no mercado brasileiro, divulgada em abril de 2014 pela Fundação Getúlio Vargas, existem 136 milhões de computadores em uso no Brasil, uma densidade de 67% per capita ou 2 computadores para cada 3 habitantes. Os avanços na miniaturização de dispositivos, aliados ao surgimento de ferramentas para a comunicação sem fio, processadores portáteis e novas tecnologias sensitivas, abriram as portas para pesquisas sobre novas formas de interação e ainda, de acordo com [2], novas tecnologias surgem dia após dia, ocupando novos espaços, transformando a realidade. Com o objetivo de aproximar e facilitar a interação entre o homem e a máquina, atualmente, diversos consoles, computadores e smartphones apresentam funcionalidades de interatividade baseadas em comandos por voz, gestos, ou ainda, pela captura de movimentos do globo ocular. De acordo com [3], os sistemas presentes nestes dispositivos, os quais permitem este tipo de interação, são denominados por sistemas interativos. O uso de gestos está em ascensão, sendo uma forma de interação natural que, para [4], consiste em sistemas que entendem ações naturalmente utilizadas pelas pessoas para se comunicar, permitindo aos usuários interagir entre eles e com o ambiente a seu redor. Com isso, o uso de gestos para a comunicação com dispositivos computacionais diminui a carga cognitiva, resultando um modo bastante natural e intuitivo de interagir. Dispositivos baseados em gestos podem ser construı́dos utilizando diferentes mecanismos de rastreamento óptico, magnético ou mecânico ligados ao computador e/ou colocados no corpo do usuário. Muitos desses sistemas utilizam equipamentos sofisticados (dispositivos de rastreamento, luvas, câmeras especiais, etc.). Outra forma de interação através de gestos é baseada na visão computacional, que para [5], tem como objetivo a interpretação automática de cenas complexas, para isso são utilizadas técnicas de reconhecimento de padrões nas imagens capturadas, ao invés de dispositivos de rastreamento, além de algumas restrições do ambiente, como por exemplo, o fundo da cena, cores dos objetos a serem reconhecidos, e condições de iluminação, construindo assim, ambientes bem controlados, de maneira a facilitar operabilidade do sistema. É fato que a utilização de dispositivos tais como: luvas de dados, sensores eletromagnéticos, entre outros, simplificam a identificação de gestos, mas como afirmam [6], aumentam o custo do sistema e, em alguns casos, requerem calibração, tornando assim uma tecnologia ainda não muito acessı́vel à maioria da população. Ao contrário desses dispositivos, interfaces baseadas em visão computacional oferecem diversas vantagens, consistindo numa interação natural entre humanos e computadores, sem a necessidade de instalações especiais, nem da utilização de qualquer dispositivo (mecânico, óptico ou magnético) que o usuário deva vestir ou manipular. Possibilitando assim, uma maior liberdade e facilidade no uso do sistema. Em paralelo ao que foi descrito e, de acordo com [7], ao longo do tempo a ciência criou novos ramos de estudo que envolvem a simulação de processos que ocorrem no corpo humano e buscam também criar modelos ou máquinas que simulem determinadas caracterı́sticas e comportamentos humanos. Algumas áreas têm se destacado em tal empreen- 19 dimento, como é o caso da Inteligência Artificial (IA). A IA consiste de esforços intelectuais e tecnológicos relacionados à construção de máquinas inteligentes, à formalização do conhecimento, à mecanização do raciocı́nio, e ao uso de modelos computacionais para compreender a psicologia e o comportamento de pessoas e animais [8]. Várias áreas da Ciência da Computação utilizam conhecimentos da IA com o intuito de automatizar processos. É o que ocorre com a visão computacional, área na qual este trabalho se enquadra. Para [7], a atenção visual é a habilidade que o sistema visual dos vertebrados superiores utiliza para selecionar e processar somente as regiões mais relevantes em uma cena visual. Podendo ser entendida assim, como um mecanismo para lidar com a incapacidade de tratar de uma só vez uma grande quantidade de informação visual, tanto em sistemas biológicos, quanto em sistemas computacionais. Sendo assim, somente as regiões mais importantes em uma cena são escolhidas para processamento. Sendo assim, este projeto consistirá em criar uma aplicação responsável por detectar a interação entre o usuário e computador, a partir de informações capturadas por uma câmera. Com a utilização de um datashow, opções serão inseridas na projeção, sendo necessária a obtenção de informações relevantes da cena, ou seja, identificação do alvo, em que o usuário ao escolher uma opção (apontando sobre o alvo com um lazer, por exemplo) uma respectiva função deverá ser executada. Para isto, serão utilizadas técnicas de Inteligência Artificial e de Processamento de Imagem. II. O BJETIVOS A. Objetivo geral Este projeto possui como principal objetivo propor uma aplicação que, utilizando técnicas de Inteligência Artificial e Processamento de Imagem, torne possı́vel a detecção, reconhecimento da ação e interação do usuário com o computador, a partir de informações providas por uma câmera de vı́deo, de modo que não seja necessária a utilização de sensores especiais. mecanismos para a captura de imagens através de câmera de vı́deo em tempo real. Na segunda etapa, serão desenvolvidos os objetivos especı́ficos propostos nesse trabalho. Assim, para permitir a interação do usuário com o computador será necessária a inserção de algumas informações adicionais ao slide, ou a imagem projetada, de forma que, intuitivamente, saiba-se onde e como a interação deva ocorrer. Portanto, faz-se necessário o tratamento e obtenção de informações relevantes da cena que possam identificar o alvo, para isso será aplicado o modelo baseado em mapas de saliências proposto por [9]. Posteriormente será feito um estudo sobre algoritmos de segmentação de imagens, para que seja possı́vel o isolamento do possı́vel objeto alvo, a partir de região identificada na etapa descrita anteriormente. Após isso, será feito o treinamento e reconhecimento da opção selecionada. R EFER ÊNCIAS a [1] F. S. Meirelles, “25 pesquisa anual do uso de ti,” 2014. [2] C. Chen, G. Panjwani, J. Proctor, K. Allendoerfer, J. Kuljis, S. Aluker, D. Sturtz, and M. Vukovic, “Visualizing the evolution of hci.” 2005. [3] V. Rusnak, “Interaction methods for large high-resolution screens. disponı́vel em http://is.muni.cz/th/172757/fi r/dtp.pdf.” 2012. [4] A. Valli, “Notes on natural interaction.” 2007. [5] A. Jain and C. Dorai, “Practicing vision: Integration, evaluation and applications.” 1997. [6] A. Erol et al, “A review on vision-based full dof hand motion estimation.” 2005. [7] E. T. Pereira, “Atenção visual bottom-up guiada por otimização via algoritmos genéticos.” 2007. [8] J. Doyle and T. Dean, “Strategic directions in artificial intelligence.” 1996. [9] L. Itti et al, “A model of saliency-based visual attention for rapid scene analysis.” 1998. B. Objetivos especı́ficos • • • • Seleção e implementação de mecanismo para a captura de imagens através de câmera de vı́deo em tempo real; Obtenção de informações relevantes da cena que possam identificar regiões candidatas a alvos; Aplicação de métodos de segmentação de imagens; Treinamento e reconhecimento de padrões necessários à interação do usuário com a imagem projetada. III. M ETODOLOGIA Ao longo de todo o trabalho, mas principalmente e mais intensamente durante a fase inicial, será feito um levantamento bibliográfico sobre o reconhecimento de gestos e seu uso em interação, logo após, um estudo e seleção de 20 Proposta de Mecanismo de Detecção e Reconhecimento de Semáforos Baseado em Atenção Visual e Inteligência Artificial Thiago da Silva Almeida, Nathanael Oliveira Vasconcelos, Alcides Xavier Benicasa Departamento de Sistemas de Informação Universidade Federal de Sergipe Itabaiana – SE, Brasil [email protected], [email protected], [email protected] Resumo—Este artigo tem como objetivo apresentar um resumo do projeto de pesquisa sobre um mecanismo de detecção e reconhecimento de semáforos que se baseia em conceitos biológicos de atenção visual e de inteligência artificial. O mecanismo proposto pode se tornar componente importante de outras pesquisas, como por exemplo, pesquisas de veículos autoguiados. Palavras-chave: detecção de semáforo; reconhecimento de semáforo; trânsito; atenção visual; inteligência artificial. I. INTRODUÇÃO A quantidade de informação visual e sonora disponível para ser processada pelos seres vivos é quase sempre muito grande. A capacidade de selecionar, consciente ou inconscientemente, determinados estímulos, sejam visuais, sonoros ou outros, dentre uma grande variedade de estímulos é essencial e intrínseca à maioria dos seres vivos. Essa capacidade biológica de atenção visual, ou sonora, nos faz capazes de reagir rapidamente a alterações no ambiente. No caso de estímulos visuais, [1] afirma que alguns estímulos são naturalmente conspicuosos ou salientes em um determinado contexto. Um bom exemplo disso é como uma jaqueta vermelha posicionada entre vários ternos pretos receberá automaticamente e involuntariamente a atenção de quem visualiza o conjunto. Tendo-se como base estudos em seres humanos e macacos, pode-se afirmar que o processo de seleção visual seleciona apenas um subconjunto da informação sensorial disponível, na forma de uma região circular do campo visual, conhecida como foco de atenção [1]. Desta forma, segundo SHIC e SCASSELLATI (2007 apud [1]), a atenção auxilia na redução da quantidade de informação que resulta de todas as combinações possíveis dos estímulos sensoriais pertencentes a uma cena, pois apenas informações que estão dentro da área da atenção são processadas, enquanto que o restante é suprimido (CAROTA et al., 2004 apud [1]). Considerado isso, ITTI (2005 apud [1]) define atenção visual como um eficiente mecanismo para reduzir tarefas complexas, como análise de uma cena, em um conjunto de sub-tarefas menores. Importante destacar que já existem sistemas computacionais baseados no mecanismo de atenção visual. Alguns modelos de atenção visual computacional são apresentados por [1], [2], [3] e [4]. Uma atividade que necessita muito da atenção visual é a direção automobilística. É notável a quantidade de atenção que um motorista precisa dispor para dirigir bem, especialmente em grandes cidades, nas quais o trânsito se torna cada vez mais caótico e, um dos artifícios utilizado mundialmente para ajudar a controlar e organizar o trânsito nas cidades é o semáforo. No entanto, o semáforo não é o único componente no trânsito que requer a atenção visual do condutor do veículo. A quantidade de itens que exigem a atenção do motorista no trânsito é imensa, por exemplo, outro veículo o ultrapassando, placas, endereço a ser procurado, pedestres atravessando a rua, algumas vezes animais na pista, motoristas imprudentes, o que pode fazer com que o semáforo passe despercebido. Apesar de algo relativamente simples, desobedecer ao sinal fechado do semáforo pode levar a conseqüências desastrosas. Neste cenário, um reconhecedor automático de semáforos poderia alertar o motorista sobre o estado do semáforo, diminuindo assim a chance de esquecimento que, poderia vir a causar um acidente grave. Ainda outro cenário de aplicação de reconhecedor automático de semáforos é o de uso de veículos autoguiados. Há um grande número de pesquisas nessa área definida como ITS (Intelligent Transportation Systems) nas pesquisas de [6] e [7], e, embora diversos pesquisadores destaquem o uso de sensores entre os carros autoguiados que dispensem o uso dos semáforos, algo mais realista, de acordo com [5], seria um cenário híbrido, com veículos autoguiados e outros não, necessitando ainda de semáforos. Os veículos autoguiados necessitariam então de um bom detector e reconhecedor de semáforos para não vir a causar acidentes. No entanto, implementar um detector e reconhecedor de semáforos não é uma tarefa trivial, uma vez que há diversos problemas a serem vencidos para se detectar e reconhecer o estado de um semáforo de forma confiável. Entre os desafios estão: a condição do tempo que altera a iluminação do ambiente e dificulta a identificação de qual sinal está ativo no semáforo; semáforos de tipos diferentes (horizontal ou vertical, suspenso ou em poste), além de outros componentes que se confundem com o semáforo por terem características comuns como a cor. 21 Alguns trabalhos já realizados na área de detecção e reconhecimento de semáforos já obtiveram sucesso em ambientes diversificados e com diferentes tipos de semáforo. Trabalhos dessa natureza são apresentados em [7], [8] e [9], por exemplo. O objetivo deste trabalho é, então, propor um mecanismo de detecção e reconhecimento de semáforos baseado em atenção visual, que funcione bem em um cenário ideal inicialmente. Os resultados indicarão quando e como a inclusão de outros cenários deverá ocorrer. Serão utilizadas técnicas de processamento de imagens e de inteligência artificial no mecanismo proposto, descritos brevemente nas seções seguintes. II. OBJETIVOS DO PROJETO A. Objetivo Geral O objetivo do projeto é propor um mecanismo de detecção e reconhecimento de semáforos baseado em atenção visual que utilize técnicas processamento de imagens e inteligência artificial. B. Objetivos Específicos Para tornar possível alcançar o objetivo geral alguns objetivos específicos foram definidos conforme apresentados a seguir: Realizar pesquisa bibliográfica sobre métodos de detecção de semáforos baseados em atenção visual; Realizar pesquisa bibliográfica sobre métodos reconhecimento de objetos utilizando inteligência artificial; Implementar e testar uma técnica de detecção de possíveis alvos (semáforos) numa imagem; Implementar e testar uma técnica de reconhecimento de semáforo; Comparar os resultados da técnica de detecção e reconhecimento implementada com outras encontradas na literatura. III. Observando a divisão apresentada previamente, a seguinte metodologia foi definida para direcionar a pesquisa: Estudo de técnicas de processamento de imagens e métodos baseados em atenção visual para detecção de alvos; Estudo de técnicas de inteligência artificial para reconhecimento dos alvos detectados; Implementar e testar as técnicas escolhidas; Escrita do trabalho final como artigo completo para submissão em eventos da área, além da redação do trabalho de conclusão de curso, ao qual este projeto está relacionado; Apresentar resultados obtidos. A técnica que será utilizada para detecção encontra-se em fase de implementação, e são as apresentadas por [1] em seu trabalho. Em seguida a técnica de inteligência artificial será escolhida e implementada. REFERÊNCIAS [1] [2] [3] [4] [5] [6] [7] METODOLOGIA O mecanismo proposto divide-se em duas partes, uma primeira para detectar o semáforo em determinado ambiente utilizando determinada informação, no nosso caso escolhemos a cor, e uma segunda parte para reconhecer se o objeto detectado pela cor é realmente um semáforo e daí inferir algum significado à informação obtida. [8] [9] 22 BENICASA, A. Sistemas Computacionais para Atenção Visual TopDown e Bottom-UP usando Redes Neurais Artificiais. USP – São Carlos. 2013 ITTI, L. Models of Bottom-Up and Top-Down Visual Attention. California Institute of Technology, Pasadena, California. 2000. ITTI, L.; KOCH, C. e NIEBUR, E. A model of saliency-based visual attention for rapid scene analysis. IEEE Transactions on Pattern Analysis and Machine Intelligence 20(11), 1254–1259. 1998. WALTHER, D. Interactions of Visual Attention and Object Recognition: Computation Modeling, Algorithms, and Psychophysics. California Institute of Technology, Pasadena, California. 2006. DIAZ-CABRERA, M.; CERRI, P. e MEDINA-SANCHEZ, J. Suspended Traffic Lights Detection and Distance Estimation Using Color Features. 2012. Disponível em http://www.ce.unipr.it/people/bertozzi/pap/cr/itsc2012.semafori.pdf. LaRa – La Route Automatissé. Disponível em http://www.lara.prd.fr/lara. Acessado em 2014. CHUNG, Y.; WANG, J. e CHEN, S. A Vision-Based Traffic Light Detection System at Intersections. Journal of National Taiwan Normal University: Mathematics, Science & Technology, vol. 47, pp 67-86, 2002. CHARETTE, R. NASHASHIB, F. Real time visual traffic lights recognition based on Spot Light Detection and adaptive traffic lights templates. IEEE Intelligent Vehicles Symposium, pp. 358-363, 2009. KIM, H.; SHIN, Y.; KUK, S.; PARK, J e JUNG, H. Night-Time Traffic iht Detection Based On SVM with Geometric Moment Features. World Academy of Science, Engineering and Technology, vol. 7, 2013. Sistema Tradutor LIBRAS - Português/Português - LIBRAS Anderson de Andrade Cunha Departamento de Sistemas de Informação Universidade Federal de Sergipe Campus Alberto Carvalho Itabaiana - Brasil [email protected] Guilherme Bruno Viturino Alves Mai-Ly Vanessa Almeida Saucedo Faro Departamento de Sistemas de Informação Universidade Federal de Sergipe Campus Alberto Carvalho Itabaiana - Brasil [email protected] Departamento de Sistemas de Informação Universidade Federal de Sergipe Campus Alberto Carvalho Itabaiana - Brasil [email protected] Resumo— De acordo com o censo de 2010, do IBGE, há no Brasil mais de 10.000.000 de pessoas com deficiência auditiva grave. Para muitas destas pessoas LIBRAS (Linguagens Brasileira de Sinais) é considerada a língua materna. Apesar de sua importância e do esforço por parte do governo federal, ao incluir LIBRAS como disciplina obrigatória dos cursos de licenciatura, sua popularização ainda não é realidade em nossa sociedade. Em um mundo de falantes, pessoas que se comunicam em LIBRAS muitas vezes ficam isoladas, restritas a se comunicar apenas com outras pessoas que dominam esta linguagem. Este trabalho versa sobre o desenvolvimento de um sistema computadorizado que possui como objetivo final permitir a clara comunicação, intermediada por computador, entre falantes de português e usuários de LIBRAS. O referido sistema será composto basicamente por dois módulos. O primeiro módulo tem como entrada uma frase em português, por voz ou por texto, que então é convertida para sua representação em LIBRAS, sendo exibida na tela do computador por meio de uma figura, digitalmente criada, que executa os movimentos. O segundo módulo, fazendo uso da tecnologia de dispositivos ópticos, capta os movimentos do usuário de LIBRAS e os converte para português, escrito ou falado por meio de um sintetizador de voz. Palavras chave; LIBRAS; Software tradutor; Inclusão Social; Comunicação. I. INTRODUÇÃO Segundo o censo realizado em 2010 pelo Instituto Brasileiro de Geografia e Estatística, (IBGE) cerca de 5,1% da população brasileira possui deficiência auditiva. Deste total, aproximadamente 1,12% possui deficiência severa, o que representa um universo de cerca de dois milhões de pessoas [1]. Infelizmente grande parte dos surdos brasileiros não conseguem se comunicar eficientemente em português escrito, entretanto se comunicam fluentemente em linguagem de sinais. Para este universo de pessoas, LIBRAS é considerada a Língua materna, sendo o fato de adquirir capacidade de se comunicar em português escrito um desafio semelhante à aprender um segundo idioma. Mesmo entre aqueles deficientes auditivos biblíngues, ou seja, alfabetizados, vê-se que a comunicação em LIBRAS é muito mais compreensível e confortável como podemos ver no texto de Ana Carolina Siqueira: “...LIBRAS como toda língua materna, é a língua que desperta a subjetividade e a capacidade de compreensão do indivíduo” [2]. Apesar da lei Nº 10.436 de 24 de abril de 2002, que torna LIBRAS parte integrante dos Parâmetros Curriculares Nacionais – PCN, sabemos que apenas uma pequena minoria de pessoas “falantes” podem ser consideradas fluentes neste idoma, a saber pessoas que lidam diretamente com surdos como familiares, cuidadores, intérpretes e alguns professores. Consequência disto é o isolamento social de surdos "falantes" de LIBRAS, que na maioria das vezes ficam restritos a se comunicar apenas com outras pessoas que dominam esta linguagem. A partir deste cenário idealizamos o projeto de um software Tradutor de LIBRAS para Português e de Português para LIBRAS. A utilização da tecnologia desenvolvida ao longo desse projeto permitiria interação imediata, mediada por computador, entre os usuários de português e de LIBRAS. Devido ao fato de que LIBRAS não é apenas um conjunto de sinais e sim um idioma completo, que além de sinais contém separadores, regras sintáticas e semântica próprias, utilizando não somente movimento de mãos mas também de algumas outras partes do corpo, considerando também à nossa falta de conhecimento inicial a respeito deste idioma, dividimos o desenvolvimento do software em algumas etapas. Na primeira etapa nosso objetivo é estudar e selecionar tecnologias que nos podem ser úteis para a construção do sistema, bem como desenvolver um software que seja capaz de traduzir o alfabeto e algumas palavras ou expressões de pouca complexidade, de português para LIBRAS e em seguida fazer também a tradução do alfabeto e dessas expressões simples de LIBRAS para português. Após esta etapa iremos ampliar o software para que seja feita a tradução das palavras mais usadas no português, segundo Antonio Cunha [3]. Posteriormente implementaremos no software a capacidade de separar uma frase, falada ao microfone ou escrita, em itens gramaticais, existentes em LIBRAS e exibir a animação correspondente à frase em LIBRAS. Deverá também ser desenvolvida no sistema a capacidade de captar os sinais em LIBRAS feitos por um usuário e estruturar uma frase em português com o mesmo significado. Esta frase poderá tanto ser exibida em texto, como "falada" por uma voz sintetizada. 23 Atualmente há dois softwares considerados referência nesta área a saber ProDeaf [4] e Hand Talk [5]. Ambos traduzem texto e voz de português para LIBRAS - com o objetivo de permitir a comunicação entre surdos e ouvintes. O diferencial do nosso projeto é que além de fazer o que os softwares citados fazem, também faremos o inverso, traduzir de LIBRAS para português, permitindo assim que a comunicação seja feita nos dois sentidos. Para avaliar a eficiência do sistema desenvolvido iremos realizar uma bateria de testes intermediando comunicação real entre surdos usuários de LIBRAS e ouvintes. II. OBJETIVO O objetivo do projeto, é desenvolver um software que realize a tradução mediada por computador de português para LIBRAS e de LIBRAS para português, em tempo real. O sistema será composto de dois módulos, cada módulo fazendo a tradução em um sentido. As entradas do módulo Português - LIBRAS podem ser feitas por voz ou de forma escrita. A saída é feita por meio de uma animação 3D executando os sinais correspondentes à frase em LIBRAS. As entradas do módulo LIBRAS - Português serão imagens, captadas por hardware específico, dos sinais em LIBRAS feito por um usuário. As saídas deste módulo podem ser tanto um texto escrito em Português como uma voz sintetizada "falando" a respectiva frase traduzida. III. A RESPEITO DE LIBRAS A língua brasileira de sinais (LIBRAS) é a língua usada pela maioria dos surdos dos centros urbanos brasileiros, sendo reconhecida pela Lei. LIBRAS não é composta simplesmente de gestos da língua portuguesa, e sim é uma língua à parte. Assim como as diversas línguagens naturais humanas existentes, ela é composta por níveis linguísticos como: fonologia, morfologia, sintaxe e semântica. Da mesma forma que nas línguas orais-auditivas existem palavras, em LIBRAS também existem itens lexicais, que recebem o nome de sinais. A diferença é sua modalidade de articulação, a saber visual-espacial. LIBRAS é comparável tanto em complexidade como em expressividade a qualquer língua oral, pois expressa idéias sutis, complexas e abstratas [6]. Para se comunicar em Libras, não basta apenas conhecer os sinais. É necessário conhecer a sua gramática para combinar as frases, estabelecendo comunicação. IV. DESENVOLVIMENTO DO SOFTWARE A. Da captação e tradução de voz para LIBRAS O código do software foi escrito em Java. A captação da voz está sendo feita pelo microfone do computador, via o software IBM Via Voice. Foi definido um arquivo de dicionário, ativado para ser usado pela Java Spech, de forma que a biblioteca "sabe o que deve procurar" ao receber o som escutado. Uma vez captada a voz do microfone, pelo IBM Via Voice, é feito um tratamento no sinal para retirar ruídos. O sinal, então, é enviado à API Java Spech que efetua testes padrões sobre o espectro de frequência do sinal recebido comparando-o com os testes padrões sobre os espectros de frequência dos padrões das palavras em português definidas no dicionário. Uma vez que seja encontrado o fonema correspondente ao som, é então chamada a animação em LIBRAS, previamente feita, que corresponde à palavra/letra escutada. Adicionalmente o software também pode trabalhar fazendo a tradução de texto para LIBRAS. Em uma próxima etapa o software fará também a tradução de frases. Ao ler/escutar uma frase, a mesma será dividida em unidades gramaticais existentes em LIBRAS e será chamada a animação correspondente a cada uma destas unidades gramaticais. Será feito um trabalho específico para tentar suavizar a transição entre animações. B. Da captação e tradução de LIBRAS para voz O módulo de tradução de LIBRAS para voz também é escrito em JAVA. Para captar os movimentos do usuário e interpretá-los como sinais de LIBRAS, é necessário tanto captar com precisão a movimentação dos dedos como também identificar a posição das mãos em relação ao corpo. Dentre alguns sensores de movimento estudados nos chamou a atenção o Kinect, um sensor de movimento desenvolvido para o console do videogame Xbox. Entretanto logo percebemos que o Kinect possui sérias limitações para a detecção de dedos. Estudamos, então o Leap Motion, um pequeno periférico que contém duas câmeras de infravermelho e três leds de infravermelhos. O dispositivo observa uma área aproximadamente hemisférica de raio de aproximadamente um metro, sendo sensível o suficiente para captar até mesmo o tremor das mãos. O Leap, entretanto possui a limitação de não conseguir identificar a posição das mãos em relação ao corpo. Surgiu então a idéia de captar os sinais de LIBRAS utilizando o Leap em conjunto com o Kinect. Uma vantagem deusarmos estes dispositivos, é o fato de ambos possuírem bibliotecas de desenvolvimento, que podem ser usadas em Java. Uma vez identificado o sentido em português do sinal feito em LIBRAS, a saída poderá ser feita em texto ou em uma voz sintetizada pelo software, conforme o usuário configure. REFERENCIAS BIBLIOGRÁFICAS [1] Disponível em <“http://sulpsurdosusuariosdalinguaportuguesa.blogspot.com.br/2012/05/censo-do-ibge2010-dados-sobre.html”>. Acesso em 10 fev 2014. [2] VELOSO, Ana Carolina Siqueira. Alfabetização do individuo surdo: primeiro em LIBRAS ou em português?.In: XVI Congresso de Leitura do Brasil - Cole: Anais do XVI COLE, Universidade do Rio de Janeiro, 2007. [3] CUNHA, Antônio Geraldo da. “A Propósito de um Dicionário de Frequência”. In: Confluência – Revista do Instituto de Língua Portuguesa. N º 8 – 2º semestre de 1994 – Rio de Janeiro; pp 31-35. 1994. [4] Disponível em < http://www.prodeaf.net/OQueE>. Acessado em 10/11/2014 às 11h. [5] Disponível em < http://handtalk.me/>. Acessado em 10/11/2013 às 10h [6] ROSA, Andréa da Silva, Entre a visibilidade da linguagem de sinais e a invisibilidade da tarefa do intérprete. 2005. 206 f. Dissertação (Mestrado em Educação) - Faculdade de Educação, Universidade Estadual de Campinas, Campinas, 2005. 24 Processamento de Imagens e IA aplicado à Apresentação Interativa: Uma Comparação entre um Método Interativo Tradicional e um Método Interativo Fuzzy Nathanael Oliveira Vasconcelos, Thiago da Silva Almeida, Ed Charles Nascimento Ferreira, Breno Santana Santos e Alcides Xavier Benicasa Departamento de Sistemas de Informação - DSI Universidade Federal de Sergipe - UFS Itabaiana-SE, Brasil Email: {breno1005, nathan-vasconcelos}@hotmail.com; {charles.si.ufs, thiago7a}@gmail.com; [email protected] Resumo—A interação intuitiva entre humanos e computadores é um campo de pesquisa que tem sido bastante investigado nos últimos anos. O uso de diferentes tipos de sensores, como por exemplo, sensores de movimento, toque, etc, têm proporcionado grandes avanços nesta área. Entretanto, de acordo com a especificidade de cada sensor, o custo para o desenvolvimento de determinadas aplicações pode tornar-se inviável. Este artigo possui como principal objetivo a proposta de um mecanismo baseado em inteligência artificial (IA) e processamento de imagens, como alternativa ao uso de sensores reais, neste caso, sensores de toque, fazendo uma comparação entre um método interativo tradicional e um método interativo Fuzzy. Para validação do mecanismo proposto, foi desenvolvida uma aplicação que torna possível a interação intuitiva entre o usuário e a imagem projetada por um projetor de imagem (datashow). Os resultados obtidos demonstram a efetividade do mecanismo proposto. Keywords-Processamento de imagens, inteligência artificial, interação humano-computador, imagem projetada, lógica fuzzy; I. I NTRODUÇÃO Nos últimos anos os computadores têm se tornado dispositivos comuns ao cotidiano das pessoas, de acordo com Meirelles [4], coordenador da 25a Pesquisa Anual do Uso de Tecnologia da Informação no mercado brasileiro, divulgada em abril de 2014 pela Fundação Getúlio Vargas, existem 136 milhões de computadores (pc, notebooks) em uso no Brasil, uma densidade de 67% per capita. Aplicações têm sido propostas com o objetivo de aproximar, facilitar ou ainda, tornar possível a interação entre o homem e a máquina, como por exemplo, captura de movimentos do globo ocular, o processamento da linguagem natural, de forma a ser compreendida automaticamente como texto, o que no passado somente seria possível através de processos mecânicos de digitação. Outro exemplo de interação emergente entre os dispositivos encontrados no mercado, é o uso de gestos como meio de comunicação com diferentes tipos de dispositivos, por ser um recurso natural do ser humano, a possibilidade de utilizá-los na comunicação com dispositivos computacionais permite com que estes sejam utilizados de modo bastante natural e intuitivo. De acordo com Rusnak [7], os sistemas presentes nestes dispositivos, os quais permitem este tipo de interação, são denominados por sistemas interativos. Ainda de acordo com Rusnak [7], os sistemas interativos são compostos pelos seguintes componentes: subsistema de visualização, camada de comunicação e camada de interação. Dentre estes, destacamos o último componente citado, o qual é o principal ponto de investigação deste trabalho. A camada de interação pode ainda ser dividida em três categorias distintas, sendo: superfície multi-touch, sensoriamento sem toque e dispositivos de apontamento [7]. Diversas pesquisas têm sido realizadas na área de sistemas interativos, relacionada às categorias citadas anteriormente. Entretanto, de acordo com os objetos deste trabalho, destacaremos aqui alguns trabalhos pertinentes ao sensoriamento sem toque, que permite a interação do usuário à aplicações, mesmo à distância, através de gestos captados a partir dos movimentos das mãos e, em alguns casos específicos, movimentos do corpo inteiro. Baudel and Beaudouin-Lafon [1] propuseram uma uma aplicação, denominada de CHARADE, que permite ao usuário controlar o computador durante uma apresentação com slides apenas utilizando gestos de mão. Para isto, os autores utilizaram uma luva especial, ligada a um controlador, responsável pela detecção dos movimentos. A luva tátil CyberGlove II possui 22 sensores espalhados entre os dedos e a palma da mão, podendo ser utilizada em uma ampla variedade de aplicações do mundo real, incluindo a avaliação digital de protótipo, realidade biomecânica virtual e animação [8]. No trabalho de Truyenque [9], gestos da mão e as posições dos dedos são utilizados para simular algumas funções presentes em mouses e teclados. Paula et al. [6] propuseram o Câmera Kombat, um jogo de luta multijogador que, com a utilização de técnicas de processamento de imagem, permite a interação do jogador com o jogo sem a necessidade de utilizar dispositivos convencionais, como teclado, mouse, joysticks, entre outros. Para isto utilizam uma webcam posicionada na frente do jogador e, quando 25 este utiliza uma sequência pré-determinada de movimentos, o personagem virtual dispara uma espécie de “magia” no outro competidor. Na pesquisa de Mistry and Maes [5], denominada de SixthSense, é utilizado uma câmera e um pequeno projetor, com uma aparência semelhante a um colar, informações são projetadas sobre superfícies, paredes e objetos físicos, permitindo interagir com a informação projetada através de gestos naturais da mão. Este trabalho possui como principal objetivo propor uma aplicação que, utilizando técnicas de inteligência artificial e processamento de imagem, torne possível a detecção e interação do usuário com o computador, a partir de informações providas por uma câmera de vídeo, de modo que não seja necessária a utilização de sensores especiais. Na seção seguinte será apresentada a revisão da literatura, onde será discutido brevemente o embasamento teórico necessário ao entendimento deste trabalho. Na seção de metodologia, descreveremos a aplicação proposta, com ênfase em seu fluxo de funcionamento. Finalmente, apresentamos as conclusões finais deste trabalho. II. E MBASAMENTO T EÓRICO O uso de câmeras para detecção da interação do usuário com uma aplicação tem sido muito comum em sistemas interativos, em especial nas aplicações baseadas em sensoriamento sem toque, onde, além do uso da câmera, algoritmos de processamento de imagens são utilizadas para o tratamento e obtenção de informações relevantes da cena. Para Gonzalez [2], uma imagem pertencente a uma cena pode ser definida como uma função bidimensional f (x, y), composta por um determinado número de pixels, de modo que cada pixel deva possuir coordenadas de localizações x e y, associadas a um valor específico. É importante notar que o processamento de uma imagem depende diretamente destes valores. Ainda de acordo com Gonzalez [2], uma grande variedade de técnicas podem ser utilizadas para o processamento de imagens. Para este trabalho, destacamos as seguintes: transformação de imagens coloridas para tons de cinza, histograma de cores e, finalmente, lógica fuzzy aplicada ao processamento de histograma de cores. Normalmente, uma imagem capturada por uma câmera de vídeo é apresentada em cores, assim, cada pixel da imagem deve ser formado por um conjunto de valores, ou também conhecido como canais de cores, geralmente de tamanho três ou quatro, podendo pertencer aos padrões de cores RGB (red, green e blue) ou CM Y K (cyan, magenta, yellow e key=black), respectivamente. A combinação dos canais de cores pode representar uma grande variedade de cores, no entanto, muitas vezes essa quantidade de informação pode ser desnecessária para os objetivos de determinadas aplicações, de modo que seu processamento possa levar a desperdício de recurso. Uma forma para a resolução deste problema é a utilização de uma técnica de transformação para tons de cinza, considerado um processo simples sob os canais de cores. Aqui consideramos o padrão RGB, uma vez que este é o padrão de cores utilizado neste trabalho. A Equação 1, apresentada a seguir, descreve a transformação dos canais de um pixel i, pertencente ao padrão RGB, para tons de cinza, como segue: Ri + Bi + Bi (1) 3 onde é calculada a média aritmética dos três canais de cores, R, G, e B do pixel i. Ii é o valor do tom de cinza obtido, também conhecido como valor de intensidade, representando o pixel i por um único valor. Conforme mencionado, outra técnica de processamento de imagem utilizada neste trabalho é o processamento de histograma. De acordo com Marques [3], o histograma de uma imagem é composto por um conjunto de números, indicando o percentual de pixels contidos na imagem, que apresentam um determinado nível de cinza. Estes valores são normalmente representados por um gráfico de barras que fornece, para cada nível de cinza, o número, ou o percentual, de pixels correspondentes na imagem. A informação obtida através do cálculo do histograma de cores de uma imagem pode ser útil para a indicação de sua qualidade quanto ao nível de contraste, brilho médio, ou demais informações a serem utilizadas para fins específicos. De acordo com Gonzalez [2], o cálculo do histograma de cores pode ser descrito como: Ii = h(rk ) = nk (2) onde rk é o k-ésimo nível de cinza e nk é o número de pixels da imagem contendo o nível de cinza rk . Com o objetivo de identificar ou “sentir” o nível de interação do usuário em relação à projeção, consideramos a lógica fuzzy como um dos principais componentes deste trabalho. Proposta inicialmente por ZADEH [10], a lógica fuzzy pode ser considerada como uma extensão da lógica tradicional, baseada na hipótese de que uma proposição lógica não é necessariamente verdadeira ou falsa, mas possui graus de verdade. Na teoria clássica dos conjuntos, o conceito de pertinência de um elemento a um conjunto é bem definido. Sendo assim, para um conjunto contido em um universo, os elementos deste universo simplesmente pertencem ou não àquele conjunto. A teoria dos conjuntos fuzzy vem sendo utilizada para tratar problemas que envolvam informações imprecisas, ajudando no desenvolvimento de soluções, de forma a aproximar o comportamento humano, comparado à soluções encontradas utilizando a teoria clássica de conjuntos. III. M ETODOLOGIA A aplicação proposta neste trabalho possui como principal objetivo a interação do usuário com uma imagem projetada 26 por um datashow comum, através de toques em regiões específicas da imagem projetada. Na Figura 1 é apresentado o layout da aplicação proposta. Figura 1. Layout do aplicativo proposto. Como pode ser observado na Figura 1, os dispositivos necessários para a utilização do aplicativo proposto são bastante comuns em salas de apresentação, sendo os seguintes: computador, datashow e câmera, que pode ser a própria câmera embutida no computador. Inicialmente, para permitir a interação do usuário com a imagem projetada foi necessário a inserção de algumas informações adicionais ao slide, ou imagem projetada, de forma que, intuitivamente, saiba-se onde e como a interação deva ocorrer. Para isto, foi criada uma máscara, como pode ser visto na Figura 1, que é incorporada à lateral direita da imagem projetada, composta, neste trabalho, por quatro funções f básicas: voltar, voltar para o início, avançar e ir para o final. De um modo geral, ao iniciar a execução do aplicativo em modo interativo, faz-se necessário definir na projeção onde estão localizadas as opções de navegação interativa, pois o processamento da imagem não ocorre sob toda a imagem projetada, mas sim em regiões específicas, as quais devem ser delimitadas inicialmente. Desta forma, caso a câmera de captura ou projeção mudar de posição, estas posições deverão ser novamente definidas. Um dos principais pontos deste trabalho está relacionado à identificação do momento no qual uma determinada interação tenha ocorrido, assim como a função de navegação correta a ser executada. Considerando a aplicação do conjunto de técnicas de processamento de imagens apresentadas na seção anterior, foi possível diminuir, consideravelmente, a quantidade de informações a serem tratadas pela aplicação, uma vez que a diferença entre os histogramas de cores de cada imagem capturada, seja a principal informação para a identificação da interação. Apesar de parecer uma tarefa trivial, a aplicação proposta neste trabalho, em um ambiente real, pode torna-se instável, uma vez que duas imagens capturadas em um intervalo de segundos, ou até menos do que um segundo, podem apresentar diferenças sutis no histograma, geradas por interferências do ambiente, mesmo que imperceptíveis à visão humana. Sendo assim, para que a comparação entre duas imagens, aparentemente iguais, seja realizada de forma correta, foi necessário definirmos um valor aceitável de diferença entre duas imagens, ou seja, um valor máximo de mudança, tornando possível a diferenciação entre uma interação real e variações naturais do ambiente. O valor de mudança aceitável, denominado aqui por σ, foi definido, para fins comparativos, de duas maneiras distintas. Na primeira, denominada aqui por Método Interativo Tradicional (MIT), o valor do σ é baseado no cálculo do desvio padrão dos valores dos histogramas, para um conjunto de imagens capturadas sequencialmente em um intervalo curto de tempo. Na segunda, denominada de Método Interativo Fuzzy (MIF), o valor de σ é definido por um sistema fuzzy, utilizando como entrada valores dos histogramas de cores. Os dois métodos são apresentados a seguir. A. Método Interativo Tradicional Neste método, o cálculo da média dos valores dos histogramas obtidos para um conjunto de imagens, referentes a uma determinada função, é descrito como segue: ! nf 255 1 X f 1 X f hi (rk ) (3) m = f n i=1 256 k=0 onde n é o número de imagens capturadas referente à função f , k representa os níveis de cinza, hfi é o valor do histograma de cores da imagem i referente à função f e rk , conforme descrito na seção anterior, representa o késimo nível de cinza. Assim, o valor de mudança aceitável é definido como segue: v u nf u 1 X f t (mf − mf )2 (4) σ = nf i=1 i f Para uma descrição resumida do fluxo da aplicação proposta, após essa o cálculo de σ f , em intervalos de 300ms, uma imagem da apresentação é capturada, transformada em seguida para tons de cinza, calculando-se em seguida a média do histograma referente a cada função. A seguir, a média obtida é comparada à média dos histogramas do conjunto de imagens capturadas inicialmente (Equação 3) somado ao desvio padrão (Equação 4), de forma que, caso o valor da média do histograma obtido seja maior do que mf + σ f , pode-se concluir que houve uma interação, e o comando relacionado à função que tenha apresentado a diferença seja executado. Para o caso de detecção simultânea de interação, nenhuma função deverá ser executada. B. Método Interativo Fuzzy No método de interação baseado em lógica fuzzy, duas variáveis linguísticas foram definidas: Valor de Alteração do Histograma (VAH) e Executar Transição (ET), consideradas, respectivamente, como entrada e saída. A variável VAH é composta pelos seguintes termos linguísticos: “Grande”, “Médio” e “Pequeno”, que representam mudanças no valor do histograma. Por outro lado, a variável linguística Executar Transição, composta pelos termos: “Sim” e “Não”, é 27 responsável por denotar o quanto de interação ocorreu entre o usuário e a imagem. A base de conhecimento utilizada foi construída de forma empírica, sendo: R1 : Se VAH é Pequeno, então ET é Não. R2 : Se VAH é Médio, então ET é Não. R3 : Se VAH é Grande, então ET é Sim. Por fim, a determinação da ocorrência de interação do usuário ocorrerá através da obtenção do grau de pertinência do valor de alteração do histograma para cada função, considerando todos os termos linguísticos de VAH, de forma que o processo de fuzificação e defuzificação ocorra para cada função. Finalmente, o valor de saída gerado pelo sistema fuzzy é utilizado para definir o nível de interação com o usuário. C. Experimentos Os experimentos foram realizados considerando quatro situações de ambientes, sendo três diferentes do ambiente ideal, conforme enumerados a seguir: 1) Luz alta sobre a apresentação, luz ambiente normal, fundo branco; 2) Luz alta sobre a apresentação, luz ambiente alta, fundo branco; 3) Luz alta sobre a apresentação, luz ambiente normal, fundo escuro; 4) Luz normal sobre a apresentação, luz ambiente normal, fundo branco (ambiente ideal). Com o objetivo de avaliar os resultados, foram definidas três medidas de desempenho. Sendo a primeira “Boa”, que significa a identificação correta de todas as interações, onde nenhuma ação tenha ocorrido na ausência de interação, a segunda, denominada por “Média”, deve ocorrer a identificação correta da maioria das interações, sendo que nenhuma ação deva ocorrer sem interação e, por fim, a medida considerada “Ruim”, na qual tenha ocorrido a identificação incorreta da maioria das interações ou ações sem interação. Tabela I E XPERIMENTOS DOS MÉTODOS MIT E MIF EM A MBIENTE H ETEROGÊNEOS Ambiente 1 2 3 4 MIT Médio Ruim Ruim Bom MIF Bom Ruim Bom Bom Na Tabela 1 são apresentados os resultados obtidos a partir de experimentos considerando todos os ambientes citados. Pode-se concluir que, embora o MIT tenha apresentado resultados satisfatórios nos ambientes 1 e 4, o MIF apresentou medidas de desempenho melhores para um número maior de ambientes. IV. C ONCLUSÕES Considerando ambientes ideais, os métodos propostos demonstraram-se robustos, de modo que não houveram interpretações de funções erroneamente ou disparo de função na ausência de interação. O ambiente ideal foi definido como uma projeção realizada em superfície de fundo claro, com iluminação ambiente normal, ou ainda, sem iluminação no ambiente, contanto que, não exista incidência direta de luz forte sobre a projeção. Observou-se também que, utilizando um intervalo de 300 à 600ms entre cada imagem capturada, foi possível uma interação natural com a projeção. Intervalos de tempo maiores causaram um atraso entre o tempo de tentativa de interação e a execução da função. Por outro lado, intervalos menores fizeram com o que a função fosse executada diversas vezes. A utilização da lógica fuzzy para a identificação de interação mostrou-se também bastante satisfatória para ambientes distintos, de modo a propiciar um importante enviesamento para pesquisas futuras. Podese concluir ainda que, a aplicação proposta neste trabalho pode ser considerada com um interessante alternativa para o desenvolvimento da interação homem-máquina, onde, através de técnicas de processamento de imagens e inteligência artificial, foi possível dispensar o uso de dispositivos menos acessíveis. R EFERÊNCIAS [1] T. Baudel and M. Beaudouin-Lafon. Charade. Communications of the ACM, 7:28–35, 1993. [2] R. E. Gonzalez, R. C. e Woods. Processamento Digital de Imagens - 3 ed. Saulo: Pearson, 2010. [3] H. N. Marques, O. F. e Vieira. Processamento Digital de Imagens. Rio de Janeiro: Brasport, 1999. [4] Fernando S. Meirelles. 25 pesquisa anual do uso de ti. 2014. [5] P. Mistry and P. Maes. Sixthsense a wearable gestural interface. 2009. [6] L. P. Paula, N. Bonini, and R. Miranda. Cra kombat intera livre para jogos. 2006. [7] V. Rusnak. Interaction methods for large high-resolution screens. disponl em http://is.muni.cz/th/172757/fi_r/dtp.pdf. 2012. [8] C. Systems. Cyberglove ii. disponl em: http://www.cyberglovesystems.com/products/cybergloveii/overview. 2014. [9] Michel Alain Q. Truyenque. Uma aplica de visomputacional que utiliza gestos da mara interagir com o computador. 2005. [10] L. A. ZADEH. Information and control. Fuzzy Sets., 8:338–353, 1965. 28 PLANEJAMENTO DA MELHORIA DO PROCESSO DE TESTES DO CENTRO DE PROCESSAMENTO DA UNIVERSIDADE FEDERAL DE SERGIPE BASEADO NO MPT.BR Weverton dos Santos, Marcos Dósea Departamento de Sistemas de Informação/DSI Itabaiana-SE, Brasil e-mail: [email protected], [email protected] A definição e utilização pela equipe de um processo de testes não é um trabalho final. O processo deve estar em constante avaliação buscando atividades do processo que podem ser melhoradas para obter um melhor desempenho e eficácia. Modelos de qualidade de processos de testes como o MPT.BR vêm sendo propostos para ajudar nessa tarefa. Nesse contexto este trabalho apresenta o planejamento para realizar a melhoria da qualidade de um processo de teste de software baseado no MPT.BR. Palavra-chave: ambiente, melhoria, nivel, processo, teste. I. INTRODUCÃO As empresas de desenvolvimento de software buscam através dos processos de testes software, melhorar a qualidade dos seus produtos. A garantia da qualidade auxilia as empresas a oferecer produtos que conquistam a confiança dos clientes, tornando-as mais competitivas. A melhoria contínua dos processos é essencial para garantir a competitividade. Para que as empresas de desenvolvimento de software consigam construir seus produtos com qualidade, tornam-se necessárias a elaboração e a utilização de estratégias de testes bem definidas, pois o processo de teste de software está intimamente ligado com a qualidade de produtos e de processos. Uma forma de garantir mais qualidade ao processo de teste é executar os testes separadamente [1] e utilizar modelos de qualidade para melhoria do processo de testes. O MPT.Br é um desses modelos de Melhoria do Processo de Teste concebido para apoiar organizações através dos elementos essenciais para o desenvolvimento da disciplina de teste. Trata a melhoria do processo de teste através das melhores práticas relativas às atividades ampliadas ao longo do ciclo de vida de teste do produto [8]. O MPT.Br avalia as empresas através de um conjunto de práticas específicas das áreas do processo e de algumas práticas genéricas em alguns níveis. Vem sendo adotado como modelo de referência por várias empresas brasileiras para guiar a melhoria dos seus processos de teste. Ele apresenta 5 níveis de maturidade, sendo que neste trabalho somente será abordado o nível 1. Visando melhorar a qualidade do software utilizada pela comunidade acadêmica, o Centro de Processamento de Dados da Universidade Federal de Sergipe (CPD/UFS) passou por um processo inicial de melhoria do seu processo de desenvolvimento de software. Várias melhorias foram realizadas, entre elas a definição de um processo para gerência de configuração e um processo para gerenciamento da execução de testes de software. Porém o processo implantado não foi guiado por nenhum modelo de maturidade de processos. Além disso, um processo de desenvolvimento depois de implantado precisa ser evoluído continuamente. O CPD/UFS se encontra em um estágio de processo onde já faz uso dos testes automatizados, o que é bastante útil para os testes de regressão. Mas possui pouca documentação dos projetos de teste. Nesse trabalho é apresentado o planejamento para avaliação da maturidade do processo de teste do CPD/UFS e a realização de melhorias no processo existente baseado no nível 1 do MPT.Br. Também serão realizados ajustes na ferramenta Testlink [4], utilizada para o gerenciamento do processo de teste, visando aumentar a eficiência e eficácia do processo. Este trabalho está organizado como segue: na Seção II é apresentada a metodologia a ser utilizada para realização das melhorias propostas no processo de testes. Na Seção 3 são apresentados alguns trabalhos relacionados e na Seção 4 as conclusões e trabalhos futuros. II. METODOLOGIA O percurso metodológico que se pretende adotar é uma pesquisa-ação definida como um tipo de pesquisa com base empírica que é concebida e realizada em estreita associação com uma ação ou ainda, com a resolução de um problema coletivo, onde todos os pesquisadores e participantes estão envolvidos de modo cooperativo e participativo [9]. O ambiente onde a pesquisa será realizada será CPD/UFS 1- Fases do Projeto Para elaboração do projeto foram consideradas as seguintes etapas: a- Fase exploratória Nesta fase será feito um levantamento do ambiente que será aplicado a melhoria de processo e as expectativas dos interessados. O processo de teste atual será modelado utilizando a notação BPMN [5] para ser possível realizar análise e identificação dos pontos de melhoria. b- Realização do seminário Nesta fase será feito um seminário para reunir os principais membros da equipe interessados na pesquisa. O objetivo é coletar propostas dos participantes para que a 29 partir dessa discussão saiam as diretrizes para elaboração da pesquisa e das ações. c- Seleção de amostra O objeto da pesquisa é o processo de testes do CPD/UFS. Para avaliá-lo serão coletadas métricas de desempenho em cada etapa do processo de pelo menos dois projetos distintos que estejam passando por um ciclo de testes. d- Coleta de dados A coleta de dados será realizada através da coleta de métricas durante a execução do processo. O objetivo será avaliar a eficiência e a eficácia do processo de testes em relatar erros válidos para equipe de desenvolvimento. As métricas que serão coletadas para avaliação do processo são o tempo médio para projeto de casos de testes; o tempo médio para execução de casos de testes; o número de casos de testes executados por ciclo e o número de erros válidos encontrados por ciclo. e- Análise e interpretação dos dados Os dados coletados serão analisados através de estatística descritiva e inferencial para prover subsídios para descoberta de possíveis pontos de melhoria no processo. Além disso, a modelagem do processo ajudará a determinar as atividades do processo que deverão ser modificadas ou incluídas no processo para atender as exigências do nível 1 do MPT.Br. f- Elaboração do plano de ação O plano de ação visa determinar as ações que serão propostas para melhoria do processo baseando-se no nível 1 do MPT.Br. O novo processo será modelado utilizando a notação BPMN e a ferramenta Testlink, utilizada atualmente no CPD/UFS, deverá ser adaptada para atender as exigências do mesmo. Para avaliação pretende-se realizar dois projetos pilotos com o novo processo, nos quais serão coletadas as mesmas métricas definidas na fase de coleta de dados. Os resultados obtidos com o novo processo serão comparados estatisticamente em relação aos dados obtidos com o processo existente. g- Divulgação dos resultados Os resultados obtidos na pesquisa serão divulgados através do Trabalho de Conclusão de Curso. Adicionalmente pretende-se apresenta-lo à equipe do CPD para que as melhorias propostas sejam adotadas para os demais projetos de testes. processo e avaliar se elas surtiram efeitos no processo da organização. Desenvolvimento do processo de teste SwTest definido para uma Empresa de Pequeno Porte Desenvolvedora de Software, este processo foi desenvolvido com base nas normas IEEE 829 e ISO/IEC 12119, seu objetivo foi melhorar e garantir a qualidade do software desenvolvido e voltado para empresa de pequeno porte [7]. Já neste projeto vai ser utilizado um processo de teste existente, mas também visando a garantia e a qualidade do software. Em outro trabalho foi realizada a melhoria da ferramenta Testlink para integrar resultados dos testes manuais com os resultados dos testes de unidade automáticos que não eram gerenciados pelo TestLink [3]. A ferramenta foi avaliada através de questionário respondido por profissionais que utilizam o TestLink. Neste projeto também propomos a integração de testes automáticos no Testlink, mas os testes que pretendemos integrar são os testes automáticos funcionais. IV. REFERÊNCIAS [1] [2] [3] III. TRABALHOS RELACIONADOS Alguns trabalhos que foram desenvolvidos no contexto de Avaliação de Maturidade em processo de teste. Em [2] é proposta a avaliação da maturidade do processo de teste utilizando o nível 1 do método de maturidade MPT.Br. Neste trabalho foi feita uma avaliação do processo de teste de software em uma organização, analisando dois projetos, comparando as práticas dos projetos com as práticas do nível 1 do modelo MPT.BR, que nesta versão só avaliava a Gerência de Projetos de Teste de Software. Com os resultados analisaram se a empresa possuía boas práticas em teste de software, e se a empresa era aderente ao nível. Foram propostas algumas sugestões de melhorias. O projeto proposto também vai analisar uma organização, utilizando o nível 1 do MPT.Br, porém o objetivo é realizar melhorias no CONCLUSÃO Neste trabalho foi apresentado o planejamento para melhoria do processo de testes do CPD/UFS baseado no modelo MPT.BR. A melhoria envolve a avaliação do processo atual e ajustes na ferramenta Testlink para incorporar as melhorias definidas. O objetivo é a melhoria contínua do processo existente aumentando a eficiência e a eficácia das atividades realizadas. O trabalho presente já passou pela fase exploratória, realização do seminário através de reuniões, seleção de amostra e coleta de dados. O próximo passo será análise e interpretação dos dados, elaboração do plano de ação e divulgação dos resultados. Esperamos que este trabalho melhore a eficácia do processo de testes existem no CPD/UFS. [4] [5] [6] [7] [8] [9] 30 BASTOS, A.; RIOS, E.; CRISTALLI, R. & MOREIRA, T. Base de conhecimento em teste de software. 3o. ed. São Paulo: Editora Martins Fontes, 2007. CRUZ, G. A. Avaliação de Maturidade em Processo de Teste de Software: uma Pesquisa-Ação. Minas Gerais: Lavras, 2010. p. 99 GOIS, ELY L.; MARTINS, D. A. Uma abordagem para o gerenciamento integrado de testes manuais e automatizados no TestLink. São Cristóvão: UFC, 2011. p. 78 HAVLAT, M. TestLink, 2013. Disponível em: <http://www.teamst.org>. Acesso em: 25 jul. 2013. OMG.BPMN - Business Process Model and Notation, 2011Disponívelem: <http://www.omg.org/spec/BPMN/2.0/PDF/>. Acesso em: 20 ago. 1013. Selenium. Disponível em: <http://www.seleniumhq.org/>. Acesso em 28 jun 2013. SILVA, V. M. DE P. SwTest: Um Processo de Teste Definido para uma Empresa de Pequeno Porte Desenvolvedora de Software. Minas Gerais: Lavras, 2006. p. 81 SOFTEXRECIFE. MPT.BR - Melhoria de Processo de teste: Guia de Implementação, 2011. Disponível em: <http://mpt.org.br/mpt/mpt/modelo-de-referencia-e-guia-deavaliacao>. Acesso em: 24 jun. 2013. THIOLLENT, Michael. Metodologia da pesquisa-ação. São Paulo: Cortez, 1985. Em Direção à Melhoria do Processo de Aplicação de Surveys em Engenharia de Software Antônio Cruz, Erivan Santana, Marcos Dósea Departamento de Sistemas de Informação Universidade Federal de Sergipe, UFS/ITA Itabaiana, Brasil e-mail: [email protected], [email protected], [email protected] Abstract- A utilização de surveys por pesquisadores em engenharia de software vem se popularizando como método de pesquisa. Entretanto entre as dificuldades encontradas pelos pesquisadores para aplicação do método é a exibição e instrumentação de código-fonte de linguagens de programação. Este trabalho visa analisar o processo e as ferramentas utilizadas para aplicação de surveys em engenharia de software. O objetivo é caracterizar as necessidades e melhorar o processo de aplicação de surveys na área de engenharia de software em relação a efetividade e custo. Palavras-chave: Ferramenta Survey; I. Engenharia de Software; INTRODUÇÃO Os métodos para realizar pesquisa em engenharia de software vêm evoluindo nos últimos anos, adotando e adaptando os mesmos métodos já utilizados há décadas por outras engenharias. Em [1], é proposto um framework para experimentação em engenharia de software que ajuda a estruturar o processo experimental e prover um esquema de classificação para entender e avaliar estudos experimentais. Entre os métodos de investigação propostos destacam-se os experimentos controlados, os estudos de caso e o survey. O survey refere-se a um tipo particular de pesquisa social empírica e realizada para permitir enunciados descritivos sobre alguma população, isto é, descobrir a distribuição de certos traços e atributos [2]. O processo de aplicação de surveys em engenharia de software envolve uma série de dificuldades para os pesquisadores: (1) as ferramentas não possuem componentes que facilitem a visualização de código-fonte em diferentes linguagens; (2) quando as respostas também são trechos de código não há recursos que facilitem a instrumentação do código-fonte resultante; (3) não há possibilidade de realizar análise sintática e semântica do código-fonte resposta do desenvolvedor. Este trabalho apresenta o planejamento para criação de uma ferramenta WEB para a realização de surveys em engenharia de software com o propósito de melhorar o processo de aplicação de surveys. A ferramenta, além de permitir a realização de perguntas objetivas e subjetivas já realizadas por outras ferramentas, possuirá recursos adicionais para instrumentação de código-fonte. Na Seção 2 é apresentada a metodologia que será utilizada para elaboração do trabalho. Na Seção 3 uma breve análise de trabalhos na área de engenharia de software que utilizam surveys como método de pesquisa. A Seção 4 faz uma apresentação de trabalhos relacionados e na Seção 5 as conclusões e trabalhos futuros. II. METODOLOGIA As fases do projeto seguirão as seguintes etapas da pesquisa-ação segundo [10], que são elas: A. Fase exploratória Nesta fase, será feita uma pesquisa por trabalhos relacionados, bem como uma busca de artigos em periódicos que falem de survey em engenharia de software. B. Formulação do problema Com base na fase anterior, será formulado o problema na qual constará as principais dificuldades dos engenheiros de software para a construção de survey na área. C. Construção de hipóteses As hipóteses deverão ser construídas baseando-se nas novas características disponibilizadas pela ferramenta. D. Realização do seminário Nesta fase, será realizado um seminário para professores e estudantes da área com o objetivo de apresentar e discutir os problemas e dificuldades no processo de elaboração de um survey em engenharia de software (ES) com o objetivo de propor melhorias. E. Seleção da amostra Serão selecionados pesquisadores e engenheiros de software que irão avaliar a eficiência da ferramenta. F. Coleta de dados Com base na fase anterior utilizando a técnica de aplicação de um questionário os dados sobre a utilização da ferramenta e as melhorias realizadas no processo de aplicação serão coletadas a partir das respostas da amostra selecionada. G. Análise e interpretação dos dados Esta fase tem como objetivo analisar o feedback dos usuários da ferramenta e o quanto que a mesma contribuiu para a elaboração de surveys em relação a eficiência e custo. H. Elaboração do plano de ação Esta fase tem como objetivo desenvolver uma ferramenta online de survey para suprir as necessidades que as demais não apresentam de acordo com as necessidades na área de engenharia de software. 31 I. Divulgação dos resultados Os resultados obtidos na pesquisa serão divulgados através de artigos em congressos e eventos da área. A Seção 3 apresenta alguns estudos na área de engenharia de software que utilizaram o método de pesquisa survey para realização da pesquisa. III. SURVEYS EM ENGENHARIA DE SOFTWARE Vários trabalhos vêm usando surveys para entender melhor o mundo dos engenheiros de software. O trabalho [3] apresenta a instanciação de uma das etapas do projeto EduES Brasil, correspondente a um survey que visa caracterizar o cenário de educação em ES no pais, sob o ponto de vista da comunidade de educadores. Em [4], desenvolveu-se um trabalho onde foi realizado um estudo empírico onde investigaram: (i) o que os desenvolvedores usaram para avaliar a coesão de diferentes módulos e (ii) em que medida as classificações que deram, eram relacionadas com medidas estruturais e de coesão conceitual. Como resultado percebeu-se que a maioria dos desenvolvedores estão familiarizados com a coesão e os que não estão familiarizados com a coesão são mais provavelmente os menos experientes. No estudo [5] procuraram determinar o estado da prática de comentários em software e inspeções. O objetivo era encontrar fatores de contexto relevantes que influenciam a forma como comentários são conduzidos. Para aplicação de surveys existem várias ferramentas disponíveis no mercado. A Seção 4 apresenta algumas dessas ferramentas e dificuldades para utilização destas na área de engenharia de software. IV. TRABALHOS RELACIONADOS: ANÁLISE DE FERRAMENTAS SURVEYS Para aplicação de surveys existem na WEB várias ferramentas que facilitam o processo de construção, aplicação e análise dos resultados. SurveyMonkey é uma ferramenta que possibilita ao usuário trabalhar tanto com questões objetivas quanto questões subjetivas e oferece um recurso de banco de questões permitindo a criação ágil de um survey, além de oferecer a análise dos resultados por meio de gráficos [6]. FreeOnlineSurveys possui como maior característica o recurso drag – and – drop que lhe atribui uma agilidade no processo de elaboração do survey sendo uma ferramenta com uma interface bastante intuitiva [7]. QuestionPro é uma ferramenta bastante completa mesmo em sua versão gratuita permite a elaboração de diversos tipos de questões, oferece controle sobre o survey, envio por e-mail, link e compartilhamento nas redes sociais e análise sobre os resultados [8]. SurveyPlanet é uma ferramenta que possibilita ao usuário trabalhar com a criação, envio e análise dos resultados de um survey, entretanto os recursos de controle sobre o survey são limitados [9]. Nenhuma das ferramentas apresentadas possui mecanismos para facilitar a exibição e manipulação de códigos-fonte de linguagens, dificultando sua utilização em muitas pesquisas realizadas na área de engenharia de software. V. CONCLUSÃO Neste trabalho apresentamos o planejamento para criação de uma ferramenta com o objetivo de melhorar o processo de aplicação de surveys em engenharia de software. Foi realizada uma exploração inicial das principais ferramentas utilizadas para realização desse tipo de estudo com o objetivo de enumerar as principais dificuldades. A utilização do método de pesquisa Survey na engenharia de software encontra várias dificuldades quando é necessário apresentar código-fonte. O principal motivo são as ferramentas disponíveis no mercado não proporcionarem recursos adequados para uma melhor elaboração de surveys na área. Como trabalhos futuros pretende-se continuar a avaliação aprofundada das ferramentas existentes no mercado e seguindo a metodologia apresentada, iniciar a construção e posterior avaliação da ferramenta. Espera-se que a ferramenta facilite o processo de aplicação de surveys por engenheiros de software. VI. [1] REFERÊNCIAS BASILI, V. R.; SELBY, R. W.; HUTCHENS, D. H. Experimentation in software engineering. IEEE Transactions on Software Engineering, v. SE-12, n. 7, p. 733–743, 1986. IEEE. Disponível em: <http://ieeexplore.ieee.org/articleDetails.jsp?arnumber=6312975>. Acesso em: 2/9/2014. [2] BABBIE, E. Metodos de Pesquisas de Survey. Belo Horizonte, 2003. [3] SCHOTS, M.; SANTOS, R.; MENDONÇA, A.; WERNER, C. Elaboração de um Survey para a Caracterização do Cenário de Educação em Engenharia de Software no Brasil. ,n. 1, p. 2–5, 2009. [4] DA SILVA, B. C.; SANT’ANNA, C. N.; CHAVEZ, C. V. F. G. An empirical study on how developers reason about module cohesion. [5] Proceedings of the 13th international conference on Modularity MODULARITY ’14, n. i, p. 121–132, 2014. New York, USA: ACM Press. Disponível em: <http://dl.acm.org/citation.cfm?doid=2584469.2577096>. Acesso em: 20/7/2014. [6] CIOLKOWSKI, M.; LAITENBERGER, O.; VEGAS, S.; BIFFL, S. Practical Experiences in the Design and Conduct of Surveys in Empirical Software Engineering. p. 104–128, 2003 [7] SURVEYMONKEY. Create Surveys. Get Answers. Disponível em: <https://surveymonkey.com>. Acesso em: 15/5/2014. [8] FREEONLINESURVEYS. Create your own Free Online Survey. Disponível em: <http://freeonlinesurveys.com>. Acesso em: 7/6/2014. [9] QUESTIONPRO. Online Research Made Easy. Disponível em: <http://questionpro.com>. Acesso em: 27/5/2014. [10] SURVEYPLANET. Disponível em: <https://www.surveyplanet.com>. Acesso em: 7/6/2014. [11] GIL, A. C. Como Elaborar Projetos de Pesquisa. 5a ed. São Paulo, 2010. 32 Planeta Saudável, Consumo Consciente em Jogo Ícaro M. R. de Oliveira, Isaac L. de Argolo e Kenia K. Cox Departamento de Computação Universidade Federal de Sergipe Aracaju-Se, Brasil [email protected], [email protected], [email protected] pensamentos. Então, uma ferramenta educativa que se destaca pelos resultados que produz neste contexto são as brincadeiras, dentre as quais tem-se os jogos. No processo educativo os jogos correspondem a ferramentas fundamentais que permitem à criança brincar com a criação de hipóteses e soluções para problemas, aproximando-se assim da realidade [3]. No casamento entre educação e brincadeiras, destaca-se o computador como uma ferramenta que adiciona diversificados recursos. Como ferramenta de apoio ao ensino, as máquinas de processamento, no ambiente educacional, auxiliam na formação de conceitos; estímulam com a multiplicidade de formas de apresentação de informações, dinamicidade e interatividade que apresentam. Ao se aliar educação, brincadeiras e computador, surgem os jogos computacionais educativos. Por meio deles é possível construir um ambiente lúdico de ensino e aprendizagem, onde a criança ao mesmo tempo em que se diverte, constrói conhecimento. Este artigo apresenta o jogo computacional PS2C – Planeta Saudável, Consumo Consciente – o qual se volta especificamente para o estímulo ao consumo consciente na infância, por meio de brincadeira. Dessa forma, o jogo corresponde a uma maneira de sensibilizar crianças para o tema e assim contribuir para construção de um mundo que respeita o meio ambiente. Supõe-se que com a assimilação desses novos conceitos as crianças comecem a desenvolver um comportamento consciente útil à divulgação de novas atitudes; então, o conhecimento adquirido no jogo alcançará também para outras pessoas. Resumo - Tendo em vista a preservação ambiental, é importante que todos adotem o consumo consciente. Esta postura deve ser ensinado principalmente para as crianças - consumidores em formação, que são educados e preparados para a vida. Isso é conseguido por meio de processos interactivos, que simula a ação no ambiente. Uma ferramenta que se destaca neste sentido é o jogo computacional educativo: instrumento lúdico que possibilita a construção de um ambiente de ensino aprendizagem, onde a criança ao mesmo tempo em que se diverte, constrói conhecimento. Assim, este artigo apresenta "Planeta Saudável, Consumo Consciente" (PS2C), com uma ferramenta pedagógica para o ensino sobre o consumo consciente. É um jogo de tabuleiro em que existem cinco grandes temas: pilares do consumo consciente, consumo consciente, consumo consciente de água, o consumo de alimentos consciente e gestão de resíduos. O objetivo do jogador é chegar ao final do caminho e manter a saúde do planeta Terra virtual. Palavras chaves: consumo consciente, Jogos Educativos, Desenvolvimento de jogos Computacionais. I. INTRODUÇÃO A economia de mercado, apoiada pelo marketing, é direcionada hoje pela produção e pelo consumo de massas [1]. O consumo pessoal desempenha um papel central neste processo, sem levar em consideração os impactos provocados por este. Entretanto, quando o consumidor passa a levar em conta tudo que será causado no planeta, em diversos aspectos, com a compra que ele está desejando fazer, pode ser considerado um consumidor consciente. Assim, com vistas à preservação ambiental, é muito importante que todos aprendam que as decisões que tomamos afetam o nosso planeta. Pressupõe-se que esse tipo de conscientização deve ser efetuado em todos os ambientes, mas em especial nos infantis em que as crianças, consumidores em formação, estão sendo educados e preparados para a vida. A formação dessa geração de consumidores com valores socioambientais saudáveis apresenta-se como uma boa alternativa de educação ambiental. Carvalho [2] afirmou que se o consumo consciente for problematizado, discutido e vivenciado pelas crianças e adolescentes, a situação passa a ser mais dialogada, menos unilateral e eles também se transformam em atores sociais. O processo educativo ambiental, por sua vez, deve ser alcançado através de processos contínuos e interativos, adequados à formação da consciência e da capacidade de avaliação crítica do mundo. Não basta apenas ensinar sobre a natureza, mas possibilitar a compreensão e a construção de novas formas de II.CONSUMO CONSCIENTE O ato de consumir não deve ser reduzido ao ato de comprar. Todo o processo envolvido direta, ou indiretamente, com a decisão e necessidade de compra, uso e descarte de um produto faz parte do consumo deste e devem estar muito claros para o consumidor que deseja adotar o consumo consciente. Quando se trata da decisão de compra, o consumidor consciente deve considerar que no processo de consumo, quando um produto é vendido significa dizer que o consumidor dele estar aprovando todos os métodos utilizados; desde a obtenção da matéria-prima até o transporte deste. O consumidor passa a ser considerado consciente quando ele decide o que irá consumir levando em conta o que ele realmente necessita e qual das marcas, dos produtos e serviços almejados, o atende é a que menos agride o nosso ecossistema durante todo o processo de criação, industrialização, comercialização, uso e descarte [1]. Ou seja, o consumidor adota uma postura de 33 consumo consigo mesmo, com os outros, com a economia e com o planeta. É de suma importância a disseminação do conhecimento necessário para que haja uma mudança de comportamento da população, fazendo com que esta consuma de uma forma consciente e agredindo o mínimo possível o meio ambiente. Assim, consumidor consciente além de minimizar os impactos negativos de suas ações para com o meio ambiente, tenta maximizar os positivos. Considerando este pensamento, adotamos temas relevantes para atingir da melhor forma o objetivo do jogo: (a) pilares do consumo consciente, (b) consumo consciente de energia, especificamente quanto ao uso de lâmpadas; (c) consumo consciente de alimentos, específico a alimentação saudável e ecologicamente sustentável; e (d) gestão do lixo, que trata do reaproveitamento de produtos recicláveis e seu correto descarte. IV.IMPLEMENTAÇÃO DO JOGO PS2C O jogo PS2C foi implementado usando a linguagem de programação JAVA, no ambiente de desenvolvimento Eclipse, e banco de dados PostgresSQL. Todas ferramentas gratuitas com vários recursos que facilitaram a codificação do jogo. A linguamgem JAVA é uma linguagem orientada a objetos, que possui recursos de heranças e polimorfismos, os quais flexibilizaram o reaproveitamento de código. III. LÚDICO NA EDUCAÇAO A importância das brincadeiras para as crianças se dá devido ao fato de que enquanto elas brincam, internalizam também conhecimento. Criar, brincar e fazer, são aspectos que podem ser trabalhados por meio da confecção de aplicação de jogos, no contexto escolar e clínico: a ansiedade, os limites, a capacidade de realização, a atenção e concentração, a estratégia, o raciocínio lógico e a criatividade [6]. Todos podem ser facilmente explorados por meio de brincadeiras. Por exemplo, num jogo de quebra-cabeça, a criança descobre que cada peça tem um valor fundamental e que é preciso concentração, dedicação e raciocínio para encaixar as peças. Outro exemplo pode ser facilmente visualizado na brincadeira chamada de esconde-esconde, na qual a criança terá que pensar no melhor esconderijo, trabalhando assim o seu raciocínio lógico, além de aprender com as demais crianças pois se uma pessoa foi encontrada rapidamente, é pouco provável que as demais crianças escolham aquele mesmo lugar da próxima vez. Usar jogos na educação corresponde a educar de maneira a entreter os alunos, atiçar sua curiosidade e fazê-los vivenciar situações reais. Além de mexer com a imaginação infantil, os jogos também melhoram sua coordenação motora e visual [4]. Vê-se o benefício que o lúdico traz para as crianças quando se utiliza a tecnologia como apoio à educação. O jogo computacional instiga as crianças e faz com que elas consigam passar horas na frente de um computador, utilizar a curiosidade infantil e o seu interesse pela dinamicidade e interativa promovidas por aparatos tecnológicos, em consonância com a educação, torna o estudar muito mais interessante e divertido. Considerando-se o importante papel desempenhado pelos jogos computacionais educativos, que aliam diversão e aprendizado, tornando o estudar mais atrativo e de qualidade, no qual a criança não simplesmente é mera receptora e sim participa, busca e interage com casos expostos. Logo, a criação de um jogo educativo voltado para o consumo consciente faz-se válido. Figura 1 – Planeta doente necessitando de cuidados. Na figura 1, a classe Questao, é uma subclasse da classe Casa, obtendo seus atributos e métodos. O que melhorar a legibilidade do código e reutiliza-o, evitando sua duplicidade desnecessária. Além disso, o ambiente JAVA possui varias api’s que facilitam a manipulação de sons e imagens. Com esses recursos os jogos computadorizados se tornam atrativos. Outro ponto forte do recurso sonoro está na forma de ressaltar um determinado acontecimento, por exemplo, quando há um acerto em uma questão um sinal sonoro de sucesso é emitido. Da mesma forma um sinal sonoro negativo é emitido no caso contrário, um poderoso meio de resposta as açõe, com fundo pedagógico. O PostgreSQL foi o software gerenciador de banco de dados utilizado no projeto, sendo um dos principais aspectos, refere-se a segurança no gerenciamento das informações. Outro fator importate é que sua linceça é gratuita o que seu uso aumente significativamente. Portanto, PostgreSQL é o sistema gerenciador de dados necessário para manipular as informações do PS2C de maneira adequada. A metodologia de desenvolvimento adotada para a consturção do jogo foi o Scrum. O Scrum é uma metodologia de desenvolvimento ágil que trabalha de forma iterativa. Essas iterações são chamadas de sprints. Sprints geralmente duram de 2-4 semanas, mas podem durar menos ou mais dependendo do tamanho do projeto. Uma das características interessante é que ele é focado em equipes auto-organizadas e auto-gerenciáveis. São equipes que tem autonomia para decidir a melhor maneira de como fazer seu trabalho sem a interferência externa [7]. Ou seja, auto-organizáveis significa que são independentes para se organizar em torno de um 34 problema a ser resolvido. Desta forma, o Scrum possibilita focar somente no problema que é desenvolver um jogo educativo de consumo consciente. O PS2C foi desenvolvido com ferramentas livres que fornecem todos os recursos necessários para implementar jogos atrativos. Que por serem livres possibilitam que outras pessoas possam prosseguir e melhorá-lo. V. JOGO PLANETA SAUDÁVEL, CONSUMO CONSCIENTE (PS2C) O jogo Planeta Saudável, Consumo Consciente é uma proposta de ferramenta lúdica, para educação da criança, voltado para as relações de consumo, que permeiam toda sua infância, bem como toda sua vida adulta. Os jogos educativos computadorizados possuem, como uma de suas principais vantagens, um grande potencial para o processo de ensino e aprendizagem, por despertarem naturalmente o interesse dos alunos [5]. Os recursos de multimídia tentem a prender a concentração das crianças, que em certa idade é dispersada facilmente. O PS2C possui uma interface colorida, visando chamar a atenção da criança, e a motiva a se concentrar no ambiente interno do jogo. Que é representado por um campo com jardim verde. Aproveitando esta ideia, o jogo possui a estratégia pedagógica, no qual o planetinha e o ambiente do jogo sofrem alterações de acordo com os resultados obtidos sobre os questionamentos que lhe são apresentados. Assim, a criança percebe que os atos, os quais ela pratica, prejudicam o meio ambiente e a saúde do planeta. Figura 3 – Planeta requerendo cuidados, de 6 a 10 pontos de saúde. No PS2C a estratégia adotada para levar a criança à reflexão é visual, pouco a pouco a interferência na paisagem vai sendo percebida à medida que a criança começa a interagir com o jogo. Se o jogador se depara com muitas situações negativas e/ou responde errado às questões que lhe são apresentadas o cenário se torna sujo, mostrando que o planeta está mal, conforme a figura 2. Caso contrário, o cenário passa a ser mais vivo, demonstrando que se o jogador agir de maneira consciente o planeta se torna saudável, e, portanto, um lugar melhor para se viver, como mostra a figura 3. Assim ganhos cognitivos ocorrem de forma gradativa e lúdica, de maneira que a criança consegue perceber que ela faz parte do mundo e suas escolhas são fundamentais para que ele se conserve. O PS2C é um jogo de tabuleiro onde o jogador se movimenta entre as casas que compõe um caminho, com o objetivo de alcançar o final deste e de preservar a saúde o planeta. A locomoção do jogador é efetuada pela definição do número de casas a avançar, em cada jogada, através do resultado aleatório de um lançamento de um dado, de 6 faces. Figura 2 – Planeta doente necessitando de cuidados. De acordo com a Figura 2 o planeta está doente e precisa urgente de cuidados. A poluição e o lixo estão presentes demonstrando a situação do planeta. Além disso, o cenário está com uma cor não tão viva, simulando para a criança que o planeta está com problemas de saúde. Figura 4 – Questão do jogo PS2C. E a saúde do planeta depende do quantitativo de acertos e erros que o jogador apresenta a questões apresentadas como desafios, a figura 4 corresponde a um questão sobre pilares do consumo consciente. O caminho será composto por 60 casas, as quais podem conter: situações positivas – quando são apresentadas informações em que as pessoas se comportaram como consumidores conscientes, situações negativas – quando são apresentadas 35 informações em que as pessoas não se comportam como consumidores conscientes, e desafios – através dos quais são lançadas questões aos jogadores, cujas resposta afetarão a saúde do planeta. Essas informações serão apresentadas ao jogador sobre 5 temas principais: pilares do consumo consciente, consumo consciente de energia, consumo consciente de água, consumo consciente de alimentos e gestão de lixo. O objetivo do jogador é alcançar o final do caminho sem deixar que a saúde do planeta Terra chegue a zero. O jogo tem 36 itens de cada tema cadastrados (12 questões, 12 situações positivas e 12 situações negativas). A saúde do planeta é medida por meio de uma escala com 15 pontos: de 1 a 5 o planeta está doente; de 6 a 10 o planeta requer cuidados; de 11 a 15 o planeta está saudável. No início do jogo o jogador é posicionado na largada do caminho e a saúde do planeta Terra encontrase na escala 8 - "requerendo cuidados", figura 3. Quando o jogador parar em uma casa cujo conteúdo seja acerto ele ganhará 1 ponto de saúde do planeta e avançará 1 casa no tabuleiro. Quando a casa conter um erro ele perderá 1 ponto de saúde do planeta e voltará 1 casa no tabuleiro. Quando for um desafio se o jogador obter sucesso neste ele ganhará 1 ponto de saúde do planeta e avançará 2 casas, caso ele erre perderá 1 ponto de saúde do planeta e voltará 2 casas no tabuleiro. Se em qualquer momento do jogo a saúde do planeta chegar a zero haverá GAME OVER. A cada rodada, para obter o número de casas a avançar, no caminho, o jogador deve jogar um dado virtual. No tabuleiro cada tema seria representado por uma cor e uma forma de casa. O jogo possuim uma base de dados através da qual estes serão aleatoriamente selecionados em cada jogo. Assim, diferentes execuções, resultarão em diferentes jogos. Um jogador pode acessar todos os acertos, erros pelos quais já passou. Através de um log de respostas. O jogo PS2C estimula a capacidade de discernimento. Por meio dele a criança aprende agir em uma esfera cognitivista, sendo livre para determinar suas próprias ações com relação ao temas. O seu principal objetivo é a saúdo do planeta, mostrando para cirança que seus atos não isolados, e que afetam a vida do planeta em que vivem. VI.CONCLUSÃO Neste artigo considera-se que o jogo eletrônico é uma ferramenta lúdica que contribui para o processo de ensino. No jogo, as crianças buscam formular soluções para o que o jogo propõe. Desta maneira, assume uma postura ativa, possibilitando a formação do seu conhecimento. O PS2C, é uma aplicação para o ensino de consumo consciente, Para trabalhos futuros, sugerimos a abrangência maior para os temas de consumo. Para facilitar ainda mais o acesso e utilização do jogo, poderia ser feita uma versão online do PS2C. Outra sugestão seria a aplicação de síntese de voz para crianças com deficiência visual. VII. REFERENCIAS [1] AKATU: Perguntas Frequentes - O que é Consumo Consciente? Disponível em: http://www.akatu.org.br/PerguntasFrequentes/Sobre-o-Instituto. Acessado em: 5 de mai. 2012. [2] CARVALHO, Fabiana. Consumo Consciente: “Sua escola estimula atitudes sustentáveis?” Revista Atividade e Experiências. 2008. [3] FRANÇA, Gisela Wajskop. “O papel do jogo na educação das crianças”. Disponível em: http://www.crmariocovas.sp.gov.br/pdf/ideias_07_p046-053_c.pdf. Série Idéias n. 7. São Paulo: FDE, 1995. [4] PASSERINO, Liliana Maria. “Avaliação de Jogos Educativos Computarizados”. Disponível em: http://www.c5.cl/tise98/html/trabajos/jogosed/index.htm. Acessado em 28 de out. 2012. [5] GRUBEL, Joceline Mausolff; BEZ, Marta Rosecler. “Jogos Educativos”, 2006. [6] LOPES, Maria da Glória. “Jogos na Educação: Criar, Fazer, Jogar”. Editora Cortez. 2011. [7] INOVATIVIDADE. “Scrum? O que é? Como funciona?” Disponível em:<http://www.inovatividade.com/metodologias/scrumo-que-e-como-funciona>. Acessado em: 12 de jan. 2013. 2009. 36 Uma Solução de Business Intelligence para Apoio a Decisão à Coordenadoria de Cursos Onezino Gabriel Moreira, Ramon Ramos, André Britto Departamento de Computação Universidade Federal de Sergipe São Cristóvão, SE, Brasil [email protected], [email protected], [email protected] Resumo—Nos dias atuais, os ambientes estão cada vez mais complexos. Logo, a informação se torna um recurso de valor estratégico no apoio a tomada de decisão. Através de ferramentas de Business Intelligence é possível disponibilizar informação atual, útil e de qualidade para os tomadores de decisão. A Coordenação Acadêmica do Departamento de Computação da Universidade Federal de Sergipe está inserida nesta realidade e necessita de mecanismos no apoio a tomada de decisão para, por consequência, melhorar a produtividade institucional. O objetivo deste trabalho é apresentar uma solução de Business Intelligence para auxiliar os coordenadores nas atividades de gerenciamento acadêmico. Este trabalho disponibilizou um projeto de Data Warehouse para armazenar informações acadêmicas e uma ferramenta OLAP que permite consultas realizadas pelos coordenadores de curso do departamento. Palavra-chave-Business Intelligence, Decisão à Coordenadoria de Curso. I. OLAP, Apoio a INTRODUÇÃO Nos dias atuais, as organizações possuem uma grande quantidade de dados, mas enfrentam dificuldades na extração de informação a partir destes dados. Os ambientes nos quais as organizações estão inseridas encontram-se cada vez mais complexos e os dados e informações devem estar disponíveis para as pessoas certas, no formato esperado, no local e tempo desejados, tornando a informação um recurso de valor estratégico [3]. A informação serve como insumo no processo de tomada de decisão e, por isso, a organização necessita controlá-la e torná-la acessível, confiável, tempestiva e adequada por meio de sistemas apropriados de gerenciamento de informações [1]. Não se pode desconsiderar a tecnologia da informação e os seus respectivos recursos para atender as necessidades informacionais dos usuários [9]. Neste contexto, surge Business Intelligence (BI). Business Intelligence é um conjunto de capacidades, tecnologias e práticas utilizadas em ambientes de negócio, de forma a adquirir melhor compreensão do contexto e transformar os dados existentes em informação útil [3]. BI tem o potencial de prover novas formas de entender os dados dos quais a organização dispõe, extraindo, portanto, informações capazes de gerar um novo entendimento ou conhecimento para o usuário final, neste caso o tomador de decisões. Os sistemas de BI estão tradicionalmente associados a três tecnologias: Data Warehouse (DW) como ferramenta de armazenamento de informação de negócio, Online Analytical Processing (OLAP) e Data Mining como ferramentas de interpretação dos dados [7]. Nas empresas privadas os sistemas de BI são utilizados, principalmente, com o intuito de se obter vantagens competitivas, satisfazer os anseios dos clientes e maximizar os lucros. Já nas entidades públicas, os gestores buscam satisfazer aos cidadãos, fazer um bom uso dos recursos públicos e maximizar a produtividade institucional. No âmbito de uma universidade pública, a produtividade institucional é beneficiar a sociedade com o maior número possível de profissionais egressos da universidade. Além de garantir que a formação destes profissionais contenha um referencial teórico e prático que os levem a exercer com qualidade as funções às quais se capacitou [2]. Para maximizar a produtividade, é necessário um estreitamento na relação entre universidade e alunos. Deve ser possível traçar o perfil dos alunos, identificar disciplinas e períodos que apresentam retenção de alunos e acompanhar, ao longo do tempo, os mais diversos indicadores. A média geral ponderada (MGP) e o índice de regularidade (IR) tanto por turma como também por aluno são exemplos destes indicadores. Neste contexto, esse trabalho apresenta uma solução de BI para auxílio na tomada de decisões dos coordenadores de cursos do Departamento de Computação da Universidade Federal de Sergipe. Este sistema é formado por um Data Warehouse com dados acerca do desempenho acadêmico dos alunos dos cursos de Ciência da Computação, Sistemas de Informação e Engenharia de Computação e uma ferramenta OLAP com consultas que solucionam algumas necessidades informacionais dos coordenadores de curso. O sistema foi desenvolvido com informações acadêmicas fornecidas pelo Centro de Processamento de Dados (CPD) da universidade (de forma anonimizada impedindo a identificação do aluno para manter a confidencialidade da informação) e disponibilizado para os coordenadores de curso do DCOMP. Os dados fornecidos pelo CPD foram integrados utilizando a ferramenta de integração Pentaho Data Integration (PDI) e o Microstrategy como ferramenta de consulta para o usuário final. Foram criadas consultas para atender as necessidades informacionais identificadas da coordenadoria de cursos do departamento. Com o monitoramento desta informação, que é representada por um conjunto de indicadores acadêmicos, é possível conhecer o que aconteceu no passado e traçar cenários para o futuro. 37 O trabalho está organizado da seguinte maneira. A seção II discute os conceitos básicos de Data Warehouse e de ferramentas OLAP. Na seção III é discutido o problema que os coordenadores enfrentam para extrair informações acadêmicas e sugere uma solução para esta dificuldade utilizando os conceitos de BI. A seção IV discute os passos no processo de desenvolvimento da solução e demonstra os resultados obtidos a partir das consultas disponibilizadas para o usuário final. Por fim, a seção V apresenta as considerações finais e as conclusões deste trabalho. II. DATA WAREHOUSE E FERRAMENTA OLAP A tradução literal de Data Warehouse (DW) é “armazém de dados”. Inmon [11] inventou o termo Data Warehouse em 1990 e define que Data Warehouse é uma coleção de dados orientada por assuntos, integrada, variante no tempo, e não volátil, que tem por objetivo dar suporte aos processos de tomada de decisão. O DW visa reunir e gerenciar dados de várias fontes com o objetivo de ganhar uma visão única e detalhada de parte ou da totalidade de um negócio [9]. Em geral, o Data Warehouse é armazenado em um banco de dados separado da base operacional. Esta separação evita a perda de desempenho no processo operacional da empresa. Um Data Warehouse contém uma grande variedade de dados que apresentam uma imagem coerente das condições da organização em um determinado ponto no tempo. O DW é uma ferramenta capaz de gerenciar grandes quantidades de dados, modelando-os para suprir as necessidades dos executivos por informações mais rápidas sobre o desempenho da empresa. Ele é um banco de dados analítico que é usado como base para os sistemas de apoio à decisão (SAD). É um banco de dados somente leitura e provê acesso intuitivo às informações que serão usadas na tomada de decisões [8]. Sistemas de Data Warehouse compreendem um conjunto de programas que: extraem os dados do ambiente operacional, um banco de dados que os mantém e sistemas que fornecem estes dados aos usuários [9]. A. Modelagem dimensional O modelo dimensional permite ao usuário compreender os dados do negócio e facilita a consulta e navegação pela informação. Ele é composto por tabelas de fatos e dimensões. O modelo dimensional permite a visão dos dados de negócio em forma de um cubo de dados sendo que as informações contidas nas células do cubo são medidas e os lados do cubo são dimensões [8]. A tabela de fatos é responsável normalmente por 90% do volume de dados de um Data Warehouse e o seu objetivo é de armazenar medições numéricas acerca do desempenho organizacional [8]. As tabelas de dimensões são consideradas as descritoras do negócio e possibilitam a análise da tabela de fatos por diferentes visões. B. Ferramentas OLAP Online Analytical Processing (OLAP) é considerado uma categoria de software que permite aos seus usuários obter resposta dentro do grande conjunto de dados do Data Warehouse. Também possibilita a realização de consultas de forma rápida, consistente, flexível, interativa, além do acesso a uma ampla variedade de possíveis visões [5]. O OLAP possibilita que o usuário produza facilmente seus próprios relatórios, análises de tendências e desempenho. Com isto, ajuda o usuário a analisar de forma mais eficiente a quantidade de dados crescentemente armazenados pelas organizações, transformando-os em informação. Bispo [4] apresenta o OLAP como uma ferramenta capaz de efetuar análises de dados com visão multidimensional do negócio, comparando-os por diversos ângulos. Aplicações que utilizam este tipo de ferramenta devem ter como características: Permitir visão multidimensional dos dados; Realizar cálculos complexos; Criar agregações e consolidações; Fazer previsões e análise de tendência; Construir cenários a partir de suposições; Fazer cálculos e manipular dados através de diferentes dimensões; Esquema otimizado para que as consultas realizadas pelos usuários sejam retornadas rapidamente; Geração de relatórios complexos de uma forma simples. III. APOIO A DECISÃO NA COORDENADORIA DE CURSOS DO DEPARTAMENTO DA COMPUTAÇÃO DA UNIVERSIDADE FEDERAL DE SERGIPE O cenário de aplicação deste trabalho foi a coordenadoria de cursos do Departamento da Computação (DCOMP) da Universidade Federal de Sergipe (UFS). Neste local, frequentemente, eram solicitados ao Centro de Processamento de Dados (CPD) dados acadêmicos do Sistema Integrado de Gestão de Atividades Acadêmicas (SIGAA). Estes dados eram verificados e salvos manualmente em planilha Excel para análise da situação do departamento. Esta dificuldade de se obter informações sobre o desempenho dos alunos dos cursos do DCOMP era externada como um fator preocupante no exercício das atribuições de um coordenador de cursos. A informação é utilizada pelos coordenadores de curso como apoio a tomada de decisões em atividades como: definição de horários, quantidade de vagas ofertadas, alocação de professores por disciplina. Além disso, os coordenadores buscam conhecer a evolução dos alunos dos cursos, buscando identificar a porcentagem de alunos egressos, períodos que apresentam a maior taxa de desistência, evolução da MGP dos alunos por semestre letivo, entre outros fatores que são importantes para apoiar os coordenadores. Assim, visando auxiliar esse processo de tomada de decisão, foi desenvolvida uma solução de BI para a coordenadoria de cursos do DCOMP. Por meio de uma entrevista com uma coordenadora de cursos, as necessidades informacionais foram identificadas. As necessidades informacionais da coordenadoria de cursos estão atreladas, basicamente, a três aspectos: acompanhamento dos alunos 38 ingressos, comparação dos alunos egressos e comparação das turmas ao longo do tempo. IV. DESENVOLVIMENTO DA SOLUÇÃO DE BUSINESS INTELLIGENCE O primeiro passo no desenvolvimento da solução de BI foi a construção do Data Warehouse. Para isto, foi definido o modelo dimensional, o qual permite desempenho nas consultas [9], baseado nas necessidades informacionais elencadas na Seção III. A Tabela 1 lista as dimensões e fatos identificados durante a concepção do modelo multidimensional. TABLE I. Nome Dmal_aluno Dmtm_tempo Dmcs_curso Dmpr_professor Dcc_comp_curricular Fttu_turma Ftda_desemp_aluno MODELO DO DATA WAREHOUSE Descrição Dimensão com informações dos alunos Dimensão com informações de período Dimensão com informações dos cursos ofertados pelo departamento Dimensão com informações do professor Dimensão com informações das disciplinas da grade dos cursos Fato com informações de acompanhamento da turma Fato Informações do desempenho individual de cada aluno A. Processo de Extract Transform Load Para carregar as informações acadêmicas no Data Warehouse foi solicitado ao Centro de Processamento de Dados (CPD) da UFS os dados necessários. Os dados foram disponibilizados no formato de Comma-Separeted-Value (CSV) para cada tabela do DW. Os dados dos alunos foram anonimizados garantido a confidencialidade. Utilizou-se a ferramenta Pentaho Data Integration (PDI), versão 5.1.0, para realizar o carregamento, garantir a integridade e padronizar a informação. Por questões de qualidade dos dados, a linha temporal de corte foi o ano de 2007. O processo ETL será executado semestralmente, após o fim de cada período letivo. Com isto, o Data Warehouse se manterá íntegro, histórico e atualizado. B. Consultas OLAP Existem diversas ferramentas OLAP disponíveis no mercado, uma variedade de ferramentas pagas ou gratuitas. Para Kimball [8], faz parte do ciclo de vida do desenvolvimento de um projeto de Data Warehouse a análise e escolha da ferramenta OLAP que melhor atenda às necessidades da organização. A ferramenta MicroStrategy Free Reporting Suite, versão 9.4.1, foi escolhida por possuir recursos que permitem ao usuário final produzir seus próprios relatórios de maneira simples, fácil, rápida, flexível e possibilitar grande parte das operações OLAP [6]. A aplicação está disponível para ser acessada pelo navegador e todos os artefatos que atendem as necessidades informacionais identificadas nos requisitos do projeto foram previamente criados. Estes artefatos são classificados como: documentos, relatórios, gráficos e dashboards. Eles permitem aos coordenadores serem explorados através de filtros e operações de consultas. Entretanto, caso surjam novas necessidades, a ferramenta permite a customização das consultas pelo usuário. As necessidades informacionais da Coordenaria dos cursos do Departamento de Computação são agrupadas por três aspectos relevantes: acompanhamento dos alunos ingressos, comparação dos alunos egressos e comparação das turmas ao longo do tempo. Por exemplo, a coordenação pode acompanhar o número médio de créditos que os alunos integralizam por semestre. Essa informação pode ser estratificada por curso, por ano, por turma, etc. Assim, os coordenadores podem prever quantos alunos irão se formar em cada semestre e prever a demanda de quantas disciplinas serão lecionadas por cada professor com antecedência. Para ter um melhor conhecimento dos alunos que ingressam no curso foi criado o relatório “Forma de Ingresso do Aluno”. Este relatório mostra a forma de ingressos dos alunos dos cursos do DCOMP. É possível verificar para cada ano a forma de ingresso dos alunos. Observando a Fig. 1, percebe-se que a grande maioria, cerca de 90% dos alunos, entrou via vestibular. Além disso, cerca de 7% dos alunos ingressam nos cursos através de transferência interna e portador de diploma. Esse número é importante para o coordenador, pois cerca de 200 alunos tiveram experiência em algum outro curso na UFS e por escolha própria resolveram cursar um curso de Computação. O coordenador deve procurar identificar o principal motivo dos alunos optarem por fazer computação e baseado nesse novo conhecimento estimular os alunos que ingressaram via vestibular a não evadirem. Dashboards são recursos disponíveis no Microstrategy que permitem combinar diversas formas de apresentar a informação. O gráfico de aprovados, apresentado na Fig. 2, representa o comparativo da quantidade de turmas e aprovados durante os anos. Ele mostra um crescimento linear de aprovados e da quantidade de turmas. O coordenador pode aplicar filtros para obter informações de uma determinada turma ou de um determinado período e incluir novos indicadores no gráfico comparativo. Figura 1. Relatório de forma de ingresso. Utilizando as operações de OLAP disponíveis no MicroStrategy conseguimos atender à necessidade informacional da coordenadoria para identificar as disciplinas que mais reprovam os alunos, Fig. 3. Visualizando apenas a dimensão de componente curricular identificamos estas disciplinas. Cálculo I é a disciplina que mais reprova os alunos. Outra informação é que as 39 disciplinas que não são do Departamento de Computação são maioria no Rank das dez disciplinas que mais reprovam. A Fig. 4 exibe a taxa de reprovação da disciplina e o seu período. O período que tem maior taxa de reprovação do curso de Ciências da Computação são o primeiro e segundo, para Sistemas de Informação o segundo e para o curso de Engenhaira da Computação o terceiro que também foi identificado como período que mais reprova alunos entre os três cursos com aproximadamente 47%. Figura 2. Gráfico de aprovados. V. CONCLUSÃO As ferramentas de BI permitem disponibilizar informações contínuas, atuais e de qualidade para os gestores, sendo um insumo de caráter estratégico nas organizações. A solução de BI implementada para a coordenadoria do Departamento de Computação mostrou-se valiosa para apoiar a tomada de decisões, atendendo as necessidades informacionais levantadas nos requisitos do projeto. A solução de BI desenvolvida permite acompanhar os indicadores acadêmicos como média, índice de regularidade, taxa de aprovação e reprovação. Baseando-se nos valores destes indicadores ao longo do tempo, será possível traçar projeções para o futuro. Foi possível identificar disciplinas e períodos com maior taxa de reprovação e o perfil dos alunos do departamento. Essa informação suporta a tomada de decisões dos coordenadores do departamento para melhorar a produtividade institucional. Como trabalhos futuros, deseja-se realizar uma tarefa de mineração de dados para extrair alguma informação não conhecida a priori. REFERÊNCIAS A. Catelli, C. Pereira, M. Vasconcelos, “Processo de gestão de sistemas de informações gerenciais” São Paulo: Atlas,2001. [2] A. C. Bianchi, M. Alvarenga, R. Bianchi, “Manual de orientações: Estágio supervisionado”, 3th ed., São Paulo: Thomson Learning, 2003. [3] C. Barbieri, “BI – Business Intelligence: modelagem e tecnologia”, 2nd ed., Axcel Books do Brasil, 2002. [4] C. A. F. Bispo, “Uma análise da nova geração de sistemas de apoio à decisão” Dissetação de mestrado, São Paulo: Universidade de São Paulo, 1998. [5] R. Barquini, “Planning and designing the warehouse” New Jersey: Prentice-Hall, 1996. [6] R. L. Sallam, “Magic Quadrant for business intelligence and analytics platforms” 2014, disponível em: <http://www.gartner/com/ technology/reprints.do?id=1-1QYL23J&ct=140220&st=sb>, acessado em: 18 out. 2014. [7] R. Khan, “Business intelligence: na integrated approach” Business Intelligence Journal, vol. 5, 2012. [8] R. Kimball, M. Ross, “ The data warehouse toolkit: the complete guide to dimensional modeling” John Wiley & Sons, 2002. [9] S. C. Cazella, “Tecnologias para inteligência competitiva” Editora Unisinos, 2011. [10] V. Francisco, “Business Intelligence – um caso prático. Faculdade de engenharia da universidade de Porto” Relatório de projeto, 2009. [11] W. Immon, “Building the Data Warehouse” 4th ed., Wiley Publishing, 2005. [1] Figura 3. Relatório de disciplinas com mais reprovação. Figura 4. Períodos com maior taxa de reprovação. 40