Introdução a Engenharia de Software Matheus Souto Maior  [email_address] @msouto
Engenharia de Software Engenharia   =  “é a atividade em que os conhecimentos científicos são empregados para resolver problemas práticos” Engenharia de Software   =  “é a atividade em que os  [conhecimentos científicos]  são empregados para resolver problemas práticos  relacionados à construção de software ”
Objetivo “ Um dos objetivos básicos da Engenharia de Software é transformar  a criação de sistemas software realizada de maneira  artística ,  indisciplinada  e  pouco entendível  para uma forma devidamente  controlada ,  quantificada  e  previsível .”
Origem... em 1968, especialistas se reúnem em Garmisch, para discutir problemas de desenvolvimento de software http://homepages.cs.ncl.ac.uk/brian.randell/NATO/index.html
problemas “da época” Produtos de Software  de baixa qualidade e sem atender requisitos e Projetos realizados acima  do orçamento e do tempo previsto e vez por outra ingerenciáveis
A Crise de Software
"[The major cause of the software crisis is] that the machines have become several orders of magnitude more powerful! To put it quite bluntly: as long as there were no machines, programming was no problem at all; when we had a few weak computers, programming became a mild problem, and now we have gigantic computers, programming has become an equally gigantic problem."  Edsger Dijkstra: The Humble Programmer
A crise de Software
O Caso do  DABHS (Denver Airport Baggage Handling System) Características: 4000 Telecars 21 milhas de trilhos 5000 Olhos Eletrônicos, 400 Receptores de Rádio, 56 Scanners, 100 computadores em rede Estava planejado que o Aeroporto de Denver abriria em  31 de Outubro de 1993 Problemas no desenvolvimento do DABHS fizeram que o aeroporto abrisse em  28 de Fevereiro de 1995 Prejuízos devido ao atraso: Capacidade do sistema foi drasticamente diminuída Aproximadamente $ 500.000.000 ($1.1M por dia)
O Caso da Integração SABRE SABRE ( Semi-Automated Business Research Environment ) Sistema de Reserva da American Airlines Terminado no fim da década de 50 Construído pela IBM $2 bilhões Tentativa de Integração com sistemas de reserva de carros e hotel Em 1992 o projeto foi cancelado $165.000.000 jogados fora
Therac-25 Equipamento de Radioterapia, controlado por  computador  criada pela empresa AECL (Atomic Energy of Canada Limited)  Muito moderna para sua época Entre 1985 e 1987 se envolveu 6 em acidentes 5  mortes por overdoses de radiação
Therac-25 Causas: O código do software não havia sido revisado/testado independentemente;  O projeto do software não havia sido documentado com detalhes suficientes para permitir o entendimento dos erros  A documentação do sistema fornecida aos usuários não explicava o significado dos códigos de erro que a máquina retornava  http://pt.wikipedia.org/wiki/Therac-25
Ariane 5 Projeto da Agência Espacial Européia 10 anos de desenvolvimento US$ 8 Bilhões  Carga avaliada em US$500 Milhões  Em 4 de junho de 1996, menos de um minuto após o lançamento o foguete se autodestruiu
Ariane 5 Causa: Ocorreu um run time error (erro de execução) e ambos computadores se desligaram.  Um programa que convertia um valor de ponto flutuante para um inteiro de 16 bits recebeu como entrada um valor que estava fora da faixa permitida. Inclusive o resultado da conversão não era mais necessário após a decolagem.
Processos para construção de Software
Processo de Desenvolvimento de Software Modelo Cascata
Análise de Requisitos Entendimento das necessidades do cliente Especificação das necessidades Linguagem mais técnica Análise da viabilidade do escopo Estimativas de Custo e Prazo
Para que “Análise de Requisitos”?
Processo de Engenharia de Requisitos
Gerenciamento de Requisitos Evolução dos requisitos
Gerenciamento de mudanças de requisitos
Análise e Projeto Desenho lógico da solução Tomada de decisão sobre coisas como  Linguagem de Programação Plataforma de Desenvolvimento Integração com outros sistemas Detalhes técnicos
Arquitetura Lógica de Software
Exemplo de Arquitetura Física
Implementação Codificação do sistema Integração dos módulos Testes isolados Otimização de módulos já construídos
Tecnologias de desenvolvimento de Software J2ME J2SE J2EE
Testes Tem como objetivo identificar erros inseridos durante a construção Testes Funcionais Testes de Performance Testes de Carga Testes de Certificação ...
Implantação Tem como objetivo a instalação do software no ambiente final de execução Instalação Treinamento Configuração Adaptação
Processo de Desenvolvimento
Outros modelos de ciclo de vida do software
Modelo de prototipação
Modelo orientado a reuso
Desenvolvimento incremental
Modelo Espiral (evolucionário)
Exercício I Identificar todos os modelos de processos apresentados e construir um quadro comparativo. Postar no grupo
Por que organizar o desenvolvimento de software??
Windows Vista 5000 desenvolvedores (sem incluir pessoal não-técnico); 40 milhões de linhas de código; 16 milhões de linhas de código somente nos últimos 3 anos; Versões compiláveis todos os dias; Testes de regressão; Intervalo de 3 dias para um mudança submetida aparecer no executável; ~1.7 pessoas testando para cada programador; Precisa ter compatibilidade com versões anteriores; Precisa ser instalado em milhares de configurações diferentes;
intuitive surgical da vinci
intuitive surgical da vinci
Telecomunicação e Mobilidade
Indústria automotiva Electronic Stability Program
Transações Financeiras
Alguns números atuais...
Quanto melhoramos?
chaos report
Team Size {dev vs. test} o século de software...ou o século dos problemas de software? – Silvio Meira Product Dev Team Size Test Team Size NT 3.1 (6->) 200 140 NT 3.5 300 230 NT 3.51 450 325 NT 4.0 800 700 Win2k 1400 1700
Defect Rates Data With serialized development: Good, small teams operate efficiently Even the absolute best large teams are always broken, and always serialized o século de software...ou o século dos problemas de software? – Silvio Meira Product and Team Size Defects: Per year Per Dev Time to Fix: Per Defect Defects: Per Day Total Defect Fix Time NT 3.1, 200 2 20 minutes 1 20 minutes NT 3.5, 300 2 25 minutes 1.6 41 minutes NT 3.51, 450 2 30 minutes 2.5 1.2 hours NT 4.0, 800 3 35 minutes 6.6 3.8 hours Win2k, 1400 4 40 minutes 15.3 10.2 hours
Mas Engenharia de Software não é só técnica... “ The book demonstrates that the major issues of software development are human, not technical.”
Mas nem tudo está perdido....
Corpo da Engenharia de Software (SWEBOK)
Corpo da Engenharia de Software (SWEBOK)
CMMi – Capability Maturity Model Integration
Em Otimização Gerenciado Quantitativamente Definido Largamente Definido Parcialmente Definido Gerenciado Parcialmente Gerenciado A B C D E F G Relacionamento com o CMMI MR-MPS 2 3 4 5
PMBok Corpo de conhecimento da Gestão de Projetos Tem como objetivo divulgar e padronizar as melhores práticas de gestão de projetos
Obrigado! Matheus Souto Maior  [email_address] @msouto

