Processos de Desenvolvimento de Software. Ricardo Argenton Ramos UNIVASF Engenharia de Software I - Aula 2



Documentos relacionados
Processos de Desenvolvimento de Software. Ricardo Argenton Ramos UNIVASF Engenharia de Software I Aula 3

Especialização em Engenharia de Software e Banco de Dados

natureza do projeto e da aplicação métodos e ferramentas a serem usados controles e produtos que precisam ser entregues

Engenharia de Software I Modelos de Processo de Software

Na medida em que se cria um produto, o sistema de software, que será usado e mantido, nos aproximamos da engenharia.

Engenharia de Software

DSI é o processo cujo objetivo é introduzir mudanças num sistema de informação, com objetivo de melhorar o seu desempenho.

Sistemas de Informação I

Engenharia de Software II

Engenharia de Software

Princípios da Engenharia de Software Aula 02. Prof.: Franklin M. Correia

Introdução a Engenharia de Software. Alterações na aula do Prof. Reinaldo Bianchi Alterado por: Antonio Carlos Souza ADS - IFBA

Modelo Cascata. Alunos: Bruno Nocera Zanette Pedro Taques

Pós Graduação Engenharia de Software

Engenharia de Software Introdução. Ricardo Argenton Ramos UNIVASF Engenharia de Software I - Aula 1

O que é um processo de software?

Características do Software

PROFESSOR: CRISTIANO MARIOTTI

Engenharia de Software Introdução. Ricardo Argenton Ramos UNIVASF Engenharia de Software I - Aula 1

O que é software? Software e Engenharia de Software. O que é software? Tipos de Sistemas de Software. A Evolução do Software

O Produto e o Processo. Engenharia de Software Profa. Inês A.G.Boaventura 2. Semestre/2005

REVISÃO ENGENHARIA DO SOFTWARE. Isac Aguiar isacaguiar.com.br

Capítulo 2. Processos de Software Pearson Prentice Hall. Todos os direitos reservados. slide 1

Objetivos. Processos de Software. Tópicos abordados. O processo de software. Modelos genéricos de modelos de processo de software.

Engenharia de Software

O Processo. Engenharia de Software: Definição. Engenharia de Software: Definição. Engenharia de Software: Definição. Engenharia de Software

Engenharia de Software e Gerência de Projetos Prof. Esp. André Luís Belini Bacharel em Sistemas de Informações MBA em Gestão Estratégica de Negócios

Metodologias de Desenvolvimento de Sistemas. Analise de Sistemas I UNIPAC Rodrigo Videschi

AULA 1 INTRODUÇÃO - ENGENHARIA DE SOFTWARE. Prof. Msc. Hélio Esperidião

PROCESSO DE DESENVOLVIMENTO DE SOFTWARE. Modelos de Processo de Desenvolvimento de Software

Engenharia de Software: conceitos e aplicações. Prof. Tiago Eugenio de Melo, MSc tiagodemelo@gmail.com

Engenharia de Software. Engenharia de Software

Ciclo de Vida Clássico ou Convencional CICLOS DE VIDA DE DESENVOLVIMENTO DE SISTEMAS. Ciclo de Vida Clássico ou Convencional. Enfoque Incremental

ENG1000 Introdução à Engenharia

Processo Unificado (RUP)

Engenharia de Software. Parte I. Introdução. Metodologias para o Desenvolvimento de Sistemas DAS

MÓDULO 9 METODOLOGIAS DE DESENVOLVIMENTO DE SISTEMAS

Processos de Desenvolvimento de Software

Modelo Cascata ou Clássico

Tópicos. Engenharia de Software: Uma Visão Geral

Engenharia de Software

Tópicos em Engenharia de Software (Optativa III) AULA 2. Prof. Andrêza Leite (81 )

Qualidade de Software. Anderson Belgamo

Professor: Curso: Disciplina:

Processos de Software

Notas de Aula 02: Processos de Desenvolvimento de Software

Processos de Software. Aécio Costa

DISCIPLINA ENGENHARIA DE SOFTWARE Aula 03 Desenvolvimento Ágil Modelos Ágeis. Profª Esp.: Maysa de Moura Gonzaga

Análise e Projeto de Sistemas. Engenharia de Software. Análise e Projeto de Sistemas. Contextualização. Perspectiva Histórica. A Evolução do Software

Processo de Desenvolvimento Unificado

Introdução à Computação

Engenharia de Requisitos

Introdução Engenharia de Software

Projeto de Sistemas I

