quarta-feira, 24 de dezembro de 2014


Pelo menos para mim e grande parte da comunidade científica, uma publicação completa precisa apresentar um estudo concluído com um experimento ou estudo de caso que comprove a tese do trabalho. Já um position paper ou artigo curto, é publicado para demonstrar um estudo em inicial, por isso tem entre 1 e 3 páginas. Outra forma de apresentar um estudo em andamento, submetido exclusivamente para eventos científicos, é através de um pôster avaliado por meio de um artigo resumido.

Em termos de avaliação da pesquisa científica, desde a seleção de cursos de pós-graduação até a atribuição de bolsas de produtividade, toda a carreira de um pesquisador é baseada em suas publicações. Nesse sentido, as universidades e agências atribuem maior pontuação para publicações de artigos completos, uma vez que trata-se de uma pesquisa comprovada por meio de um experimento ou estudo de caso, o que demanda anos de pesquisa.

Surpreendentemente, estava realizando uma revisão sistemática e encontrei alguns resumos de um dos eventos internacionais mais qualificados da área de engenharia de software, o International Computer and Software Engineering (ICSE). Os artigos completos publicados nesse evento são considerados QUALIS A1, são os melhores do mundo na área de engenharia de software. O artigo é avaliado por um comitê altamente qualificado e exige muito rigor dos revisores para comprovação dos resultados obtidos no trabalho, investigação do estado da arte da pesquisa e comparações com outros trabalhos. Por isso uma pesquisa completa demora anos, muito diferente de um artigo curto que podemos escrever em poucas semanas.

Voltando a surpresa, queria saber se os autores continuaram as pesquisas apresentadas em seus resumos, então procurei os lattes deles e notei que os resumos foram declarados ao CNPQ como artigos completos. Se a publicação está completamente relacionada com o desempenho do pesquisador, desde o seu início de carreira quando participa de seleções em programas de pós-graduação, depois quando docente para a obtenção de recursos em projetos e concorrer em bolsas de produtividade, não seria uma trapaça com os outros estudantes e pesquisadores? Além disso, a CAPES realiza uma avaliação trienal, atribuindo maior nota nos artigos completos e publicados com QUALIS A1.

Portanto, essa constatação é muito grave para Sociedade Brasileira de Computação. Estudantes, pesquisadores e programas podem ter sido prejudicados com a perda de recursos. Ao analisar alguns artigos, percebi a existência de 80 resumos declarados como artigos completos. É muita coisa!

Segundo Conselho de Ética e Pesquisa (CONEP), é também um caso de desvio de conduta sério. Diversas bolsas de pesquisa e investimentos em infraestrutura poderiam ser alocados para outros programas de pós-graduação, universidades e estudantes. Infelizmente, pesquisadores que disputaram bolsa de produtividade em pesquisa podem ter perdido várias oportunidades para esses pesquisadores. Eu perdi uma bolsa de pesquisa!

Enquanto a sociedade clama por ética e combate à corrupção, em menos de 10 minutos, detectei diversas fraudes em currículos de pesquisadores. Uma fraude desse tipo tem o objetivo claro de obter vantagens seja para o estudante, pesquisador, coautores, grupo de pesquisa, programa de pós-graduação e universidade. É muito triste saber que pesquisadores renomados ao invés de melhorarem de fato a qualidade da pós-graduação do país, criaram um artifício para demonstrar uma qualidade artificial.

Toda a comunidade de computação deveria repudiar essa prática e o ministério público entrar com um processo para reparação dos prejuízos causados à sociedade. Conheço diversos pesquisadores do nordeste, além do interior de São Paulo e Minas, que lutam para obter recursos. Há universidades que não possuem nem mesmo uma estrutura adequada de pesquisa.

Apenas esses 80 artigos, distribuídos entre um grupo de 20 e poucos, conseguem dar uma enorme vantagem ao pesquisadores numa avaliação entre pares competindo para obtenção de bolsas e projetos, porque nenhuma agência verifica artigos. Todos os 80 tem sempre o mesmo co-autor. Por isso, poderia até achar que é um esquema bem montado, se não houvesse internet. Pesquisei os eventos e estão descritos claramente que foram aceitos como pôster e resumos. Existem artigos também que simulam pesquisas, adicionando referências às idéias alheias.

