Anais WRA2005-páginas 37-68 - arq. zipado
Transcrição
Anais WRA2005-páginas 37-68 - arq. zipado
Rastreamento em Realidade Aumentada com Artoolkit e Marcadores Priscila Santarosa Lahr, Paulo César Lourenço, Carlos Alberto Dainese Universidade Metodista de Piracicaba - (UNIMEP) Faculdade de Ciências Matemáticas, da Natureza e Tecnologia da Informação {pslahr, pclouren, cdainese }@unimep.br Abstract The evolution of hardware and software computing resources has allowed the development on visualization techniques. The use of graphics resources with specific input and output devices makes possible to define experiments using Augmented Reality, define procedures to calculate orientation and space information, and frame tracking. This work is a study of Augmented Reality to take the x, y and z space coordinates (translation) and orientation (angle rotation) from the environment by marks. It was utilized the ARToolkit software with a digital camera and Pentium IV microcomputer to perform experiments and get the date. 1. Introdução A Realidade Aumentada é definida como uma área de investigação que pretende desenvolver “mundos” que combinem objetos reais com cenas virtuais geradas por computador, possibilitando adicionar, ao mundo real, informações adicionais[2]. Com a Realidade Aumentada é possível que o usuário possa interagir, em tempo real, com esse mundo “aumentado”, tornando difícil à distinção entre os ambientes real e virtual. A Realidade Aumentada proporciona um aumento da percepção humana através da adição de informação não detectada diretamente pelos sentidos naturais. Nela, objetos virtuais são inseridos e posicionados na cena real em função da posição relativa do observador. Para desenvolver um Sistema de Realidade Aumentada é imprescindível o tracking. O tracking mede a posição e orientação do observador no espaço em relação ao sistema de captura de imagens (câmera). Vários autores têm desenvolvido estudos em Realidade Aumentada com uso de tracking para detecção de movimento das mãos, como Piekarski [5], e Dias [3,4] para reconhecimento de gestos. Para os experimentos deste estudo, foi utilizado o software ARToolkit [1] e marcadores para o reconhecimento de movimentação espacial e orientação. 2. Sistema de Realidade Aumentada e Tracking Um típico sistema de Realidade Aumentada é formado de uma ou mais câmeras, software para construção de objetos virtuais, sistema gráfico e dispositivo de interação para as tarefas de: a) captura da cena real, b) criação de imagens virtuais, c) sobreposição dos objetos reais e virtuais no mesmo cenário, d) rastreamento para posicionamento e orientação espacial do usuário e, e) interação em tempo real. O processo de criar um ambiente de Realidade Aumentada consiste em obter imagens reais, via câmera, e misturá-las com objetos sintetizados por computador dentro do mesmo ambiente. Uma tarefa importante é extrair informações para instruir o sistema gráfico no processo de formação de um ambiente a partir do ponto de vista do usuário. Uma das formas para efetuar esta operação é utilizar marcadores que permitem, ao sistema gráfico, definir coordenadas espacial e orientação dos objetos a partir do ponto de vista do usuário, quanto identificar alterações de posicionamento (tracking) e interação do usuário com os objetos. 37 2.1. O Software ARTOOLKIT ARToolKit [1] é uma biblioteca que permite desenvolver aplicações em Realidade Aumentada utilizando de técnicas de visão computacional para o processo de orientação e calibração de câmera, sobreposição e visualização de imagens reais e virtuais no mesmo cenário, além de detecção de movimentos em tempo real, cujo processo é feito com a utilização de um marcador. Além disso, suporta dispositivos como luva, capacete para visualização 3D, podendo ser utilizado em plataforma SGI IRIX e Windows PC 95/98/NT. O software ARTookit foi projeto por Hirokazu Kato e está disponível na Universidade de Washington. 3. Experimentos Realizados Para os experimentos do estudo foi utilizado um computador Pentium IV, uma câmera digital Sony, os software Artoolkit e Visual C++. Foram construídos marcadores (figura 1) no formato quadrado, de diferentes tamanhos, compostos de bordas pretas e, tendo ao centro, símbolos pretos, que serviram de identificação para as etapas de calibração e posicionamento de objetos virtuais sobre os marcadores. Os objetos utilizados para o estudo foram elaborados através do software VRML com tamanhos, formatos e cores diferenciadas. Figura 1 – Exemplos de marcadores utilizados nos experimentos Definiu-se uma mesa de trabalho na escala de 28,0 X 39,0 cm com a mesma estrutura dos marcadores (figura 2). Com a câmera focalizada a uma distância de 65 cm (figura 3) e centrada com a relação à mesa, foi possível estabelecer um sistema de coordenadas em relação à câmera. 38 Figura 2 – Mesa utilizada como apoio para desenvolver os experimentos Figura 3 – Ambiente com mesa e câmera Utilizando o ARToolKit 2.65 with vrml, foram realizados experimentos para identificação de deslocamento e orientação espacial. Foi utilizado um marcador (figura 4) posicionado obliquamente e deslocado do centro da mesa. Ao reconhecer o marcador, o ARToolKit retorna uma matriz de transformação de ordem 3x4, definida na função arGetTransMat( ). Nessa matriz, a última coluna contém as coordenadas do marcador em relação ao sistema da câmera (figura 5). Na primeira coluna da matriz podemos retornar os ângulos mínimos e máximos de cada eixo. As coordenadas espaciais e orientação são detectadas enquanto o marcador está sendo reconhecido e o objeto está visível. Todos os dados são gravados em um arquivo texto. 39 Figura 4- Marcador para extração de dados de rotação e translação Figura 5- Resultados de rotação e translação 4. Discussão e trabalho futuro Com a realização dos experimentos conseguimos executar uma fase importante e essencial para os sistemas de Realidade Aumentada que é o tracking. Com os resultados é possível identificar que o ARToolkit consegue detectar movimentação de translação e rotação com base em marcadores para aplicações em Realidade Aumentada. A fase seguinte do estudo será o reconhecimento de gestos com o Artoolkit. Referências [1] Augmented and Mixed Reality, “ARToolKit version 2.65” - Human Interface Technology Lab HITLab – disponivel em http://www.hit.washington.edu. [2] Azuma, R. T. - "A Survey of Augmented Reality"; Hughes Reserch Laboratories; Teleoperators and Virtual Environments, 6, 4 (August 1997), 355-385. [3] Dias, J.M.S., Santos, P., Nande, P., Barata, N.,Correia, A. “Image Manipulation throught Gestures”, Portugal, ADETTI/ISCTE – http://www.adetti.iscte.pt. [4] Dias, J.M.S., Santos, P., Nande, P., Barata, N.,Correia, A. “In Your Hand Computing: Tangible In terfaces for Mixed Reality”, Portugal, ADETTI/ISCTE – http://www.adetti.iscte.pt. [5] Piekarski, W., Thomas, B.H.,”Using ARToolKit for 3D Hand Position Tracking in Mobile Outdoor Environments”, University of South Australia, Australia. 40 Acesso via Internet para Máquina Virtual de Medir por Coordenadas Ricardo Zottino, Nivaldi Calonego Junior, Álvaro José Abackerli, Carlos Eduardo Della Coletta Faculdade de Ciências Matemáticas, da Natureza e da Terra UNIMEP - Universidade Metodista de Piracicaba Programa de Pós Graduação em Ciência da Computação Caixa Postal 68 – 13.400-901 – Piracicaba – SP – Brasil [email protected], [email protected], [email protected], [email protected] Abstract This article discusses the Virtual Coordinates Measurement Machine support for Internet application programs. Firstly, a synthesis on related works is present, reviewing different Virtual Distributed Environments models, and its influences on the system architecture. This discussing comprehend in a dedicate communication protocol and portable for multiple platforms, that will be responsible to manage the data exchange in a Collaborative Virtual Environment Distributed. Introdução A evolução das pesquisas no campo da realidade virtual durante a década de 90 propiciaram o surgimento de vários ambientes virtuais, distribuídos e colaborativos, que na sua maior parte está atualmente implementada em C++. Essa opção é devido à limitação dos recursos de hardware e de software existentes que induzem ao uso de plataformas proprietárias, tais como: SUN, HP-UX, IBM RISC, Silicon Graphics. A evolução tecnológica dos computadores pessoais, o barateamento de dispositivos de interface gráfica e o crescimento da rede mundial de computadores criaram as condições necessárias à Realidade Virtual Distribuída (RVD) via Internet. Atualmente, os processadores embutidos nos computadores pessoais oferecem a performance necessária para o processamento gráfico, e os meios de comunicação oferecem largura de banda necessária para garantir taxas de comunicação suficiente para que essas aplicações a Internet. Neste contexto, emerge a criação de uma camada de protocolo portável para múltiplas plataformas que faça uso das tecnologias Java, Shout3D, VRML ou X3D para a implementação de Realidade Virtual Distribuída para a Internet. Trabalhos Correlatos O DIVE (Distributed Interactive Virtual Environment) é um sistema de Realidade Virtual Distribuído Interativo, multi-usuário baseado em Internet, que proporciona navegação e visualização espacial 3D, possibilitando a interação de usuários e aplicações. Desenvolvido na Suécia pela Swedish Institute of Computer Science (SICS), sua primeira versão surgiu em 1991. A interação de um usuário provoca a difusão do evento na rede, com comunicação multi-cast, não possuindo servidor centralizado. O compartilhamento de estado é análogo à memória compartilhada, onde um conjunto de processos interage através de acessos concorrentes a essa “memória compartilhada” [6, 13, 5]. Ele é o precursor de outros ambientes, como o Avango, que oferece é um framework para desenvolvimento de ambientes virtuais distribuídos, que utiliza um modelo de programação análogo ao DIVE. O Avango é desenvolvido em C que distribui as informações através da replicação de uma cena para todos os processos que participam da aplicação distribuída [15]. Noutra linha, aparece o SPIN-3D em que se explora a plataforma CORBA/ORB de sistemas distribuídos para implementar o Ambiente Virtual Colaborativo (AVC). Disponibiliza cenas 3D destinadas à colaboração entre pequenos grupos utilizando VRML. A implementação é linguagem C++, com CORBA e ORBacus, utilizando o framework Open Communication Interface (OCI) para implementar o protocolo Multicast Inter-ORB Protocol (MIOP). O trabalho de colaboração entre os 41 usuários é realizado através da replicação do mundo virtual VRML por um servidor, que faz cópia ou “clone” da cena para cada cliente conectado [10]. O COVEN é uma concepção mais ampla de RVD. Ele se apresenta como derivação do DIVE e do dVS e foi desenvolvido por um consórcio Europeu, no período de 1994 a 1998, objetivando a análise de requisitos e viabilidade de aplicações Computer Supported Cooperative Work (CSCW). Ele utiliza múltiplos servidores para o gerenciamento das comunicações, estes definem espaços de interação diferentes, permitindo comunicação em longas distâncias para a colaboração em ambientes virtuais, e uso de multimídia para reuniões [6, 3]. Outro experimento é o VEOS (Virtual Environment Operation System), implementado em 1993, é uma ambiente de programação C e AutoLISP, desenhado para a prototipação rápida de um Ambiente Virtual Distribuído, em que o estado é armazenado um banco de dados contendo tuplas privadas e publicas. Neste caso, o banco de dados reflete o estado atual do mundo virtual, cujo modelo enfatiza a comunicação assíncrona e a distribuição baseada em entidades [6, 2, 13]. A questão da persistência de um mundo virtual é o foco do NPSNET. Em desenvolvimento desde 1993, sua versão atual é o NPSNET-V, que implementa um componente Java para o desenvolvimento de aplicações cliente-servidor, ponto-a-ponto ou produtos standalone. Seu objetivo é disponibilizar uma plataforma capaz de implementar no “cyberspace” a persistência de um mundo virtual que não necessita ser desativado para manutenção ou upgrade do sistema, buscando qualidades como extensibilidade de conteúdo e aplicações, escalabilidade em mundos complexos e com grande número de participantes e composição heterogênea de conteúdo e aplicações [6, 13, 9]. Os trabalhos citados anteriormente representam concepções diferentes para a implementação de ambientes para o desenvolvimento de aplicações em Realidade Virtual. Projetos como o MASSIVE [8] e WorldToolKit [14] continuam em aprimoramento de novas versões. Mas, muitos dos ambientes virtuais colaborativos, distribuídos e frameworks não tiveram continuidade, devido à forte correlação do software com plataformas específicas ou à falta de um planejamento para continuidade do projeto em futuros projetos de pesquisa, ou mesmo abandono do projeto inicial. A pesquisa bibliográfica revela outras implementações, tais como: ADVICE [12], AVIARY [6, 13, 1], AVIT [7], VIRTUS 13], VUE [6]. Os problemas detectados para a elaboração de ambientes virtuais distribuídos podem ser significativamente reduzidos pela delimitação do problema. Neste caso, o desenvolvimento do suporte de uma “Máquina Virtual de Medir por Coordenadas” para acesso via Internet. Dos modelos anteriormente apresentados, será experimentado o modelo de programação cliente-servidor, implementando os mecanismos de comunicação via RMI e Socket. Arquitetura do Ambiente Para a concepção da proposta considerou-se: a utilização máxima de recursos Open Source; a adoção de padrões da comunidade científica, para que o projeto possa ser reutilizado e aperfeiçoado em trabalhos futuros; possibilitando seu reuso em aplicações de Realidade Virtual Distribuída via Internet. A visão macroscópica apresentada na Figura 1, ilustra a adoção do modelo cliente-servidor em que as modificações do ambiente virtual estão associadas a diferentes serviços (som, imagem, interação, navegação e comandos), conforme ilustra a Figura 2. Esse modelo flexibiliza tanto o desenvolvimento quanto o uso. O desenvolvimento permite o projeto modular, possibilitando a implementação e o teste de cada uma das partes e serviços, facilitando a geração dos casos de teste e a depuração. Mas, introduz problemas com sincronismo necessário a determinadas aplicações, especialmente no que tange ao som e imagem conjugados. Mas, no caso da “Máquina Virtual de Medir por Coordenadas - VCMM” essa questão não é significativa. 42 O módulo “Protocolo de Realidade Virtual” (PRVD), usa o arquivo de configurações, Figura 2, para determinar protocolos de comunicação ponto-a-ponto, multi-cast ou broadcast para cada um dos serviços. Assim, diferentes clientes têm a possibilidade de estarem associados a diferentes servidores, permitindo que a interação e os comandos sejam compartilhados, de acordo as configurações definidas. Os mecanismos de comunicação podem ser configurados por serviço para usar o Transfer Control Protocol ou Datagram Control Protocol sobre o Internet Protocol. Os usuários devem usar o arquivo de configuração para determinar como ocorrerá a execução das atividades tanto no lado dos servidores quanto no lado dos clientes. Essa decisão poder ser útil, por exemplo: (i) para os dispositivos de navegação, dado que a perda de alguns pontos de vista não prejudicará a visualização; (ii) iniciar clientes em máquinas diferentes; (iii) isolar ambientes virtuais diferentes e em execução numa mesma rede. Servidor Cliente Aplicação Interação Navegação Comandos PRVD Socket RMI TCP TCP/UDP IP Rede Figura 1 – Camada dos protocolos. A definição para a utilização de Remote Method Invocation (RMI/JAVA) e Sockets como mecanismos de controle e comunicação, proporcionará ao final do projeto, a realização a análise de desempenho comparativa entre dois modelos citados [4]. Arquivo de Configurações XML Arquivo de Configurações Cliente Interação Navegação Comando XML Servidor msg msg msg PRVD PRVD PRVD end. ip, porta end. ip, porta end. ip, porta PRVD PRVD PRVD msg msg msg Interação Navegação Comando Os fatores considerados críticos para a implementação da VCMM é o número de usuários, número de cenas, objetos e de aplicações ou serviços, e a complexidade dos conhecimentos da Engenharia, necessário à base de transformações que representam a dinâmica do sistema. Figura 2 – Diagrama da lógica de serviços Com o intuito de delimitar o escopo deste trabalho e consequentemente diminuir sua complexidade, estaremos abordando a integração de uma quantidade limitada de usuários em um único mundo virtual, correspondendo à quantidade de alunos de uma sala de aula. Mas, a aplicação oferece a possibilidade de uso via Internet, dados que serão implementadas as cenas no formato Shout3D [11], havendo a possibilidade de uso dos formatos X3D [16]. Considerações finais Essa abordagem apresenta vantagens, por exemplo: (i) o uso de UDP para os dispositivos de navegação, dado que a perda de alguns pontos não necessariamente prejudica a visualização; (ii) iniciar clientes em máquinas diferentes, para explorar recursos específicos, tais como, rastreadores óticos; (iii) isolar ambientes virtuais diferentes em execução na mesma rede. Apesar das possíveis dificuldades de 43 sincronização, decorrentes do modelo, podem ser discutidas da ótica dos requisitos, que não é o foco deste trabalho. Referências [1] AVIARY. http://www.crg.cs.nott.ac.uk/people/Dave.Snowdon/vr/aviary/, 2004. [2] COCO, Geoffrey P. The Virtual Environment Operating System: Derivation, Function and Form. University of Washington, 1993. http://www.hitl.washington.edu/publications/th-93-1/th-93-1.pdf, 2004. [3] COVEN. http://coven.lancs.ac.uk, 2004. [4] Deitel, II. M. Java Como Programar. Bookman, 2001. [5] DIVE. Swedish Institute of Computer Science (SICS). http://www.sics.se/dce/dive/dive.html, 2004. [6] Greenhalgh, Chris. Supporting Complexity in Distributed Virtual Reality Systems. Technical Report NOTTCS-TR-96-6, Department of Computer Science, The University of Nottingham, Nottingham, NG7 2RD, UK. [7] Ipolito, Juliano Ribeiro. AVIT – Ambiente Virtual Interativo Tridimensional, Uma Plataforma Configurável para Desenvolvimento de Ambientes Virtuais Interativos Multi-Usuários. Universidade Federal de São Carlos, 1999. [8] MASSIVE.http://www.crg.cs.nott.ac.uk/research/systems/MASSIVE-3, 2004. [9] NPSNET. http://www.npsnet.org/~npsnet/v/, 2004. [10] Picard, Stéphane Louis Dit, Degrande, Samuel, Gransart, Christophe, Chaillou, Christophe, Saugis, Grégory. Comunication Platform for Synchronous Collaborative Virtual Environmnet, 2001. http://www.lifl.fr/~louisdit/, 2004. [11] Polevoi, Rob. Interactive Web Graphics with Shout3D. Sybex, 2001. [12] Rodrigues, Silviane G., Oliveira, Jauvane C., Peixoto, Marcos V. ADVICE: Um Ambiente VIrtual Colaborativo para o Ensino a Distância, 2003. http://www.lncc.br/~jauvane/papers/WTD_Webmidia_VersaoFinal.pdf, 2004. [13] SAAR, Kurt. VIRTUS: A Collaborative Multi-User Platform. ACM VRML99, Pag. 141-152, Paderborn Germany, 1999. [14] Sense8.http://www.sense8.com, 2004. [15] Tramberend, Henrik. Avango: A Distribuited Virtual Reality Framework. GMD – German National Research Center for Information Technology, 2000. http://www.avango.org, 2004. [16] X3D. Extensible 3D (X3D). International Draft Standards. Disponível na Internet. http://www.web3d.org/fs_specifications.htm, 2003. 44 Visualização de Dados em Ambientes com Realidade Aumentada Claudio Kirner, Nivaldi Calonego Júnior, Carolina V. Buk, Tereza G. Kirner Universidade Metodista de Piracicaba - UNIMEP Faculdade de Ciências Matemáticas da Natureza e Tecnologia da Informação Programa de Pós Graduação em Ciência da Computação {ckirner, ncalonego,tgkirner}@unimep.br, [email protected] Resumo The growing of information demands new techniques to represent and visualize data, so that the user can understand the information set and make decision in a fast way. This paper presents a tool based on augmented reality, that allow graphics to be superimposed over live video of the real world, so that the user can manipulate (put, delete, arrange and configure) graphs in a real environment. 1. Introdução Os avanços tecnológicos vêm permitindo a produção e armazenamento de dados em computadores, de maneira vertiginosa a cada ano. Ao mesmo tempo em que isto pode ser visto como um benéfico para as pessoas, é também um problema, na medida em que dificulta a identificação de informações importantes contidas nos dados. As técnicas de exploração visual dos dados, com a ajuda do computador, exercem um papel importante na solução ou minimização desse problema. No entanto, em função das restrições do ambiente, muitas vezes são disponíveis sistemas de visualização limitados ao plano da tela do monitor, mas a Realidade Virtual veio expandir as possibilidades de visualização, rompendo a barreira da tela. Com realidade virtual, consegue-se um espaço tridimensional (3D) infinito, no qual podem ser dispostos gráficos 3D e por onde pode-se navegar e interagir. Apesar das vantagens, a realidade virtual permite que uma pessoa fique longe de um foco de interesse importante, o que deve ser contornado por soluções como acionamento de alertas. Como a navegação e interação em ambientes de realidade virtual depende de algum treino e familiaridade com dispositivos não convencionais, procurou-se superar um problema com o uso de realidade aumentada, de forma que, adicionando-se os objetos (gráficos) virtuais ao ambiente real, pudesse também usar as mãos para mover e atuar sobre os gráficos dispostos no ambiente. Este trabalho discute a representação de dados em gráficos discretos 3D, buscando soluções para seu uso em ambientes de realidade aumentada. 2. Representação e Visualização de Dados O fato das pessoas terem maior facilidade em analisar representações gráficas do que quantidades de dados repercutiu no impacto da visualização nas questões cognitivas. Assim, a cognição, ligada à aquisição ou uso de conhecimento, tem seu foco orientado mais para o objetivo do que para o significado da visualização [4]. Desta forma, o objetivo da visualização é a percepção e o entendimento do conteúdo representado que levam à descoberta, à tomada de decisão, à explicação e não à figura. 2.1. Visualização de Informação A visualização científica tende a basear-se em dados físicos e, mesmo quando trata de abstrações, elas são atreladas ao espaço físico. Informações não físicas, como dados financeiros, podem beneficiar-se da representação visual, mas não apresentam um mapeamento espacial óbvio. Os benefícios para a cognição decorrem de uma boa representação visual do problema e de sua 45 manipulação interativa, fazendo com que as pessoas usem suas capacidades inerentes de percepção visual. Visualização da informação pode, assim, ser definida como “o uso de representações visuais, interativas de dados abstratos, suportadas por computador, para amplificar a cognição" [4]. O tipo de visualização a ser empregado está relacionado à representação dos dados. Há sete tipos de visualização da informação: unidimensional, bidimensional, tridimensional, multidimensional, temporal, hierárquica e em rede [4, 6]. Os quatro primeiros tipos são espaciais e os outros três tipos são estruturais. A visualização de dados unidimensional é baseada em uma posição, focando um ponto na reta (por exemplo, linha de tempo) ou um elemento no monitor (por exemplo, conjunto de documentos). A visualização de dados bidimensional é baseada na percepção da posição e de outro atributo como altura, largura, área, cor, etc.(por exemplo, diagramas de barras e gráficos de pizza). A visualização de dados tridimensional é baseada em três atributos, incorporando freqüentemente a noção de volume. Aqui se tem a aplicação imediata de realidade virtual. Muitas vezes, pela facilidade da representação de um espaço bastante grande, usa-se realidade virtual para a visualização de dados bidimensionais, dispondo-se gráficos de barras, por exemplo, espalhados pelo cenário do mundo virtual. Por outro lado, a incorporação de quatro ou mais atributos aos dados, que pode usar três atributos espaciais e outros como cor, tonalidade, forma, etc., usando a visualização tridimensional com realidade virtual para navegar pelo cenário e interagir com as representações dos dados. Os outros três tipos de visualização da informação, embora importantes, não serão abordados neste trabalho. 2.2 Representação de Dados A representação de dados visa apresentar a informação ao usuários, de maneira simples e sintética. Uma das formas mais comuns de se fazer isto é através de gráficos discretos tridimensionais com múltiplos atributos, como diagramas de barras dispostos no espaço e incrementados com com elementos de animação, visuais e sonoros. Os elementos visuais incluem: forma, dimensão (largura, profundidade e altura), cor, tonalidade, transparência, pulsação de cor (frequência), etc. Os elementos de animação mostram as variações dos gráficos (ou de parte deles), em um determinado período de tempo e com uma velocidade escolhida (taxa de variação do tempo). Os elementos visuais costumam oferecer uma noção estática da situação dos dados, mas podem também incorporar uma visão da história recente e de tendências, quando estão associados à derivada e outras funções dinâmicas. Os elementos sonoros são mais usados como advertência, ou para chamar a atenção para ocorrências especiais ou atípicas, de forma que o usuário possa perceber o fato, mesmo que esteja focando outra seção do conjunto de gráficos [5]. Os elementos animados permitem a avaliação dos dados de forma dinâmica, visualizando o seu comportamento em períodos de tempo [8]. 2.3. Interação com a Representação dos Dados Embora a maior parte dos sistemas de visualização da informação se preocupem exclusivamente com a visualização em si, única, em janelas ou através de navegação tridimensional, a interação com a representação dos dados vem se tornando foco das atenções, uma vez que pode potencializar as aplicações, incrementando a análise e tomada de decisão por parte do usuário. Assim, gráficos podem ser mapeados em regiões clicáveis, sujeitos à interação com o usuário, fornecendo informações adicionais ou executando ações específicas. Limites visuais com mínimos, máximos, faixas de erro, etc. podem ser inseridos ou alterados graficamente pelo usuário. 46 Essas características de interação podem ser incorporadas a sistemas implementados como aplicações tradicionais (ambientes bidimensionais) ou aplicações avançadas tridimensionais, usadas em realidade virtual e realidade aumentada [2, 3, 7]. 3. Projeto de um Visualizador de Dados com Realidade Virtual O visualizador de dados com realidade virtual consiste num sistema de visualização tridimensional de gráficos de barras, composto por um ambiente virtual interativo, um banco de dados e um módulo de controle/configuração. O ambiente virtual interativo, programado com VRML e JavaScript, é responsável pela renderização dos gráficos de barras, cuja estrutura é definida pelo usuário, através do módulo de controle/configuração, e cujos dados são atualizados através de consulta ao banco de dados. O módulo de controle/configuração é uma interface do usuário com o sistema, responsável pela configuração dos gráficos e pela atualização do banco de dados. O banco de dados mantém os dados atuais, que são renderizados como gráficos, e os últimos dados históricos, utilizados para a obtenção de atributos dinâmicos, como derivada e outras funções, além de servir para alimentar animações históricas, quando solicitadas. O elemento de referência do ambiente virtual interativo é a barra mostrada na Figura 1a que, além de uma série de atributos, apresenta também dois planos sensores ajustáveis par indicar valores máximo e mínimo para o dado. Figura 1a- Elemento de Referência Figura 1b - Ambiente Virtual Simplificado A replicação estruturada do elemento de referência forma o ambiente virtual final, conforme exemplo mostrado na Figura 1b. 4. Uma Experiência de Visualização de Dados com Realidade Aumentada Usando o Visualizador de Dados com Realidade Virtual e o Sistema de Realidade Aumentada ARTOOLKIT [1], foi realizada a experiência de se colocar os gráficos virtuais no mundo real, ou seja, sobre uma placa na mão do usuário. Para isto foi usado um computador com uma webcam e o software ARTOOLKIT, que, através de mecanismos de visão computacional, reconhece marcas previamente cadastradas e sobre elas coloca objetos virtuais associados. Assim, o visualizador com Realidade Virtual foi definido como um objeto e associado com um marcador reconhecido pelo ARTOOLKIT. Ao colocar-se a placa com o marcador no campo de visão da webcam, o sistema coloca o gráfico sobre a placa, que pode ser inspecionada pelo usuário (Figura 2). Além disso, o usuário pode interagir com o gráfico na tela, usando o mouse para movimentar planos de mínimos e máximos. Há um projeto em andamento que vai substituir o cursor controlado pelo mouse pelas mãos do usuário, tornando o sistema 47 mais natural. Figura 2 - Exemplos de uso do Visualizador de Dados com Realidade Aumentada Como o sistema reconhece várias marcas diferentes simultaneamente, o próximo passo do projeto é construir um tabuleiro quadriculado com espaço para várias placas, de forma que cada placa contenha uma parte do gráfico geral. Assim, o usuário poderá ver o conjunto, pegar uma parte do gráfico e movimentá-lo, trocar partes de lugar e mesmo substituir, eliminar ou incluir novas partes do gráfico, além de executar interações. 5. Conclusões A realidade virtual apresenta elevado potencial para visualização de dados, na medida em que não impõe limites de espaço, mas exige algum treinamento e conhecimento para ser manipulada. A colocação da solução com realidade virtual dentro do ambiente real, fazendo sobreposição de imagens capturadas por câmeras de vídeo com imagens geradas por computador, facilita a análise e a interação com os gráficos, potencializando o aspecto cognitivo, relacionado com o entendimento da informação. Este trabalho apresentou uma discussão sobre visualização de dados, e o projeto de um visualizador com realidade virtual e sua inserção em um ambiente de realidade aumentada. Referências [1] [2] [3] [4] [5] [6] [7] [8] ARToolKit - <http://www.hitl.washington.edu/research/shared_space/ > Acesso em 02/04/04 AZUMA.R.et al. Recent Advances in Augmented Reality. IEEE Computer Graphics and Applications, v .21, n.6, 2001, p. 34-47. BELCHER, D. et al. Using Augmented Reality for Visualizing Complex Graphs in Three Dimensions. Proc. of the Second IEEE and ACM International Symposium on Mixed and Augmented Reality (ISMAR'03), Tokyo, Japan, Oct. 2003, p. 84-92. CARD, S.K.; MACKINLAY, J.D.; SHNEIDERMAN, B. - Readings in Information Visualization: Using Vision to Think. Morgan Kaufmann Pub. 1999. FRANKLIN, K.N.; ROBERTS, J. - Pie Chart Sonification. Proc. of the Seventh International Conference on Information Visualization (IV'03), London, England, July 2003, p. 4-9. KEIM, D.; HAO; M.C.; DAYAL, U. - Hierarchical Pixel Bar Charts. IEEE Trans. On Visualization and Computer Graphics, v.8 N.3, p.255-269, July/Sep. 2002. KIRNER, T.G.; MARTINS, V.F. Development of an Information Visualization Tool Using Virtual Reality. Proc. 15th ACM Symposium on Applyed Computing - SAC'2000, Como, Italy, March 2000, p. 604-607. NAKAKOJI, K.; TAKASHIMA, A.; YAMAMOTO, Y. - Cognitive Effects of Animated Visualization in Exploratory Visual Data Analysis. Proc. of the Fifth International Conference on Infomation Visualization (IV'01), London, England, July 2001, p. 77-84. 48 Ambiente de Visualização e Interação de Simulações Neurais Abstract Galesandro Henrique Capovilla, Regina Célia Coelho, Luís Augusto Consularo Universidade Metodista de Piracicaba - UNIMEP Faculdade de Ciências Matemáticas da Natureza e Tecnologia da Informação Programa de Pós Graduação em Ciência da Computação [email protected], [email protected], [email protected] Modeling neurons and neural structures has provided a powerful tool to examine and better understand the nervous system, especially since experiments with animals are often difficult. In this sense, this paper propose to the generation a virtual reality environment to allow visualizing, navigating and interacting with a simulator of neural cells and structures of friendly and efficient way. 1. Introdução A realidade virtual vem crescendo a cada dia e atuando cada vez mais em diversas áreas relacionadas a ciência; como é o caso das simulações na área de neurociência, que hoje representam um grande avanço em pesquisas relacionadas a esta área, possibilitando estudos mais avançados e eficazes. A melhor forma de visualizar estas simulações é recorrendo à Computação Gráfica, ou mais especificamente, à Realidade Virtual, que permite, além da visualização tridimensional, a interação, imersão e navegação do usuário no sistema. O advento das tecnologias em Realidade Virtual (RV) tem colaborado para a abertura de uma nova dimensão para diversos pesquisadores, que podem “entrar” em simulações eletrônicas, o que permitem a eles ocupar um espaço imaginário. Pelo fato da RV ser uma etapa além da visualização computacional, ela nos permite “andar” de fato em um ambiente visual simulado (“realidade simulada”) e analisar o funcionamento do “mundo” sendo percorrido. Recentemente, este fato tem se tornado um grande aliado para os neurocientistas, uma vez que a RV pode auxiliá-los na interpretação da grande quantidade de dados gerada pelas simulações. O surgimento de novas tecnologias e a melhora na qualidade de tecnologias já existentes (como velocidade computacional e qualidade dos monitores de vídeo) tem tornado a RV muito atrativa tanto para pesquisas quanto para aplicações em neurociência. Várias aplicações da RV e da computação gráfica como um todo em neurociência têm surgido em pesquisa, treinamento e tele-imersão [1,2,3,4]. Em termos de impacto realista nas simulações, estas aplicações podem ser tão boas ou até melhor que realidade física. Esta tecnologia permite criar universos inteiros e, o que é melhor, improvisar "realidades". Além disso, o desenvolvimento de técnicas de realidade virtual e o progresso da computação gráfica permitem agora a implementação de algoritmos extremamente complexos e rápidos para criar, mostrar e manipular modelos de estruturas neurais. A proposta deste artigo é gerar um ambiente de RV para visualizar, navegar e interagir com um simulador neural. Atualmente já existe um simulador neural desenvolvido por COELHO [5,6] cuja uma das funções é gerar células com características morfológicas estatisticamente idênticas às células naturais e para isso utiliza L-Systems estocáticas e modificadas para considerarem medidas morfológicas extraídas de células naturais [5,6]. Se gerarmos um ambiente de RV distribuída, ele dará o suporte necessário ao simulador para que o usuário possa analisar o que ocorre durante o crescimento destas células, podendo, inclusive, interferir no crescimento. 2. O Ambiente de RV Uma das grandes vantagens da construção de um ambiente RV para as simulação neurais é a possibilidade de executar diversas vezes um experimento sem se preocupar em danificar os tecidos neurais naturais ou com sacrifícios de animais, sem contar que não seria possível repetir o experimento com uma mesma estrutura neural, no caso de tecidos naturais. Este é o principal fator para o 49 crescimento nas pesquisas envolvendo realidade virtual e experimentos biológicos. Um exemplo é o trabalho de SUBRAMANIAN e MARSIC [7], que descreve um ambiente de RV chamado ViBE (Virtual Biology Experiments) como sendo um laboratório virtual voltado para pesquisas em biologia. Através do ViBE, é permitido ao aluno executar diversas vezes um mesmo experimento, sem se preocupar com os gastos de materiais, desperdícios. Através do ViBE, o aluno pode interagir com o software verificando, por exemplo, uma divisão celular, uma mitose, uma meiose. Outro trabalho que trouxe uma contribuição muito forte para a realidade virtual ligada à neurociência é o trabalho de COSTA, OLIVEIRA e MINGHIM [8] em que tratam da visualização tridimensional de neurônios e mostra as diferentes formas dos neurônios dependendo da função que cada um executa. Há também o trabalho de TARR e WARREN [9] que demostra algumas aplicações da realidade virtual voltada para a neurociência, psicologia e algumas outras áreas afins. Em seu artigo é descrito o laboratório VENlab (Virtual Environment Navigation Laboratory), que realiza as experiências de imersão possibilitando pesquisas comportamentais. O objetivo principal deste trabalho é a visualização de um simulador neural que promova interatividade e imersão com o usuário, ou seja, permitir que o usuário possa interferir no crescimento de células neurais, analisar o crescimento e formação de uma estrutura neural, analisar alguns aspectos relacionados à neurogênese destas estruturas, como por exemplo, a reorganização neural na presença de campos tróficos (campos de atração ou repulsão neural) e na apoptose (morte neural natural). As estruturas neurais que estão sendo utilizadas no ambiente, são geradas utilizando conceitos matemáticos e de computação, tais como, tipo, conexão e propriedades fisiológicas de cada neurônio. O programa de simulação gera uma quantidade de células neurais sintéticas, que possuem características reais e, além disso, é possível obter dados sobre o campo elétrico gerado em torno de um neurônio [5,6]. Para o ambiente de RV, consideramos uma estrutura neural como sendo nada mais nada menos que dados armazenados na memória do computador que serão utilizados para gerar cilindros que irão representar os neurônios. A representação por cilindros foi escolhido com base no modelo do cabo [10,11], que surgiu com a necessidade de interpretar e modelar os dados obtidos de neurônios individuais por meio de microeletrodos introduzidos no neurônio. Este modelo, em geral utilizado para dendritos, fornece um modelo teórico que nos permite conectar uma estrutura morfológica e elétrica do neurônio à sua função. Nele, as árvores dendríticas são aproximadas por cilindros e são utilizadas equações diferenciais parciais para descrever o fluxo de corrente de uma árvore dendrítica [12]. Os cilindros, por sua vez, apresentam uma renderização simples e rápida devido à pequena quantidade de dados necessários para a sua criação. Os dados de entrada para o ambiente virtual serão capturados da rede (por enquanto são lidos de arquivos), uma vez que a simulação enviará os resultados pela rede. Estes serão enviados obedecendo a seguinte estrutura: Número Neurônio Número Galho Coordenada X1 Coordenada Y1 Coordenada Z1 Coordenada X2 Coordenada Y2 Coordenada Z2 Raio Cada neurônio é identificado por um número para que seja possível identificar a que neurônio pertence o galho que está crescendo a cada momento. Cada galho também recebe um número que o identificará. Desta forma, dado o número do neurônio e o galho é possível controlar a quem pertence cada ponto que está sendo enviado ao ambiente de RV pelo simulador. O simulador envia dois pontos que indicam em que lugar da cena deverá ser criado um cilindro (início e fim do cilindro). O raio deste cilindro é enviado pelo simulador, que indicará a espessura do galho. Sendo assim, os dados são recebidos, interpretados, normalizados (apenas para diminuir o tamanho da cena gerada) e, através de um objeto denominado Pipe1, a visualização é gerada. A cena será criada de acordo com o recebimento dos dados enviados pela simulação. Quando há ramificação para um novo galho (bifurcação), um novo Pipe é 1 Pipe: objeto existente na biblioteca GLScene, que possibilita, através de algumas propriedades, desenhar um cilindro, tendo ainda a possibilidade de definir um raio diferente para cada extremo do cilindro. 50 gerado dinamicamente, que possuirá novas coordenadas, gerando, assim, a visualização da simulação neural. Note que em ramificações, apenas um pipe novo é gerado, uma vez que o segundo pipe (o outro lado da bifurcação) poderá ser a continuação do pipe anterior. O ambiente proposto possibilitará ao usuário executar interações do tipo alterar o ponto de vista, visualizar o crescimento neural através de diferentes ângulos, ampliar a cena utilizando a opção zoom. Possibilitará ainda que o usuário possa eliminar (matar) algumas células e verificar a reorganização neural causada pela morte de determinadas células e pela presença de campos tróficos. Além disso, como será desenvolvido utilizando RV distribuída, poderemos ter usuários em diferentes máquinas interagindo com o ambiente. Para isso utilizaremos o conceito de sockets, que nada mais é que uma interface de comunicação entre os dispositivos encontrados na rede. Através dos sockets conseguiremos fazer com que todos os usuários interajam no mesmo mundo virtual. Na Figura 1 é apresentado um exemplo do crescimento de 3 células neurais tridimensionais. Neste figura são ilustrados três estágios de crescimento das células. Como podemos notar, as três células estão crescendo ao mesmo tempo (em paralelo). Em uma estrutura com mais células, quando o dendrito de uma célula encontrar um axônio de outro ocorrerá uma conexão, permitindo que estes neurônios possam trocar sinais elétricos. Embora neste exemplo esteja ilustrado apenas três células, o ambiente permite que mais células possam ser incluídas, porém as conexões entre elas ainda não está implementada no ambiente de RV gerado. Figura 1 – Visualização de três estágios do crescimento paralelo de três células neurais. O ambiente está sendo desenvolvido utilizando a linguagem orientada a objetos DELPHI juntamente com uma biblioteca gráfica denominada GLScene [13,14], que possui alguns componentes já desenvolvidos que facilitam a elaboração de um ambiente gráfico 3D e é freeware. 3. Conclusão O ambiente proposto será útil não apenas para a análise em tempo real das simulações, como também para a observação e análise de cada etapa de todo processo de crescimento e formação da estrutura neural, incluindo fatores que influenciam no crescimento. Assim, o usuário poderá acompanhar e estudar a plasticidade que ocorre com as células na presença de substâncias químicas. Outro grande atrativo do ambiente é que ele permitirá que algumas células sejam mortas, simulando a apoptose que ocorre naturalmente nos seres vivos. Com isso, as células que estiverem em volta das que morreram se reorganização para tentarem formar novas conexões, suprindo, desta forma, a falta das células mortas. Desta forma, o ambiente gerado poderá contribuir muito para o avanço nos estudos do comportamento de células neurais. É importante ressaltar também que será permitido que mais de um usuário possa visualizar, navegar e interagir com a cena ao mesmo tempo, uma vez que o ambiente será construído de forma distribuída. 51 Futuramente o ambiente poderá ser estendido para um ambiente que suporte realidade aumentada também, não apenas RV. A biblioteca GLScene oferece suporte de captura do mundo real e a mistura deste mundo com o virtual. Desta forma, poderíamos, por exemplo, utilizar um dispositivo de interação simples, como uma barra com uma bolinha vermelha, capturar os movimentos desta barra utilizando uma webcam e reproduzir tais movimentos na cena. Referências [1] LEIGH, J. et al. Virtual Reality in Computational Neuroscience, in: Virtual Reality and Its Applications, eds: R. Earnshaw; H. Jones; J. Vince, Academic Press, London, 1994. [2] ASCOLI, G. A. et al. Computational Neuroanatomy of the Hippocampus, Draft of the poster for SFN98, Los Angeles, 1998, http://www.krasnow.gmu.edu/ascoli/sfn98/index.html (acessado em 07/12/2002). [3] BÜLTHOFF, H. H.; van VEEN, A. H. C. Vision and Action in Virtual Enviroments: Modern Psychophysics In Spatial Cognition Research, Technical Report No. 77, Max-Planck-Institut für Biologische Kybernetik, Germany, 1999. [4] TARR, M. J.; WARREN, W. H. Virtual Reality in Behavioral Neuroscience and Beyond (Review), Nature Neuroscience Supplement, v. 5, 2002, p. 1089 -1092. [5] COELHO, R. C.; COSTA, L. F., Realistic neuromorphic models and their application to neural reorganization simulations, Neurocomputing, n. 48, 2002, p. 555-571. [6] COELHO, R. C. ; JAQUES,O. Generating Three-Dimensional Neural Cells Based On Bayes Rules And Interpolation With Thin Plate Splines, 8th Iberoamerican Congress on Pattern Recognition, Havana, Cuba, in: Progress in Pattern Recognition, Speech and Image Analysis, Lecture Notes in Computer Science, v. 2905, 2003, p. 675-682. [7] SUBRAMANIAN, R.; MARSIC, I., Vibe: Virtual Biology Experiments, Hong Kong, May, 2001, p. 1-5. [8] COSTA, L. F.; OLIVEIRA, M. C.; MINGHIM, R., De olho nos neurônios – As formas virtuais do pensamento, Ciência Hoje, v. 28, n. 167. [9] TARR, M. J.; WARREN, W. H., Virtual reality in behavioral neuroscience and beyond, Nature Neuroscience Supplement, v. 5, November 2002. [10] BOWER, J. M.; BEEMAN, D. The Book of GENESIS, Springer-Verlag New York , Inc. Published by TELOS, 1995. [11] KOCH, C.; SEGEV, I. Methods in Neuronal Modeling, The MIT Press, 1995. [12] NEDEL, L. P., Escola de informática da SBCSul, Passo Fundo, 21 a 25 de maio/2001. [13] GLScene - <http://www.ibrtses.com/opengl/> Acesso em 02/04/04 [14] GLScene - <http://glscene.sourceforge.net/index.php> Acesso em 02/04/04 52 Entrada de Senhas com Realidade Aumentada Ricardo Armengol Silva, Luís Augusto Consularo, Regina Célia Coelho Faculdade de Ciências Matemáticas, da Natureza e da Terra UNIMEP - Universidade Metodista de Piracicaba Programa de Pós Graduação em Ciência da Computação Caixa Postal 68 – 13.400-901 – Piracicaba – SP – Brasil [email protected], {laconsul, rccoelho}@unimep.br Abstract The password authentication has become an ordinary task for all personal computer users. Banks, intranets or service providers has required mouse point-and-click password entry to avoid spywares or snoopy intruders eavesdropping on keyboard typing. This work proposes an alternative solution to password entry with augmented reality. A PC-connected webcam picture frames are segmented to identify a finger tip whose position tracking translates a virtual finger on a virtual numerical keyboard. 1. Introdução A entrada de senhas em computadores pessoais ainda permanece um problema de segurança, especialmente quando o usuário, para usar um serviço em seu computador deve utilizar o teclado para fazê-lo. Já se tornou prática comum o uso do mouse para apontar caracteres que componham uma senha, principalmente em páginas cujas entradas devam ser autenticadas. Este tipo de artifício evita que programas invasores monitorem as entradas do usuário ou cliente pelo teclado. Um dispositivo que vem se tornando bastante popular, a webcam, pode ser aplicada em soluções de entrada de senhas. Este trabalho propõe o uso de webcams como dispositivos de entrada de senhas a partir do rastreamento da posição do dedo indicador em uma superfície planar. Desta maneira, no momento da entrada da senha, uma imagem rastreada do dedo do usuário deverá tocar um teclado virtual sobre a imagem real. 2. Dispositivos e componentes As webcams têm se tornado um dispositivo de baixo custo e bastante comum em computadores pessoais ou mesmo em aplicações corporativas. Contudo, seu uso geral em computadores pessoais restringe-se a videoconferências, captura de instantâneos ou pequenos vídeos ou ainda em vigilância. Componentes ou funções de aquisição de imagens em movimento, permitindo o seu processamento em tempo-real, já são abundantes e variam entre os disponíveis em caráter gratuito e comercial. Neste trabalho utiliza-se um componente gratuito para o ambiente RAID Delphi 5.0, o VideoCap [1]. Este componente permite selecionar o dispositivo de aquisição de vídeo e também, a partir de um ponteiro para a região de memória na qual são colocados os pixels da imagem de cada quadro, processá-la e rastrear um objeto na cena. A idéia, neste caso, é rastrear o dedo indicador do usuário para que sua posição na imagem adquirida seja mapeada sobre um objeto virtual que será mostrado ao usuário na tela. Na verdade, as imagens em movimento são mapeadas como o fundo da cena virtual na qual está inserido o teclado (veja Figura 1). Este teclado ou teclas virtuais compõem uma cena virtual elaborada com uma suíte de componentes que encapsula a API gráfica OpenGL no Delphi, a GLScene [2]. Embora pouco documentada esta suíte de componentes permite que se edite ambientes virtuais hierarquicamente estruturados com elementos de iluminação, objetos, câmeras e efeitos. 53 Figura 1. Um teclado virtual mapeado sobre uma cena real, adquirida por uma webcam (modelo Webcam 3, Creative Labs). 3. Indicando onde está o indicador Os experimentos iniciais consideraram um dispositivo de interação bastante simples, uma vareta com uma pequena esfera vermelha acoplada a sua extremidade. Foi necessário utilizar um filtro de cor de pele [3] para eliminar os ruídos gerados pela limiarização da cor vermelha. Este mesmo filtro deverá ser aplicado na segmentação do dedo indicador, que servirá então como referência do espaço de interação. Para identificar qual dedo é o indicador serão reconhecidos os tamanhos e as posições relativas da mão e de seus dedos [4]. Uma vez identificada a região da imagem que contém o dedo indicador, a parte do contorno do dedo com maior curvatura deverá ser localizada e então mapeada sobre o objeto virtual [5]. Uma alternativa a este processo é a esqueletonização da mão segmentada com algoritmos rápidos de distância, tais como as distâncias Chamfer (veja Figura 2) [6]. A vantagem desta alternativa é que as extremidades podem ser mais facilmente localizadas nos esqueletos. Além disso, as distâncias Chamfer podem ser calculadas com apenas duas convoluções de pequenas máscaras sobre a imagem. Figura 2. Esqueleto de uma mão utilizando algoritmo de distâncias Chamfer d∞. 4. O espaço de interação 54 O local onde a mão poderá ser capturada pela câmera é o espaço de interação. Por ser planar, este espaço de interação pode ser mapeado por uma homografia, restringindo espaços da imagem adquirida como teclas. Uma outra solução é utilizar a matriz de projeção da câmera obtida por um processo de calibração. Este processo requer um padrão de pontos distribuídos no espaço 3D real cujas coordenadas sejam previamente conhecidas. A matriz de projeção conhecida resolve a posição do pixel na imagem correspondente a uma coordenada 3D real. Deste modo, restringindo a posição do teclado à mesma inclinação do objeto usado na calibração é possível inferir a tecla que o usuário quer pressionar e assim, entrar com esta escolha. Esta solução permite que o teclado simulado não seja resultado de uma projeção ortográfica, mas com uma opção de projeção em perspectiva. 5. O objeto tecla ou teclado O teclado é um modelo 3D hierárquico, isto é, um grafo de cena que representa um teclado numérico de 14 teclas (10 numéricas, um ponto decimal, retrocesso, remoção e confirmação). Este modelo é implementado no GLScene como uma árvore com nodos de suporte, teclado, câmera e iluminação. Após invocada, a aplicação lança uma tela para que o usuário acione alguma de suas teclas apenas posicionando os dedos na mesa. O usuário tem como referência uma imagem real com o teclado virtual sobreposto e um toróide envolvendo alguma tecla. A cada movimento do dedo na tela, este toróide virtual se movimenta na cena virtual sobreposta ao quadro da imagem adquirida. A escolha da tecla, isto é, o evento de pressionamento ocorre quando o usuário pressiona a tecla de espaço no teclado real. Deve ser estudada a possibilidade de se usar o movimento do dedo para gerar este evento. 6. Comentários Finais Este trabalho apresentou uma experiência inicial para a solução de entrada de senhas baseada em realidade aumentada. Embora simples, pois a aplicação depende apenas de mapeamentos homográficos, foi mostrado que é possível construir um rastreamento do dedo do usuário para tomar uma ação sobre um objeto virtual, um teclado. Aplicações em segurança vêm tendo crescente interesse e a realidade virtual e aumentada, por se basear em tecnologias de interação com usuário, mostra-se uma importante fonte de soluções. Referências [1] HUEBLER, J. TVideoCap Version 2.2 Help File. email: [email protected], Weingarten, Alemanha. 17 de maio de 2000. [2] GRANGE, E. GLSCene - OpenGL solution for Delphi. http://www.glscene.org, 1º de abril de 2004. Desde 13 de abril de 2000. [3] CHIANG, C-C.; TAI, W-K.; YANG, M-T.; HUANG, Y-T.; HUANG, C-J. A novel method for detecting lips, eyes and faces in real time. Real-Time Imaging, 9(4), p277-287, 2003. [4] LI, W.; HSU, W.; PUNG, H.K. Twins: A Practical Vision-based 3D Mouse. Real-Time Imaging, 4, p389-401, 1998. [5] OKA, K.; SATO, Y.; KOIKE, H. Real-Time Fingertip Tracking and Gesture Recognition. IEEE Computer Graphics and Applications, 6, p64-71, 2002. [6] BORGEFORS, G. Distance Transformations in Digital Images. CVGIP, 34, p344-371, 1986. 55 Visualização de dados da Rede de Computadores utilizando técnicas de Realidade Virtual Eduardo Noboru Sasaki, Nivaldi Calonego Junior, Luis Augusto Consularo Faculdade de Ciências Matemáticas, da Natureza e da Terra UNIMEP - Universidade Metodista de Piracicaba Programa de Pós Graduação em Ciência da Computação Caixa Postal 68 – 13.400-901 – Piracicaba – SP – Brasil [email protected], [email protected], [email protected] Abstract The technological development and the use of new resources of three-dimensional interfaces in virtual environment in network make with that they are available alternatives for the management of architectures, topologies and projects of the network. This work has as objective to study, to project and to implement an interface based on virtual reality for a practical application in computer network, contributing for the visualization of information of management of three-dimensional form and in real time. The proposal of the research is to investigate mechanisms and interfaces in the virtual environment that can be used for the manager of network in the search of better interpretation of the data. 1. Introdução Os equipamentos computacionais, as redes digitais cada vez mais presentes em nosso dia-a-dia e a crescente evolução tecnológica de hardware e software destinados à simulação, navegação, imersão e interação em um espaço virtual, fazem com que o usuário tenha a sensação de estar em outra realidade, a Realidade Virtual (RV). O uso da RV permite a elaboração de modelos de visualização aplicados às redes de computadores, oferecendo recursos para o seu gerenciamento, como: navegação na rede através da conectividade por IP, identificação e localização do host por níveis de detalhes em 3D. Atualmente, a apresentação das informações físicas e lógicas de redes de computadores, na maioria dos casos é bidimensional e está sujeita às limitações desse tipo de interface visual. Tem-se, então, a aplicação da RV como interface de gerência da rede para facilitar a inteligibilidade das topologias e outras informações através da RV em ambiente virtual. A RV permite a manipulação de objetos complexos, através de imersão, navegação e interação em ambientes virtuais tridimensionais gerados por computador. Um experimento dessa natureza está em desenvolvimento no Colégio Notre Dame de Campinas, contando com uma infra-estrutura do parque tecnológico de Informática com 120 computadores distribuídos em rede, conectados por cabos de par trançado e fibra ótica, distribuídos em quatro laboratórios de hardware e de software. A rede utiliza, em sua maioria, equipamentos 3COM de rede com placas de rede, switches e roteadores, incluindo o pacote de gerenciamento de rede 3COM Network Supervisor. Este software fornece uma visualização de rede bidimensional com capacidade para atender as necessidades de empresas de pequeno e médio porte. As operações automatizadas ajudam gerentes de rede para um controle da rede por meio de identificações e ligações de IP na rede em até 1500 dispositivos. Após a identificação, a estrutura da rede é traçada automaticamente para fornecer uma exposição gráfica dos dispositivos e das conexões. O mapa da rede monitora rapidamente o stress, ajusta pontos iniciais e alertas, captura eventos da rede, gera relatórios e lança ferramentas da configuração de dispositivo. Para fornecer notificação dos problemas, os alertas do supervisor da rede anunciam problemas da rede através de alarmes. O evento da rede que relata a capacidade da rede, o inventário e a topologia, bem como os relatórios definidos pelo usuário, facilitam a gerência de rede pro ativa. Essas informações gerenciais podem ser insuficientes quando há a necessidade da apresentação da localização geográfica dos equipamentos no 56 espaço físico da Instituição. 2. Realidade Virtual e Rede de Computadores O termo Realidade Virtual é bastante abrangente e seus adeptos tendem a defini-los com base em suas próprias experiências, ocasionando diversas definições na literatura [1, 4, 6, 7, 10], que conceituam RV como uma técnica avançada de interface que permite ao usuário imergir, navegar e interagir em ambientes virtuais 3D gerados por computador, utilizando canais multisensoriais. A interface de realidade virtual envolve um controle tridimensional altamente interativo de processos computacionais. O usuário entra no espaço virtual das aplicações, visualiza, manipula e explora os dados da aplicação em tempo real, usando seus sentidos, particularmente os movimentos naturais tridimensionais do corpo. A vantagem da interface é que o conhecimento intuitivo do usuário a respeito do mundo físico pode ser transferido para manipular o mundo virtual. Para suportar esse tipo de interação, o usuário utiliza dispositivos não convencionais como capacete de visualização e controle, luva, e outros. Esses dispositivos causam no usuário a impressão de que a aplicação está funcionando no ambiente tridimensional real, permitindo a exploração do ambiente e a manipulação natural dos objetos, por exemplo, com o uso das mãos, ou seja, permitem apontar, pegar, e realizar outras ações [5]. A partir deste cenário histórico, a RV vem despertando um crescente interesse em diferentes áreas de aplicação, incluindo-se as redes de computadores. Cubeta discute um modelo em que o administrador da rede pode interagir intuitivamente e em tempo real com os objetos da rede. O modelo gera imagens tridimensionais resultantes do comportamento da rede, fazendo com que a exibição de suas informações se torne mais próximo da realidade [2]. Deri apresenta um trabalho análogo desenvolvido para o gerenciamento da rede da University of Berne, em que a linguagem VRML é utilizada para a modelagem dos aspectos tridimensionais dos componentes da rede [3]. Numa linha mais abrangente, há a “RV e Análise de dados, utilizando a análise exploratória de dados” [8]. O modelo permite a visualização do espaço físico, no qual os equipamentos operam, as respectivas conexões físicas e configurações desses equipamentos, considerando que as informações devem ser apresentadas em diferentes níveis de detalhes, conforme ilustram os módulos da Figura 1. Os aspectos do comportamento dinâmico da rede são obtidos com o Supervisor 3COM, que informa o IP da estação conectada, o número da porta em que está conectado ao switch e conseqüentemente a sua topologia física e lógica. O sistema de visualização proposto descreve um editor de cenários composto pelo navegador Web, plug-in de visualização de arquivos VRML, applet Java e um banco de dados de objetos. 57 Os dados da rede são configurados no banco de dados pelo administrador da rede, que determina a distância física do entre os equipamentos, configurações individuais, locais em que os respectivos equipamentos estão instalados, cena que representa o equipamento, nome do dispositivo, endereço de acesso ao meio (MAC Address), endereço IP, plataforma instalada, dentre outros. Nesse caso, os atributos dos meta-modelos estáticos descritos em VRML podem ser modificados de acordo com as atualizações do parque tecnológico da empresa, ou das reconfigurações da rede. Os dados fornecidos pelo gerenciador de redes S3Com definem apenas se uma determinada máquina está ou não ativa e, no caso de estar ativa, fornece quais acesso ocorrem. Portanto, a realidade virtual facilita o gerenciamento da rede ao permitir que um leigo possa identificar quais equipamentos reais estão em uso e as suas respectivas localizações físicas. No momento foram projetados e testados os bancos de dados, com acesso em Java, que permitem verificar quais máquinas do conjunto da empresa estão ativas selecionar as suas respectivas configurações, conforme ilustra a figura 2. O módulo S3COM é o gerenciador de rede utilizado para atualizar as informações de conexão, mas essas informações não chegam diretamente na interface do usuário, havendo a necessidade de serem verificadas as conexões ativas. Essa funcionalidade é atribuída ao objeto “VerificarConexão”, que detecta atualizações geradas pelo S3COM e verifica no seu conjunto de endereços a qual máquina real está associada. Esse elo determina a chave de acesso aos atributos da máquina virtual que passa a estar disponível na cena. O controle da cena permite a visualização da empresa toda em diferentes níveis de detalhes, apresentando combinações de cenas que auxiliam na representação do todo num dado instante, isto é, apresenta apenas partes do mundo virtual que são determinadas por escolha do administrador. Um exemplo disso é a visualização de um dos laboratórios em conjunto com uma parte do sistema administrativo. Esse tipo de informação é especialmente interessante quando se deseja detectar tentativas de acesso não autorizado a partir de pontos internos. Neste caso, conhecer o número do IP da máquina é suficiente para que saiba de onde provém o acesso, mas em organizações complexas, encontrar a localização física do equipamento pode ser demandar tempo superior ao esperado. 3. Considerações Finais O uso de VRML facilita ao usuário a carga do software, permitindo que uma página HTML informe ao Browser o arquivo VRML e configure os parâmetros da applet de controle. A applet permite o usuário montar o ambiente virtual de acordo com as informações obtidas pelo S3COM. O mundo virtual é atualizado a cada manipulação (inclusão, remoção, mudança de tamanho ou 58 posição dos objetos) do usuário, que através da consulta do Bando de Dados de IP, será exibido, por meio de Applet, com a opção de um navegador, o arquivo de VRML referente aos dados solicitados pelo gerente da rede. Referências [1] BURDEA, G.; COIFFET, P. Virtual RealityTechnology, John Wiley & Sons, New York, NY, 1994. [2] CUBETA, J, et al. Virtual Environment for Network Monitoring. IEEE Virtual Reality Annual International Symposium (VRAIS '98), 1998.\ [3] DERI, L. VRML: Adding 3D to Network Management University of Berne, http://jake.unipi.it/~deri, 2003. [4] JACOBSON, L. Virtual Reality: A Status Report, AI Expert, pp. 26-33, Agosto, 1991. [5] KIRNER, C. Apostila do Ciclo de Palestras de Realidade Virtual. Atividade do Projeto AVVICCNPQ (Protem – CC – fase III) - DC/UFSCAR, pp.1-10, Outubro, 1996. [6] KRUEGER, M.W. Artificial Reality II. Addison-Wesley, Reading, MA, 1991. [7] LATTA, J. N.; ODEBERG, D.J. A Conceptual Virtual Reality Model. IEEE Computer Graphics & Applications, 1994. [8] LOUREIRO, J. A. Realidade Virtual e Análise de Dados, CIn-UFPE, 2003. [9] TODD, L. CCNA: Cisco Certified Network Associate, 1a. Ed., Ed. Campus, 2003. [10] VON SCHWEBER, L.; VON SCHWEBER,E. Cover Story: Realidade Virtual, PC Magazine Brazil, V. 5, n° 6, Junho, 1995. 59 Uma Ferramenta de Visualização de Redes Neurais Artificiais do tipo Neocognitron Bruno Zanetti 1, José Hiroki Saito2 1 Rua Antônio Fischer dos Santos, 50, Apto 14J, CEP 13564-390 [email protected], Fone: (16) 9103-7412 2 UFSCar - Rod. Washington Luís, Km 235 - CEP: 13565-905 São Carlos – SP – (16) 260-8576 – [email protected] Abstract This article presents a model, and the implementation of it, for the visualization of artificial neural networks based on particle engines. Using an object-oriented language to implement a class library was possible to create a visualization of a Neocognitron network that is insightful and clean as it is easy to use and configure. A software tool that use this library is also presented. It allows the use of the library in a easy to manipulate environment, providing a useful lab to experiment with small Neocognitron networks. Introdução Vivemos na era da informação e portanto, recebemos cada vez mais informações que precisamos analisar e entender em um ritmo cada vez mais rápido. O progresso da velocidade dos processadores não auxiliou em nossa tarefa de entender os dados, muito pelo contrário. Agora possuímos a capacidade de realizar simulações cada vez mais complexas e próximas da realidade que nos geram cada vez mais dados e os computadores ainda não são capazes de interpretá-las em nosso lugar. A visualização surgiu como uma proposta para resolver parte desse problema, aproveitando-se da capacidade cada vez maior dos computadores de processarem dados numéricos. A proposta é simples: modificar a representação dos dados, de forma que possamos enxergá-los não como tabelas gigantescas, mas de forma gráfica, facilitando a compreensão dos dados pelos seres humanos. A idéia é aproveitar os recursos biológicos de reconhecimento de padrões e associação visual[1] para que possamos entender os dados de uma forma global, observando o conjunto como um todo a procura de características que nos escapam quando olhamos para números[2]. Este trabalho traz um modelo de visualização para redes neurais artificiais, mais especificamente as redes do tipo Neocognitron, criada por Fukushima [4], um tipo de rede que tende a gerar um grande número de nós durante seu treinamento, o que torna difícil o estudo da rede de forma global. Este trabalho possui diversos objetivos, sendo o principal o estudo da aplicação da visualização no estudo da rede neural Neocognitron, visando a melhoria do entendimento sobre o comportamento desta rede específica. Como resultado desse estudo, foi criada uma ferramenta que permite manipular essa visualização livremente, de modo a ser utilizada no estudo da rede neural. Para a implementação deste trabalho, transformamos as estruturas das redes neurais em partículas de um sistema hierárquico de partículas [5] [3] de modo a representar cada nível de abstração da rede neural como uma partícula. Utilizando ainda do recurso de separar a simulação da visualização [6] visando flexibilidade de trabalho, foram criados dois sistemas de partículas principais: o primeiro representando o simulador da rede neural e o segundo, se conectando a ele em busca de dados, fazendo a visualização dos dados gerados pelo primeiro. A implementação desses sistemas de partículas é feita orientada a objetos, visando atingir a independência entre as partículas de um mesmo sistema e utilizando sistemas com maior nível de abstração para o controle de grupos de partículas independentes. Usando recursos de especialização é 60 possível expandir ambos os sistemas de partículas ou criar uma grande variedade de redes neurais com visualizações diferentes. Cada elemento da rede neural é representado por um objeto do simulador, que controla seus dados e calcula sua saída, e um que faz a visualização, representando cada elemento como um objeto visual diferente, como esferas (nós), segmentos de reta (conexões) e quadriláteros (planos), entre outros. Exemplos dessa visualização podem ser vistos na Figura 3. Uma interface para a manipulação dos sistemas de partículas foi criada, possibilitando configurar interativamente a rede neural, com grande flexibilidade para aumentar ou diminuir a quantidade de planos, nós, níveis, etc. Essa interface possui menus popup para o comando dos sistemas de partículas e janelas de diálogos para a alteração de dados de partículas específicas. Exemplos das capacidades e características dessa interface podem ser vistos na Figura 4. manipulação permite que leigos tenham um rápido entendimento da estrutura do Neocognitron. Figura 3 - Exemplos de visualização geradas pela ferramenta, em diversos ângulos de visão Para flexibilizar a biblioteca de classes que implementa o simulador e a visualização, não foram efetuadas algumas otimizações, o que faz com que o sistema como um todo seja um pouco lento, ainda mais quando utilizado com a rede do tipo Neocognitron, que cria uma grande quantidade de nós. 61 Portanto, apesar de haver uma interface de manipulação implementada e que possibilita a manipulação interativa da rede criada, ela permite a manipulação apenas de pequenas redes Neocognitron, sob a pena de ter seu tempo de resposta aumentado drasticamente se utilizado com imagens ou quantidade de planos muito grandes. (a) (b) (c) Figura 4 - Capacidades da Interface: (a) Menus Popup com comandos dos objetos (b)Janelas de Diálogo com edição das propriedades dos objetos (c)Trabalho com diversas redes diferentes simultaneamente Apesar disso, a estrutura da biblioteca permite que novas otimizações sejam aplicadas independentemente à simulação ou à visualização, permitindo melhorias futuras da mesma, enquanto que a interface de manipulação permite que leigos tenham um rápido entendimento da estrutura do Neocognitron. Referências [1] BATAIOLA, André Luiz. Análise de conceitos relacionados à implementação de sistemas de visualização tridimensional de dados meteorológicos. Tese de Doutorado, INPE, São José dos Campos, 1992. [2] CARD, S. K.; MACKINLAY, J. D.; SHNEIDERMAN, B. Readings in Information Visualization: Using Vision to Think. Academic Press, 1999. 62 [3] FRANÇON, J.; LIENHARDT, P. Basic Principles of Topology-Based Methods for Simulating Metamorphoses of Natural Objects. In: THALMANN, N. M. (Ed.), THALMANN, D. (Ed.) Artificial Life and Virtual Reality. John Wiley & Sons, 1994. [4] FUKUSHIMA, K. Neocognitron: A Self-organizing Neural Network Model for a Mechanism of Pattern Recognition Unaffected by Shift in Position. Biological Cybernetics, 36, pp. 193-202 (April 1980). [5] REEVES, W. T. Particle Systems: A Technique for Modeling a Class of Fuzzy Objects. ACM Computer Graphics – Volume 2 number 2. April 1983. [6] HELBING, R.; RÜGER, M., ILGENSTEIN, U. A Flexible Approach to Modelling Computer Visualization using Simulation Traces. Institut für Simulation und Graphik, Otto-von-GuerickeUniversität Magdeburg, 1997. 63 Realidade Virtual Distribuída para Simulação Neural Regina Célia Coelho e Luís Augusto Consularo Universidade Metodista de Piracicaba - UNIMEP Faculdade de Ciências Matemáticas da Natureza e Tecnologia da Informação Programa de Pós Graduação em Ciência da Computação {rccoelho, laconsul}@unimep.br Abstract This paper proposes a Virtual Reality Distributed environment to the visualization of realistic morphologically neural network simulation, including the growth neural, that is, the simulation of the development and the death (apoptosis) of neural cells. The user will be able to interact with the environment by using virtual reality devices that allow its complete navigation in the environment, including the three-dimensional visualization of the scene using stereoscopic vision. It is also proposed an investigation about critical performance factors of a virtual environment where it is predominated the three-dimensional representation of ramified fractionary structures, not only neurons. 1. Introdução A visualização tem como exemplos de fontes dos dados o sensoriamento de fenômenos naturais ou algum banco de dados armazenando informações transacionais, operacionais ou históricas, ou ainda a simulação computacional. Na simulação, em geral, deseja-se avaliar seu resultado comparando-o com alguma característica ou medida do objeto utilizado para a elaboração do modelo de simulação. Esta avaliação pode ocorrer em momentos determinados pela necessidade da aplicação. A visualização de simulações de objetos naturais, artificiais ou apenas abstrações devem refletir a aplicação de um modelo cujo resultado pode ser colhido com uma dada freqüência ou depender de eventos críticos. De uma forma ou de outra, a visualização dependerá do tipo de resultado que se deseja. Por exemplo, se for necessária uma interação em tempo-real com os objetos virtuais da cena visualizada, é preciso definir uma política de acesso aos resultados da simulação para que haja um compromisso entre a usabilidade e a disponibilidade dos dados. Na visualização de simulações é preciso que seus resultados contribuam para compor um modelo de representação virtual tridimensional. Este modelo é parte de uma cena que pode conter outros objetos que, por sua vez, podem ser interativos ou representar o posicionamento de algum dispositivo de interação. Uma vez construído o modelo é preciso transformá-lo em uma cena 3D. É a vez da renderização, que deve envolver o tratamento de cores, sombreamento, transparência, textura e estereoscopia. A qualidade visual e o desempenho da interação são decorrentes de uma estratégia de disponibilidade destas qualidades visuais em detrimento de um compromisso com o desempenho. A atual disponibilidade e custo de dispositivos de visualização tais como monitores estereoscópicos, projetores, dispositivos HMD (Head Mounted Devices), telas de polarização seletiva, bem como de placas gráficas multiprocessadas e programáveis tem viabilizado aplicações que exigem desempenho e qualidade visual. A necessidade de manipulação dos dados resultantes de simulações é freqüente em Neurociência, já que tipicamente aplicações dessa área geram grande volume de dados e, conseqüentemente, ferramentas poderosas de análise de dados. As potencialidades da Realidade Virtual têm chamado a atenção, tanto de pesquisadores quanto de fornecedores de aplicação em Neurociência [1,2,3,4,5]. Este artigo propõe um ambiente de Realidade Virtual Distribuída para visualização da simulação de Redes Neurais Morfologicamente Realistas. Esta rede é formada por neurônios artificiais obtidos por variações gramáticas L-systems estocásticas que consideram a distribuição de características morfológicas de neurônios reais para elaborarem as estruturas ramificadas dos neurônios 64 [6,7]. Estas características são resultantes de medidas realizadas em traçados de neurônios usando microscópios confocais para a visualização do neurônio real em fatias. Este processo in vitro de visualização confocal permite apenas a visualização de fatias que estejam em uma determinada profundidade de campo. Normalmente, estes traçados são elaborados manualmente ou com algum auxílio computacional. De posse dos traçados, estes podem ser reunidos em um banco de dados, de onde se extrai as distribuições estatísticas dos números de ramificações, tamanhos de segmentos, entre outras medidas. Com o ambiente de Realidade Virtual Distribuída (RVD) o usuário poderá: (1) selecionar neurônios virtuais (ou parte dele) em uma rede simulada ou em crescimento; (2) mudar seu ponto de vista em relação ao neurônio; (3) alterar os parâmetros de simulação a partir da cena; (4) visualizar uma simulação, podendo interferir em seus parâmetros dinamicamente; (5) compartilhar o espaço de visualização com outros usuários também imersos no ambiente, porém em diferentes computadores, para analisar colaborativamente a estrutura neural e seu crescimento. Embora a principal motivação das simulações de crescimento neural em RVD seja a compreensão do processamento neural de uma forma mais realista, o ambiente gerado por este trabalho oferece ainda contribuições para uma melhor compreensão de problemas neurológicos (e consequentemente, auxiliar no seu tratamento) e analisar o desempenho das propriedades de um sistema de Realidade Virtual com estruturas fracionárias ramificadas. Segundo Noser [8], ambientes virtuais devem ser dinâmicos, variáveis e complexos, propriedades estas presentes neste trabalho. O sistema será validado utilizando-se gramáticas (L-systems estocásticas) por sua característica dinâmica e por permitir variar a complexidade das ramificações. Esta complexidade influencia diretamente o desempenho do sistema de RVD, exigindo decisões entre qualidade e desempenho para o renderizador ou para a interação/navegação. 2. Organização do SVRD O “Sistema de Realidade Virtual Distribuída” (SRVD) terá como entrada os resultados do simulador já implementado. O diagrama apresentado na Figura 1 ilustra as funcionalidades pretendidas e as respectivas articulações lógicas. O SVRD proposto deve ser formado por dois tipos de módulos: um módulo Gerador de Dados (GD) e outro Modificador de Cena (MC). Neste caso, é possível a ocorrência de vários Modificadores de Cena e vários Geradores de Dados, contudo só haverá um módulo Simulador (SM). O Modificador de Cena, por sua vez, é composto de seis submódulos: o Controle de Cena (Ccn), o módulo de Interação (Int), o módulo de Crescimento Neural (Cnr), o módulo de Navegação (Nav), o Controle de Colaboração (Ccb) e o Protocolo de Acesso à Rede (Par). O módulo Ccn concentra informações sobre o crescimento, interação e navegação para provocar as alterações no modelo virtual. É importante delimitar cada uma destas partes, isto é, a Navegação (Nav) restringe-se à locomoção do usuário no ambiente virtual, bem como a mudança de seus pontos de vista. A complexidade visual dos neurônios em 3D impõe o uso de visualização estereoscópica, exigindo também que a posição dos olhos do usuário sejam rastreadas para não provocar a diplopia. A navegação pela cena deve dar ao usuário o poder de escolher regiões de interesse ou então de chegar de maneira mais rápida a estas regiões. Já a Interação (Int), comandos do usuário, deve permitir que a cena se modifique a partir de uma ação do usuário. Esta alteração da cena pode ser, por exemplo, a mudança da cor de um neurônio para que este se destaque entre os demais, facilitando sua identificação pelo usuário. 65 " # $ ,!)$ ) ! ) ) ) ! ( ! ( ! ( + ( ! ! ! + ( ! ! % ! (CV) % ! ! & ' % 0% ! ! ! ( ! ! ( ,!)$ ) ! % % ! Modificadores de Cena (MC) - . - . 0% ) * ) ) /% 0% 1 Figura 1 – Módulos de desenvolvimento do SVRD A interação (Int), controle, exigirá um rastreamento da posição do usuário. Este rastreamento será implementado com câmeras que recuperarão a posição de marcadores ou partes do corpo como mãos e cabeça para: (1) tocar algum objeto na cena virtual e selecioná-lo; (2) rotacionar e transladar algum objeto selecionado; (3) remover ou alterar propriedades visuais (como transparência ou cor) para facilitar a visualização; (4) navegar pela cena; (5) mudar o ponto de vista da visualização; (6) alterar parâmetros morfológicos de crescimento e morte neural, que determinarão a sobrevivência da célula e exigindo a reorganização da rede; (7) alterar parâmetros sobre os campos que influirão no crescimento neural, simulando a influência de substâncias que determinam a direção do cone de crescimento. O módulo Crn implementa as funcionalidades necessárias à geração das formas gráficas que representam os componentes dos neurônios. O núcleo de Controle de Colaboração (Ccb) tem a função de decodificar as mensagens transportadas na rede pelo Protocolo de Acesso à Rede (Par), com o intuito de diferenciar os canais de comunicação que determinam a navegação (Nav), a interação (Int) e os dados do simulador (SM). Este particionamento hierárquico possibilita o uso de diferentes dispositivos de interação e navegação e, além disso, minimizam a coesão, o que permitirá que os módulos geradores de dados atuem em diferentes MC, oferecendo uma visão compartilhada do crescimento neural aos usuários. Os módulos do SVRD deverão ser desenvolvidos de forma gradual, considerando suas interdependências. Desta forma, o primeiro passo é a definição do renderizador do grafo de cena representando a rede neural. Uma vez definido o grafo de cena, é a vez de considerar a implementação e testes do protocolo de acesso à rede, o Par, que deve ser capaz de estabelecer comunicação entre os nodos usando uma API Socket em TCP/IP. A implementação do Par deve ser seguida da implementação do núcleo de controle de contribuição, o Ccb. O Ccb consistirá de um protocolo de mensagens que implemente serviços de navegação, interação e criação de nodos de um grafo de cena. Disponíveis os serviços de comunicação, o próximo módulo se refere ao Controle da Visualização (CV), que atenderá aos controles de navegação de avatar (Nav); aos pedidos de inserção, remoção ou alteração de segmentos neurais (Cnr); ou ainda aos comandos de interação (Int), sejam provenientes de dispositivos, seja de uma simples console interpretando comandos textuais. Cada uma destas intervenções será estruturada em XML para que a configuração do CV seja modular e possa crescer sem a necessidade de alteração da arquitetura do sistema. A linguagem C++ e Java oferecem bibliotecas gratuitas para tratamento de XML para este fim. Portanto, o gerenciamento desta configuração, atendendo as requisições dos diversos nodos clientes, é o papel do Controle de Cena (Ccn) 66 O desenvolvimento dos dispositivos de Interação e Navegação exigirá basicamente o rastreamento da cena real para identificação e detecção da posição de objetos reais bem como seu mapeamento no ambiente virtual. 5. Conclusões Muitos desafios têm sido impostos ao entendimento do processamento neural. O SVRD apresenta, entre outros, três benefícios: (1) a abordagem não é invasiva, ou seja, não é preciso manter qualquer animal sob efeito de droga alguma para se obter o processamento neural resultante; (2) não há restrições quanto ao número de hipóteses que podem ser testadas, permitindo que o entendimento seja mais abrangente e que o modelo seja confrontado com dados de modelos biológicos; (3) a escala de tempo do experimento não fica confinada ao tempo biológico, ou seja, é possível acelerar a execução de uma simulação, desde que disponíveis os recursos computacionais. Este ambiente de RVD permitirá que o próprio ciclo-de-vida do desenvolvimento do software do simulador ganhe mais agilidade e flexibilidade, pois os resultados da simulação poderão ser depurados com mais eficácia. Referências [1] LEIGH, J. at al. Virtual Reality in Computational Neuroscience, in: Virtual Reality and Its Applications, eds: R. Earnshaw; H. Jones; J. Vince, Academic Press, London, 1994. [2] ASCOLI, G. A at. al. Computational Neuroanatomy of the Hippocampus, Draft of the poster for SFN98, Los Angeles, 1998, http://www.krasnow.gmu.edu/ascoli/sfn98/index.html (consultado em 07/12/2002). [3] BÜLTHOFF, H. H.; van VEEN, A. H. C. Vision and Action in Virtual Enviroments: Modern Psychophysics In Spatial Cognition Research, Technical Report No. 77, Max-Planck-Institut für Biologische Kybernetik, Germany, 1999. [4] ASCOLI, G. A.; KRICHMAR, J. L. L-neuron: A modeling tool for the efficient generation and parsimonious description of dendritic morphology, Neurocomputing, v. 32-33, 2000, p. 1003-1011. [5] TARR, M. J.; WARREN, W. H. Virtual Reality in Behavioral Neuroscience and Beyond (Review), Nature Neuroscience Supplement, v. 5, 2002, p. 1089 -1092. [6] COELHO, R. C.; COSTA, L. F., Realistic neuromorphic models and their application to neural reorganization simulations, Neurocomputing, n. 48, 2002, p. 555-571. [7] COELHO, R. C. ; JAQUES,O. Generating Three-Dimensional Neural Cells Based On Bayes Rules And Interpolation With Thin Plate Splines, 8th Iberoamerican Congress on Pattern Recognition, Havana, Cuba, in: Progress in Pattern Recognition, Speech and Image Analysis, Lecture Notes in Computer Science, v. 2905, 2003, p. 675-682. [8] NOSER, H.; STERN, C. STUCHI, P. Distributed Virtual Reality Enviroments Based on Rewriting Systems, IEEE Transactions on Visualization and Computer Graphics, 9(2), 213-225, 2003. 67 Lista de Autores Álvaro José Abackerli ........................................................ Analis Michele dos Santos.................................................. Carlos Alberto Dainese....................................................... Bruno Zanetti ..................................................................... Carlos Eduardo Della Coletta ............................................ Carolina V. Buk ………………………………………..... Cláudio Kirner………………………………………......... Daniela Akagui …………………………………………... Ednaldo Brigante Pizzolato …………………………........ Eduardo Sasaki …..……………………………………..... Fabiano Utiyama ...……………………………………..... Galesando Henrique Capovilla .………………………..... João Guilherme Darezzo Martins de França …………….. José Hiroki Saito ……………………………………….... Luís Augusto Consularo …………………………………. Márcia Aparecida de Jesus ………………………………. Marcio Merino Fernandes ……………………………….. Mário Alexandre Gazziro ………………………………... Nivaldi Calonego Junior .................................................... Otto Rössler ........................................................................ Paulo César Lourenço …………………………………… Priscila Santarosa Lahr ………………………………….. Rafael Santin .......………………………………………... Regina Célia Coelho …………………………………….. Réryka Rubia P.C.L. Silva ………………………………. Ricardo Armengol Silva …………………………………. Ricardo Zottino .................................................................. Sandro Canavezzi de Abreu ............................................... Silvia C. Galana …………………………………………. Tânia Rossi Garbin ………………………………………. Tereza Gonçalves Kirner ………………………………… 41 33 33, 37 60 41 45 1, 5, 9, 13,33, 45 5 21 56 9 49 25, 29 25, 29, 60 49, 53, 56, 64 33 21 25, 29 41, 45, 56 29 37 37 13 49, 53, 64 17 53 41 29 17 33 45 68