DISCIPLINA ENGENHARIA DE SOFTWARE Aula 03 Processo Unificado e Desenvolvimento Ágil. Profª Esp.: Maysa de Moura Gonzaga

REPROJETO DA ORGANIZAÇÃO COM SISTEMAS DE INFORMAÇÃO

ENGENHARIA DE SOFTWARE II

ISO/IEC 12207: Gerência de Configuração

Engenharia de Software Processo de Desenvolvimento de Software

GARANTIA DA QUALIDADE DE SOFTWARE

ENGENHARIA DE SOFTWARE/ SISTEMAS DE SOFTWARE

Algoritmos e Programação (Prática) Profa. Andreza Leite andreza.leite@univasf.edu.br

EVOLUÇÃO DE SOFTWARE

Engenharia de Software: Introdução. Mestrado em Ciência da Computação 2008 Profa. Itana Gimenes

PROCESSOS DE DESENVOLVIMENTO DE SOFTWARE 1. VISÃO GERAL 1.1. PROCESSOS EM GERAL

Tecnologias Atuais de. Desenvolvimento de Software

APOO Análise e Projeto Orientado a Objetos. Requisitos

! Introdução. " Motivação para Processos de Software. ! Processo Unificado (USDP) " Definições " RUP x USDP " Características do Processo Unificado

Campus Capivari Análise e Desenvolvimento de Sistemas (ADS) Prof. André Luís Belini prof.andre.luis.belini@gmail.com /

Introdução a Informática. Prof.: Roberto Franciscatto

Projeto de Arquitetura

REPROJETO DA ORGANIZAÇÃO COM SISTEMAS DE INFORMAÇÃO

MODELOS DE PROCESSO. Isac Aguiar isacaguiar.com.br

Engenharia de Software II

Modelos de Processo (métodos)

Prototipação de Software

Conteúdo. Disciplina: INF Engenharia de Software. Monalessa Perini Barcellos

RESOLUÇÃO CFC Nº 1.029/05

Laudon & Laudon MIS, 7th Edition. Pg. 1.1

Introdução à Engenharia de Software

ENGENHARIA DE SOFTWARE I

Engenharia de Software II

Manutenção e Ferramentas CASE. Marcos L. Chaim Segundo Bimestre 2003 Mestrado Profissional IC/Unicamp

ARCO - Associação Recreativa dos Correios. Sistema para Gerenciamento de Associações Recreativas Plano de Desenvolvimento de Software Versão <1.

Msc. Daniele Carvalho Oliveira Doutoranda em Ciência da Computação UFU Mestre em Ciência da Computação UFU Bacharel em Ciência da Computação UFJF

Modelos de Processo de Software. SSC Engenharia de Software 1 Profa. Dra. Elisa Yumi Nakagawa 2 o semestre de 2012

Engenharia de Software II

Engenharia de Software

Processo de Desenvolvimento de Software. Engenharia de Software.

Engenharia de Software II

AUTOR: DAVID DE MIRANDA RODRIGUES CONTATO: CURSO FIC DE PROGRAMADOR WEB VERSÃO: 1.0

UNIVERSIDADE FEDERAL RURAL DE PERNAMBUCO DEPARTAMENTO DE ESTATÍSTICA E INFORMÁTICA BACHARELADO EM SISTEMAS DE INFORMAÇÃO RAPID APPLICATION DEVELOPMENT

Roteiro para a escrita do documento de Especificação de Requisitos de Software (ERS)

Modelos do Design de Software

Plano de projeto. Cronograma e Controle

O Rational Unified Process (RUP) é um processo de desenvolvimento de software inspirado no

Transcrição:

Processos de Desenvolvimento de Software Ricardo Argenton Ramos UNIVASF Engenharia de Software I - Aula 2

A Engenharia de Software Uma Tecnologia em Camadas ferramentas métodos processo foco na qualidade Gerenciamento da Qualidade Total e filosofias similares produzem uma mudança cultural que permite o desenvolvimento crescente de abordagens mais maduras para a Engenharia de Software Modelos de Processos 2

ENGENHARIA DE SOFTWARE pode ser vista como uma abordagem dedesenvolvimento de software elaborada com disciplina e métodos bem definidos.... a construção por múltiplas pessoas de um software com múltiplas versões [Parnas 1987] Modelos de Processos 3

Introdução O processo de software é visto por uma seqüência de atividades que produzem uma variedade de documentos, resultando em um programa satisfatório e executável. Os níveis e arquitetura do processo de software é formada por: Nível Universal: possa utilizar em qualquer projeto; Nível Mundial: Específico para um determinado projeto; Nível Atômico: Seqüência algorítmica do projeto, específico para as tarefas do processo. Modelos de Processos 4