Uma coisa é preciso reconhecer, são excelentes escritores de ficção e sabem administrar sua produção como poucos. Todos da base da pirâmide colocam os nomes dos orientadores e dos ex-orientadores deles, mesmo que não tenham qualquer projeto juntos. Elevam um por um do grupo através dos anos, até que este ganhe notoriedade e possa criar muitas parcerias de pesquisa. Então ele abastece a pirâmide com novos orientandos até de outros programas, citando o pesquisador parceiro e o mais antigo. Gerando novas pirâmides, sempre citando quem está no topo, assim todos eles mantém suas bolsas de produtividade. 

É muito difícil e dispendioso realizar uma pesquisa para publicar em eventos A1. Enquanto um pesquisador ético trabalha junto com um aluno de doutorado por 4 anos e a CAPES paga uma bolsa de R$2.200, ou seja, o mínimo de R$105.600, esse grupo converte seus resumos em uma pesquisa completa sem apresentar qualquer resultado ou avanço para a sociedade. Imagine quanto se gasta para pagar os custos dessas viagens em detrimento de outros pesquisadores que não conseguem publicar suas pesquisas completas por conta da ausência de recursos nas suas universidades?

Essa triste constatação é uma vergonha para a pesquisa científica no Brasil, especialmente por saber que se trata de um dos maiores grupos na área de engenharia de software. Estou completamente decepcionado por algum dia ter mencionado esses pesquisadores e seus estudos em minhas referências.  

Pior é saber que esses são apenas exemplos dessa fraude praticada por muitos outros pesquisadores. A Sociedade Brasileira de Computação e a Sociedade Brasileira para o Progresso da Ciência precisa fazer alguma coisa. Quem sabe automatizar os passos para comprovar que artigos declarados completos realmente possuem uma pesquisa completa para evitar outras fraudes como essas?

Repúdio.

Nature diz que produção científica brasileira é lixo acadêmico

sábado, 4 de outubro de 2014



Parece que está se tornando comum encontrar trabalhos com uma lista de coautores cada vez maior. No entanto, o papel de coautor é estabelecido em lei e não se pode incluir nomes a torto e direito sem que tenha havido participação efetiva no trabalho. Nesse post eu tento aproximar a legalidade do direito autoral de acordo com os critérios estabelecidos na Lei 9.610

Além de infringir a Lei 9.610 que trata do direito autoral, incluir coautores para ter proveito pessoal e/ou coagir um estudante a fazê-lo são atitudes criminosas. Apesar da lei ter sido sancionada em 1998, a prática é cada vez mais comum e muitos estudantes de pós-graduação não conhecem os seus direitos autorais, por isso, podem acabar repassando sua propriedade intelectual para outras pessoas explorarem sem proteção jurídica.

De acordo com a Lei 9.610, o autor é a pessoa criadora da obra e seu nome deve aparecer em primeiro na lista de autores. Já um coautor, é aquele que contribui diretamente na criação da obra, NÃO APENAS QUEM REVISA UM TEXTO. Em muitos casos arbitrários, alguns pesquisadores apenas participam do processo final do trabalho, revisando textos, logo são indicados como coautores da obra por parceiros de pesquisa.

Do ponto de vista legal, a contribuição do coautor não deve ser limitada a revisão, atualização, bem como direção. Em suma, a propriedade intelectual de uma obra só pode incluir coautoria se há de fato PARTICIPAÇÃO EFETIVA DURANTE TODA A CRIAÇÃO DA OBRA. O que garante a proteção ao autor e evita que qualquer pessoa, por incluir comentários sobre uma obra acabada, se declare coautora e tenha os mesmos direitos de propriedade da obra.

A inclusão de coautoria incorreta, lesa o erário por inflar currículos de falsos pesquisadores. Aqueles que não corroboram com os avanços de uma comunidade e visam apenas obter vantagens pessoais, concorrer a bolsas de produtividade, editais científicos, promoções em universidades e títulos honoríficos. Aqui eu explico mais sobre o assunto.

Não é difícil encontrar na plataforma lattes currículos de coautores que se apropriam das obras dos estudantes. Casos comuns podem ser vistos na publicação de versões da obra em outros eventos e congressos sem a inclusão do estudante como autor principal, invertendo a ordem dos autores por apenas traduzir a obra para uma outra língua. 

