ISSN 2316-5804

Transcrição

ISSN 2316-5804
S.I.nforme
ISSN 2316-5804
S.I.NFORME
Revista de Tecnologia da Informação do Curso de Sistemas de
Informação
Faculdade Escritor Osman da Costa Lins - FACOL
Vitória de Santo Antão, PE – ANO 1, Nº. 1 – dez.2012
S.I.nforme
Publicação anual
Revista do Curso de Sistemas de Informação – Bacharelado da Faculdade Escritor Osman da Costa
Lins – Facol
Diretor da FACOL:
Dr. Paulo Roberto de Leite Arruda
Vice-Diretor da FACOL:
Túlio Albuquerque Duarte
Diretor Pedagógico:
Prof. Péricles Tavares Austregésilo Filho
Coordenadora Geral Acadêmica:
Profª. Nancy Farias Martins Leite
Coordenador do Curso de Sistemas de
Informação
Prof. MSc. Cleyton Mário de Oliveira
Rodrigues
Conselho Editorial:
Cleyton Mario de Oliveira Rodrigues
Elcias Ferreira da Costa
Péricles Tavares Austregésilo Filho
José Procópio da Silveira
Gleibson Rodrigo Silva de Oliveira
Conselho Científico:
Prof. MSc. Cleyton Mário de Oliveira
Rodrigues
Prof. MSc. Ryan Ribeiro de Azevedo
Profª. MSc. Ana Cristina Freitas CesarStefano
Toscano
Profª. Esp. Audrey Bezerra de Vasconcelos
Prof. Esp. Iuri Santos Souza
Profª. Msc. Jailze de Oliveira Santos
Profº. Esp. Gleibson Rodrigo Silva de Oliveira
Diagramação:
Evandro Bonifácio de Andrade – Departamento
de Web Design.
Publicação:
Associação Vitoriense de Educação, Ciências e
Cultura, entidade mantenedora da Faculdade
Escritor Osman da Costa Lins – FACOL.
CNPJ: 03.391.726/0001-90.
Endereço:
Rua do Estudante, 85, Bairro Universitário, Vitória de Santo Antão/PE. CEP 55612-650. Tel. (81)
3114-1200 www.facol.com - e-mail: [email protected]
IMPRESSÃO:
Luci Artes Gráficas Ltda
[email protected]
REVISTA DE TECNOLOGIA DA INFORMAÇÃO DO CURSO DE SISTEMAS DE
INFORMAÇÃO: S.I.nforme
Vitória de Santo Antão, PE: Facol, a. 1, n.1 ___. 2012, ____p.
ISSN 2316-5804
SUMÁRIO
SEVAC: Um Estudo de Caso do Uso de Sistemas Especialistas na Educação Básica _ 3
Test-Module: uma ferramenta para gerenciamento de testes de software integrada ao
FireScrum ___________________________________________________________ 12
LSVF: A heuristic search to reduce the backtracking calls when solving Constraint
Satisfaction Problems __________________________________________________ 19
O Lixo eletrônico no Brasil: Leis e Impactos Ambientais ______________________ 28
An Experimental Research on the Relationships between Preferences for
TechnicalActivities and Behavioural Profile in Software Development ___________ 34
CHRr f ∨: A Logic Inference Engine to Resolution Leveraged by Heuristics _______ 51
1
EDITORIAL
2
SEVAC: Um Estudo de Caso do Uso de Sistemas Especialistas
na Educação Básica
Maria José dos Santos Takeshita1, Cleyton Mário de Oliveira Rodrigues2
1
2
Sistemas de Informação– Faculdade Escritor Osman da Costa Lins (FACOL)
Vitória de Santo Antão – PE – Brasil
Centro de Informática – Universidade Federal de Pernambuco, (CIn/UFPE) Código
Postal 7851 – RECIFE – PE – Brasil
[email protected], [email protected]
Abstract. To evaluate the knowledge acquired by students of Elementary
Education is a subject that involves areas of cognitive psychology, approaches
and styles of teaching/learning process and, more recently, the use of
techniques that concern the field of Artificial Intelligence. This article, in this
context, presents a proposal using the I. A. to assess and diagnose the learning
of elementary school students based on an Expert System. This proposal was
substantiated through a case study within a context of knowledge in
particular; it also presents the questionnaires through which we sought to
assess the acceptability of the system developed by both the teachers as the
student body.
Resumo. Avaliar o conhecimento adquirido pelos alunos da Educação
Elementar é um tema que envolve áreas da Psicologia Cognitiva, das
abordagens e estilos do processo Ensino/Aprendizagem e, mais recentemente,
do uso de técnicas que tangem o domínio da Inteligência Artificial. Este
artigo, neste contexto, apresenta uma proposta utilizando a I. A. para avaliar
e diagnosticar o aprendizado de alunos do Ensino Fundamental baseado em
um Sistema Especialista. Tal proposta foi fundamentada através de um estudo
de caso, dentro de um contexto de conhecimento em particular; ela também
apresenta questionários através do qual se pretendeu avaliar a aceitação do
sistema desenvolvido tanto pelo corpo docente, como pelo corpo discente.
1. Introdução
De acordo com [Valente 2009] “o termo Informática na Educação significa a inserção
do computador no processo de aprendizagem dos conteúdos curriculares em todos os
níveis e modalidades de educação. Para tanto, o professor da disciplina curricular deve
ter conhecimento e domínio sobre o potencial educacional do computador e ser capaz de
alternar adequadamente atividades tradicionais de ensino-aprendizagem e atividades que
usam o computador” para que dessa forma a apropriação do conhecimento transmitido
seja bem adquirida pelo aluno.
Os computadores são vistos como um importante recurso para auxiliar o
processo de ensino-aprendizagem, aprimorando os conceitos básicos já conhecidos
[Andrade e Lima 1996], e “possibilitando a busca e compreensão de novas idéias e
valores; quando utilizado como máquina de ensinar aborda os métodos de ensino
tradicional ou instrucionista” [Valente 2009]. Vale salientar, contudo, que mesmo o
aluno construindo seu conhecimento através de ambientes de aprendizagem
3
informatizados, a máquina não deve ser usada exclusivamente e isoladamente, pelo
contrário, como ferramenta não é capaz de trazer sozinha, avanços educacionais.
Paralelamente ao desenvolvimento do Construtivismo-Interacionista de Piaget
[Piaget 1972], sistemas computacionais como a Inteligência Artificial, e, em particular,
subáreas de atuação, como os Sistemas Especialistas [Giarratano e Riley 1998] e os
Sistemas Tutores Inteligentes [Wenger 1987] surgiram, permitindo novas formas para
buscar, construir e manter conhecimentos, porém mais adaptáveis às características
cognitivas dos alunos. Tais avanços fomentaram a criação e o desenvolvimento de
novas idéias que pudessem auxiliar todo o processo de ensino-aprendizagem,
vivenciado nas escolas afora.
Este presente trabalho, contudo, delimita-se ao estudo/avaliação das técnicas
atuais usadas em sala para avaliar o nível de aprendizado dos alunos. Enquanto pelo
lado discente, há recorrentes reclamações acerca das provas elaboradas (tediosas e
estáticas), pelo lado do corpo docente, há a necessidade de poder criar provas mais ricas
de detalhes, há um baixo custo de tempo e, sobretudo, que não acarrete sobrecargas de
trabalhos durante a correção, podendo prejudicar, sobretudo, a imparcialidade na
avaliação dos alunos. É neste contexto, que este trabalho apresenta o SEVAC, uma
ferramenta desenvolvida durante o trabalho de graduação, que incorpora características
da Inteligência Artificial, particularmente de Sistemas especialistas, e que serve como
uma proposta de avaliação rápida, dinâmica, e imparcial ao nível de assimilação dos
alunos.
Este trabalho está estruturado como se segue. Na seção 2, revisitaremos as
principais características dos Sistemas Especialistas. De forma a poder avaliar bem o
SEVAC, a seção 3 explica os métodos comuns utilizados nas redes de ensino como
formas de avaliação do aprendizado. Em seguida, a seção 4 apresenta o SINTA, o
framework básico através do qual o SEVAC, discutido na seção 5, foi desenvolvido. Por
fim, a seção 6 resume os principais resultados alcançados até então, e a seção 7 encerra
este trabalho com as conclusões e as perspectivas de trabalhos futuros.
2. Sistemas Especialistas
Os sistemas especialistas fazem parte da área de interesse da Inteligência Artificial (IA),
podendo ser considerado, inclusive, como um ramo da I.A., [Giarratano e Riley 1998],
como pode ser observado na figura 1.
4
Figura 1: Áreas da Inteligência Artificial [Giarratano & Riley. 1998]
Um sistema especialista é um programa de computador que usa o conhecimento
e inferências para resolver problemas muito difíceis e que requerem a expertise humana,
ou seja, habilidades intelectuais que uma pessoa tenha em uma determinada área do
conhecimento para solucioná-los [Harmon, Maus e Morrisey 1988] [Metaxiotics,
Askounis e Nikolopoulos 2006].
Figura 2: Arquitetura de um Sistema Especialista [Nikolopoulos 1997]
Os Sistemas Especialistas possuem uma arquitetura composta de (figura 2)
[Nikolopoulos 1997]: uma base de conhecimento responsável por estruturar todo o
conhecimento sobre o domínio da aplicação, um motor de inferência contendo os
algoritmos com regras que serão satisfeitas pelos fatos ou objetos implantados, um
módulo para aquisição do conhecimento o qual é constantemente refinado aumentando
o conhecimento adquirido do especialista, módulo de explanação responsável por
justificar os passos utilizados para chegar ao resultado final e uma interface, através da
qual o sistema especialista interage com o usuário.
Parafraseando [Mendes 1997], os resultados obtidos através da utilização da técnica
de sistema especialista são diferentes daqueles encontrados por meio de sistemas
tradicionais, por tratar-se de sistemas dotados de inteligência e conhecimento. Podemos
destacar alguns exemplos, tais como:
5

O sistema habilita tanto um especialista, bem como leigos a serem capazes de
tomar decisões mais coerentes;

Melhora a produtividade e desempenho, uma vez que o conhecimento está
armazenado em uma base de dados e pode ser usado de forma distribuída, tantas
vezes quantas necessárias forem, mantendo sempre a integridade nas decisões
tomadas; e

Podem servir de instrumento para coleta de informações sobre o desempenho
dos usuários, permitindo que o próprio sistema possa ser reformulado para
adequar-se cognitivamente a este grupo de usuários.
Este trabalho, portanto, explora mais largamente o terceiro item acima; a partir do
diagnóstico do nível de aprendizado dos alunos em uma área de conhecimento em
particular, é possível que o sistema evolua continuamente até atingir um nível adequado
de avaliação.
3. Métodos Tradicionais de Avaliação de Aprendizado
De acordo com [Kraemer 2005], “avaliar é atribuir um valor sobre a propriedade de um
processo para a aferição da qualidade do seu resultado está associada a medir
conhecimentos adquiridos pelos alunos”. A avaliação da aprendizagem é marcada pelo
desenvolvimento de testes padronizados para medir quais aptidões e habilidades foram
adquiridas pelos alunos. No âmbito escolar, tal informação é necessária para que o
professor encontre meios e estratégias que possam ajudar os alunos a absorver da
melhor forma possível os conteúdos estudados. Os tipos de avaliação são enquadrados
em três grandes tipos [Haydt 1997]:

A Avaliação Diagnóstica é aquela em que é verificada a posição do aluno face
às novas aprendizagens que lhe vão ser propostas e a aprendizagens anteriores
que servem de base àquelas, no sentido de identificar as dificuldades futuras e,
em certos casos, de resolver situações presentes.

A Avaliação Formativa permite constatar se os alunos estão, de fato, atingindo
os objetivos pretendidos, verificando a compatibilidade entre tais objetivos e os
resultados efetivamente alcançados durante o desenvolvimento das atividades
propostas.