Introdução O desenvolvimento de software tem-se caracterizado por uma sobreposição de atividades necessárias para especificar, projetar e testar retorno dos resultados do software que está sendo criado. O feedback dessa atividade nos ajuda a compreender o que é necessário para criar um produto. A partir do feedback obtido em experiências com protótipos, podemos efetuar mudanças na forma e na construção conceitual do software. O feedback possui quatro formas básicas: Medições da entidade do software: número derivado de resultados produzidos por processos executores; Corretiva: erros, faltas e falhas cometidas no software; Mudança: Modificar o software para eliminar defeitos; Aprimoramento: Aperfeiçoar o software. Modelos de Processos 5

Modelos de Processo de Software Existem vários modelos de processo de software (ou paradigmas de engenharia de software) Cada um representa uma tentativa de colocar ordem em uma atividade inerentemente caótica Modelos de Processos 6

Modelos de Processo de Software O Modelo Sequencial Linear também chamado Modelo Cascata O Modelo de Prototipação O Modelo RAD (Rapid Application Development) Modelos Evolutivos de Processo de Software O Modelo Incremental O Modelo Espiral O Modelo de Montagem de Componentes Técnicas de Quarta Geração Modelos de Processos 7

Modelos de Processo de Software O Modelo Sequencial Linear também chamado Modelo Cascata O Paradigma de Prototipação O Modelo RAD (Rapid Application Development) Modelos Evolutivos de Processo de Software O Modelo Incremental O Modelo Espiral O Modelo de Montagem de Componentes Técnicas de Quarta Geração Modelos de Processos 8

O Modelo Cascata modelo mais antigo e o mais amplamente usado da engenharia de software modelado em função do ciclo da engenharia convencional requer uma abordagem sistemática, seqüencial ao desenvolvimento de software o resultado de uma fase se constitui na entrada da outra Modelos de Processos 9

O Modelo em Cascata Exploração de conceitos Requisitos Verificar Plano Evoluir Feedback Projeto Requisitos de V & V Implementação Testes Projeto de V & V Sistema de V & V Instalação e liberação Tarefas de V & V Manutenção e operação Sistema de V & V O quê Como Operação Operação de V & V Modelos de Processos 10

O Modelo em Cascata Exploração de Conceitos / Informação e Modelagem Engenharia de Sistemas Análise de Requisitos Envolve a elicitação de requisitos do sistema, com uma pequena Projeto quantidade de projeto e análise de alto nível; Preocupa-se com aquilo que conhecemos Codificação como engenharia progressiva de produto de software; Testes Iniciar com um modelo conceitual de alto nível para um sistema e prosseguir com o projeto, implementação e teste Manutenção do modelo físico do sistema. Modelos de Processos 11

O Modelo em Cascata Análise de Requisitos de Software o processo Engenharia de elicitação dos requisitos é Sistemas intensificado e Análise concentrado de especificamente no Requisitos software Projeto deve-se compreender o domínio Codificação da informação, a função, desempenho e interfaces exigidos Testes os requisitos (para o sistema e para o Manutenção software) são documentados e revistos com o cliente Modelos de Processos 12

O Modelo em Cascata Projeto tradução dos requisitos do software para um conjunto de representações que podem ser avaliadas quanto à qualidade, antes que a codificação inicie Modelos de Processos 13

O Modelo em Cascata Implementação tradução das representações do projeto para uma linguagem artificial resultando em instruções executáveis pelo computador e implementado num ambiente de trabalho. Modelos de Processos 14

O Modelo em Cascata Concentra-se: Testes nos aspectos lógicos internos do software, garantindo que todas as instruções tenham sido testadas nos aspectos funcionais externos, para descobrir erros e garantir que a entrada definida produza resultados que concordem com os esperados. Modelos de Processos 15

O Modelo em Cascata Manutenção provavelmente o software deverá sofrer mudanças depois que for entregue ao cliente causas das mudanças: erros, adaptação do software para acomodar mudanças em seu ambiente externo e exigência do cliente para acréscimos funcionais e de desempenho Modelos de Processos 16

Problemas com o Modelo em Cascata Projetos reais raramente seguem o fluxo seqüencial que o modelo propõe; Logo no início é difícil estabelecer explicitamente todos os requisitos. No começo dos projetos sempre existe uma incerteza natural; O cliente deve ter paciência. Uma versão executável do software só fica disponível numa etapa avançada do desenvolvimento (na instalação); Difícil identificação de sistemas legados (não acomoda a engenharia reversa). Modelos de Processos 17

