domingo, 23 de novembro de 2008

Trabalho de Diploma: Suporte da Arquitetura Orientada a Serviços na integração de sistemas médicos

Resumo

Nesta última sexta-feira 21, apresentamos nosso Trabalho de Diploma (ou TD, mesma coisa que TCC) na UNIFEI e fomos aprovados! :D

Nosso TD foi sobre SOA. Na época, li os seguintes materiais para aprender sobre este assunto:

1. Proposta

O co-orientador e o orientador deste trabalho apresentaram um artigo, onde demonstraram a implementação de um sistema médico para o gerenciamento de imagens digitais denominado Picture Archiving and Communication System (PACS). O PACS, em conjunto com Radiology Information System (RIS) e Hospital Information System (HIS), formam a base para um serviço de Radiologia Filmless (tecnologia que indica a manipulação de imagens médicas sem utilizar filme fotográfico, que demandava relevante custo e tempo para revelar).

As imagens são obtidas de modalidades de imagens médicas digitais, como Ressonância Magnética Nuclear (RMN) e Tomografia Computadorizada (TC), em formato DICOM (Digital Imaging and Communication in Medicine) 3.0, indexadas, armazenadas e vinculadas ao RIS do Hospital para posterior visualização.

Este sistema PACS foi concebido e desenvolvido dentre um escopo bem-definido. No entanto, há diversos outros requisitos de negócio em ambientes médicos que necessitam de manipular as informações obtidas pelo sistema apresentado. De forma a permitir futuras integrações com tal sistema de forma escalável e padronizável, é proposta a utilização de SOA.

Com essa proposta em mente, é possível utilizar de serviços pré-existentes e também integrá-los entre si e também com serviços que venham a ser criados. Assim tem-se um sistema que pode trabalhar com todo o sistema legado, integrar as bases de dados e ser distribuído, facilitando o acesso das várias redes hospitalares que necessitam dessas informações.

A proposta baseia-se em realizar serviços de consulta utilizando dois sistemas existentes: um sistema RIS e um sistema de aquisição de imagens médicas. Cada serviço realizará consultas em ambos sistemas e depois unirá seus resultados sob uma mesma resposta, conforme o diagrama UML de caso de uso abaixo:

Diagrama UML de caso de uso

2. Desenvolvimento

Cada sistema acima teve suas principais funcionalidades exportadas como Web Services. Para cada sistema foi gerado um Web Service para expor seus serviços simples.

Utilizando estes Web Services, foi construido um outro Web Service de integração, denominado Web Service PACS, caracterizando-se como um serviço composto. Este Web Service possui interface parecida ao Web Service do sistema RIS, com exceção da mensagem de resposta, e segue o seguinte fluxo para cada requição:
  1. Extrai os parâmetros da requisição
  2. Chama o Web Service do sistema RIS, passando os parâmetros recebidos. Receberá uma lista com exames radiológicos ou uma lista com pacientes.
  3. Se recebeu uma lista com exames radiológicos, para cada exame radiológico chama o Web Service do sistema de aquisição de imagens, passando a identificação do exame como parâmetro. Receberá uma imagem para cada exame.
  4. Retorna uma mensagem SOAP contendo todas as informações solicitadas, provenientes de ambos sistemas.
Os Web Services descritos acima foram publicados no servidor Apache Axis2. Por sua vez, o Web Service PACS também foi publicado no ESB Apache ServiceMix. Assim, qualquer componente membro deste barramento poderá usufruir da mesma maneira e sob o controle da mesma infra-estrutura.

O diagrama UML de atividades abaixo ilustra todo o processo:

Diagrama UML de atividades

3. Conclusão

Com a organização em serviços das funcionalidades dos sistemas apresentados, e sua utilização sobre uma infra-estrutura padronizada, alcança-se a robustez necessária para que o sistema cresça sem maiores problemas, aumentando assim seu valor agregado. Além disso, é possível ter controle sólido sobre segurança, roteamento e monitoramento do serviço.

Ao publicar tais serviços sobre tal arquitetura orientada a serviços, torna-se possível a construção de operações mais complexas com respeito à gestão e manipulação de informações dos pacientes, como por exemplo a obtenção de prontuário completo para um paciente, baseado num histórico médico que possa estar distribuído em sistemas distintos e em localidades distintas.

Ainda, a utilização de SOA introduz diretrizes para guiar o desenvolvimento de futuras integrações entre outros sistemas médicos, fazendo respeito tanto sobre a questão tecnológica quanto a questão de pessoal.

Desta forma, ao aplicar SOA em um ambiente médico, concluimos que SOA é uma tecnologia adequada para a integração de ambientes heterogêneos como os ambientes da área médica.


4. Arquivos

sexta-feira, 7 de novembro de 2008

JMRP, um sistema acadêmico para MRP (Materials Requirement Planning)

Um trabalho acadêmico muito interessante que fiz na UNIFEI em 2006 foi um sistema MRP para realizar a programação de uma linha de produção em termos do PCP – Planejamento e Controle da Produção.