A Avaliação Somativa busca traduzir o quão distante o avaliado ficou de atingir
uma meta estipulada inicialmente. Esse tipo de avaliação deve ser aplicado em
momentos específicos ao longo de um curso, como por exemplo, no final de um
período ou ano letivo.
Atualmente é notória a necessidade da inserção dos novos recursos tecnológicos na
área escolar, uma vez que a sociedade busca por profissionais qualificados, capazes de
enfrentar situações diversas, e o uso dessas novas tecnologias visam adequá-los a esse
meio fazendo com que alunos e professores façam parte dessas mudanças sociais,
culturais e profissionais que o terceiro milênio visa proporcionar.
Tais avanços tecnológicos, em destaque o computador, assim como os softwares
educativos, emergem como o artefato principal, oferecendo suporte na aprendizagem.
Pois é através dele que se expande o raciocínio e a criatividade dos alunos. É grande a
necessidade no uso dos recursos computacionais em salas e/ou laboratórios de
6
informática, sejam eles utilizados como instrumento para auxiliar na aprendizagem do
conteúdo, ou para avaliação da aprendizagem servindo como suporte ao professor.
4. SINTA
O Sistema Especialista Expert SINTA [LIA 2010] é um software desenvolvido na
Universidade Federal do Ceará – UFC que utiliza linguagem Shell, um projeto da
UFC/UECE, criado pelo Grupo SINTA - Sistemas Inteligentes Aplicados, o qual utiliza
em sua criação técnicas de Inteligência Artificial.
Seu conjunto de instruções utiliza um modelo de representação do
conhecimento, através de regras de produção e probabilidades, objetivando reduzir o
trabalho de implantação na construção de sistemas especialistas. Adicionalmente, utiliza
uma máquina de inferência compartilhada, com suporte à construção automática de telas
e menus, modelando dessa forma uma base de conhecimento, ao mesmo passo que já
provê para o usuário a GUI – Guide User Interface.
Sendo assim, é bastante viável a utilização desse sistema para classificação de
problemas, uma vez que o usuário responde a uma seqüência de perguntas e o sistema
fica encarregado de fornecer respostas que sejam adequadas às solicitações feitas pelo
usuário. Este foi um dos motivos que levou à escolha desta ferramenta neste projeto de
pesquisa. Saliente-se também que é uma ferramenta grátis, diferente de outras
pesquisadas.
5. SEVAC
O SEVAC - Sistema Especialista Voltado a Avaliação do Conhecimento, visa priorizar
e analisar o nível de aquisição do conhecimento do aluno no domínio do Reino Animal,
uma vez que o computador deve ser utilizado também, na construção do conhecimento
do mesmo. A criação de um Sistema voltado ao domínio do Reino animal visa explorar
de forma contínua os conceitos vistos em sala de aula, como também fazer uma
avaliação do nível de aprendizagem do aluno relativo ao conteúdo estudado. No caso, o
domínio proposto para estruturação desse software visa explorar os animais vertebrados
onde o aluno deverá identificar tanto sua classificação, quanto as características, habitat
e reprodução dos mesmos.
A escolha por esse tipo de domínio para desenvolvimento do software está
diretamente relacionada à necessidade da professora de ciências da escola analisada,
uma vez que o conteúdo apresentado faz parte da grade curricular da disciplina para a
unidade vigente. Dessa forma, essa aplicação apresenta uma metodologia onde se
possibilita a utilização de Sistema Especialista na aula de ciências, promovendo assim
melhor assimilação e aprendizagem do conteúdo apresentado. Pretende-se com esta
proposta atingir os objetivos e validar o uso do Sistema Especialista SEVAC como um
recurso didático.
A arquitetura desenvolvida para o SEVAC é composta pela Base de
conhecimentos, a qual possui informações que um especialista utiliza. Ela é armazenada
em diversas estruturas de árvore binária, onde a interface do programa armazena
diretamente as regras encontradas nas estruturas. A Máquina de Inferência é a parte do
sistema especialista responsável pelas deduções sobre a base do conhecimento. Por fim,
o Banco de Dados Global tem a função de representar as evidências apontadas pelos
usuários do sistema especialista durante a consulta.
7
Figura 3: Exemplo de Tela do SEVAC
A consulta se desenvolve por meio de menus de múltipla (ou única) escolha, tal
como a figura 3. Até então foram criadas 26 perguntas com respostas.
Figura 4: Tela de Resultados
A tela de resultados (figura 04) exibe, ao final, os conhecimentos corretos
obtidos através das respostas assinaladas pelo usuário. Pode aparecer em uma consulta
tantas vezes quanto for o número de objetivos a serem alcançados. Sendo assim as
janelas são dividas e exibidas por classe (mamíferos, peixes, répteis, anfíbios e aves)
onde cada classe tem uma quantidade de perguntas e respostas, capazes de suprir a
necessidade de uma avaliação sobre a mesma, as questões assinaladas erroneamente são
descartadas pelo sistema apresentando assim apenas às opções corretas, dando
sequência à consulta das demais classes; o professor nesse caso soma os acertos e
atribui uma nota ao aluno.
6. Resultados
A fim de avaliar a ferramenta desenvolvida, foi selecionado um grupo de alunos e
professores que fizeram uso do sistema e, em seguida, responderam a um
miniquestionário ressaltando seus pontos positivos e negativos. Todos os alunos
entrevistados fazem parte da 6ª série do ciclo fundamental, de uma escola pública
municipal.
8
No intuito de comparar as visões do corpo docente e discente, foram criados, de
fato, dois questionários, um para cada grupo. O objetivo era investigar como cada grupo
via o sistema: pelo lado discente era importante investigar se a ferramenta era mais
atrativa e de simples uso; já pelo lado docente, era necessário investigar se ela poderia
ser utilizada como recurso pedagógico.
A aplicação da ferramenta junto ao corpo discente foi de grande valia, pois foi
possível avaliar através da mesma, a assimilação do conteúdo estudado durante a
unidade, de forma interativa e nova. Ficou constatado que tal ferramenta é de fato capaz
de dinamizar o processo avaliativo, deixando-o de ser monótono e cansativo tanto para
os alunos quanto para os professores. Este questionário foi realizado durante 1 semana.
Inicialmente, todos os alunos responderam uma prova tradicional. Em seguida, houve
um pequeno curso para explicar o uso do SEVAC para, só então, aplicar uma nova
prova por intermédio deste sistema.
Tabela 1: Resultado Parcial do Questionário Aplicado ao Corpo Discente
9
Tabela 2: Resultado Parcial do Questionário Aplicado ao Corpo Docente
Analisando os dados obtidos através do questionário aplicado ao corpo discente,
observou-se que a grande maioria dos alunos mostrou-se receptível ao sistema
desenvolvido. Foram questionados tanto os pontos fortes (interatividade, dinamismo e
praticidade) quanto os pontos fracos da ferramenta. O motivo de tal análise foi averiguar
principalmente o que falta ser adicionado à ferramenta para deixá-la mais completa. No
caso, os itens mais relatados foram: (i) manter um histórico das avaliações, (ii) projetar
uma interface com mais recursos visuais.
Ao analisar os dados encontrados na aplicação do questionário junto aos
professores, observou-se que a maioria dos docentes está disposta a utilizar o Sistema
Especialista como uma ferramenta de avaliação em suas aulas. Uma minoria mostrou
alguma reserva e resistência ao sistema e, conseqüentemente, às mudanças necessárias
quando se busca uma educação de qualidade.
7. Conclusão
Foi analisada através de questionários a carência de um sistema automatizado e digital,
sendo este capaz de tornar a avaliação do ensino elementar mais dinâmica. A partir das
análises feitas, foi proposta uma ferramenta capaz de suprir tal necessidade: a utilização
de um Sistema Especialista implantado com uma base de conhecimentos capaz de
avaliar os conteúdos estudados pelo usuário a partir de suas respostas.
Surge, então, a oportunidade de pensar na aplicação desse sistema como uma
forma avaliativa, compreendendo-o como um recurso didático de auxílio pedagógico.
Analisando se o conteúdo estudado foi assimilado de forma eficiente, o sistema
permitirá ao aluno tomar consciência do seu limite e das suas necessidades de avanço.
Considerando que a missão da escola é a auto-formação assistida, visando o pleno
desenvolvimento do educando, então a avaliação da aprendizagem, focalizada apenas
em conteúdos, não é suficiente. É necessário agregar à avaliação escolar, ao nível do
indivíduo, indicadores de avaliação, como este sistema especialista, que permite
acompanhar o domínio de competências e habilidades.
10
Saliente-se também que esta pesquisa foi enriquecida através das pesquisas de
campo e bibliográficas, entendendo melhor como funciona os Sistemas Especialistas e
aplicando-o como uma ferramenta de avaliação no âmbito escolar, trazendo-o como
instrumento construtivista na prática docente, podendo assim melhorar a qualidade do
ensino-aprendizagem entre professor e aluno.
O sistema especialista desenvolvido nesse trabalho é apenas um protótipo,
servindo como base para os trabalhos futuros, uma vez que se faz necessário um
aplicativo que disponibilize uma interface mais atrativa ao usuário, com figuras, help
on-line, que seja mais flexível e adequada à realidade dos alunos.
Referências
Andrade, P. F. and Lima, M. C. M. (1996). Programa nacional de informática educativa:
A utilização da informática na escola pública brasileira (1970-2004). Technical
report, MEC: Secretaria de Educacão à Distância.
Giarratano, J. C. and Riley, G. D. (1998). Expert Systems: Principles and Programming,
Third Edition. Course Technology, 3 edition.
Harmon, P., Maus, R., and Morrissey, W. (1988). Expert systems: tools and
applications. John Wiley & Sons, Inc., New York, NY, USA.
Haydt, R. (1997). Avaliacão do Processo Ensino Aprendizagem. São Paulo, SP, 6
edition.
Kraemer, M. E. P. (2005). A avaliação da aprendizagem como processo construtivo de
um novo fazer. http://www.gestiopolis.com/Canales4/rrhh/aprendizagem.htm.
LIA (2010). Expert synta: Manual do usuário. http://www.lia.ufc.br.
Mendes, R. D. (1997). Inteligência artificial: sistemas especialistas no gerenciamento da
informação. Ciência da Informação, 26.
Metaxiotis, K. S., Askounis, D., and Nikolopoulos, K. (2006). Identifying the
characteristics of successful expert systems: an empirical evaluation. IJITM, pages
21–36.
Nikolopoulos, C. (1997). Expert Systems: Introduction to First and Second Generation
and Hybrid Knowledge Based Systems. Marcel Dekker, Inc., New York, NY, USA,
1st edition.
Nilsson, N. J. (1998). Artificial Intelligence: A New Synthesis. Morgan Kaufmann
Publishers Inc., San Francisco, CA, USA, 1st edition.
Piaget, J. (1972). Desenvolvimento e aprendizagem.
Valente,
J.
A.
(2009).
Diferentes
usos
do
computador.
http://www.educacaopublica.rj.gob.br/biblioteca/educacao/edu2007.ghtm.
Wenger, E. (1987). Artificial intelligence and tutoring systems: computational and
cognitive approaches to the communication of knowledge. Morgan Kaufmann
Publishers Inc., San Francisco, CA, USA.
11
Test-Module: uma ferramenta para gerenciamento de testes
de software integrada ao FireScrum
Audrey B. Vasconcelos, Iuri Santos Souza, Ivonei F. da Silva, Keldjan Alves
Centro de Informática – Universidade Federal de Pernambuco, (CIn/UFPE) Código
Postal 7851 – RECIFE – PE – Brasil
{abv,iss2,ifs3,kao}@cin.ufpe.br
Abstract. The increasing demand for software development with higher quality
increases its competitiveness and turns critical the creation of a software
testing process in parallel with the development’s, including projects that
adopt agile methodologies. In this context, the use of tools that support the
management of testing activities is essential to project success. This paper
presents an open source tool integrated to the FireScrum – a tool for projects
management using Scrum - that allows the management of these activities.
Resumo. Com o aumento da competitividade e complexidade no âmbito
dodesenvolvimento de software, e a conseqüente exigência por produtos com
qualidade assegurada, torna-se imprescindível a realização do processo de
testes de software em paralelo ao processo de desenvolvimento, inclusive em
projetos que adotam metodologias ágeis. Neste contexto, o uso de ferramentas
de suporte à gestão das atividades de testes é essencial para o sucesso dos
projetos. Este trabalho apresenta uma ferramenta de código aberto integrada
ao FireScrum – ferramenta para gestão de projetos ágeis utilizando Scrum – a
qual permite gerenciar as principais atividades de testes.
1. Introdução
É notável a crescente necessidade do uso de produtos de software pelas organizações,
sendo muitas vezes essencial à sua sobrevivência. O crescimento da indústria de
desenvolvimento de software acarretou um aumento significativo na competitividade
entre as organizações provedoras desse serviço. Os usuários de software, consumidores
desse serviço, estão cada vez mais exigentes quanto aos atributos de qualidade do
software, tais como: desempenho, confiabilidade e usabilidade.
Uma técnica de verificação e validação para certificar artefatos de software,
como testes de software, é uma abordagem que contribui para o aumento da qualidade
ao longo do processo de desenvolvimento de software [Sommerville 2007]. Todavia,
testar software não é uma tarefa trivial, pois envolve pessoas, processos, ferramentas,
aplicações, releases (conjunto de artefatos), grupos de scripts (roteiros de testes), dentre
outros. Além disso, o uso de planilhas ou documentos de textos não é eficaz para uma
gestão de testes produtiva e com baixo custo.
Na literatura da engenharia de software, observa-se que um projeto típico de
desenvolvimento de software tem 30% a 50% do custo total do projeto referente aos
testes [Myers 1979], [Pressman 2006], [Sommerville 2007] e este número ainda pode
ser mais alto para sistemas críticos [Harrold 2000].
12
Dessa forma, para que o custo da atividade de testes não seja um fator limitador
para a sua aplicação, usar uma ferramenta adequada para auxiliar na execução dessas
atividades otimiza a produtividade.
Neste contexto, ferramentas para gestão de testes em um âmbito de
desenvolvimento ágil de software devem auxiliar os desenvolvedores nas tarefas de
planejamento e execução dos testes [Beizer 1990]. A partir da execução dos ciclos de
testes é possível extrair métricas sobre os casos de testes que obtiveram sucesso ou falha
em sua execução. Outras características desejáveis para essas ferramentas de gestão de
testes consistem no relacionamento entre casos de testes e requisitos, além do
mapeamento e monitoramento dos defeitos detectados.
2. Uma Ferramenta para Gerenciamento de Testes
Esta seção apresenta a ferramenta Test-Module, desenvolvida com o objetivo de auxiliar
a especificação e gestão das atividades de teste em projetos de desenvolvimento de
software que adotam metodologias ágeis, em particular Scrum, integrada à ferramenta
FireScrum [FireScrum 2010]. A Test-Module permite criar casos de testes, associá-los
aos requisitos, organizá-los em bibliotecas, gerenciar planos para as execuções de testes
em projeto de software e gerenciar ciclos de testes que serão executados, além de captar
resultados das execuções, coletar métricas, registrar e monitorar defeitos.
2.1. Visão Geral da Test Module
A Test-Module possui um fluxo lógico de execução. Primeiramente, é necessário criar a
biblioteca de casos de teste (Test Suite), que consiste em um agrupamento de casos de
testes relacionados. A Figura 1 apresenta a tela de cadastro de bibliotecas, na qual se
observa como exemplo a biblioteca “Test Suite Cadastro Evento”.
A Figura 2 apresenta a tela de cadastro de casos de teste (Test Cases), na qual se
observa o caso de teste “Test Case – Validar Campos Cadastro Eventos”. Durante o
cadastro de casos de testes, a ferramenta permite associá-los a requisitos do projeto
(Backlog Item), além de cadastrar o tipo de execução do teste (manual, automático,
semi-automático), a prioridade, o cenário e os passos para execução do teste.
Após criar um conjunto de casos de testes, cria-se o plano de testes para o
projeto. A Figura 3 apresenta a tela de cadastro de planos de testes (Test Plan), na qual
se observa um plano de testes “Test Plan – Validação Cadastros Sistema de Eventos”.
Durante o cadastro do plano de testes, o usuário seleciona os casos de testes,
além de inserir o objetivo, a estratégia, a agenda e outros dados importantes para um
planejamento de testes.
13
Figura 1: Cadastro de bibliotecas de casos de teste (Test Suites)
Figura 2: Cadastro de casos de teste (Test Cases)
Na última etapa desse fluxo de gerenciamento de testes, o usuário define o ciclo de
execução dos testes. A Figura 4 apresenta a tela para a criação de ciclo de testes (Test
Cycle) para o plano de testes selecionado. O fluxo lógico apresentado acima segue a
seqüencia de agrupamento, criação e planejamento de testes, podendo ser realizado em
outra ordem, a critério do usuário. Além desse, ainda há o fluxo de execução, coleta de
resultados e coleta de métricas, também contemplados na ferramenta.
14
Figura 3: Cadastro de planos de teste (Test Plans)
2.2. Arquitetura da Teste-Module
A arquitetura geral da ferramenta Test-Module compreende o uso de Adoble Flex
[Adobe Flex 2010] como camada de apresentação (front-end) e JAVA [Java 2010] com
BlazeDS [BlazeDS 2010] como camada de processamento (back-end). A Figura 5
apresenta uma visão simplificada, porém completa, da arquitetura utilizada. A camada
de visão foi desenvolvida através de uma interface RIA (Rich Internet Applications)
[RIA 2010]. A camada de negócios empregou o uso de JAVA com o uso de padrões de
projeto. O acesso aos dados é realizado através do framework Hibernate [Hibernate
2010], o qual fornece a característica de independência do banco de dados. A seguir, são
explanados mais detalhes sobre os elementos presentes na arquitetura.
15
Figura 4: Cadastro de ciclos de execução (Test Cycles)
Figura 5: Arquitetura geral da Test-Module no FireScrum
2.2.1 Camada de Apresentação
A camada de apresentação fornece ao usuário experiência de uso otimizado dos
componentes e menus do sistema construídos com o Adobe Flex – um framework multiplataforma para desenvolvimento de aplicações RIA. Assim, a aplicação cliente
processa algumas informações do sistema no terminal cliente e o processamento
complexo fica a cargo do servidor da aplicação no Back-end.
2.2.2 Camada de Processamento
Esta camada utiliza diversas tecnologias para prover todas as funcionalidades desejadas.
A linguagem JAVA foi utilizada como plataforma de desenvolvimento e controle dos
objetos necessários à Test-Module. O BlazeDS foi utilizado para conectar os dados do
back-end com o front-end em Adobe Flex, e a persistência dos dados foi realizada
através do framework Hibernate. Mais detalhes sobre a ferramenta Test-Module
encontra-se na página do FireScrum [FireScrum 2010].
16
3. Trabalhos Relacionados
Geralmente as ferramentas comerciais para gestão de teste de software limitam-se a
oferecer suporte para as principais atividades de teste de software, como criação e
gestão de planos, casos e roteiros de testes, além do registro dos resultados e elaboração
de relatórios [Beizer 1990]. Um exemplo é o software HP TestDirector, produzido e
comercializado pela Hewlett-Packard [HP 2010], que adicionalmente tem suporte a
gerenciamento de defeitos. Cobrindo todas as etapas de testes definidas pelo processo
unificado da Rational, há o software fabricado e comercializado pela IBM Rational: o
Rational TestManager [Rational 2010]. Oferecendo, além das principais atividades de
teste, suporte ao desenvolvimento distribuído com gestão ágil de projetos de software, a
Borland produziu e comercializa a SilkCentral Test Manager [Borland 2010].
Dentre as ferramentas de código aberto com licença GPL destaca-se a QaTraq
[Traq Software 2010a], desenvolvido pela Traq Software, que atualmente também
oferece versão comercial [Traq Software 2010b]. A QaTraq oferece suporte para as
principais atividades de testes de software, além de modelos de relatórios para
resultados de execuções de teste. Outra ferramenta popular de gestão das atividades de
testes de software é a TestLink [TestLink 2010], que foi desenvolvida colaborativamente
por uma comunidade composta por engenheiros de testes. Esta ferramenta oferece
recursos adicionais, tais como priorização e atribuição de tarefas e suporte para
integração com ferramentas de gerenciamento de defeitos.
A FireScrum Test-Module destaca-se, em relação a essas ferramentas, por
centralizar em uma única aplicação as seguintes características: possui código aberto;
está integrada a uma ferramenta de gestão ágil de processo de software; organiza os
casos de testes em bibliotecas autônomas, facilitando o reuso destes; gestão dos ciclos
execução; interface rica na camada de apresentação web; possui integração direta com
ferramenta de gerenciamento de defeitos; e ainda possibilita o monitoramento dos
passos que não alcançarem os resultados esperados durante a execução de um caso de
teste.
4. Conclusões e Trabalhos Futuros
Neste trabalho foi apresentada uma ferramenta que auxilia os desenvolvedores de
software, em contexto ágil, a fazer gestão de testes do projeto de software. A ferramenta
Test-Module permite aos usuários definir planos e bibliotecas de testes, casos de testes,
ciclos de execução e associá-los aos requisitos. Além disso, a ferramenta permite a
integração com ferramenta de gerenciamento de defeitos rastreando a execução ao
defeito identificado.
Para trabalhos futuros, a ferramenta deverá evoluir para atender a necessidade de
relatórios mais elaborados, ampliar a coleta de métricas e permitir a integração com
outras ferramentas de gerenciamento de defeitos consolidadas na comunidade, a
exemplo do Bugzilla [Bugzilla 2010] e do Mantis [Mantis 2010]. Por ser um ferramenta
de código aberto, e originalmente idealizada dentro do projeto FireScrum, a TestModule também terá uma evolução associada ao progresso das necessidades oriundas da
comunidade de software livre que estiver interessada em gestão ágil de projetos e gestão
de testes.
17
5. Referências
Adobe Flex. (2010). http://www.adobe.com/products/flex/, Maio.
Beizer, B. (1990). Software Testing Techniques, John Wiley & Sons, Inc., New York,
NY, USA.
BlazeDS. (2010). http://opensource.adobe.com/wiki/display/blazeds/BlazeDS/, Maio.
Borland. (2010). “SilkCentral Test Manager”, http://www.borland.com/us/products/silk/
silkcentral_test/index.html, Maio.
Bugzilla. (2010). http://www.bugzilla.org/, Maio.
FireScrum.
(2010).
“FireScrum
http://www.firescrum.com/, Maio.
...the
open
source
Scrum
Tool”,
GPL. (2010). http://www.gnu.org/licenses/gpl.html, Maio.
Harrold, M. J. (2000). "Testing: A Roadmap." Em International Conference on Software
Engineering.
Hibernate. (2010). http://www.hibernate.org/, Maio.
HP.
(2010).
“HP
Quality
Center”,
https://h10078.www1.hp.com/cda/hpms/display/main/hpms_content.jsp?zn=bto&cp
=1-11-127-24_4000_100__, Maio.
Java. (2010). http://www.java.com/en/download/faq/whatis_java.xml, Maio.
Mantis. (2010). http://www.mantisbt.org/, Maio.
Myers, G. J. (1979). Art of Software Testing, John Wiley & Sons, Inc.
Pressman, R. S. (2006). Engenharia de Software, McGraw Hill, 6ª Edição.
Rational.
(2010).
“Rational
TestManager”,
01.ibm.com/software/awdtools/test/manager/, Maio.
http://www-
RIA. (2010). http://en.wikipedia.org/wiki/Rich_Internet_application, Maio.
Sommerville, I. (2007). Engenharia de Software, Addison Wesley, 8ª Edição.
TestLink. (2010). http://testlink.sourceforge.net/docs/testLink.php, Maio.
Traq
Software.
(2010a).
“QaTraq
http://sourceforge.net/projects/qatraq/, Maio.
-
Open
Source”,
Traq Software. (2010b). “QaTraq Software”, http://www.testmanagement.com/, Maio.
18
LSVF: A heuristic search to reduce the backtracking calls
when solving Constraint Satisfaction Problems
Cleyton Rodrigues1, Eric Galvão1, Ryan Azevedo1
¹ Centro de Informática, Universidade Federal de Pernambuco, Av. Professor Luís
Freire 50740-540, Recife, Pernambuco, Brasil
{cmor, ergd, rra2}@cin.ufpe.br
Abstract. Along the years, many researches in the Artificial Intelligence (AI)
field seek for new algorithms to reduce the amount of memory and time
consumed for general searches in the family of constraint satisfaction
problems. Normally, these improvements are reached with the use of some
heuristics which either prune useless tree search branches or even “indicate”
the path to reach the solution (many times, the optimal solution) more easily.
Many heuristics were proposed in the literature, like Static/ Dynamic Highest
Degree heuristic (SHD/DHD), Most Constraint Variable (MCV), Least
Constraining Value (LCV), and while some can be used at the pre-processing
time, others just at running time. In this paper we propose a new preprocessing search heuristic to reduce the amount of backtracking calls,
namely the Least Suggested Value First (LSVF). LSVF emerges as a practical
solution whenever the LCV can not distinguish how much a value is
constrained. We present a pedagogical example to introduce the heuristics,
realized through the general Constraint Logic Programming CHRv, as well as
the preliminary results.
Keywords: Constraint, Satisfaction Problem, Heuristics, Constraint Logic
Programming.
1 Introduction
Constraint Satisfaction Problems (CSP) remains as one of the most prominent AI
research fields. Having a wide range of applicability, such as planning, resource
allocation, traffic air routing, scheduling [Brailsford, Potts and Smith 1999], CSP has
been largely used either for toys or even for real large complex applications.
Furthermore, in general, CSP are NPcomplete and they are combinatorial in nature.
Amongst the various methods developed to handle this sort of problems, in this
paper, our focus concerns the search tree approach coupled with the backtracking
operation. In particular, we address some of the several heuristics used so far to reduce
(without guaranties) the amount of time need to find an solution, namely: Static/
Dynamic Highest Degree heuristic (SHD/DHD), Most Constraint Variable (MCV) and
Least Constraining Value (LCV) [Russel and Norvig 2003].
Some problems, however, like the ones common referred as instances of the
Four Color Map Theorem [Robertson et al 1997], present the same domain for each
entity, making the LCV heuristic impossible to decide the best value to the asserted
first.
19
For these cases, we propose a new pre-processing heuristic, namely Least
Constraint Value First (LCVF), which can bring significant gains by a simple domain
value sorting, respecting an order made by the following question “Which is the least
used value to be suggested now?”. Additionally, we enumerate some assumptions to
improve the ordering. Along the paper, we show some preliminary results with
remarkable reduce of backtracking calls.
This paper is organized as follows: Section 2 explains briefly the formal
definition of CSP and the most common heuristics used in the class of CSP; following,
Section 3 details what is CHRv and why we have chosen it to our examples; Section 4
introduces the LCVF heuristic with a pedagogical example, highlighting some
preliminary results, and finally, Section 5 presents the final remakes and the future
works.
2 CSP and Heuristics
Roughly speaking, CSP are problems defined by a set of variables X = {X 1, X2,…, Xn},
where each one (Xi) ranges in a known domain (D), and a set of Constraints C = {C1,
C2,…, Cn} which restricts specifically one or a group of variables with the values they
can assume. A consistent complete solution corresponds to a full variable valuation,
which is further in accordance with the constraints imposed. Along the paper, we refer
to the variables as entities. Figure 1 depicts a pedagogical problem.
Figure 1 - A pedagogical Constraint Satisfaction Problem.
In the above figure, the entities are {X1, X2, X3, X4, X5, X6, X7} and each one can assume
one of the following value: D = {r,g,b}, referring to the colors, red, green, and blue,
respectively. The only constraint imposed restricts the neighboring places (that is, each
pair of nodes linked by an arc) to have different colors. As usual, this problem can be
reformulated into a search tree problem, where the branches represent all the possible
paths to a consistent solution. By definition, each branch not in accordance with C, must
be pruned. The backtracking algorithm, a special case of depth-first, is neither complete
nor optimal, in case of infinite branches [Vilain, Kautz and Beek 1989]. As we have not
established an optimal solution to the problem, our worries rely only upon the
completeness of the algorithm. However, we only take into account problems in which
search does not lead to infinite branches, and thus, the completeness of the problem is
ensured.
20
2.2 Search Heuristics
Basically, the backtracking search is used for this sort of problems. Roughly, in a depthfirst manner, a value from the domain is assigned, and whenever na inconsistency is
detected, the algorithm backtracks to choose another color (another resource). Although
simple in conception, the search results are far to be satisfactory. Further, this algorithm
lacks for not being intelligent, in the sense to re-compute partial valuations already
prove to be consistent. A blind search, like the backtracking, is improved in efficiency
employing some heuristics. Regarding CSP, general heuristics (that is, problemindependent, opposite to domain-specific heuristics, as the ones in A* search [Dechter
and Pearl 1985]) methods speed up the search while removing some sources of random
choice, as:

Which next unassigned variable should be taken?

Which next value should be assigned?
The answer for the questions above arises by a variable and value ordering. The
most famous heuristics are highlighted below. Note that the two first methods concern
the variable choice, and the later refers to the value ordering:

Most Constrained Variable avoids useless computations when an assignment
will eventually lead the search to an inconsistent valuation. The idea is to try
first the variables more prone to error;

When the later method is useless, the Degree Heuristic serves as a tie-breaker,
once it calculates the degree (number of conflicts) of each entity;

The Least Constraining-Value, in turn, sorts decreasingly the values in a domain
respecting how much the value conflicts with the related entities (that is, the
values less shared are tried first).
As said before, we have restricted our scope of research to the class of problems
similar to the family of the four color theorem, where the domain is the same for each
variable. In this sense, the LCV heuristic is pointless since the “level” of constraining
for each value is the same. This drawback force us to search alternatives for sort the
values of CSP in similar situations, but also improving the efficiency. However, before
to present the solution, it is worth to explain why we have used the logic constraint
programming CHRv to carry out the tests.
3 CHRV
Constraint Handling Rules with Disjunction (CHRV) [Abdennadher and Schütz 1985] is
a general concurrent logic programming language, rule-based, which have been adapted
to a wide set of applications as: constraint satisfaction [Wolf 2005], abduction
[Gavanelli, Alberti and Lamma 1985], component-development engineering [Fages,
Rodrigues and Martinez 2008], and son on. It is designed for creation of constraint
solvers.
CHRV is a fully accepted logic programming language, since it subsumes the
main types of reasoning systems [Frühwirth 2008]: the production system, the term
rewriting system, besides Prolog rules. Additionally, the language is syntactically and
semantically well-defined [Abdennadher and Schütz 1985].
21
Concerning the syntax, a CHRv program is a set of rules defined as:
rule_name@ 𝐻𝑘 ⁄ 𝐻𝑟 ⇔ G | B
Rule_name is the non-compulsory name of the rule. The head is defined by the
predicates represented by Hk and Hr, with which an engine tries to match with the
constraints in the store. Further, G stands for the set of guard predicates, that is, a
condition imposed to be verified to fire any rule. Finally, B is the disjunctive body,
corresponding to a set of constraints added within the store, whenever the rule fires. The
logical conjunction and disjunction of predicates are syntactically expressed by the
symbols ‘,’ and ‘;’, respectively. Logically, the interpretation of the rule is as follows:
∀𝑉𝐺𝐻 ( 𝐺 → ((𝐻𝑘 ∧ 𝐻𝑟) ↔ (∃𝑉𝐵⁄𝐺𝐻 𝐵 ∧ 𝐻𝑘))) , 𝑤ℎ𝑒𝑟𝑒 𝑉𝐺𝐻 =
𝑣𝑎𝑟𝑠(𝐺) ∪ 𝑣𝑎𝑟𝑠(𝐻𝑘) ∪ 𝑣𝑎𝑟𝑠(𝐻𝑟), 𝑉𝐵⁄𝐺𝐻 = 𝑣𝑎𝑟𝑠(𝐵)⁄𝑉𝐺𝐻
(1)
For the sake of space, we ask the reader to check the bibliography for further
reference to the declarative semantics.
The problem depicted in figure 1 is represented by the logical conjunction of the
following rules:
𝑓@ 𝑓𝑎𝑐𝑡𝑠 ==> 𝑚, 𝑑(𝑥1, 𝐶1), 𝑑(𝑥7, 𝐶7), 𝑑(𝑥4, 𝐶4), 𝑑(𝑥3, 𝐶3),
𝑑(𝑥2, 𝐶2), 𝑑(𝑥5, 𝐶5), 𝑑(𝑥6, 𝐶6)
𝑑1@ 𝑑(𝑥1, 𝐶) ==> 𝐶 = 𝑟𝑒𝑑; 𝐶 = 𝑔𝑟𝑒𝑒𝑛; 𝐶 = 𝑏𝑙𝑢𝑒.
𝑑7@ 𝑑(𝑥7, 𝐶) ==> 𝐶 = 𝑟𝑒𝑑; 𝐶 = 𝑔𝑟𝑒𝑒𝑛; 𝐶 = 𝑏𝑙𝑢𝑒.
𝑑4@ 𝑑(𝑥4, 𝐶) ==> 𝐶 = 𝑟𝑒𝑑; 𝐶 = 𝑔𝑟𝑒𝑒𝑛; 𝐶 = 𝑏𝑙𝑢𝑒.
𝑑3@ 𝑑(𝑥3, 𝐶) ==> 𝐶 = 𝑟𝑒𝑑; 𝐶 = 𝑔𝑟𝑒𝑒𝑛; 𝐶 = 𝑏𝑙𝑢𝑒.
𝑑2@ 𝑑(𝑥2, 𝐶) ==> 𝐶 = 𝑟𝑒𝑑; 𝐶 = 𝑔𝑟𝑒𝑒𝑛; 𝐶 = 𝑏𝑙𝑢𝑒.
𝑑5@ 𝑑(𝑥5, 𝐶) ==> 𝐶 = 𝑟𝑒𝑑; 𝐶 = 𝑔𝑟𝑒𝑒𝑛; 𝐶 = 𝑏𝑙𝑢𝑒.
𝑑6@ 𝑑(𝑥6, 𝐶) ==> 𝐶 = 𝑟𝑒𝑑; 𝐶 = 𝑔𝑟𝑒𝑒𝑛; 𝐶 = 𝑏𝑙𝑢𝑒.
𝑚@ 𝑚 ≤> 𝑛(𝑥1, 𝑥2), 𝑛, 𝑛(𝑥1, 𝑥4), 𝑛(𝑥1, 𝑥7),
𝑛(𝑥2, 𝑥6),
𝑛(𝑥3, 𝑥7), 𝑛(𝑥4, 𝑥7), 𝑛(𝑥4, 𝑥5), 𝑛(𝑥5, 𝑥7), 𝑛(𝑥5, 𝑥6).
𝑛1@ 𝑛(𝑅𝑖, 𝑅𝑗), 𝑑(𝑅𝑖, 𝐶𝑖), 𝑑(𝑅𝑗, 𝐶𝐽) <=> 𝐶𝑖 = 𝐶𝑗 | 𝑓𝑎𝑖𝑙
The first rule ‘f’ introduces the constraints into the store, which is a set of
predicates with functor d and two arguments: the entity and a variable to store the
valuation of the entity. The seven following rules relate the entity with the respective
domain. Additionally, rule ‘m’ adds all the conceptual constraints, in the following
sense: n(Ri,Rj) means there is an arc linking Ri to Rj, thus, both entities could not share
the same color. Finally, the last rule is a sort of integrity constraint. It fires/ whenever
the constraints imposed is violated. Logically, it says that if two linked entities n(Ri,Rj)
shares the same color (condition ensured by the guard), then the engine needs to
backtrack to a new (consistent) valuation.
In the literature, many operational semantics was proposed, as [Abdennadher,
Frühwirth and Meuss 1999]. However, the ones most used in CHRv implementations are
based on the refined semantics [Duck at al 2004] (as the SWI-Prolog version 5.6.52
[SWI-Prolog 2010] used in the examples carried out along this paper). According the
refined operational semantics, when more than one rule is possible to fire, it takes into
22
account the order in which the rules were written in a program. Hence, as SHD heuristic
orders the entities to be valued in accordance with the level of constraining, this preanalysis help us to write the rules based on this sort. Thus, we could concentrate our
effort on the order of the values in the domain.
4 Least Suggested Value First – LSVF
The last section has introduces the rule-based constraint language, CHRv. Many aspects
of the operational semantics were left unexplained, and we encourage the reader to
check the references for additional information. However, some points need be
discussed to clarify the technique developed to improve the search, decreasing the
amount of backtracking calls. The first point, “which rule will trigger”, was discussed
before. The second important subject of discussion is the order of which the values are
taken from the domain in the search. We have already said that the logical disjunction is
denoted in the body of a CHRV rule, syntactically expressed by ‘;’. In order to maintain
consistency with the declarative semantics, CHRV engine tries all the alternatives since
the user tell the engine to do so. A disjunctive body is always evaluated from left-toright.
𝑑1@ 𝑑(𝑥1, 𝐶) ==> 𝐶 = 𝑟𝑒𝑑; 𝐶 = 𝑔𝑟𝑒𝑒𝑛; 𝐶 = 𝑏𝑙𝑢𝑒
Taking a rule from the example (as stated above), the engine tries the following
order of valuation for X1: (1) red, (2) green and, (3) blue. All the rules were created
respecting the same valuation order.
At first glance, we can note a relevant problem: if all the entities try first the
same color, and we know that these entities are related, a second evaluated entity always
needs to backtrack. Furthermore, since the entities shares the same domain, LCV is
pointless: each value has the same level of constraining. In order to make our idea clear,
we introduce a second example.
Figure 2 - An example regarding the order of the colors.
The Figure 2 shows the motivation problem for the new heuristics discussed. There are
3 entities {X1,X3,X7}, each one sharing the same domain. Let us respect the order of
valuation from left to right, and the order of variable chosen based on the numerical
order. Thus, the engine works as follows:
I.
X1 is chosen, and the color red is taken;
II.
X3 is chosen, and the color red is taken;
III.
Inconsistency found: backtracking;
23
IV.
X3 is chosen, and the color blue is taken;
V.
X7 is chosen, and the color red is taken;
VI.
Inconsistency found: backtracking;
VII.
X7 is chosen, and the color blue is taken;
VIII. Inconsistency found: backtracking;
IX.
X7 is chosen, and the green is taken.
Following, in the figure 3, the values order is changed to avoid, as much as possible,
the conflicts.
Figure 3 - The same example with domain reordered.
The engine now works as stated below:
I. X1 is chosen, and the color red is taken;
II. X3 is chosen, and the color blue is taken;
III. X7 is chosen, and the color green is taken.
The above modification prevented the backtracking calls, and the solution was
reached just with three steps, unlike the last example, which did the same, in 9 steps.
Evidently, in practice, we can not avoid all backtracking calls, but each reduction is
well-suited for the overall search time-consumption.
4.1 How the heuristic works?
Our propose is to enjoy the operational semantics addressed by the CHRV
implementation to sort the order in which the values from the domain is asserted,
decreasing the amount of backtracking calls. We believe this reduction can be well
appreciated in large and complex problems, where the time is a relevant factor.
The approach does not yield only the first color, but the entire domain. In our
case, the focus is in problems with three or four colors. In this context, the members of
the set of entities are categorized in accordance with the level of corresponding
restriction:

Soft Entities, that is, less constrained;

Middle Entities, that is, half constrained;

Hard Entities, that is, more constrained.
24
Hence, instead of proposing a solution of random sorting, we have taken the
following assumptions:

Usually, the entities less constrained are likely linked to others more
constrained, and, further, the entities less restricted are not connected to each
other (if this were the case, the entities owned other restrictions than those that
connect them, and they would be deemed more constrained). Thus, the domain
of these entities are sorted in the same manner;

Normally, hard entities are linked to middle ones, and thus the order of valuation
must be in conformance to this fact, example, if a hard entities domain is ordered
like (1)red, (2)green, (3)blue, the middle should be sorted like (1)blue, (2) green
(3)red, that is, the less suggested value first.

The first value assumed by the hard entities should be the last for the soft and
middle entities, since potentially both are linked to the former (this is why they
were classified as hard).
In order to exemplify this approach, we are going to show the reformulation of the
example used along this paper, illustrating gradually the gains obtained.
With respect the problem, we divided the set of entities as follows: (i) soft entities:
{X2,X3,X6}, (ii) middle entities: {X4,X5}, and (iii) hard entities {X1,X7}, with 6, 9 and 12
conflicts, respectively. What was considered for division was precisely the amount of
conflict in relation to other variables, done according the Static Highest Degree (SHD)
heuristic.
Table 1 summarizes the amount of inferences made and the number of backtracking
calls. The time is a relevant aspect only when evaluated to large problems.
Table 1 - First Results with the LSVF Heuristic
Sorting Level
Inferences
Backtracking Calls
I
4,897
8
II
4,694
7
III
4,415
6
IV
4,208
5
Not accidentally, the table was populated according to the level of values sorted
in respect to the assumptions raised earlier. Each level corresponds to a different CHRV
program. The Sorting Levels are the following:
Table 2 - Domain used for Entities
Level
Soft
Midle
Hard
I
red, green blue
red, green blue
red, green blue
II
red, green blue
blue, red, green
red, green blue
III
green, red blue
blue, red, green
red, green blue
IV
green, blue, red
blue, green, red
red, green blue
In the Level I, the heuristic was not used. It is worth to keep their results in the
table to compare with the other levels, where the assumptions (which define the LSVF)
25
were gradually applied. Level II has changed the first suggested color of the Middle
entities with respect the hard. Following, the level III has changed the first color of
domain of soft entities with respect the others (middle and hard). There has been a
reduction of 25% of backtrack calls in accordance with the level I. Finally, the level IV
has used all assumptions talked, and both measures were visibly reduced. In this latter
case, the engine backtracks 5 times, three calls less than the original program. Note that
level IV obeys all the assumptions discussed, and the results obtained were remarkable.
5 Final Remakes and Future Work
The preliminary results obtained were very satisfactory. We might see that, as we
organize the values of the domain of the entities, gradually the search has been getting
more efficient with respect to the number of inferences necessary to reach a solution. A
small comparison between the level I and level IV, the program without the heuristic
and the program totally in accordance with LSVF, respectively, shows a significant
reduction in the amount of backtrackings and inferences realized.
It was important to mention that we are neither worried with optimal solutions
nor with all the solutions for the problem. We only focus on our overall effort to reach a
solution, and nothing else.
In order to validate completely the LSVF heuristics, our next step is to analyze
the approach with more complex problems. Additionally, our aim is to check the time
resource allocated for this kind of problem, since this was not possible due to the size of
the example discussed (all instances executed in less than one second).
Acknowledgments. We acknowledge REUNI for financial support and the Center of
Informatics of Federal University of Pernambuco – CIn/UFPE – Brazil for support in
this research.
References
Brailsford, S., Potts, C., Smith, B. (1999) Constraint satisfaction problems: Algorithms
and applications. European J. Operat. Res. 119, 557—581.
Russel, S., Norvig, P. (2003) Artificial Intelligence: A Modern Approach. New Jersey:
Prentice-Hall, 2nd edition, 143—144.
Robertson, N., Sanders, D. P., Seymour, P. D., Thomas, R. (1997) The four colour
theorem, J. Combin. Theory Ser. B., 2--44
Vilain, M., Kautz, H., Beek, P. (1989) Constraint propagation algorithms for temporal
reasoning: A revised report. In D. S. Weld and J. de Kleer, editors, Readings in
Qualitative Reasoning about Physical Systems, 373--381.
Dechter, R., Pearl, J. (1985) Generalized best-first search strategies and the optimality
of A*. J. ACM 32, 505—536.
Abdennadher, S., Schütz, H. (1985) CHRv: A Flexible Query Language, In Proceedings
of the Third International Conference on Flexible Query Answering Systems, pp.1-14, May 13-15.
26
Wolf, A. (2005) Intelligent search strategies based on adaptive Constraint Handling
Rules. Theory Pract. Log. Program. 5, 4-5 (Jul. 2005), 567—594.
Gavanelli, M., Alberti, M., Lamma, E. (1985) Integrating Abduction and Constraint
Optimization in Constraint Handling Rules. In Proceeding of the 2008 Conference on
ECAI 2008: 18th European Conference on Artificial intelligence. M. Ghallab, C. D.
Spyropoulos, N. Fakotakis, and N. Avouris, Eds. Frontiers in Artificial Intelligence
and Applications, vol.178. IOS Press, Amsterdam, The Netherlands, 903—904.
Fages, F., Rodrigues, C. M. O., Martinez, T. (2008). Modular CHR with ask and tell. In
T. Schrijvers, F. Raiser, and T. Frühwirth, editors, CHR '08: Proc. 5th Workshop on
Constraint Handling Rules, Hagenberg, Austria, 95--110, 2008. RISC Report Series
08-10, University of Linz, Austria.
Frühwirth, T. (2008) Welcome to Constraint Handling Rules. In Constraint Handling
Rules: Current Research Topics, T. Schrijvers and T. Frühwirth, Eds. Lecture Notes
In Artificial Intelligence, vol. 5388. Springer-Verlag, Berlin, Heidelberg, 1—15.
Abdennadher, S., Frühwirth, T., Meuss, H. (1999) Confluence and Semantics of
Constraint Simplification Rules.Constraints 4, 2 (May. 1999), 133-165.
Duck, G. J., Stuckey, P. J., De la Banda, M. G., Holzbaur, C. (2004) The Refined
Operational Semantics of Constraint Handling Rules. In Proceedings of the 20th
International Conference on Logic Programming, B. Demoen and V. Lifschitz, Eds.,
90-104.
SWI-Prolog
(2010)
Reference
Manual.
Avaliable
in
http://
gollem.science.uva.nl/SWIProlog/Manual/ Contents.html. Last access in 15th March
2010.
27
O Lixo eletrônico no Brasil: Leis e Impactos Ambientais
Rodrigo Diego Gonçalves Ferreira1, Cleyton Mário de Oliveira Rodrigues2
1
2
FACOL – Faculdade Osman da Costa Lins, Vitória de Santo Antão – PE – Brasil
Centro de Informática – Universidade Federal de Pernambuco, (CIn/UFPE) Código
Postal 7851 – RECIFE – PE – Brasil
[email protected], [email protected]
Resumo: Uma preocupação mundial e com forte impacto social, econômico e,
principalmente, ecológico é o desenvolvimento sustentável. Muito se fala sobre
degradação do meio ambiente, contudo, pouco se faz para conter esse
problema que ameaça as futuras gerações do planeta. Este artigo informativo
denota, neste âmbito, uma visibilidade aos fatores que levaram o Brasil a ser
criticado por instituições não-governamentais de diversos lugares do mundo
por não ter uma legislação vigente sobre os aspectos do lixo eletrônico, bem
como a falta de regulamentação de práticas sustentáveis de recolhimento das
sucatas eletroeletrônicas pelos seus respectivos fabricantes. Também são
motivos de debate e questionamento as metas do poder executivo e legislativo
do país, com respeito às ações dos fabricantes de eletroeletrônicos.
1. Introdução
Com o grande avanço das tecnologias e das suas inovações em meio ao consumismo na
busca da comodidade e do conforto, a população sente a necessidade de sempre estar
atenta às novas tendências do mercado, ou seja, equipamentos mais modernos e
poderosos, com novas funções e serviços integrados. Com o aumento do poder de
compra do consumidor brasileiro, tornou-se comum a constante troca de seus
equipamentos tecnológicos, como: celulares, computadores, notebooks, TVs, geladeiras,
entre outros. Neste contexto, observa-se que a velocidade com que os consumidores
passam a procurar por novos produtos, é bem superior ao que acontecia há tempos atrás
[Planeta Sustentável 2008].
O ciclo de vida destes produtos é curto, aumentando conseqüentemente, o
descarte irregular de materiais eletrônicos no meio-ambiente. A poluição ambiental,
gerada pela poluição eletrônica através de seus metais pesados, ocasiona danos não só
ao meio ambiente, mas também à saúde humana. Grande parte desse lixo tóxico
proveniente das sucatas eletrônicas é jogado em terrenos baldios, queimado a céu aberto
ou recolhido pela coleta de lixo fornecida pelos governos municipais, mas sem que
exista nenhum tipo de seleção ou tratamento destes materiais tóxicos.
Instituições mundiais voltadas à preservação do meio ambiente apontaram, nos
últimos meses, o Brasil como um dos maiores produtores de lixo eletrônico entre os
países emergentes: Brasil, México, Índia e China. O país foi apontado por abandonar
aproximadamente 96,8 mil toneladas de componentes utilizados em computadores e
mais de 35 milhões de toneladas de sucatas eletrônicas por ano, uma produção de lixo
maior que a média dos outros países [Ecodebate 2010]. Mesmo com a grande produção
de lixo eletrônico, não houve nenhuma mudança legislativa com a formulação de
normas nacionais, impossibilitando uma fiscalização adequada de combate ao
desperdício irracional de eletroeletrônicos.
28
Este artigo toma o aspecto técnico-ambiental, objetivando a conscientização dos
consumidores e mostrando o posicionamento político, legislativo, de Organizações Não
Governamentais (ONGs) e de fabricantes que atuam no mercado Brasileiro.
2. Brasil: atual situação e legislação
É chamado de lixo eletrônico, também conhecido como e-lixo ou sucata eletrônica, todo
material que é descartado e compõe os eletroeletrônicos, como resíduos sólidos,
componentes tóxicos e metais pesados. O Greenpeace [GREENPEACE] e a
Organização das Nações Unidas (ONU) [ONU] consideram o Brasil como o país
emergente que gera maior volume de lixo eletrônico, além de maior produtor de e-lixo
per capita por ano. Também, o país tem o maior número de toneladas de geladeiras
abandonadas a cada ano por pessoa, e é um dos líderes em descartar celulares, TVs e
impressoras, entre os países emergentes. Na composição de um computador, por
exemplo, são utilizados diversos produtos considerados tóxicos ao ser humano, como:
sílica, plástico, ferro, alumínio, cobre e chumbo. A tabela 1 relaciona alguns destes
metais com os problemas que podem causar à saúde das pessoas.
Tabela 1 - Danos causados por metais pesados
METAL PESADO
DANOS À SAÚDE
Chumbo
Atinge o sistema nervoso, a medula óssea e os rins, gerando
lesão renal e cerebral e fraqueza muscular.
Mercúrio
Concentra-se em diversas partes do corpo como pele, cabelo,
glândulas sudoríparas e salivares, tireóide, sistema digestivo,
pulmões, pâncreas, fígado, rins, aparelho reprodutivo e
cérebro, provocando inúmeros problemas de saúde.
(Intoxicação do sistema nervoso central).
Manganês
Causa problemas respiratórios e efeitos neurotóxicos.
Sílica
Causa problemas respiratorios, provocando o endurecimento
dos pulmões, podendo assim ser fatal.
Alumínio
A ingestão pode causar: demência, danos ao sistema nervoso
central, perda de memória e dores musculares.
Com as políticas de incentivo e marketing pela compra de computadores por
todos os segmentos da sociedade, o computador está cada vez mais barato e conseguir
um destino ecológico e socialmente correto para a máquina antiga torna-se complicado.
Seu destino acaba sendo, dessa forma, o lixo comum. As autoridades brasileiras devem
criar e fazer valer o cumprimento das leis e regimentos estaduais de combate a
degradação da natureza causada pelo e-lixo. Cabe também aos órgãos ligados ao meio
ambiente a fiscalização e autuação aos fabricantes que descumprirem o normativo
nacional. Existe em tramitação, a Política Nacional de Resíduos Sólidos (PNRS) [PNRS
2010]. Aprovado depois de 19 anos pala Câmara dos Deputados, o projeto ainda passará
pelo senado e, por último, pelo executivo. Os eletroeletrônicos estão inseridos no artigo
33 do plano, sendo divididos em três categorias: eletrodomésticos, bens de informática e
eletrônicos em geral.
29
Constam no PNRS penalidades previstas na Lei 13576, que trata de crimes
ambientais. As leis que atualmente regem as ações no Plano Nacional Ambiental
Brasileiro não são específicas aos resíduos eletrônicos, e sim, aos resíduos sólidos de
forma geral. Alguns estados, como Minas Gerais, Paraná, Rio de Janeiro, Piauí, Espírito
Santo e Pernambuco contam com uma legislação direcionada apenas aos resíduos
sólidos (de uma forma geral), incluindo a poluição por metais pesados, entretanto, não
existe citação sobre o recolhimento de produtos eletrônicos pelos respectivos
fabricantes, exceto quando há punições.
No estado de São Paulo existe a lei 13.576/09, da autoria do Deputado Estadual
Paulo Alexandre Barbosa (PSDB), a qual instituiu que os fabricantes de eletrônicos são
responsáveis pela reciclagem, gerenciamento e destino final do lixo tecnológico. Essa é
a única lei específica sobre elixo. O Brasil ainda é, de uma forma geral, carente de um
normativo relacionado à poluição eletrônica. A lei 3.968 de 31 de agosto de 1981, que
estabelece a PNMA [PNMA], seus fins e mecanismos de formulação e aplicação,
constituiu o Sistema Nacional do Meio Ambiente (SISNAMA) [SISNAMA] e instituiu
o Cadastro de Defesa Ambiental. A PNMA tem como principais objetivos a melhoria e
preservação da qualidade ambiental, defendendo o desenvolvimento socioeconômico do
país, bem como a segurança e a vida humana.
Como abordado ao longo do artigo, o Brasil tem um normativo regido por
órgãos estaduais e nacionais de preservação do meio ambiente, baseado numa legislação
interna a cada departamento ambiental. Nestes últimos anos, existe uma preocupação
parlamentar nacional para formulação de um plano de reciclagem e reaproveitamento de
resíduos eletroeletrônicos, onde torna o fabrincante responsável pelo recolhimento dos
produtos gerados em suas unidades fabris, incluídos nas leis de resíduos sólidos.
3. Legislação internacional do e-lixo
A União Européia (UE) possui a diretiva ROSH [Lei Lixo Eletrônico] que restringe em
seis substâncias tóxicas a produção de eletroeletrônicos, onde responsabiliza também os
produtores pela redução destas substâncias: chumbo, mercúrio, cádmio, crómio
hexavalente, polibromatos (PBB e PBDE). Esta legislação foi implantada e adaptada
pela China em 2006, três anos após a implantação da UE. A Eletronic Equipament
Collection dos Estados Unidos (EUA) impõe as responsabilidades da reciclagem e
reaproveitamento ao fabricante. A legislação foi criada em 2008 e estima que até 2015
aproximadamente 25% de todo lixo eletrônico produzido pelo país será reaproveitado,
além de deixar claro que os fabricantes devem submeter um plano de tratamento às
prefeituras, tornando-se proibido descatar lixo eletrônico junto ao lixo comum, isto é,
deve-se destiná-los a aterros sanitários.
No Canadá e nos EUA, além da obrigação do recolhimento de produtos ser dos
fabricantes, a legislação ajudou a definir as reponsabilidades do consumidor (exemplo,
mandar o produto para reciclagem), do fabricante (criação da rede coletora) e do estado
(mantenedora da reciclagem e dos recursos utilizados). No Japão, o governo é o
responsável pelo processo de coleta e logística reversa, os fabricantes são responsáveis
pela reciclagem e neutralização adequada dos componentes tóxicos (a legislação Home
Appliance Recycling Law). Com base nessa legislação, muitas empresas se adaptaram as
regras estabelecidas internacionalmente, mas outras não.
30
4. Como as grandes empresas comportam-se hoje em dia?
A maioria dos fabricantes de eletroeletrônicos, eletrodomésticos e empresas de
tecnologia não anexam nos seus produtos informações suficientes sobre o recolhimento
dos equipamentos descartados, como: Apple, CCE, Le novo, LG, Positivo e Samsung.
Mais grave ainda, empresas como Acer, Dell, Philips, Siemens, TIM e Semp Toshiba
não dispõem de nenhuma informação sobre a devolução de seus produtos.
As seis primeiras empresas citadas, nos dias de hoje, procuram realizar ações
sustentáveis na fabricação de seus produtos, como exemplo, os equipamentos levam em
sua composição matériasprimas recicladas, como o plástico. Além disso, em seus
componentes, os metais pesados são utilizados em quantidades menores, assim as
fabricantes integram um rank no programa do Guia de Eletrônicos Verdes do
Greenpeace [Baixaki 2010].
As grandes empresas mundiais estão seguindo um padrão de reutilização e
mudança de matéria-prima na fabricação de produtos eletroeletrônicos integrando assim
a corrente da TI VERDE (Tecnologia da Informação Verde). Empresas como Samsung,
Toshiba, Nokia, Sony, Lenovo e Dell estudam políticas internas de reciclagem com a
participação e adesão de ações sugeridas pelas instituições voltadas à defesa e à
preservação do meio ambiente, como o Greenpeace. A instituição mostra para o mundo
um rank de empresas que realizam atividades em favor do meio ambiente, o chamado
Guia de Eletrônicos Verdes. O guia é publicado trimestralmente, como forma de fazer
com que a indústria de eletrônicos encare o problema do lixo que produz. A intenção é
fazer que os fabricantes parem de usar produtos tóxicos em seus produtos.
5. Reciclagem: Um caminho aberto a novas oportunidades
O setor de reciclagem de Resíduos de Aparelhos Elétricos e Eletrônicos, ou
simplesmente RAEE, é um nicho do mercado cheio de potencial e que já começou a ser
trabalhado. O ramo ganha espaço à medida que aumenta o consumo de eletroeletrônicos
em geral. Desmontar, triturar e transformar diversos equipamentos é o que as empresas
de remanufatura fazem, e ao mesmo tempo evitam a contaminação do ambiente por
materiais tóxicos. Com o crescimento do mercado brasileiro, existem empresas que
encontraram a partir das sucatas uma oportunidade de oferecer reciclagem para grandes
fabricantes. Uma delas é a Oxil (lixo ao contrário), de Paulínia no Estado de São Paulo
[OXIL].
A companhia tem nove grandes clientes, dos quais não revela os nomes por
motivos contratuais, e processa 2 mil toneladas de produtos por ano. A empresa
conseguiu reciclar 99,7% do material enviado. O ato de transformar equipamentos fora
de uso em matéria-prima é chamado de “manufatura reversa”. Na Universidade de São
Paulo (USP) foi criado, em 2009, o primeiro centro de descarte e reciclagem de
equipamentos eletrônicos, criação pioneira de um órgão público no Brasil. O projeto
visa recuperar computadores, notebooks e equipamentos de telefonia móvel e fixa. Os
equipamentos podem ter dois destinos: são encaminhados para reciclagem ou destinados
a ONGs e projetos sociais, caso possam ainda ser usados. O projeto cria a oportunidade
de reutilização gerando a inclusão digital em comunidades carentes administradas por
instituições não governamentais.
As grandes empresas também garantem a reutilização de seus produtos, como a
IBM que encontrou uma saída criativa para o descarte de seus monitores. Até o ano
31
2000, o destino dos resíduos descartados era o aterro. A partir daquele ano, o processo
foi interrompido e os monitores foram armazenados até que uma solução ambiental
fosse encontrada. Em 2008, 180 toneladas de monitores foram para a reciclagem. Um
parceiro da IBM coletou o vidro e o transformou em bolinhas de gude, que hoje estão
por aí, no mercado, à venda. Quanto à Dell, seus equipamentos usados podem ter dois
destinos, ou são mandados para a reciclagem ou são recondicionados e doados para
projetos sociais (mais de 46 milhões de toneladas de equipamentos). No Brasil, algumas
das empresas acima citadas não desenvolvem estas atividades de
recuperação/reciclagem, por ausência de ações repressivas por parte do cumprimento de
leis e normas dos órgãos ambientais, levando em consideração que nosso país ainda não
tem uma legislação específica sobre o e-lixo.
6. Concluindo
O lixo eletrônico aumenta a cada dia, pois com o constante crescimento das inovações
tecnológicas o consumidor segue a mudança de equipamentos com a mesma frequência.
O Brasil ainda hoje é alvo de críticas por parte das instituições internacionais, pela
grande quantidade de sucata gerada e pela carência de políticas ambientais relacionadas
ao assunto. Neste ano de 2010, depois de um 2009 de críticas, a Câmara dos Deputados
resolveu aprovar um projeto de lei engavetado há 19 anos.
Além das ações de grandes fabricantes e do surgimento de empresas voltadas
para reciclagem das sucatas eletrônicas, em algumas cidades, projetos de recuperação de
sucatas tecnológicas são desenvolvidos por grupos de amigos, que recolhem
equipamentos computacionais descartados para serem recuperados e, posteriormente,
destinados a crianças carentes e entidades sociais, como forma de inclusão digital. O
problema do lixo eletrônico no Brasil será resolvido (amenizado, pelo menos) quando
houver efetivamente as devidas leis criadas, e os órgãos de defesa possam fiscalizar e
punir os fabricantes que infringirem as resoluções contidas no normativo nacional. Por
fim, é importante destacar que cada consumidor pode atuar como um elemento ativo
nesse processo, seja conscientizando os menos informados, seja procurando empresas
que preguem a sustentabilidade, ou até atuando criativamente na transformação do elixo em algo novo, que possa ser usado por aqueles menos afortunados.
Recursos
Planeta
Sustentável
(2008)
Consumismo
Gera
Lixo
http://planetasustentavel.abril.com.br/noticia/atitude/conteudo_278998.shtml
-
Ecodebate (2010) Estudo mostra Brasil no topo do ranking de produção per capita de
lixo
eletrônico
vindo
de
computadores
http://www.ecodebate.com.br/2010/03/25/estudo-mostra-brasil-no-topo-dorankingde-producao-per-capita-de-lixo-eletronico-vindo-de-computadores/
GREENPEACE BRASIL - http://www.greenpeace.org/brasil/
ONU – Organização das Nações Unidas - http://www.onu-brasil.org.br/
PNRS
(2010)
http://www.revistasustentabilidade.com.br/documentos-dereferencia/pnrs-textoaprovado-na-camara-10-03-2010
PNMA - http://www.semarh.al.gov.br/programas/programa-nacional-do-meio-ambiente
32
SISNAMA - www.mma.gov.br/port/conama/estr1.cfm
Lei
Lixo
Eletrônico.
LEI
ROSH
DA
UNIÃO
http://www.lixoeletronico.org/system/files/UE_ROHS_PT.pdf
EUROPÉIA
-
Baixaki (2010) Ranking de Empresas Verdes - http://www.baixaki.com.br/info/3634ranking-de-empresasverdes.htm
OXIL MANUFATURA REVERSA - http://oxil.com.br/
Revista
Sustentabilidade
(2010)
LEI
BRASILEIRA
DO
E-LIXO
http://www.revistasustentabilidade.com.br/documentos-dereferencia/pnrs-textoaprovado-na-camara-10-03-2010
-
33
An Experimental Research on the Relationships between
Preferences for TechnicalActivities and Behavioural Profile in
Software Development
Fabio Q. B. da Silva, Ana Cristina F. César
Centro de Informática – UFPE Recife, Brasil
{fabio, acfc}@cin.ufpe.br
Resumo - Este artigo descreve uma pesquisa de campo conduzida a fim de identificar
as correlações entre preferência por atividades técnicas e o perfil de comportamento no
trabalho em equipe de engenheiros de software. O universo da pesquisa foram
estudantes de graduação em engenharia de software do Estado de Pernambuco. As
informações sobre preferências e comportamento, obtidas em uma pesquisa de campo
envolvendo 100 estudantes, receberam tratamento estatístico através do cálculo do
coeficiente de correlação por posto de Spearman. Os resultados contribuem para um
melhor entendimento da gestão de equipes de desenvolvimento de software.
Abstract - This article describes a survey conducted to identify correlations between
preferences for technical activities and behavioral profiles for work in a team of
software engineers. The context of the research was software engineering
undergraduate students at State University of Pernambuco, Brazil. The information
about preferences and behavior obtained in a field study involving 100 students
received a statistical treatment using the Spearman rank correlation coefficient. The
results contributed to a better understanding of the construction of effective software
development teams
Perfis de comportamento; perfis de equipe; engenharia de sofware.
1. INTRODUÇÃO
O gerenciamento de pessoas é uma atividade reconhecidamente complexa. Para
entender esta complexidade, o ponto de partida é a compreensão, já consolidada nos
estudos da psicologia humana, de que as pessoas são diferentes em diversos aspectos.
Por exemplo, na solução de problemas, na forma de obtenção de informação, na tomada
de decisão, na relação como o ambiente e as outras pessoas, no comportamento durante
o trabalho em equipe, entre vários outros. Estas diferenças influenciam motivação,
preferência por atividades profissionais, efetividade no trabalho em equipe e, em última
instância, desempenho individual e coletivo. Além disso, as diversas atividades técnicas
e gerenciais do desenvolvimento de software exigem diferentes níveis qualitativos e
quantitativos de processos mentais e sociais, tais como, criatividade, atenção a detalhes,
comunicabilidade, persistência, flexibilidade, liderança, etc.
A gestão de pessoas é especialmente importante para a indústria de software, por
três motivos: (1) o desenvolvimento de software é uma atividade mental e, portanto,
intensiva em pessoas; (2) é, quase sempre, desenvolvido em equipe; e (3) é composto de
diversas atividades técnicas cujo agrupamento define papéis funcionais distintos em
uma equipe de desenvolvimento. Estas características, de forma isolada e nas suas
interações, aumentam a complexidade e a importância da gestão de pessoas no
desenvolvimento de software quando comparada com setores menos intensivos em
atividades mentais.
34
Nos últimos anos, diversas pesquisas têm buscado aplicar teorias da psicologia à
engenharia de software com o objetivo de obter teorias, técnicas e ferramentas
específicas para projetos de software, em dois aspectos complementares: na alocação de
pessoas a papéis funcionais (técnicos e gerenciais) do desenvolvimento de software; e
na composição e gerenciamento das equipes de desenvolvimento.
Entre estas pesquisas, de forma geral, podem ser distinguidas duas vertentes:
 Trabalhos que têm como foco o indivíduo, sua personalidade e seus traços de