Problemas com o Modelo em Cascata Embora o Modelo em Cascata tenha fragilidades, ele é significativamente melhor do que uma abordagem casual de desenvolvimento de software. Modelos de Processos 18

O Modelo em Cascata O Modelo de processo em Cascata trouxe contribuições importantes para o processo de desenvolvimento de software: Imposição de disciplina, planejamento e gerenciamento a implementação do produto deve ser postergada até que os objetivos tenham sido completamente entendidos; Permite gerência do baseline, que identifica um conjunto fixo de documentos produzidos ao longo do processo de desenvolvimento; Modelos de Processos 19

Modelos de Processo de Software O Modelo Sequencial Linear também chamado Modelo Cascata O Paradigma de Prototipação O Modelo RAD (Rapid Application Development) Modelos Evolutivos de Processo de Software O Modelo Incremental O Modelo Espiral O Modelo de Montagem de Componentes Técnicas de Quarta Geração Modelos de Processos 20

O Modelo de Prototipação o objetivo é entender os requisitos do usuário e, assim, obter uma melhor definição dos requisitos do sistema. possibilita que o desenvolvedor crie um modelo (protótipo)do software que deve ser construído apropriado para quando o cliente não definiu detalhadamente os requisitos. Modelos de Processos 21

O Paradigma de Prototipação para obtenção dos requisitos Obter Requisitos Refinamento do Protótipo Elaborar Projeto Rápido Avaliar Protótipo Construir Protótipo Modelos de Processos 22

O Paradigma de Prototipação para obtenção dos requisitos 1- OBTENÇÃO Obter Requisitos DOS REQUISITOS: desenvolvedor e cliente definem os objetivos gerais do software, identificam quais requisitos são conhecidos e as áreas que necessitam de definições adicionais. Refinamento do Protótipo Elaborar Projeto Rápido Avaliar Protótipo Construir Protótipo Modelos de Processos 23

O Paradigma de Prototipação para obtenção dos requisitos Obter Requisitos Refinamento do Protótipo Avaliar Protótipo 2- PROJETO RÁPIDO: R Elaborar Projeto Rápido representação dos aspectos do software que são visíveis ao usuário (abordagens de entrada e formatos de saída) Construir Protótipo Modelos de Processos 24

O Paradigma de Prototipação para obtenção dos requisitos Obter Requisitos Avaliar Protótipo Elaborar Projeto Rápido Refinamento do Protótipo 3- CONSTRUÇÃO DO PROTÓTIPO: TIPO: implementação rápida do projeto Construir Protótipo Modelos de Processos 25

O Paradigma de Prototipação para obtenção dos requisitos Obter Requisitos Refinamento do Protótipo Elaborar Projeto Rápido TIPO: cliente e desenvolvedor avaliam o protótipo 4- AVALIAÇÃO DO PROTÓTIPO Avaliar Protótipo Construir Protótipo Modelos de Processos 26

O Paradigma de Prototipação para obtenção dos requisitos Obter Requisitos 5- REFINAMENTO DO PROTÓTIPO: Refinamento do Protótipo Elaborar Projeto Rápido TIPO: cliente e desenvolvedor refinam os requisitos do software a ser desenvolvido. Avaliar Protótipo Construir Protótipo Modelos de Processos 27

O Paradigma de Prototipação para obtenção dos requisitos Obter Requisitos CONSTRUÇÃO DO Refinamento PRODUTO do Protótipo Elaborar Projeto Rápido Avaliar Protótipo Construir Protótipo Modelos de Processos 28

O Paradigma de Prototipação para obtenção dos requisitos Obter Requisitos 6- CONSTRUÇÃO PRODUTO: identificados os requisitos, o protótipo deve ser descartado e a versão de produção deve ser construída considerando os critérios de qualidade. CONSTRUÇÃO DO Refinamento PRODUTO do Protótipo Avaliar Protótipo Elaborar Projeto Rápido Construir Protótipo Modelos de Processos 29

Problemas com a Prototipação cliente não sabe que o software que ele vê não considerou, durante o desenvolvimento, a qualidade global e a manutenibilidade a longo prazo desenvolvedor freqüentemente faz uma implementação comprometida (utilizando o que está disponível) com o objetivo de produzir rapidamente um protótipo Modelos de Processos 30

Comentários sobre o Paradigma de Prototipação ainda que possam ocorrer problemas, a prototipação é um ciclo de vida eficiente. a chave é definir as regras do jogo logo no começo. o cliente e o desenvolvedor devem ambos concordar que o protótipo seja construído para servir como um mecanismo para definir os requisitos Modelos de Processos 31