Estudantes em geral desconhecem o seu direito de propriedade intelectual, assim, muitos orientadores os induzem à incluir amigos e parceiros como coautores por interesses pessoais, até apresentam nos currículos de pesquisas deles os prêmios e/ou honras obtidos pelos orientados como se fossem seus. O que é definitivamente execrável. Mas o comum mesmo é incluir parceiros como coautores em troca de favores.

No periódico The Journal of Systems and Software, encontrei um artigo escrito por 34 autores. Se escrever um artigo com 3 pessoas já é difícil, imagine 34... Talvez o autor tenha confundido referências com coautoria. Sem dúvida, esse trabalho deve ser investigado.

A pesquisa científica não deveria admitir a inclusão de coautores a torto e direito e a punição deveria ser severa em todos os casos em que não se comprova participação durante toda a obra. Uma visão particular que tenho é que a coautoria é nociva não só por simular um conhecimento, mas por fingir uma contribuição que muitas vezes nem mesmo é pontual.

Ao imaginar uma rede de coautoria que também revisa periódicos, posso vislumbrar a comodidade em publicar com os amigos. E o maior problema é que o conhecimento não se renova na sala de aula, já que o coautor é fajuto! Não se surpreenda por esses pesquisadores não demonstrarem conhecimento sobre o que publicam.

A competência é pragmática. É difícil disfarçá-la em teorias, porque é transparente aos olhos.

Veja mais sobre os seus direitos de autoria nos links abaixo e não aceite participar do circo de coautoria acadêmica -> DENUNCIE! 




sábado, 6 de setembro de 2014


1st International Seminar on Safety-critical Systems



Na semana de 02 a 04 de setembro de 2014 participei do Primeiro Seminário Internacional Sobre Segurança em Sistemas Críticos no Parque Tecnológico de São José dos Campos, o que envolveu os domínios de aviação, saúde, transporte, energia e afins. Durante o seminário criei algumas perspectivas sobre Verificação & Validação, Engenharia de Sistemas Baseados em Modelos (MBSE) e Segurança (reliability:safety). Uma vez que a imensa dificuldade em juntar os pontos já é uma barreira para o desenvolvimento das indústrias no Brasil, o objetivo desse artigo é contrastar métodos, técnicas e ferramentas entre as engenharias de software e a de sistemas que foram apresentadas no seminário. No final, cito referências e indico outros estudos. Boa leitura!


Primeiro dia

O primeiro dia foi dedicado a V&V com foco na disciplina de teste de sistemas, cujas técnicas e métodos são as mesmas de teste de software, inclusive indico a leitura das notas que escrevi alguns anos atrás para entender, brevemente, as técnicas e métodos. Se quiser se aprofundar, leia o excelente livro "Foundations of Software Testing" de Aditya P. Mathur. Infelizmente, não faz parte das referências básicas dos cursos que tenho visto no Brasil, embora seja o melhor livro que já li sobre o assunto até o momento.

Entre os desafios para construção de sistemas críticos na disciplina de teste, não encontrei muitas novidades sobre o que pesquisamos em engenharia de software nos últimos 47 anos, com exceção as restrições de normas idiomáticas para cada domínio de sistemas. Nesse sentido, duas normas foram bastante citadas no evento, a norma MISRA referente ao domínio de sistemas automotivos e a norma DO-178B/C referente aos sistemas aviônicos.

Na engenharia de software quando criamos uma maneira de codificar abrangendo definição de nomes, criação de métodos, classes e acessos, além de melhores práticas, chamamos de idioma da linguagem. Um ótimo livro sobre o idioma da linguagem Java é "Java 2 Performance and Idiom Guide: Guidelines for Java 2 performance, coding, and testing" do Craig Larman. Enquanto muitos desenvolvedores aprendem a programar com maturidade em uma linguagem com o mínimo de 5 anos, com o estudo de um idioma esse tempo pode ser reduzido em até 2. O problema é que muitas empresas, ainda aquelas que desenvolvem sistemas críticos, pouco sabem sobre como associar idiomas de uma linguagem em seu processo de desenvolvimento, tornando-se um dos primeiros desafios no tocante a V&V. Por isso a existência dos padrões MISRA e DO-178B/C, porém nada foi comentado a cerca dos design patterns, princípios, estilos e padrões adotados na engenharia de software. 