omportamento, e como estes elementos influenciam o trabalho individual no
desenvolvimento de software [Acuna, Juristo e Moreno 2006],[Capretz 2002],[
Capretz 2003],[Cunha 2007].

E trabalhos que colocam o indivíduo no contexto do trabalho em equipe,
analisando as formas de interação e os papéis em equipe, e como estes elementos
influenciam o trabalho em equipe em software [Gorlae Lam 2004],[Karn e
Cowling 2006].
Certamente as duas vertentes são importantes e complementares, uma vez que cada
indivíduo isoladamente contribui para o trabalho em equipe e a equipe, por sua vez, cria
um contexto social e organizacional que pode moldar ou ajustar o comportamento
individual. Este trabalho busca contribuir com a interação destas duas vertentes. O
objetivo é estudar as relações entre a preferência individual por atividades técnicas e
gerenciais do desenvolvimento de software (foco no indivíduo) e os perfis de
comportamento individual no trabalho em equipe (foco no trabalho em equipe). E para
contemplar este objetivo, este artigo é guiado pelas seguintes perguntas de pesquisa:

Existem atividades técnicas ou gerenciais no desenvolvimento de software
preferidas pelos engenheiros de software?

Existem perfis de comportamento no trabalho em equipe com maior tendência
de ocorrência entre os engenheiros de software?

Finalmente, existem correlações entre a preferência por atividades técnicas e os
perfis de comportamento dentre os engenheiros de software?
Para responder a estas perguntas foi realizada uma pesquisa de campo (survey), de
natureza quantitativa, cuja unidade experimental foi o engenheiro de software, estudante
de cursos de graduação em engenharia de software. O universo da pesquisa é formado
341 estudantes do Centro de Informática da UFPE e foram coletados dados de uma
amostra de 100 estudantes (29% do universo) entre os meses de setembro de 2008 e março
de 2009.
O instrumento de coleta de informações de campo foi um questionário estruturado
com perguntas fechadas composto de três partes: (I) informações de controle; (II)
preferência por atividades; e (III) perfil de comportamento no trabalho em equipe. A
parte II foi desenvolvida neste trabalho tomando por base as atividades técnicas e
gerenciais descritas na norma ISO/IEC 12207 e no Rational Unified Process (RUP).
Para identificar os perfis de comportamento no trabalho em equipe foi utilizada a Teoria
de Papéis em Time de Belbin (Belbin’s Team Role Theory) apresentada em (BELBIN,
1981) e, desta forma, a parte III do questionário é o instrumento associado à esta teoria,
denominado Team Role Self-Perception Inventory (TRSPI), que é fornecido em [Belbin
1981].
35
Este artigo está organizado da seguinte forma: na Seção 2 é apresentado o referencial
teórico do trabalho composto pela Teoria Teoria de Papéis em Time de Belbin (Belbin’s
Tearm Role Theory) e pela descrição das atividades técnicas e gerenciais segundo a
norma ISO/IEC 12207 e o RUP. Na Seção 3, é apresentada a metodologia e os métodos
experimentais utilizados no trabalho. Na Seção 4, são apresentados e analisados os
resultados da pesquisa. Finalmente, na Seção 5, são apresentadas conclusões e direções
para pesquisas futuras.
2. REFERENCIAL TEÓRICO
Para responder às perguntas da pesquisa, é necessário selecionar uma teoria de papéis e
definir claramente as atividades técnicas e gerencias do desenvolvimento de software,
para então estudar as suas correlações. A literatura sobre teoria de papéis é ampla,
conforme apresentado em [Aritzeta, Swailes e Senior 2007], e uma avaliação teórica do
assunto está fora do escopo deste artigo. Neste trabalho, a teoria de papéis utilizada é a
Teoria de Papéis em Time de Meredith Belbin [Belbin 1981], escolhida por um
conjunto de razões:

A teoria é focada em papéis relacionados ao trabalho em equipe, atendendo a um
requisito deste trabalho que é estudar o comportamento individual no trabalho em
equipes de desenvolvimento de software.

A teoria e os instrumentos de avaliação (questionários e escalas de medição)
passaram por um extenso trabalho de crítica teórica e testes experimentais, com a
conclusão de que a teoria é consistente e os instrumentos são válidos conforme
resumido em [Aritzeta, Swailes e Senior 2007], [Senior 1998].

A teoria e os instrumentos de avaliação não são oficialmente aceita pelos
conselhos de psicologia no rasil (assim como outros testes muito utilizados na
prática, como o MBTI). Porém, os riscos da teoria não ser adequada ao contexto
brasileiro é baixa uma vez que foi construída a partir de extensa pesquisa de campo
envolvendo indivíduos de diversos países e culturas distintas, procurando eliminar um
possível viés cultural.