Modelos de Processo de Software O Modelo Sequencial Linear também chamado Modelo Cascata O Paradigma de Prototipação O Modelo RAD (Rapid Application Development) Modelos Evolutivos de Processo de Software O Modelo Incremental O Modelo Espiral O Modelo de Montagem de Componentes O Modelo de Desenvolvimento Concorrente Modelos de Métodos Formais Técnicas de Quarta Geração Modelos de Processos 32

O Modelo RAD RAD ( Rapid Application Development) é um modelo sequencial linear que enfatiza um ciclo de desenvolvimento extremamente curto O desenvolvimento rápido é obtido usando uma abordagem de construção baseada em componentes. Modelos de Processos 33

O Modelo RAD Os requisitos devem ser bem entendidos e o alcance do projeto restrito O modelo RAD é usado principalmente para aplicações de sistema de informação Cada função principal pode ser direcionada para uma equipe RAD separada e então integrada para formar o todo. Modelos de Processos 34

O Modelo RAD Equipe #1 Modelagem do Negócio Modelagem dos Dados 60 a 90 dias Equipe #2 Modelagem do Processo Modelagem do Negócio Modelagem dos Dados Modelagem Geração da Aplicação Equipe #3 Modelagem do Negócio do Processo Geração da Aplicação Teste e Modificação Teste e Modificação Modelagem dos Dados Modelagem do Processo Geração da Aplicação Teste e Modificação Modelos de Processos 35

O Modelo RAD Desvantagens: Exige recursos humanos suficientes para todas as equipes Exige que desenvolvedores e clientes estejam comprometidos com as atividades de fogorápido a fim de terminar o projeto num prazo curto Modelos de Processos 36

O Modelo RAD Nem todos os tipos de aplicação são apropriadas para o RAD: Deve ser possível a modularização efetiva da aplicação se alto desempenho é uma característica e o desempenho é obtido sintonizando as interfaces dos componentes do sistema, a abordagem RAD pode não funcionar Modelos de Processos 37

Modelos de Processo de Software O Modelo Sequencial Linear também chamado Modelo Cascata O Paradigma de Prototipação O Modelo RAD (Rapid Application Development) Modelos Evolutivos de Processo de Software O Modelo Incremental O Modelo Espiral O Modelo de Montagem de Componentes Técnicas de Quarta Geração Modelos de Processos 38

Modelos Evolutivos de Processo Existem situações em que a engenharia de software necessita de um modelo de processo que possa acomodar um produto que evolui com o tempo. Modelos de Processos 39

Modelos Evolutivos de Processo quando os requisitos de produto e de negócio mudam conforme o desenvolvimento prossegue quando uma data de entrega apertada (mercado) - impossível a conclusão de um produto completo quando um conjunto de requisitos importantes é bem conhecido, porém os detalhes ainda devem ser definidos Modelos de Processos 40

Modelos Evolutivos de Processo modelos evolutivos são iterativos possibilitam o desenvolvimento de versões cada vez mais completas do software Modelos de Processos 41

Modelos de Processo de Software O Modelo Sequencial Linear também chamado Modelo Cascata O Paradigma de Prototipação O Modelo RAD (Rapid Application Development) Modelos Evolutivos de Processo de Software O Modelo Incremental O Modelo Espiral O Modelo de Montagem de Componentes Técnicas de Quarta Geração Modelos de Processos 42

O Modelo Incremental o modelo incremental combina elementos do modelo cascata (aplicado repetidamente) com a filosofia iterativa da prototipação o objetivo é trabalhar junto do usuário para descobrir seus requisitos, de maneira incremental, até que o produto final seja obtido. Modelos de Processos 43

O Modelo Incremental Versão Inicial Análise Análise Projeto Projeto Descrição geral Engenharia de sistemas/informação Codificação Codificação Versões Intermediárias Descrição geral Teste Teste Versão Final Modelos de Processos 44

O Modelo Incremental a versão inicial é frequentemente o núcleo do produto (a parte mais importante) a evolução acontece quando novas características são adicionadas à medida que são sugeridas pelo usuário Este modelo é importante quando é difícil estabelecer a priori uma especificação detalhada dos requisitos Modelos de Processos 45

O Modelo Incremental o modelo incremental é mais apropriado para sistemas pequenos As novas versões podem ser planejadas de modo que os riscos técnicos possam ser administrados (Ex. disponibilidade de determinado hardware) Modelos de Processos 46