Segundo meu professor Fabiano Leal:
Materials Requirement Planning (MRP) é um sistema de informações computadorizado, desenvolvido especificamente para auxiliar as empresas na administração do estoque de demanda dependente e programar pedidos de reposição. Desenvolvido nos anos 60, na IBM, era voltado exclusivamente ao planejamento de materiais. Com o desenvolvimento dos meios computacionais, a idéia básica transformou-se no MRP II (Manufacturing Resource Planning) para atender não apenas ao setor produtivo, mas a toda a corporação.

O objetivo do sistema MRP é calcular as quantidades e os prazos dos vários elementos (materiais) necessários à constituição de uma certa quantidade de um certo produto num prazo de entrega definido.

Quem quiser se aprofundar no assunto, pode consultar o material do curso da disciplina do professor Fabiano Leal. Muito bom e auto-explicativo!

MRP usualmente compõe um sistema Enterprise Resource Planning (ERP), que segundo Wikipedia é um sistema de informações que integra todos os dados e processos de uma organização. A integração pode ser vista sob a perspectiva funcional (sistemas de: finanças, contabilidade, recursos humanos, fabricação, marketing, vendas, compras, etc) e sob a perspectiva sistêmica (sistema de processamento de transações, sistemas de informações gerenciais, sistemas de apoio a decisão, etc).

Pois bem, na ocasião que cursei as disciplinas EPR-27 (Planejamento e Controle da Produção) e CCO-511 (Programação Orientada a Objetos), eu desenvolvi um software em Java para calcular as Ordens Liberadas de uma produção, chamado de JMRP.

As atividades suportadas pelo sistema Java Materials Resource Planning (JMRP) são: gerenciamento de materiais, listas de materiais, políticas de loteamento, planos mestre de produção, estoques e ordens abertas, cálculo de programações de produção e emissão de relatórios de ordens liberadas de programações de produção.

O JMRP busca obter programações de produção otimizadas, de acordo com o mais difundido algoritmo de cálculo computacional da gestão de materiais. Desta forma, provê a simulação de cenários de problemas práticos de sistemas MRP, assumindo o papel de ferramenta de apoio ao ensino.

Para conhecer melhor o JMRP e ver alguns diagramas UML veja sua apresentação na disciplina CCO-511.

Na disciplina de EPR-27 apresentamos um artigo propondo a utilização do JMRP como complemento das aulas de EPR-27 em sala de aula, por ser um software de cunho didático, que dessa forma procura contribuir para a assimilação do conteúdo pelo aluno. Veja o artigo apresentado na disciplina EPR-27.

Este foi um projeto edificante para mim, onde pratiquei bastante meus conhecimentos em desenvolvimento OO em Java e MVC. Eu tinha intenção de dar continuidade ao mesmo, melhorando sua arquitetura e construindo interface web para disponibilizá-lo para acadêmicos em rede nacional, visando neste sentido escrever artigos sobre isto.

Se você possui intenção de ajudar, fique à vontade. Quem sabe um dia eu faço isso! :)

quarta-feira, 5 de novembro de 2008

O lançamento de favorpals.com, um mundo sem dinheiro!

San Francisco, CA (PRWEB), 22 de outubro de 2008

Favorpals.com está agora aberto ao público, oferecendo um método alternativo para satisfazer necessidades da vida sem o uso do dinheiro. Apoiado em seu slogan, “um mundo sem dinheiro”, oferece a seus membros trocarem serviços por outros sem o uso ou mesmo menção de valor monetário. Adequado especialmente para nossas épocas econômicas desafiadoras, Favorpals representa um substituto à economia monetária permitindo trocas diretamente entre as pessoas.

“Favorpals é uma comunidade de relacionamento social online, onde serviços são trocados por outros serviços e/ou bens,” disse Zeo Solomon, co-fundador de Favorpals. “Artesãos, artistas, trabalhadores, profissionais — de fato qualquer um com habilidades ou bens a trocar pode intercambiar com serviços ou artigos de qualquer um na comunidade Favorpals. Devido ao amplo alcance da Web, os usuários podem fazer trocas com outros em sua esquina ou até mesmo num continente distante.”

“Projetamos nossa tecnologia de maneira que permite às pessoas encontrarem com facilidade correspondência entre o que precisam e o que estão oferecendo em troca”, disse Amir Razmara, outro co-fundador de Favorpals. Favorpals também fornecerá a seus usuários um sistema de avaliação inteligente a fim de certificar-se que os demais membros do site serão reconhecidos por suas boas ações. “Desta maneira, estamos fazendo uma reviravolta moderna sobre o antigo sistema de troca”, disse Sr. Razmara.

Favorpals é especialmente significativo quando uma troca de favores cruza a divisão entre pessoas de diferentes classes sociais, onde ambas as partes se beneficiarão igualmente, não obstante a classe ou o status. Favorpals tanto é um movimento social quanto uma economia alternativa. A utilização de Favorpals é gratuita e todas as trocas são confidenciais e seguras.

Favorpals é mantido em escritórios start-up situados em San Francisco no endereço 300 Beale Street.

O site de Favorpals pode ser visto em http://www.favorpals.com.

Todas as questões podem ser dirigidas a Zeo Solomon, +1 (415) 300-6652