Já que pouco se sabe sobre idioma, como medir a qualidade do código? Embora existam diversas métricas para medir coesão, reuso, acoplamento e manutenibilidade dos sistemas, pelo que notei através das perguntas, as práticas de gerenciamento da dívida técnica ainda estão muito longe de serem utilizadas nos sistemas críticos. O fato de existir uma série de riscos a serem mitigados [que incorrem em perdas humanas], incluir essas preocupações não aumentaria a complexidade para um desenvolvedor de sistemas comuns, mas talvez para engenheiros de sistemas essa mudança seja radical, até pela forma densa que os sistemas são desenvolvidos. Continue lendo que eu explico lá na frente porque.


Segundo dia

No segundo dia, problemas relacionados aos custos, qualidade e comunicação foram evidenciados como outros desafios a serem enfrentados durante o desenvolvimento dos sistemas críticos. Uma das causas principais se dá pelo fato da inexistência de engenheiros de sistemas necessários, já que estes são substituídos por bacharéis ou mestres das linhas de sistemas de computação ou profissionais próximos. Nesse sentido, foi necessário criar abordagens para contornar barreiras de comunicação entre os profissionais, daí surge o paradigma de Engenharia de Sistemas Baseados em Modelos (MBSE). A Model-driven Architecture (MDA) é uma forma pragmática de aplicar a MBSE, embora ela tenha sido mencionada apenas em um único slide no evento [fiquei realmente frustrado, porque pesquiso MDA há 8 anos]. 

Por conta do foco dado a utilização de uma das ferramentas que patrocinou o evento, pouquíssimo foi mostrado sobre os benefícios da MDA, se tornando o ponto baixo do seminário na minha opinião. Em relação a MDA, sabe-se desde 2005 que o maior desafio está em gerar modelos corretos de acordo com as regras de negócio. O metamodelo MOF (Meta Object Facilit), que suporta os metamodelos da UML e SysML (linguagens utilizadas pela ferramenta), é muito limitado nesse sentido. Diante desse problema, vários pesquisadores tentaram criar extensões do MOF ou criar pontos específicos para adicionar formalismos e assim poder trabalhar com sistemas críticos adequadamente.

No Brasil, o trabalho mais citado na história do Simpósio Brasileiro de Componentes, Arquiteturas e Reutilização de Software (SBCARS) trata justamente sobre isso. O artigo “Separação e Validação de Regras de Negócios MDA Através deOntologias e Orientação à Aspectos” tem como objetivo principal construir modelos corretos do ponto de vista formal, gerar um modelo de regras de negócio separado e derivá-lo para uma linguagem de programação automaticamente. Desta forma, o trabalho demonstra um passo importante para criação de sistemas críticos utilizando MBSE por incluir V&V do ponto de vista formal, algo que não pode ser alcançado apenas com a UML e SysML. Outro ponto positivo do trabalho é que a abordagem também facilita a criação e manutenção de linhas de produtos de software tornando-as mais robustas, já que as regras de negócio é a variabilidade do domínio mais difícil de se gerenciar. Se você ainda duvida, pergunte-se por que empresas que mantém ERPs cobram uma fortuna para modificar regras de negócios: antes, durante e após a implantação desses sistemas?

Voltando ao segundo dia, o evento focou numa ferramenta que é considerada uma das mais desejadas pelos engenheiros de sistemas, porém não avança no principal problema da abordagem MBSE, que é melhorar a confiabilidade dos sistemas críticos. Apenas criar modelos com base na UML e SysML não é o bastante! Percebendo o diferencial entre essa ferramenta e as outras, comumente utilizadas para geração de modelos, há possibilidade de inserir um diagrama de blocos (SysML) ou de atividades (UML) com o objetivo de simular a troca de estados de componentes, porém nada muito distante que outras ferramentas como UPPAAL e SPIN fazem há décadas e com a vantagem de serem abertas, sem custo e promover o formalismo que não existe no MOF. Por fim, me senti extremamente desapontado pela MBSE e MDA não terem sido abordadas com a devida importância que a própria engenharia de sistemas as elevou nos últimos anos.