Modelos de Processo de Software O Modelo Sequencial Linear também chamado Modelo Cascata O Modelo de Prototipação O Modelo RAD (Rapid Application Development) Modelos Evolutivos de Processo de Software O Modelo Incremental O Modelo Espiral O Modelo de Montagem de Componentes Técnicas de Quarta Geração Modelos de Processos 47

O Modelo Espiral (Boehm, 1986) O modelo espiral acopla a natureza iterativa da prototipação com os aspectos controlados e sistemáticos do modelo cascata. O modelo espiral é dividido em uma série de atividades de trabalho ou regiões de tarefa. Existem tipicamente de 3 a 6 regiões de tarefa. Combina as características positivas da gerência baseline (documentos associados ao processo); Modelos de Processos 48

O Modelo Espiral (com 4 regiões) DETERMINAR OBJETIVOS, ALTERNATIVAS E RESTRIÇÕES PLANEJAR PRÓXIMA FASE REVIEW Requirements plan Life-cycle plan Develop ment plan Integrati on and test p lan Risk analys is Risk analys is Risk analys is Prototyp e 2 Risk analysis Prototy pe 1 Concept of Operati on Requi rement valid ation Desi gn V&V Serv ice S/W requi rement s Accep tance test AVALIAR ALTERNATIVAS IDENTIFICAR, RESOLVER RISCOS Prototype 3 Operati onal protoyp e Simulations, models, b en chmarks Prod uct desi gn Integr ati on test Code Unit test Detail ed desi gn DESENVOLVER, VERIFICAR O PRODUTO NO PRÓXIMO NÍVEL Modelos de Processos 49

O Modelo Espiral (com 4 regiões) DETERMINAR OBJETIVOS, ALTERNATIVAS E RESTRIÇÕES cada ciclo na espiral representa uma fase do processo de software PLANEJAR PRÓXIMA FASE REVIEW Requirements plan Life-cycle plan Develop ment plan Integrati on and test p lan Risk analys is Risk analys is Risk analys is Prototyp e 2 Risk analysis Prototy pe 1 Concept of Operati on Requi rement valid ation Desi gn V&V Serv ice S/W requi rement s Accep tance test AVALIAR ALTERNATIVAS IDENTIFICAR, RESOLVER RISCOS Prototype 3 Operati onal protoyp e Simulations, models, b en chmarks Prod uct desi gn Integr ati on test Code Unit test Detail ed desi gn DESENVOLVER, VERIFICAR O PRODUTO NO PRÓXIMO NÍVEL Modelos de Processos 50

O Modelo Espiral de Processo de Software o ciclo mais interno está concentrado nas possibilidades do sistema REVIEW Requirements plan Life-cycle plan Risk analysis Prototy pe 1 Concept of Operati on Modelos de Processos 51

O Modelo Espiral de Processo de Software o próximo ciclo está concentrado na definição dos requisitos do sistema Development plan Risk analys is Requi rement validati on Prototype SW requi rements Simulations, models, benchmarks Modelos de Processos 52

O Modelo Espiral de Processo de Software Risk analys is o ciclo um pouco mais externo está concentrado no projeto do sistema prototype 3 si mul ati ons, models, benchmarks Product desi gn Integrati on and test plan Desi gn V&V Modelos de Processos 53

O Modelo Espiral de Processo de Software Risk nalys is um ciclo ainda mais externo está concentrado na construção do sistema Serv ice Acceptance test Operati onal protoype Simulations, models, benchmarks Integrati on test Code Unit test Detail ed desi gn Modelos de Processos 54

O Modelo Espiral (com 4 regiões) DETERMINAR OBJETIVOS, ALTERNATIVAS E RESTRIÇÕES Risk analys is não existem fases fixas no modelo Risk analys is Risk analys is Operati onal as fases mostradas na figura são Prototype 3meramente Prototyp e 2 protoyp e Risk exemplos REVIEW analysis Prototy pe 1 Requirements plan Simulations, models, b en chmarks a gerência decide Life-cycle plan como Concept ofestruturar o projeto Operati on S/W requi rement s em fases PLANEJAR PRÓXIMA FASE Develop ment plan Integrati on and test p lan Requi rement valid ation Desi gn V&V Serv ice Accep tance test AVALIAR ALTERNATIVAS IDENTIFICAR, RESOLVER RISCOS Prod uct desi gn Integr ati on test Code Unit test Detail ed desi gn DESENVOLVER, VERIFICAR O PRODUTO NO PRÓXIMO NÍVEL Modelos de Processos 55