Contr avali engenharia de software-introdução

  • 1.
    Introdução a Engenhariade Software Matheus Souto Maior [email_address] @msouto
  • 2.
    Engenharia de SoftwareEngenharia = “é a atividade em que os conhecimentos científicos são empregados para resolver problemas práticos” Engenharia de Software = “é a atividade em que os [conhecimentos científicos] são empregados para resolver problemas práticos relacionados à construção de software ”
  • 3.
    Objetivo “ Umdos objetivos básicos da Engenharia de Software é transformar a criação de sistemas software realizada de maneira artística , indisciplinada e pouco entendível para uma forma devidamente controlada , quantificada e previsível .”
  • 4.
    Origem... em 1968,especialistas se reúnem em Garmisch, para discutir problemas de desenvolvimento de software http://homepages.cs.ncl.ac.uk/brian.randell/NATO/index.html
  • 5.
    problemas “da época”Produtos de Software de baixa qualidade e sem atender requisitos e Projetos realizados acima do orçamento e do tempo previsto e vez por outra ingerenciáveis
  • 6.
    A Crise deSoftware
  • 7.
    "[The major causeof the software crisis is] that the machines have become several orders of magnitude more powerful! To put it quite bluntly: as long as there were no machines, programming was no problem at all; when we had a few weak computers, programming became a mild problem, and now we have gigantic computers, programming has become an equally gigantic problem." Edsger Dijkstra: The Humble Programmer
  • 8.
    A crise deSoftware
  • 9.
    O Caso do DABHS (Denver Airport Baggage Handling System) Características: 4000 Telecars 21 milhas de trilhos 5000 Olhos Eletrônicos, 400 Receptores de Rádio, 56 Scanners, 100 computadores em rede Estava planejado que o Aeroporto de Denver abriria em 31 de Outubro de 1993 Problemas no desenvolvimento do DABHS fizeram que o aeroporto abrisse em 28 de Fevereiro de 1995 Prejuízos devido ao atraso: Capacidade do sistema foi drasticamente diminuída Aproximadamente $ 500.000.000 ($1.1M por dia)
  • 10.
    O Caso daIntegração SABRE SABRE ( Semi-Automated Business Research Environment ) Sistema de Reserva da American Airlines Terminado no fim da década de 50 Construído pela IBM $2 bilhões Tentativa de Integração com sistemas de reserva de carros e hotel Em 1992 o projeto foi cancelado $165.000.000 jogados fora
  • 11.
    Therac-25 Equipamento deRadioterapia, controlado por computador criada pela empresa AECL (Atomic Energy of Canada Limited) Muito moderna para sua época Entre 1985 e 1987 se envolveu 6 em acidentes 5 mortes por overdoses de radiação
  • 12.
    Therac-25 Causas: Ocódigo do software não havia sido revisado/testado independentemente; O projeto do software não havia sido documentado com detalhes suficientes para permitir o entendimento dos erros A documentação do sistema fornecida aos usuários não explicava o significado dos códigos de erro que a máquina retornava http://pt.wikipedia.org/wiki/Therac-25
  • 13.
    Ariane 5 Projetoda Agência Espacial Européia 10 anos de desenvolvimento US$ 8 Bilhões Carga avaliada em US$500 Milhões Em 4 de junho de 1996, menos de um minuto após o lançamento o foguete se autodestruiu
  • 14.
    Ariane 5 Causa:Ocorreu um run time error (erro de execução) e ambos computadores se desligaram. Um programa que convertia um valor de ponto flutuante para um inteiro de 16 bits recebeu como entrada um valor que estava fora da faixa permitida. Inclusive o resultado da conversão não era mais necessário após a decolagem.
  • 15.
  • 17.
    Processo de Desenvolvimentode Software Modelo Cascata
  • 18.
    Análise de RequisitosEntendimento das necessidades do cliente Especificação das necessidades Linguagem mais técnica Análise da viabilidade do escopo Estimativas de Custo e Prazo
  • 19.
    Para que “Análisede Requisitos”?
  • 20.
  • 21.
    Gerenciamento de RequisitosEvolução dos requisitos
  • 22.
  • 23.
    Análise e ProjetoDesenho lógico da solução Tomada de decisão sobre coisas como Linguagem de Programação Plataforma de Desenvolvimento Integração com outros sistemas Detalhes técnicos
  • 24.
  • 25.
  • 26.
    Implementação Codificação dosistema Integração dos módulos Testes isolados Otimização de módulos já construídos
  • 27.
    Tecnologias de desenvolvimentode Software J2ME J2SE J2EE
  • 28.
    Testes Tem comoobjetivo identificar erros inseridos durante a construção Testes Funcionais Testes de Performance Testes de Carga Testes de Certificação ...
  • 29.
    Implantação Tem comoobjetivo a instalação do software no ambiente final de execução Instalação Treinamento Configuração Adaptação
  • 30.
  • 31.
    Outros modelos deciclo de vida do software
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
    Exercício I Identificartodos os modelos de processos apresentados e construir um quadro comparativo. Postar no grupo
  • 37.
    Por que organizaro desenvolvimento de software??
  • 38.
    Windows Vista 5000desenvolvedores (sem incluir pessoal não-técnico); 40 milhões de linhas de código; 16 milhões de linhas de código somente nos últimos 3 anos; Versões compiláveis todos os dias; Testes de regressão; Intervalo de 3 dias para um mudança submetida aparecer no executável; ~1.7 pessoas testando para cada programador; Precisa ter compatibilidade com versões anteriores; Precisa ser instalado em milhares de configurações diferentes;
  • 39.
  • 40.
  • 41.
  • 42.
  • 43.
  • 44.
  • 45.
  • 46.
  • 47.
    Team Size {devvs. test} o século de software...ou o século dos problemas de software? – Silvio Meira Product Dev Team Size Test Team Size NT 3.1 (6->) 200 140 NT 3.5 300 230 NT 3.51 450 325 NT 4.0 800 700 Win2k 1400 1700
  • 48.
    Defect Rates DataWith serialized development: Good, small teams operate efficiently Even the absolute best large teams are always broken, and always serialized o século de software...ou o século dos problemas de software? – Silvio Meira Product and Team Size Defects: Per year Per Dev Time to Fix: Per Defect Defects: Per Day Total Defect Fix Time NT 3.1, 200 2 20 minutes 1 20 minutes NT 3.5, 300 2 25 minutes 1.6 41 minutes NT 3.51, 450 2 30 minutes 2.5 1.2 hours NT 4.0, 800 3 35 minutes 6.6 3.8 hours Win2k, 1400 4 40 minutes 15.3 10.2 hours
  • 49.
    Mas Engenharia deSoftware não é só técnica... “ The book demonstrates that the major issues of software development are human, not technical.”
  • 50.
    Mas nem tudoestá perdido....
  • 51.
    Corpo da Engenhariade Software (SWEBOK)
  • 52.
    Corpo da Engenhariade Software (SWEBOK)
  • 53.
    CMMi – CapabilityMaturity Model Integration
  • 54.
    Em Otimização GerenciadoQuantitativamente Definido Largamente Definido Parcialmente Definido Gerenciado Parcialmente Gerenciado A B C D E F G Relacionamento com o CMMI MR-MPS 2 3 4 5
  • 55.
    PMBok Corpo deconhecimento da Gestão de Projetos Tem como objetivo divulgar e padronizar as melhores práticas de gestão de projetos
  • 56.
    Obrigado! Matheus SoutoMaior [email_address] @msouto

Notas do Editor

  • #46 http://www.standishgroup.com/press/article.php?id=2
  • #47 http://www.standishgroup.com/press/article.php?id=2