Existem diversos trabalhos na área de engenharia de software que utilizam a
Teoria de Belbin, permitindo que os resultados deste trabalho possam ser
comparados, entre eles [Stevens 1998], [Henry e Stevens 1999],[Schoenhoff
2001],[Rajendran 2005],[França e Da Silva 2007],[Ferreira e Da Silva 2007].

Finalmente, apesar da Teoria de Belbin ter sido originalmente construída para
times de gerentes, existem estudos que demonstram sua utilização consistente
em times de quaisquer naturezas [Fisher, Hunter e Macrosson 2002] p. 15.
Para a identificação e descrição das atividades do desenvolvimento de software foi
utilizado como fundamento a norma ISO/IEC 12207 e o RUP. A primeira por ser uma
norma formalmente estabelecida e que possui ampla utilização prática. O segundo por
ser um modelo de processo largamente utilizado na prática e apresentar uma definição
precisa das atividades do desenvolvimento.
2.1 Teoria de Papéis de Time de Belbin
Durante os anos 70, Meredith Belbin e sua equipe de pesquisadores do Henley
Management College, na Inglaterra, estudaram vários comportamentos de gerentes de
várias nacionalidades, durante um período de nove anos. Neste estudo, os gerentes
36
foram submetidos a testes psicométricos para avaliar traços de personalidades, modos
de interação, preferências intelectuais e estilos de comportamento. Os testes usados
foram o 16 Personality Factors (16PF), o Watson-Glaser Critical Thinking Appraisal
(CTA) e o Personal Preference Questionnaire (PPQ). A partir deles, os gerentes foram
alocados em equipes de diversas composições, com o apoio de um grupo de
observadores que registravam todas as ações [Belbin 1981].
A partir dos resultados dos testes e da observação do comportamento dos indivíduos
em situações de trabalho em equipe, vários grupos de comportamento foram
identificados e consistentemente relacionados ao sucesso ou fracasso das equipes. Os
padrões de comportamento identificados foram classificados e nomeados,
originalmente, em oito tipos de papéis em times (team roles): Company Worker, Team
Worker, Monitor Evaluator, Chairman, Plant, Shaper, Resource Investigator e
Completer Finisher. Neste trabalho serão mantidos os nomes originais em inglês dos
papéis uma vez que uma tradução livre poderia causar distorções de significado e
prejudicar o entendimento dos resultados.
Na Teoria de Belbin, um papel em time é definido como “uma tendência para se
comportar, contribuir e se relacionar com outros de uma forma particular em um
trabalho em equipe”. A Teoria de Papéis em Time advoga que estes papéis quando
alocados de forma balanceada em uma mesma equipe melhoram as chances de sucesso
do trabalho coletivo uma vez que aumentam a coesão e sintonia entre os membros,
criando equilíbrio entre as forças e fraquezas inerentes a cada papel individual.
Belbin [Belbin 1993] apresenta uma extensão da Teoria de Papéis com a adição do
papel de Specialist. Além disso, foram alterados os nomes de dois papéis de time para
melhor representar seu significado: Chairman passou a ser chamado Co-ordinator e
Company Worker passou a Implementer. A utilização do papel Specialist possui críticas
na literatura por não possuir poder discriminatório suficiente [Aritzeta, Swailes e Senior
2007], [Senior 1998]. Por esta razão, este trabalho considera os oito papéis originais da
Teoria, mas com os novos nomes Co-ordinator e Implementer.
A Tabela 1 explica de forma resumida cada perfil de comportamento de Belbin,
especificando suas características, pontos fortes e fracos.
A Teoria de Papéis de Belbin é complementada por uma ferramenta de análise
chamada Team Role Self-Perception Inventory (TRSPI), apresentada em [Belbin 1981],
com o qual é possível identificar os papéis que um indivíduo tenderá a assumir em uma
situação de trabalho em equipe. O TRSPI é brevemente descrito na Seção 3.4.
2.2 Atividades Técnicas e Gerenciais
A Norma ISO/IEC NBR 12207 [NBR 1998] foi desenvolvida pela ISO (International
Organization for Standardization) e a IEC (International Electrotechnical Commission)
e tem como objetivo estabelecer uma estrutura comum para os processos de ciclo de
vida de software. O escopo da ISO/IEC 12207 abrange todo o ciclo de vida de software,
desde sua concepção até a descontinuidade do projeto de software, e os processos são
agrupados em três classes: Fundamentais, de Apoio e Organizacionais.
O Rational Unified Process© (RUP©), descrito em 15], é um processo genérico
para engenharia de software, que descreve atividades e papéis funcionais que servem de
37
base para implantação de processos de desenvolvimento em uma ampla variedade de
organizações que desenvolvem software.
Neste trabalho, foi realizado um estudo das atividades associadas aos processos
Fundamentais e de Apoio da Norma e dos 32 papéis funcionais descritos no RUP,
juntamente com as atividades a eles atribuídas, com o objetivo de consolidar um
conjunto pequeno de atividades técnicas que fosse capaz de cobrir a maioria das
atividades envolvidas em um processo genérico de desenvolvimento de software.
Tabela 1 - CARACTERIZAÇÃO DOS PAPÉIS EM TIME
Papel em
time (Título
Original)
Completer
Finisher
Sigla
CF
Descritores
Ansioso,
consciencioso,
introvertido,
autocontrole,
autodisciplina,
submisso
preocupado.
tem
tem
Pontos Fortes
Possíveis Fraquezas
Meticuloso,
consciencioso, rocura por
erros e omissões, entrega
sem atraso.
Tendência a se preocupar
demais. Relutante a
delegar.
e
Implementer
(former
Company
Worker)
IMP
Conservador,
controlado,
disciplinado, eficiente,
inflexível,
metódico,
sincero,
estável
e
sistemático.
Disciplinado, confiável,
conservador e eficiente,
transforma idéias em
ações práticas.
Um tanto inflexível.
Lento para responder a
novas possibilidades.
Team Worker
TW
Extrovertido, amigável,
leal, estável, submisso,
confortante,
não
assertivo
e
não
competitivo.
Cooperativo, suave, boa
percepção e diplomático,
escuta, constrói, evita
atritos, acalma o clima.
Indeciso em situações de
conflito.
Monitor
Evaluator
ME
Seguro,
fidedigno,
justo,
introvertido,
aberto a mudanças,
sério, estável e sem
ambições.
Sóbrio, estratégico e
perspicaz, visualiza todas
as opções, julga com
precisão.
Não tem impulso e
habilidade para inspirar
outras pessoas.
Co-ordinator
(former
Chairman)
CO
Dominante, confia nos
demais, extrovertido,
maduro, positivo, tem
autocontrole,
tem
autodisciplina, estável.
Maduro, confiante, bom
diretor,
esclarece
objetivos, promove a
tomada
de
decisão,
delega bem.
Pode ser visto como
manipulador.
Sobrecarregado
com
trabalho.
Plant
PL
Dominante,
imaginativo,
introvertido, original,
pensamento
radical,
cheio de confiança, não
se inibe.
Criativo, não ortodoxo,
soluciona
problemas
difíceis.
Muito
absorto
em
pensamentos; dificuldade
para
se
comunicar
efetivamente.
Shaper
SH
Abrasivo,
ansioso,
arrogante, competitivo,
dominante,
irritável,
emocional,
extrovertido,
Desafiador,
dinâmico,
prospera sob pressão,
tem impulso e coragem
para vencer obstáculos.
Suscetível
provocações.
a
Ofende o sentimento das
pessoas.
38
impaciente, impulsivo,
autoconfiante.
Resource
Investigator
RI
Diplomático,
dominante, entusiasta,
extrovertido, flexível,
inquisitivo,
otimista,
persuasivo,
positivo,
descontraído, social e
estável.
Extrovertido,
comunicativo,
explora
oportunidades,
desenvolve contatos.
Excessivamente otimista.
Perde interesse depois do
entusiasmo inicial.
Esta consolidação é apresentada na Tabela 2 e teve como meta reduzir a quantidade
de valores para as variáveis da pesquisa. As características apresentadas na Tabela 2
foram utilizadas para construir o questionário de avaliação das preferências individuais
por atividades técnicas e gerenciais, que é discutido na Seção 3.4.
Tabela 3 - ATIVIDADES DO DESENVOLVIMENTO DE SOFTWARE
CONSOLIDADAS
OBJETIVOS
CARACTERÍSTICAS
Análise
ATIVIDADES
Identificar as necessidades
dos usuários e avaliação e
concepção do sistema.
Desenvolvimento
Transformar especificações
em código.
Teste
Executar teste em programas
ou sistemas de programação
com
a
finalidade
de
encontrar erros.
Revisão
Avaliar os artefatos de
planejamento e do projeto
nos pontos principais de
revisão do ciclo de vida do
projeto.
Planejar e gerenciar os riscos
do projeto.
1. Identificação requisitos e modelagem de caso de
uso;
2. Especificar dados e avaliar resultados;
3. Detalhar as funcionalidades do sistema;
4. Entender o domínio da aplicação;
5. Investigar o que o cliente deseja.
1. Identificação dos componentes do software;
2. Definir abordagem de teste e assegurar sua
correta implementação;
3. Seguir padrões adotados para o projeto;
4. Seguir o projeto e a arquitetura definida;
5. Realizar testes unitários.
1. Buscar falhas no sistema;
2. Verificar os requisitos quanto a sua consistência,
completude e previsão;
3. Avaliar a qualidade global da interface;
4. Gerar relatório de teste;
5. Verificar os componentes gerados
1. Planejar e conduzir as revisões;
2. Verificar código fonte;
3. Observar detalhes;
4. Revisar requisitos;
5. Revisar código.
1. Coordenar as interações com cliente e usuários;
2. Analisar decisões;
3. Manter a equipe de projeto concentrada na meta
certa.
4. Acompanhar atividades;
5. Procurar alternativas quando surge algum
problema.
Gerenciamento
3. METODOLOGIA
Esta pesquisa apóia-se no método de abordagem hipotético-dedutivo, onde a hipótese
geral é de que existem correlações entre preferências por atividades e perfis de Belbin.
Quantos aos meios, a pesquisa utiliza uma abordagem quantitativa apoiada no método
de procedimento estatístico. Os fenômenos observados são as preferências por
39
atividades técnicas e perfis de comportamento de Belbin entre engenheiros de software.
As variáveis têm natureza quantitativa. Quantos aos fins, a pesquisa é descritiva, pois
objetiva colher um conjunto de variáveis a partir de um estudo de campo e identificar
correlações existentes entre estas variáveis.
3.1 Fases da Pesquisa
Este trabalho foi estruturado em três fases:
 Fase 1: esta pesquisa iniciou-se com uma revisão não sistemática da bibliografia
sobre equipes de desenvolvimento de software e comportamento do trabalho em
equipe. Ao final desta revisão, a norma ISO/IEC 12207 e o RUP foram
escolhidos como fundamento para descrição das atividades técnicas e gerenciais
no desenvolvimento de software e a Teoria de Belbin foi escolhida para
descrever o comportamento individual no trabalho em equipe. Estas escolhas
foramjustificadas na Seção 2

Fase 2: após o estudo e a seleção das teorias apropriadas, uma pesquisa de
campo foi cuidadosamente planejada e executada. A coleta de dados ocorreu
entre os meses de setembro de 2008 e março de 2009, em duas iterações, e
envolveu um total de 100 estudantes de graduação do Centro de Informática da
UFPE, em Recife, PE. Esta coleta foi realizada utilizando um questionário
objetivo, de questões fechadas, desenhado especificamente para este fim.