O Modelo Espiral (com 4 regiões) Cada loop do espiral é dividido em 4 setores DETERMINAR OBJETIVOS, ALTERNATIVAS E RESTRIÇÕES ESTABELECIMENTO DE OBJETIVOS PLANEJAMENTO PLANEJAR PRÓXIMA FASE REVIEW Requirements plan Life-cycle plan Develop ment plan Integrati on and test p lan Risk analys is Risk analys is Risk analys is Prototyp e 2 Risk analysis Prototy pe 1 Concept of Operati on Requi rement valid ation Desi gn V&V Serv ice S/W requi rement s Accep tance test AVALIAR ALTERNATIVAS IDENTIFICAR, RESOLVER RISCOS AVALIAÇÃO E REDUÇÃO DE RISCOS Prototype 3 Operati onal protoyp e Simulations, models, b en chmarks Prod uct desi gn Integr ati on test Code Unit test Detail ed desi gn DESENVOLVIMENTO E VALIDAÇÃO DESENVOLVER, VERIFICAR O PRODUTO NO PRÓXIMO NÍVEL Modelos de Processos 56

O Modelo Espiral de Processo de Software ESTABELECIMENTO DE OBJETIVOS são definidos objetivos específicos para a fase do projeto são identificadas restrições sobre o processo e o produto é projetado um plano de gerenciamento detalhado são identificados riscos do projeto dependendo dos riscos, estratégias alternativas podem ser planejadas Modelos de Processos 57

O Modelo Espiral de Processo de Software para cada um dos riscos identificados, COLOCAÇÃO DE uma análise detalhada é executada. OBJETIVOS passos são tomados para reduzir o risco AVALIAÇÃO E REDUÇÃO DE RISCOS Modelos de Processos 58

O Modelo Espiral de Processo de Software ESTABELECIMENTO DE OBJETIVOS AVALIAÇÃO E REDUÇÃO DE RISCOS depois da avaliação do risco, um modelo de desenvolvimento é escolhido para o sistema DESENVOLVIMENTO E VALIDAÇÃO Modelos de Processos 59

O Modelo Espiral de Processo de Software COLOCAÇÃO DE OBJETIVOS PLANEJAMENTO AVALIAÇÃO E REDUÇÃO DE RISCOS o projeto é revisto e é tomada uma decisão de continuidade se é decidido continuar, são projetados planos DESENVOLVIMENTO para a próxima fase do projeto (próximo E VALIDAÇÃO loop ) Modelos de Processos 60

O Modelo Espiral engloba as melhores características do ciclo de vida Clássico e da Prototipação, adicionando um novo elemento: a Análise de Risco segue a abordagem de passos sistemáticos do Ciclo de Vida Clássico incorporando-os numa estrutura iterativa que reflete mais realisticamente o mundo real usa a Prototipação em todas as etapas da evolução do produto, como mecanismo de redução de riscos Modelos de Processos 61

Comentários sobre o Ciclo de Vida em Espiral é, atualmente, a abordagem mais realística para o desenvolvimento de software em grande escala. usa uma abordagem que capacita o desenvolvedor e o cliente a entender e reagir aos riscos em cada etapa evolutiva pode ser difícil convencer os clientes que uma abordagem "evolutiva" é controlável Modelos de Processos 62

Comentários sobre o Ciclo de Vida em Espiral exige considerável experiência na determinação de riscos e depende dessa experiência para ter sucesso o modelo é relativamente novo e não tem sido amplamente usado. Demorará muitos anos até que a eficácia desse modelo possa ser determinada com certeza absoluta Modelos de Processos 63

O Modelo Espiral (com 6 regiões) (win win) Planejamento Análise de Riscos Comunicação com Cliente Engenharia Avaliação do Cliente Construção e Liberação Modelos de Processos 64

O Modelo Espiral adiciona um novo elemento: a Análise de Risco usa a Prototipação, em qualquer etapa da evolução do produto, como mecanismo de redução de riscos exige considerável experiência na determinação de riscos e depende dessa experiência para ter sucesso o modelo é relativamente novo e não tem sido amplamente usado. Modelos de Processos 65

Modelos de Processo de Software O Modelo Sequencial Linear também chamado Modelo Cascata O Modelo de Prototipação O Modelo RAD (Rapid Application Development) Modelos Evolutivos de Processo de Software O Modelo Incremental O Modelo Espiral O Modelo de Montagem de Componentes Técnicas de Quarta Geração Modelos de Processos 66

O Modelo de Montagem de Componentes Utiliza tecnologias orientadas a objeto Quando projetadas e implementadas apropriadamente as classes orientadas a objeto são reutilizáveis em diferentes aplicações e arquiteturas de sistema O modelo de montagem de componentes incorpora muitas das características do modelo espiral. Modelos de Processos 67