Outra palestra que também aconteceu no segundo dia deveria apresentar tópicos sobre o desenvolvimento de requisitos, porém não mencionou guias, standards, métodos ou técnicas, ficou muito aquém do título "Requirements Development". Achei realmente péssima, apenas abordou o modelo V. No Guide to the Software Engineering Body of Knowledge (SWEBOK), guia criado com colaboração de muitos especialistas em diversas linhas da computação e engenharia de sistemas (inclusive participei da revisão de alguns tópicos na última versão), é possível ver tudo que a palestra deveria nos fornecer sobre desenvolvimento de requisitos.

Outros desafios foram a rastreabilidade de requisitos e o tratamento de exceções. Alguns anos atrás a engenharia de software conseguiu contornar esses problemas com o uso de anotações. Aumentou a produtividade, permitiu associar idiomas e padrões, além de detectar e tratar exceções em tempo de execução com a utilização de frameworks de teste e da plataforma de uma linguagem de programação. No tocante ao tratamento de exceções de regras de negócio, a ferramenta "OWLtoAspectJ" permite gerar código automaticamente usando uma abordagem MDA. Se a média do tempo gasto para realizar a construção de testes pode chegar até 20% do esforço em um projeto, tudo isso poderia ser reduzido completamente com o aperfeiçoamento dessa ferramenta para o domínio de sistemas críticos.


Terceiro dia

Foi um dia bastante agradável. Logo percebe-se a importância que a segurança (realiability:safety) possui nos cenários de uso dos sistemas críticos de aviação e os problemas para utilização de abordagens ágeis: as normas. 

As normas de defesa e civil são abrangentes não só a arquitetura de sistemas de sistemas (SoS), mas adentram no seu cerne, as regras de negócio. No desenvolvimento de sistemas não-críticos não estamos acostumados a ter uma interferência tão direta no nosso domínio. Assim, em um processo padrão de SoS, constituído pelo gerenciamento de requisitos, análise e design, desenvolvimento e teste, é preciso incluir fatos para provar que o código implementa as regras de negócio impostas pelas normas.

A Alston apresentou um case no segundo dia para ser exato, mas foi tanta overdose da ferramenta de análise e design que só consegui lembrar no dia seguinte. Eles criaram um EAF (Enterprise Architecture Framework) e derivaram uma metodologia para criar novas arquiteturas de sistemas que permitissem utilizar idiomas, processos e ferramentas de acordo com o ciclo de vida dos sistemas. Ainda não conseguiram obter reuso e gestão das variabilidades, mas estão no caminho certo. A abordagem da Embraer foi específica para segurança, mas a estrutura de EAF está oculta, apenas emergiram um processo compartilhado para coleta de dados com fins de simulação e previsão de defeitos. Entretanto, logo vão descobrir que existe uma arquitetura corporativa que pode prover benefícios além da coleta automática de dados e o desenvolvimento de novos produtos com mais facilidade.

Toda parte de segurança é primordial para garantir o funcionamento correto dos sistemas críticos no domínio de aviação. Existe ainda muitas normas específicas para simulação de modelos, somando-se as “normais” do desenvolvimento. É preciso definir cada função do SoS incluindo um processo de V&V para cobrir todas as falhas previstas nos requisitos. A confiabilidade é tão alta, que o objetivo é evitar que um sistema destrua a imagem da empresa definitivamente por conta de um defeito catastrófico. Essa máxima se aplica -> “você é o que você faz” e não cabe o ditado: “casa de ferreiro espeto de pau” de forma alguma.

Entre as ferramentas possíveis, procuram-se as que possam facilitar simulações de falhas, como a Simulink, Rede de Petri, Cadeias de Markov e criação automática de árvores de falhas relacionadas com cada função do SoS. Lembrando que o desafio desse terceiro dia é unir mais uma vez as normas para certificar que o sistema é seguro, conforme autoridades europeias e/ou americanas. Nesse sentido, ficou constatado durante o evento que escolher um centro de certificação que não esteja alinhado ao seu arcabouço pode complicar ainda mais o processo de desenvolvimento do seu sistema. Assim, penso que seria mais fácil utilizar um EAF mais alinhado a autoridade, que tentar criar um próprio, a exemplo do DoDAF (Departmentof Defense Enterprise Architecture Framework) para área de defesa. 