Fase 3: após a finalização da pesquisa de campo, os resultados foram gerados
utilizando-se o tratamento estatístico em duas fases. Primeiro houve a
identificação das preferências por atividades e dos perfis de comportamento de
Belbin. Em seguida, foram calculadas as correlações entre as atividades técnicas
e os perfis de comportamento através do coeficiente “_” de Spearman que mede
a intensidade destas relações. Uma vez com estes resultados, seguiu-se a análise
e elaboração de conclusões.
3.2 Unidade Experimental, Universo e Amostra da Pesquisa
A unidade experimental da pesquisa é o estudante de engenharia de software dos cursos
de graduação em Ciência e Engenharia de Computação do Centro de Informática da
UFPE, localizado em Recife – PE. Para caracterizar formalmente o universo, foram
considerados os estudantes que já haviam completado com sucesso (aprovação) a
disciplina de Engenharia de Software quando responderam ao questionário. Para validar
esta caracterização foi realizada uma verificação dos respondentes no sistema de
informação SIGA da UFPE.
De acordo com os dados fornecidos pela Coordenação de Graduação do CInUFPE a população compreendia na época da coleta de dados 341 estudantes (135 de
Engenharia da Computação e 206 de Ciências da Computação). Esta população está
segmentada por gênero em ambos os cursos da seguinte forma: 91% de estudantes do
sexo masculino e 9% do sexo feminino.
A pesquisa utilizou uma amostra estratificada, proporcional à segmentação por
gênero da população. O tamanho da amostra, de 100 estudantes, correspondendo à 29%
do universo, foi calculado a priori para atingir um nível de confiança aceitável (95%),
com um intervalo de confiança de 8,25%.
40
3.3 Definição de Variáveis e Escalas
As variáveis desta pesquisa são a preferência por atividades técnicas extraídas da norma
ISO/IEC 12207 e do RUP e os papéis em time de Belbin, sumarizadas no Quadro 1.
Quadro 1 - Variáveis
Preferência por Atividades
AN Análise
DE Desenvolvimento
TE Teste
RE Revisão
GE Gerenciamento
Papéis em Time de Belbin
IMP Implement
CO Co-ordinator
SH Shaper
PL Plant
RI Resource Investigator
ME Monitor Evaluator
TW Team Worker
CF Completer Finisher
Na Teoria de Tipos de Belbin, os papéis em time são medidos utilizando uma
escala razão com valores inteiros que variam entre 0 e 70. As pontuações são
convertidas para uma escala ordinal para refletir as tendências específicas de cada
experimento. Belbin (1981) utiliza uma conversão para uma escala ordinal de quatro
valores Baixo, Médio, Alto e Muito Alto, obtida a partir dos percentuais apresentados
no Quadro 2.
Quadro 2 - TABELA DE NORMAS DE BELBIN
Papel
Baixo
0-33 %
Médio
33-66 %
Alto
66-85 %
Muito
Alto
85-100%
Média
IMP
0-6
7-11
12-16
17-23
10,0
CO
0-6
7-10
11-13
14-18
8,8
SH
0-8
9-13
14-17
18-36
11,6
PL
0-4
5-8
9-12
13-29
7,3
RI
0-6
7-9
10-11
12-21
7,2
ME
0-5
6-9
10-12
13-19
8,2
TW
0-8
9-12
13-16
17-25
10,9
CF
0-3
4-6
7-9
10-17
5,5
Esta conversão reflete as tendências específicas de determinadas amostras de
apresentarem ocorrências maiores ou menores de alguns perfis. Estas tendências
representam características sócio-culturais que não seriam capturadas na utilização
direta dos valores. A mesma conversão foi utilizada na amostra desta pesquisa e será
apresentada na Seção 4.
Para manter a compatibilidade com a variável Papel em Time, a variável
Preferência por atividade também é medida por uma escala razão com valores inteiros
entre 0 e 25. Os valores são obtidos através de um questionário semelhante ao TRSPI
(explicado abaixo), garantindo a possibilidade de correlacionar os valores das duas
variáveis. Da mesma forma que para os Papéis em Time, os valores da Preferência por
41
Atividades são convertidos para uma escala ordinal de valores Baixo, Médio, Alto e
Muito Alto, utilizando os mesmos percentuais no Quadro 2.
3.4 Instrumento da Pesquisa
O instrumento de coleta de informações de campo foi um questionário estruturado com
perguntas objetivas (fechadas) composto de três partes: (I) informações de controle; (II)
preferência por atividades; e (III) perfil de comportamento no trabalho em equipe. A
parte II foi desenvolvida neste trabalho tomando por base as atividades técnicas e
gerenciais descritas na norma ISO/IEC 12207 e no RUP. Esta parte é composta de cinco
questões, com cinco itens por questão. Cada questão descreve uma situação do
desenvolvimento de software e cada item descreve uma preferência dentro desta
situação e está relacionada a uma atividade técnica ou gerencial. A Figura 1 apresenta
uma das questões como exemplo.
O respondente deve atribuir cinco pontos (números inteiros) entre os cinco itens
em cada questão, de forma a refletir a sua preferência em cada situação. Assim, para
cada atividade do desenvolvimento de software a pontuação no questionário varia entre
o mínimo de 0 e o máximo de 25.
Para identificar os perfis de comportamento no trabalho em equipe foi utilizada a
Teoria de Papéis em Time de Belbin (Belbin’s Team Role Theory) e, desta forma, a
parte III do questionário é o instrumento associado à esta teoria, denominado Team Role
Self-Perception Inventory (TR-SPI), que é fornecido em [Belbin 1981]. O TRSPI
(versão original com oito papéis) é composto de sete questões, com oito itens por
questão. Cada item descreve um comportamento relativo a uma situação de trabalho em
equipe e está relacionada a um papel em time. A Figura 2 apresenta uma das questões
como exemplo.
O respondente deve atribuir 10 pontos (números inteiros) entre os oito itens em cada
questão, de forma a refletir a sua auto-percepção de como se comportaria em cada
situação descrita. Assim, para cada papel em time a pontuação no questionário varia
entre o mínimo de 0 e o máximo de 70.
Figura 1 - Questionário de Preferência por Atividades Técnicas e Gerenciais
Figura 2 - Questionário de Preferência por Atividades Técnicas e Gerenciais
42
3.5 Métodos e Ferramentas Estatísticas
Durante a coleta de dados, estes foram tabulados na ferramenta Microsoft Office Excel
2007. Ao final da coleta, as análises estatísticas foram realizadas com o pacote SPSS
(Statistical Package for Social Sciences) versão 13.0. Para verificar a existência de
correlação entre a por atividades e o papel em equipe na Teoria de Papéis de Time de
Belbin foi utilizado o coeficiente correlação de Posto de Spearman, normalmente
designado “rho” (_), e definido pela seguinte fórmula:
𝜌 ∑𝑛𝑖=1 𝑑𝑖2
𝜌 =1−
, 𝑜𝑛𝑑𝑒,
−1 ≤ 𝜌 ≤ +1
𝑛3 − 𝑛
Onde, n representa o número de pares (Xi, Yi) e d é diferença entre os postos
para as duas observações dentro de um par ((postos de Xi dentro os valores de X) –
(postos de Yi dentro os valores de Y)). O coeficiente _ de Spearman varia entre -1 e 1.
Quanto mais próximo estiver destes extremos, maior será a associação entre as
variáveis. O sinal negativo da correlação significa que as variáveis variam em sentido
contrário, isto é, as categorias mais elevadas de uma variável estão associadas a
categorias mais baixas da outra variável.
4. RESULTADOS E ANÁLISE
A PESQUISA ENVOLVEU UM TOTAL DE 100 ESTUDANTES DE
INFORMÁTICA, DOS CURSOS DE CIÊNCIAS DA COMPUTAÇÃO E
ENGENHARIA DE SOFTWARE DO CENTRO DE INFORMÁTICA – CIN DA
UNIVERSIDADE FEDERAL DE PERNAMBUCO - UFPE, CONSIDERANDO
APENAS OS RESPONDENTES VÁLIDOS.
Quadro 3 ilustra a amostra estratificada dos estudantes de informática em relação
ao sexo.
Quadro 3 - UNIVERSO E AMOSTRA DA PESQUISA
Curso
Masculino
%
Feminino
%
Total
Universo
Ciência da Computação
215
91%
21
9%
236
Engenharia da Computação
123
91%
12
9%
135
Amostra
Ciência da Computação
61
91%
6
9%
67
Engenharia da Computação
30
91%
3
9%
33
4.1 Conversão das Escalas
Conforme explicado na Seção 3, os valores das variáveis devem ser convertidos para
uma escala ordinal para refletir as características específicas da amostra da pesquisa.
Assim, utilizando o procedimento definido em [Belbin 1981], duas tabelas de normas
foram construídas para as variáveis Preferência por Atividades e Papéis em Time e
estão apresentadas no Quadro 4 e no Quadro 5, respectivamente.
Quadro 4 - NORMAS PARA AS PREFERÊNCIAS POR ATIVIDADES
43
Papel
Baixo
0-33 %
Médio
33-66 %
Alto
66-85 %
Muito
Alto
85-100%
Média
AN
0-7
8-10
11-13
14-19
9,2
DE
0-6
7-9
10-12
13-19
8,1
TE
0-4
5-8
9-10
11-18
7,0
RE
0-3
4-5
6-8
9-12
4,9
GE
0-3
4-7
8-10
11-17
5,9
Quadro 5 - NORMAS PARA OS PAPÉIS EM TIME
Papel
Baixo
0-33 %
Médio
33-66 %
Alto
66-85 %
Muito
Alto
85-100%
Média
IMP
0-8
9-11
12-15
16-22
10,7
CO
0-6
7- 9
10-13
14-21
8,8
SH
0-7
8-11
12-14
15-22
8.5
PL
0-6
7-10
11-13
14-20
8,5
RI
0-5
6-8
9-11
12-18
7,2
ME
0-5
6-8
9-12
13-23
7,7
TW
0-7
8-11
12-15
16-36
10,7
CF
0-5
6-9
10-11
12-20
7,9
O Quadro 6 compara as médias apresentadas por Belbin (1981) e as obtidas neste
trabalho.
Quadro 6 - COMPARAÇÃO COM AS MÉDIAS DE BELBIN
Papel
Baixo
0-33 %
Médio
33-66 %
Alto
66-85 %
Muito
Alto
85-100%
IMP
10,0
10,7
0,7
-7%
CO
8,8
8.8
0,0
0%
SH
11,6
8.5
-3,1
26%
PL
7,3
8.5
1,2
-16%
RI
7,8
7.2
-0,6
7%
ME
8,2
7.8
0,4
5%
TW
10,9
10.7
0,2
2%
CF
5,5
7.8
2,4
-43%
É importante ressaltar três diferenças significativas nos resultados acima. Primeiro,
existe uma diminuição nos valores para o papel SH, demonstrando que a amostra exibe
44
este papel associado à liderança em menor nível que no estudo original de Belbin, que é
consistente com o fato de que o estudo de Belbin utilizou somente gerentes atuantes no
mercado, para os quais se esperava um percentual alto de papéis de liderança. Segundo,
existe um aumento nos valores para o papel PL, que pode ser considerado consistente
com o fato da amostra desta pesquisa ser composta de sujeitos com perfil de criação e
solução de problemas complexos.
Finalmente, existe um considerável aumento nos valores do papel CF,
considerado um papel que possui baixa ocorrência na população em geral. Este perfil,
de acordo com [Ferreira e Da Silva 2007] está associado aos processos de garantia de
qualidade e aderência a processos. Neste caso, uma hipótese que pode ser levantada é
que a área de engenharia de software está atraindo indivíduos com tendências a exibir
este papel em time, pois este papel está sendo valorizado no mercado em função das
necessidades crescentes de aumento de qualidade e aderência a processos de
desenvolvimento bem definidos. No entanto, esta hipótese ainda precisa ser testada.
4.2 Tendências na Preferência por Atividades e pelos Papéis em Time
Uma tentativa inicial de responder às perguntas de pesquisa 1 e 2 (Seção 1) é através
da análise da freqüência de ocorrência de valores Alto e Muito Alto para as duas
variáveis. Porém, uma inspeção simples destas ocorrências não permite concluir se
existem tendências na amostra para determinadas preferências ou papéis. Para buscar
respostas mais conclusivas para as perguntas 1 e 2, foi analisada a uniformidade da
distribuição das médias dos valores numéricos dos variáveis, utilizando o teste de
Bonferroni. Os próximos quadros apresentam os resultados do teste.
O quadro 7. mostra que as médias mais elevadas registradas nas Preferências por
Atividades foram AN (9.2) e DE (8,1) e a menos elevada correspondeu à atividade RE
(4,9). Através do resultado do teste de Bonferroni (letras semelhantes entre parêntesis)
comprovam-se diferenças significantes entre o par AN-DE com cada uma das variáveis
TE, RE e GE. Portanto, mostrasse que a preferência por atividades técnicas e gerenciais
não é uniformes na amostra. Conclui-se que as atividades de análise e desenvolvimento
têm uma tendência a despertar maior interesse dos engenheiros de software, enquanto
revisão e gerenciamento despertam menor interesse.
Explicações para este resultado podem ser atribuídas a dois fatores. Primeiro, a
ênfase na formação dos engenheiros de software é nas atividades relacionadas à solução
de problemas e implementação de sistemas: análise e desenvolvimento. Portanto,
atividades como teste e revisão, são apresentadas com ênfase menor. Segundo, as
atividades de gerenciamento (GE) demandam maturidade pessoal e profissional que o
os participantes desta pesquisa não possuem. É, portanto, consistente a baixa preferência
por atividades de gerenciamento.
O quadro 8 mostra as maiores médias para os papéis TW e IMP com valores
idênticos (10,7) e a menor média para o perfil RI (7,2). O teste de Bonferroni agrupa os
papéis TW e IMP em uma categoria (letras iguais entre parêntesis), expressando uma
tendência da amostra nestes papéis. O teste também agrupa as médias de CO, SH, PL,
CF, ME e RI. Estes agrupamentos evidenciam que, também para os papéis em time,
existe uma tendência, respondendo à pergunta 2 da pesquisa.
45
Com os resultados acima é possível mostrar que existem tendências tanto para as
Preferências como para os Papéis. Porém, estes testes não permitem avaliar se existem
relações entre estas tendências, o que será realizado na próxima seção.
Quadro 7 - COMPARAÇÕES PAREADAS DE BONFERRONI DAS MÉDIAS DAS
PREFERÊNCIAS
Preferência por Atividades
AN
Média dos Valores Numéricos
DE
TE
GE
RE
9,2(4.1) 8,1(4.1) 7,0(4.2) 5,9(4.2) 4,9(4.2)
Quadro 8 - MÉDIA DOS PAPÉIS E COMPARAÇÕES PAREADAS DE
BONFERRONI
Papeis
em Time
TW
IMP
CO
SH
PL
CF
ME
RI
Média dos 10.7(4.1) 10.7(4.1) 8.8(4.1,4.2) 8.5(4.2) 8.5(4.2) 7.9(4.2) 7.8(4.2) 7.2(4.2)
Valores
Numéricos
4.3 Correlações entre Preferências por Atividades e Papéis em Time
Nesta seção serão estudas as possíveis correlações entre as duas variáveis, utilizando o
coeficiente de correlação _ de Spearman. No Fonte: Elaboração própria Quadro 9, os
valores grifados em negrito mostram as correlações significantes.
Quadro 9 - CORRELAÇÃO ENTRE PREFERÊNCIAS E PAPÉIS
IMP
CO
SH
PL
RI
ME
TW
CF
AN
-.149
.059
-.271(*)
.133
177
.076
.080
-.033
DE
.207(*)
-.295(**)
.164
.184(*)
-.231(*)
.013
-.065
-.028
TE
.041
-.121
-.024
-.153
-.124
.161
.119
-.025
RE
.073
.038
.069
.028
.078
-.104
-.210(*)
.199(*)
GE
-.199(*)
.286(**)
.122
-.119
.236(**)
-.145
-.025
-.054
Tabela 3 - CORRELAÇÕES ENTRE AS VARIÁVEIS
Variáveis Correlação Explicação Preliminar
AN-SH
(-)
DE-IMP
(+)
DE-CO
(-)
Esta correlação negativa era esperada. A análise envolve “investigar o que
o cliente deseja” enquanto o perfil Shaper é “abrasivo, ansioso, arrogante”
podendo “ofender o sentimento alheio. A necessidade de relacionamento
supostamente amigável com o cliente deve levar a pessoas que exibam o
papel de Shaper a não ter preferência por atividades de análise.
Esta correlação positiva é esperada e corroborada por França e da Silva
(2007). Pessoas com papel Implementer apresentam o comportamento de
transformar planos em ação, e devem ter uma tendência a preferir
atividades de implementação.
Esta correlação negativa não é óbvia, mas é consistente com a correlação
negativa entre GE e IMP e a positiva entre DE-IMP.
46
DE-PL
(+)
DE-RI
(-)
RE-TW
(-)
RE-CF
(+)
GE-IMP
(-)
GE-CO
(+)
GE-RI
(+)
A correlação positiva não é prevista em França e da Silva (2007), mas é
corroborada por Stevens (1998), Schoenhoff, (2001) e Rajendram (2005),
em particular quando existem problemas não triviais no desenvolvimento.
A correlação pode ser entendida uma vez que o Resource-Investigator
“perde interesse depois do entusiasmo inicial”, sendo um papel que deve
preferir atividades com maior desafio intelectual e menos características
operacionais.
Esta correlação negativa não é imediatamente decorrente do referencial
teórico nem da análise comparativa entre papéis e atividades. Novas
pesquisas devem aprofundar este achado experimental.
Esta correlação é esperada uma vez que a atividade de Revisão envolve
“observar detalhes” e o papel Completer-Finisher é “meticuloso,
consciencioso, procura por erros e omissões”.
Rajendram (2005) associa o papel CF com as atividades de Revisão e
Teste.
As três correlações da atividade Gerenciamento estão previstas nos
trabalhos de França e da Silva (2007) e Fernandes e da Silva (2007). Em
particular, a correlação negativa também pode ser explicada pois o papel
Implementer tende a ter um comportamento “inflexível e lento para
responder a novas possibilidades”, características que não ser adéquam à
atividade de Gerenciamento.
É importante notar que não foi encontrada nenhuma correlação entre a Preferência
pela Atividade de Teste e os Papéis em Time. Uma explicação possível é que esta
preferência (alta ou baixa) está uniformemente espalhada entre os papéis fazendo com
que não existe uma correlação significativa com nenhum grupo em particular.
O teste estatístico de correlação não determina a relação de causa e efeito. Portanto,
não é possível concluir se é o papel que determina a preferência, apesar de que esta é
uma hipótese razoável. Além disso, não faz parte do escopo da análise quantitativa
explicar o porquê dos resultados, no caso, as correlações.
No entanto, utilizando resultados da literatura (principalmente [Stevens 1998],
[Schoenhoff 2001],[França e Da Silva 2007],[Ferreira e Da Silva 2007]) e a
caracterização dos papéis em time da tabela 1, é possível apresentar explicações
preliminares para estes resultados, que devem ser analisadas com mais profundidade em
um estudo qualitativo futuro. A Tabela 3 apresenta estas explicações.
5. CONSIDERAÇÕES FINAIS
Neste trabalho foram investigadas relações entre preferências individuais por atividades
técnicas e gerenciais do desenvolvimento de software e papéis que descrevem
comportamento pessoal no trabalho em equipe. Três perguntas centrais nortearam o
desenvolvimento da pesquisa: (1) existe tendência nas preferências por atividades; (2)
existe tendência na ocorrência de papéis em time; (3) existe correlação entre
preferências e papéis. Para as três perguntas, as respostas obtidas através de uma
pesquisa de campo foram positivas:
1. As atividades de Análise e Desenvolvimento são preferidas em relação às de
Teste, Revisão e Gerenciamento.
2. Os papéis Teamworker e Implementer tendem a ocorrer mais freqüentemente
na amostra do que os outros seis papéis.
47
3. Das 40 possíveis combinações entre Preferências e Papéis, 10 apresentam
correlação significativa de acordo com o coeficiente por Posto de Spearman.
A resposta para (1) evidencia que os estudantes de engenharia de software têm
uma tendência a preferir atividades diretamente relacionadas à solução de problemas e
construção de sistemas. Seria importante realizar um estudo qualitativo para saber se
esta preferência está relacionada a uma percepção dos estudantes de que estas atividades
são mais intelectualmente desafiadoras. Os resultados em (2) mostram que os papéis
associados ao desenvolvimento (Implementer) e ao trabalho em equipe (Teamworker) ocorrem
com mais frequência.
As correlações encontradas como resposta para (3) contribuem nos processos de
composição de equipes de desenvolvimento de software, principalmente quando
utilizadas em conjunto com os resultados da literatura e em particula [Fernandes e Fabio
2007], [Ferreira e Da Silva 2007], [França e Da Silva 2007]. Estes resultados podem ser
utilizados para auxiliar na alocação de pessoas aos papéis funcionais em uma equipe de
desenvolvimento levando em consideração suas características comportamentais e
pessoais.
Quanto à validade, a pesquisa possui validade de conclusão, uma vez que existe
correlação entre as variáveis, confirmada pela análise estatística, dentro dos limites do
nível de confiança (95%) e do intervalo de confiança (8,25%). Não é possível afirmar a
validade interna da pesquisa pois não foram estabelecidas relações de cause-efeito entre
as variáveis. Trabalhos futuros devem investigar estas relações. A generalização dos
resultados, validade externa, está restrita a populações com perfis comparáveis ao deste
trabalho: estudantes de cursos de ciência ou engenharia da computação que tenham
cursado disciplinas de engenharia de software. Estudos com populações distintas (por
exemplo, profissionais atuantes no mercado) estão sendo conduzidas com o objetivo de
ampliar a validade externa deste trabalho.
Como trabalho futuro propõe-se a investigação do impacto da formação de
equipes considerando características comportamentais e pessoais no desempenho das
equipes. Além disso, aspectos sociais e organizacionais serão acrescentados ao
problema de formação e desenvolvimento de equipes com o objetivo de se estabelecer
modelos e processos de suporte à gestão de equipes de melhor desempenho em
engenharia de software. Esta pesquisa tem o objetivo mais amplo de estudar os vários
aspectos relacionados ao ciclo de vida de equipes de desenvolvimento de software e este
trabalho é uma contribuição nesta direção.
REFERÊNCIAS
Acuna, S. T.; Juristo, N.; Moreno, A. M. (2006) Emphasizing human capabilities in
software development. IEEE Software, vol. 23:(2), 2006, pp. 94–101.
Aritzeta, A., Swailes, S., And Senior, B. (2007) "Belbin`s Team Role Model:
Development, Validity and Applications for Team Building". Journal of
Management Studies, vol. 44:(1), 2007, pp. 96-118.
Belbin, M. R. (1981) Management Teams: Why they succeed or Fail? ButterworthHeinemann Ltd., 1981.
Belbin, M. R. (1993) Team Roles at Work. Elsevier Butterworth-Heinemann Ltd., 1993.
48
Capretz, L. F. (2002) Implications of MBTI in Software Engineering Education.
SIGCSE Bulletin, vol. 34:(4), 2002.
Capretz, L. F. (2003) Personality types in software engineering. Int. J. HumanComputer Studies vol. 8, 2003, pp. 207–214.
Cunha, A. D. (2007) Greathead, D. Does personality matter? : an analysis of codereview ability. Communications of the ACM. New York, USA: Associatiom for
Computing Machinery, vol. 50:(5), 2007, pp. 109-112.
Fernandes, F.; Da Silva, Fabio Q. B. (2007) Relações entre competências pessoais e
tipos de personalidade do gerente de projetos. Anais do 2º Congresso Brasileiro em
Gerenciamento de Projetos, Salvador, BA, 2007.
Ferreira, P.G.; Da Silva, F. Q. B. (2008). Fatores que influenciam a utilização de
processos de software. Anais do VII Simpósio Brasileiro de Qualidade de Software,
Florianópolis, SC, 2008.
Fisher, S. G., Hunter, T. A. And Macrosson, W. D. (2002) ‘Belbin’s team role theory:
for non-managers also? ’. Journal of Managerial Psychology, vol. 17, 2002, pp. 14–
20.
França, A.C.; Da Silva, F. Q. B. (2007). Um estudo sobre Relações entre Papéis
Funcionais do RUP e o Comportamento Pessoal no Trabalho em Equipe em Fábricas
de Software. III WOSES -Workshop Um Olhar Sociotécnico sobre a Engenharia de
Software, 2007.
Gorla, N., And Lam, Y.W. (2004) Who should work with whom? Building effective
software project teams. Communication of the ACM, vol. 47:(6), 2004.
Henry, S. M.; Stevens, K. T. (1999) Using Belbin’s Leadership Role to Improve Team
Effectiveness: an empirical investigation, Journal of Systems and Software, vol.
44:(3), 1999, pp. 241-250.
Karn, J. And Cowling, T. (2006) A Follow up Study of the Effect of Personality on the
Performance of Software Engineering Teams. Proceedings of the 2006 ACM/IEEE
International Symposium on Empirical Software Engineering (ISESE’06), Rio de
Janeiro, Brazil, 2006, pp. 232-241.
Kruchten, P. (2003) Introdução ao RUP – Rational Unified Process, Rio de Janeiro:
Editora Ciência Moderna Ltda., 2003.
NBR ISO/IEC 12207. (1998) NBR ISO/IEC 12207 – tecnologia de informação:
processos de ciclo de vida de software. Rio de Janeiro: ABNT, 1998.
Rajendran, M. (2005) Analysis of team effectiveness in software development teams
working on hardware and software environments using Belbin Self-perception
Inventory, Journal of Management Development, vol. 24:(8), 2005, pp. 738-753,
Emerald Group Publishing Limited, 0262-1711, DOI 10.1108/02621710510613753.
Schoenhoff, P.K. (2001) Belbin's Company Worker, The Self-Perception Inventory, and
Their Application to Software Engineering Teams. Master Thesis, Virginia
Polytechnic Institute and State University, 2001.
49
Senior, B. (1998) An empirically-based assessment of Belbin s team roles Human
Resource Management. Human Resource Management Journal, vol. 8:(3), 1998, pp.
54-60.
Stevens, K.T. (1998) The Effects of Roles and Personality Characteristics on Software
Development Team Effectiveness. Doctoral Thesis, Virginia Polytechnic Institute
and State University, 1998.
Swailes, S. And Aritzeta, A. (2006) Scale Properties of the Team Role Self-Perception
Inventory. International Journal of Selection and Assessment, vol. 14:(3), 2006, pp.
292-298.
50
𝑪𝑯𝑹𝒓∨ 𝒇 : A Logic Inference Engine to Resolution Leveraged by
Heuristics
Cleyton Rodrigues, Renata Maria de Souza
Federal University of Pernambuco, Informatics Center, CDU, 7851, Recife,
Pernambuco, Brazil.
{cmor,rms6}@cin.ufpe.br
Abstract. Automated Reasoning (AR) has been a traditional research area. In this
field, Theorem Proving (TP) concerns the deductive view of a problem solving. Many
theorem prover were created in the literature, however, while some of them are not
fully-automatic (requires human interaction along the proof calculus), others are not
clear-cut enough to work with the engine. Further, many of these are highly inflexible,
in other words, they do not allow to be extended with new heuristics. Thus, this work
proposes the 𝐶𝐻𝑅𝑟∨ 𝑓 (Constraint Handling Rule Engine for Resolution/Factoring) a
resolution Classical First Order Logic (CFOL) inference engine built upon the general
declarative logic constraint language 𝐶𝐻𝑅 ∨ . In this paper, we show how a 𝐶𝐻𝑅 ∨
inference engine can also support the following form of fully automated theorem
proving: entailment of a disjunction of conjunctions of atomic formulas by an arbitrary
first-order logic formula.
1. Introduction
Automated Reasoning is the Artificial Intelligence field which studies computational
knowledge representation and reasoning in terms of Decidability, “that is, there exists
an algorithm such that for every formula in the system the algorithm is capable of
deciding in finitely many steps whether the formula is valid in the system or not”
[NationMaster 2010], and others properties such as completeness, monotonicity and
consistency. Decidability can be reformulated as a task of logical consequence. In short,
it is the reasoning in which, given a formula H and a set of assumptions KB (in other
words, a domain-specific knowledge base for the representation and acquisition of
knowledge), H is a logical consequence of KB in a deduction system, if there is a proof
of H from KB, notated as: KB |= H. In this sense, this paper presents 𝐶𝐻𝑅𝑟∨ 𝑓 , an
automatic resolution inference engine for theorem proving, which can also be easily
extend to addresses some heuristics, special maneuvers leading to a more skillful
theorem prover.
This paper is organized as follows: section 2 and 3 resumes, briefly, the main
concepts of Resolution and 𝐶𝐻𝑅 ∨ (the language used to implement the 𝐶𝐻𝑅𝑟∨ 𝑓 system),
respectively; further, in section 4 the system is detailed and the first results are outlined,
and finally section 5 presents the conclusion and the future works.
2. Resolution
When working with theorem provers, completeness becomes a critical factor in
choosing the best logic inference engine. However, this is not possible in CFOL when
inferences as Modus Ponens is used. Therefore, there is the urgency of working with
Resolution. Coupled with Factoring, this procedure is complete for CFOL clauses.
Actually, Resolution is a refutation completeness [Russell and Norvig 2003]
51
inference procedure in the sense that, it can not derive from the the knowledge base all
the true sentences, but it can reason about the entailment of any one. Furthermore,
Refutation, or reduction ad absurdum is a proof by contradiction, where to check
whether KB entails H, is enough to check the unsatisfiability of KB ^ ¬H. In
Resolution, it is essential that all clauses assume the Conjunctive Normal Form (CNF)
notation. According to it, a clause is represented by a disjunction of literals. We say that
two literals can be resolved if they are complementary, in the sense that the positive
literal is unifiable with the negative one. Factoring, by other side, is an auxiliary
mechanism coupled with resolution, which removes copies of the same literals in the
consequent clause. A copy of one literal is not necessarily equivalent, but unifiable with
it.
3. CHRV in a Nutshell
Constraint Handling Rules with Disjunction (𝐶𝐻𝑅 ∨ ) [Abdennadher and Schtz 1998] is a
general concurrent logic programming language, rule-based, which have been adapted
to a wide set of applications as: constraint satisfaction [Wolf 2005], abduction
[Gavanelli, Alberti and Lamma 2008], componente-development engineering [Fages,
Rodrigues and Martinez 2008], and son on. It is designed for creation of constraint
solvers. 𝐶𝐻𝑅 ∨ is a fully accepted logic programming language, since it subsumes the
main types of reasoning systems: the production system, the term rewriting system,
besides Prolog rules. Additionally, the language is syntactically and semantically welldefined (check the references for further details). Concerning the syntax, a
𝐶𝐻𝑅 ∨ program is a set of rules defined as:
rule_name@ 𝐻𝑘 ⁄ 𝐻𝑟 ⇔ G | B
Rule name is the non-compulsory name of the rule. The head is defined by the
predicates represented by Hk and Hr (user-defined predicates), with which na engine
tries to match with the constraints in the store. Further, G stands for the set of guard
predicates (built-in predicates), that is, a condition imposed to be verified to fire any
rule. Finally, B is the disjunctive body (a collection of user-defined and built-in
predicates), corresponding to a set of constraints added within the store, whenever the
rule fires. The logical conjunction and disjunction of predicates are syntactically
expressed by the symbols , and ;, respectively. Logically, the interpretation of the rule is
as follows:
∀𝑉𝐺𝐻 ( 𝐺 → ((𝐻𝑘 ∧ 𝐻𝑟) ↔ (∃𝑉𝐵⁄𝐺𝐻 𝐵 ∧ 𝐻𝑘))) , 𝑤ℎ𝑒𝑟𝑒 𝑉𝐺𝐻
= 𝑣𝑎𝑟𝑠(𝐺) ∪ 𝑣𝑎𝑟𝑠(𝐻𝑘) ∪ 𝑣𝑎𝑟𝑠(𝐻𝑟), 𝑉𝐵⁄𝐺𝐻 = 𝑣𝑎𝑟𝑠(𝐵)⁄𝑉𝐺𝐻
4. 𝑪𝑯𝑹∨𝒓 𝒇 : Experiments and Outcome
This sections addresses the reformulation of CNF clauses (the refutation rule, inclusive),
enjoying the ability of program user defined constraints in CHR_engine. Roughly
speaking, CHR_rf is a rule system capable to perform the basic inference rules presented
in the previous section, namely: resolution and factoring. Therefore, for each pair of
these user constraints, the engine tries to resolve based on the complementary literals.
Each new resolution is taken to resolve itself until no resolution is possible or the
CHR_engine derives a constraints with no parameters (logically, the empty-clause).
Initially, all CFOL clauses and the refutation rule are expressed in CNF notation. Then,
52
each conjunctive clause of the form: ¬𝜌1 ∨ ¬𝜌2 ∨ ¬𝜌3 ∨ ¬𝜌4 turns onto a implies/6
𝐶𝐻𝑅 ∨ user defined constraint:
𝑖𝑚𝑝𝑙𝑖𝑒𝑠(𝑎𝑛𝑑([ ], [𝜌1 , 𝜌2 ]), 𝑜𝑟 ([ ], [𝜌3 , 𝜌4 ]), 𝑆𝑡𝑎𝑔𝑒, 𝐼𝑑, 𝐼𝐷_𝐶𝑜𝑛𝑠𝑡𝑟𝑎𝑖𝑛𝑡, 𝑆𝑆)
where: [𝜌1 , 𝜌2 ] represents a list with the negative literals, [𝜌3 , 𝜌4 ] represents a list with
the positive literals, Stage corresponds to the current status of the constraint, thus
indicating which operation is possible to be realized (possible values are: toSort,
toFactor, and toResolve); Id corresponds to a integer (unique) associated with the
constraint; ID Constraint corresponds to a list of identifiers of constraints, with which
the constraint has already tried to resolve (thus, before resolving the constraints, the
engine checks if this process had not tried yet, avoiding trivial non-termination); SS is a
enumeration type which can assume one of the values: n which says that the implies
token is not part of the Set of Support, or y, otherwise.
Once all clauses in CNF have been reformulated to implies/6 CHR_constraints, we
apply (manually) some additional steps to fix mismatches between both representations
(CFOL and 𝐶𝐻𝑅 ∨ ), they are: (i) universal vs. existential quantifiers and (ii) unification
vs. matching. In (i), we add additional variables in the head of 𝐶𝐻𝑅 ∨ rules1 (for all the
local existential variables), which changes the variable semantics to be universally
quantified, as a skolemized CFOL formula, while for (ii) the engine uses a prolog
predicate which preforms a sound-unification unify with occurs check
(+Term1,+Term2), since, in nature, 𝐶𝐻𝑅 ∨ performs matching, that is, one-side
unification.
𝐶𝐻𝑅𝑟∨ 𝑓 system operates in three well-defined phases: phase 1 (toSort)- both list of
constraints are sorted to help the resolution and factoring, phase 2 (to-Factor) - each list
from implies/6 constraint are revisited to delete equivalente terms 2; phase 3 (toResolve)
- each pair of constraints is tried to resolve; if not possible, the identifier of each
constraint is added to the list of the partner, to avoid further futile attempts. On the other
hand, if the resolution occurs, a new constraint is created with status toSort and its id is
formed by junction of the parents identifiers. In order to improve the system, 𝐶𝐻𝑅 ∨ is
flexible enough to extend with some heuristics, like: Set of Support and Linear
Resolution. For the former case, as mentioned earlier, the field SS for the constraints
tells which constraint is part of the set (in our context, only the refutation clause and all
the clauses derived by resolution). For the Linear Resolution, in turn, we ensure that a
constraint from the SS may resolve with the others (not part of the set) or with any of its
ancestor (this is possible, since the id keeps a track of all the parents constraints). The
table below outlines some results with the engine. The problems and 𝐶𝐻𝑅𝑟∨ 𝑓 can be
found at http://cin.ufpe.br/~cmor/JELIA/.
Table 1 - Results for the 𝑪𝑯𝑹𝒓∨ 𝒇 system
Problem/Puzzle
Fido
Nr. Implies
Refutation Query
4
die(Fido)
Time(s)
0,016
Variables in 𝐶𝐻𝑅 ∨ head rules are universally quantified, while the ones presented locally in 𝐶𝐻𝑅 ∨ body
rules are existentially quantified
2
In this context, equivalents terms are a variant of each other, or in other word, they have the same
functor and the variables are renamed.
1
53
Lucky
7
happy(john)
0,062
Tuna
8
kill(curiosity,tuna)
2,403
11
loves(melinda,bill)
0,172
9
hate(marcus,caesar)
5,772
Happy
Marcus-Caesar
5. Final Remakes and Future Works
𝐶𝐻𝑅 ∨ is a very versatile constraint language to knowledge representation and
inference. This article showed briefly a resolution inference system coupled with some
heuristics deployed by the 𝐶𝐻𝑅 ∨ language. In order to validate the engine, some
benchmark tests will be carried out to compare with some research related. Further, we
will improve the engine to hold others inference algorithm, such as, forward chaining
and backward chaining.
References
NationMaster (2010) Encyclopedia-decidability
Russell, S., Norvig, P. (2003) Constraints Satisfaction Problems. In: Artificial
Intelligence: A Modern Approach. 2nd edition edn. Prentice-Hall, Englewood Cliffs,
NJ (2003) 214
Abdennadher, S., Schtz, H. (1998) Chrv: A flexible query language. In: In FQAS 98:
Proceedings of the Third International Conference on Flexible Query Answering
Systems, Springer-Verlag (1998) 1–14
Wolf, A. (2005) Intelligent search strategies based on adaptive constraint handling rules.
Theory Pract. Log. Program. 5(4-5) (2005) 567–594
Gavanelli, M., Alberti, M., Lamma, E. (2008) Integrating abduction and constraint optimization in constraint handling rules. In: Proceeding of the 2008 conference on
ECAI 2008, Amsterdam, The Netherlands, The Netherlands, IOS Press (2008) 903–
904
Fages, F., Mário de Oliveira Rodrigues, C., Martinez, T. (2008). Modular CHR with
ask and tell. In: CHR ’08: Proc. 5th Workshop on Constraint Handling Rules, (Linz,
Austria) 95–110
54