O Modelo de Montagem de Componentes Planejamento Análise de Riscos Comunicação com Cliente Avaliação do Cliente Engenharia Construção e Liberação Modelos de Processos 68

O Modelo de Montagem de identificar componentes candidatas Componentes procurar componentes na biblioteca Planejamento Construir a n a iteração do sistema Análise de Riscos Comunicação extrair com Cliente componentes se disponíveis colocar os novos componentes na biblioteca Avaliação do Cliente construir os componentes não disponíveis Engenharia Construção e Liberação Modelos de Processos 69

O Modelo de Montagem de Componentes O modelo de montagem de componentes conduz ao reuso do software a reusabilidade fornece uma série de benefícios: redução de até 70% no tempo de desenvolvimento redução de até 84% no custo do projeto índice de produtividade de até 26.2 (normal da indústria é de 16.9) esses resultados dependem da robustez da biblioteca de componentes Modelos de Processos 70

Modelos de Processo de Software O Modelo Sequencial Linear também chamado Modelo Cascata O Modelo de Prototipação O Modelo RAD (Rapid Application Development) Modelos Evolutivos de Processo de Software O Modelo Incremental O Modelo Espiral O Modelo de Montagem de Componentes Técnicas de Quarta Geração Modelos de Processos 71

Técnicas de 4 a Geração Concentra-se na capacidade de se especificar o software para uma máquina em um nível que esteja próximo à linguagem natural Engloba um conjunto de ferramentas de software que possibilitam que: o sistema seja especificado em uma linguagem de alto nível e o código fonte seja gerado automaticamente a partir dessas especificações Modelos de Processos 72

Ferramentas do Ambiente das Técnicas de 4 a Geração O ambiente de desenvolvimento de software que sustenta o ciclo de vida de 4 a geração inclui as ferramentas: linguagens não procedimentais para consulta de banco de dados geração de relatórios manipulação de dados interação e definição de telas geração de códigos capacidade gráfica de alto nível capacidade de planilhas eletrônicas Modelos de Processos 73

Técnicas de 4 a Geração Obtenção dos Requisitos Estratégia do Projeto Implementação usando 4GL Testes Modelos de Processos 74

Técnicas de 4 a Geração OBTENÇÃO DOS REQUISITOS: Obtenção dos Requisitos o cliente descreve os requisitos, que são traduzidos para um protótipo operacional Estratégia do o cliente pode Projeto estar inseguro Implementação quanto aos requisitos usando 4GL Testes o cliente pode ser incapaz de especificar as informações de um modo que uma ferramenta 4GL possa consumir as 4GLs atuais não são sofisticadas suficientemente para acomodar a verdadeira "linguagem natural" Modelos de Processos 75

Técnicas de 4 a Geração ESTRATÉGIA DO "PROJETO": Obtenção dos Requisitos Para pequenas aplicações é possível moverse do passo Estratégia do Projeto de Obtenção dos Requisitos para o passo de Implementação usando uma usando 4GL linguagem de quarta geração Testes Para grandes projetos é necessário desenvolver uma estratégia de projeto. De outro modo ocorrerão os mesmos problemas encontrados quando se usa abordagem convencional (baixa qualidade) Modelos de Processos 76

Técnicas de 4 a Geração Obtenção dos Requisitos IMPLEMENTAÇÃO Estratégia do USANDO 4GL : Os resultados Projeto desejados Implementação são representados de modo que haja geração usando automática 4GL de código. Deve existir uma estrutura de dados com Testes informações relevantes e que seja acessível pela 4GL Modelos de Processos 77

Técnicas de 4 a Geração Obtenção dos Requisitos TESTES: Estratégia do Projeto Implementação usando 4GL Testes O desenvolvedor deve efetuar testes e desenvolver uma documentação significativa. O software desenvolvido deve ser construído de maneira que a manutenção possa ser efetuada prontamente. Modelos de Processos 78

Comentários sobre as Técnicas de 4 a Geração PROPONENTES: redução dramática no tempo de desenvolvimento do software (aumento de produtividade) OPONENTES: as 4GL atuais não são mais fáceis de usar do que as linguagens de programação o código fonte produzido é ineficiente a manutenibilidade de sistemas usando técnicas 4GL ainda é questionável Modelos de Processos 79

Para escolha de um Modelo de Processo de Software: natureza do projeto e da aplicação métodos e ferramentas a serem usados controles e produtos que precisam ser entregues Modelos de Processos 80