Se você quiser saber qual EAF é mais adequado a sua realidade, procure a revista Mundo J edição de janeiro/fevereiro de 2012. Escrevi um roteiro com esse objetivo! Leia mais sobre o FACTO Framework de Arquitetura Corporativa aqui.

No tocante aos sistemas computacionais, as áreas de Engenharia de Software e Sistemas Distribuídos (construção de sistemas, confiabilidade e formalismo) estão um pouco distantes. Assim, é possível encontrar tópicos de pesquisas que a outra possui maturidade há anos, tornando os avanços apresentados nos últimos anos até mesmo insignificantes em uma determinada área na minha opinião. É muito raro alguém estudar grandes áreas para propor algo novo, a maioria fica centrada em sua área do doutorado, o que é natural. No mestrado e doutorado, aprofundamos conhecimento numa área, assim estudamos na vertical e top-down, mas os problemas dos sistemas críticos e complexos crescem na horizontal também, por isso é necessário unir conhecimentos maduros das outras áreas para evitar esforços desnecessários. 


Conclusão

Em face aos desafios constatados: (i) V&V com foco na disciplina de teste de sistemas, (ii) geração de modelos corretos, (iii) implantação de regras de negócios aderentes as normas de certificação, (iv) rastreabilidade de requisitos e (v) tratamento de exceções, há de fato poucos avanços na engenharia de sistema vistos no evento. Desde o início, foi percebido que uma das maiores dificuldades é a junção de diversas visões alinhadas às estratégias de negócio, processos de desenvolvimento e de gestão, além das competências pessoais e aderência às normas de certificação. Como se não bastasse tudo isso, é preciso gerenciar as variabilidades por domínio e produto, incluindo as perspectivas dos interessados no ciclo de desenvolvimento dos sistemas. Ao elevar esses desafios a um patamar de corporação, tornou-se possível pensar num sistema holístico, dinâmico e pragmático, como demonstrou o case da Alston. Nesse sentido, um EAF pode ser uma solução ainda mais robusta que a própria MBSE para construir sistemas críticos e complexos. Espero que todos tenham percebido isso!


Referências (leia cada uma delas)

DO 278 - http://www.adacore.com/gnatpro-safety-critical/atm/do-278-overview/

ARP 4761 -  http://standards.sae.org/arp4761/

ARP 5150/51 -  http://www-users.cs.york.ac.uk/~mark/projects/aja506_project.pdf

ARP 4754 - http://sunnyday.mit.edu/16.355/arp4754a.pdf 


The relationship between ARP 4761 and STPA  http://sunnyday.mit.edu/papers/ARP4761-Comparison-Report-final-1.pdf

Quantitative Measures for Software Independent Verification and Validation http://ston.jsc.nasa.gov/collections/trs/_techrep/TP3634.pdf

Normas para cobertura estrutural

Confiabilidade de Requisitos 
ISO/IEC 17000-2005 - http://www.google.com.br/

Linha de produtos de Software e Engenharia de Sistemas
ISO/IEC 26550 - http://www.iso.org/

Uma taxonomia de falhas para sistemas distribuídos em 2004 pode ser muito útil para criar uma perspectiva de confiabilidade e assim atender as normas durante o desenvolvimento de sistemas críticos https://homes.cs.washington.edu/~ransford/srg/papers/avizienis--dependable-secure.pdf

Como organizar a perspectiva de confiabilidade através do desenvolvimento de sistemas de forma pragmática "Tratamento de Falhas Residuais Durante o Design de Sistemas de Software" http://jaguaracisilva.blogspot.com.br/2012/09/tratamento-de-falhas-residuais-durante.html

Para organizar o seu sistema de monitoramento da qualidade para atender a perspectiva de confiabilidade, poderia criar o seu próprio modelo de qualidade para V&V de sistemas críticos usando ISO/IEC 25000 (Square)  http://iso25000.com/index.php/en/iso-25000-standards

Inscreva-se

Creative Commons 3.0. Tecnologia do Blogger.

Teste a Velocidade da Internet

Siga-me

Curta