Guia de Contagem APF Versão 1.00 - RedeCompras

Transcrição

Guia de Contagem APF Versão 1.00 - RedeCompras
Guia de Contagem APF
Versão 1.00
Guia de Contagem APF
HISTÓRICO DE REVISÕES
Data
20/11/2010
Versão
1.00
Descrição
Criação do Guia de Contagem APF
Guia de Contagem APF ATI – www.ati.pe.gov.br
Autor
Célio Santana / Gustavo
Santos
Pág. 2 de 65
Guia de Contagem APF
SUMÁRIO
1. INTRODUÇÃO ............................................................................................................................................. 5
1.1. Definições, Acrônimos e Abreviações ............................................................................................. 5
2. OBJETIVOS DO DOCUMENTO .................................................................................................................. 6
3. ESTIMATIVAS DE PROJETO DE SOFTWARE .......................................................................................... 6
3.1. DETALHAMENTO DO PROCESSO DE ESTIMATIVA ................................................................. 10
3.2. PAGAMENTO BASEADO NO CICLO DE VIDA DA ENTREGA ................................................... 16
3.3. ESTIMATIVA DE PRAZO .............................................................................................................. 17
3.4. ESTIMATIVA DE CUSTO .............................................................................................................. 19
4. CONTAGEM DE PONTOS DE FUNÇÃO PARA PROJETOS DE MANUTENÇÃO .................................. 19
4.1. PROJETOS DE MELHORIA ......................................................................................................... 19
4.2. PROJETOS DE MANUTENÇÃO CORRETIVA ............................................................................ 23
4.3. MANUTENÇÃO COSMÉTICA ....................................................................................................... 24
4.4. MANUTENÇÃO ADAPTATIVA EM REQUISITOS NÃO FUNCIONAIS ........................................ 25
4.4.1. REDESENVOLVIMENTO DE PROJETOS EM OUTRA PLATAFORMA ............................. 25
4.4.2. ATUALIZAÇÃO DE PLATAFORMA...................................................................................... 25
4.4.3. ADEQUAÇÃO DE FUNCIONALIDADES ÀS MUDANÇAS DE NEGÓCIO .......................... 26
4.4.4. APURAÇÃO ESPECIAL ....................................................................................................... 27
4.4.5. MANUTENÇÃO EM PÁGINAS ESTÁTICAS DE INTRANET, INTERNET OU PORTAL..... 28
4.4.6. MANUTENÇÃO DE DOCUMENTAÇÃO DE SISTEMAS LEGADOS .................................. 29
4.4.7. VERIFICAÇÃO DE ERROS .................................................................................................. 30
4.4.8. FATOR DE CRITICIDADE DE SOLICITAÇÃO DE SERVIÇO ............................................. 30
4.4.9. PONTOS DE FUNÇÃO DE TESTE ...................................................................................... 30
5. ITENS NÃO MENSURÁVEIS ..................................................................................................................... 31
6. ASPECTOS NÃO CONSIDERADOS PELO IFPUG CONSIDERADOS PELA ATI ................................... 33
6.1. MÚLTIPLAS MÍDIAS ..................................................................................................................... 33
6.1.1. MÚLTIPLAS MÍDIAS ............................................................................................................. 35
6.1.2. MESMOS DADOS DE SAÍDA COMO DADOS EM ARQUIVOS E RELATÓRIOS IMPRESSO
35
6.1.3. MESMOS DADOS DE ENTRADA BATCH E ON-LINE........................................................ 35
6.1.4. MÚLTIPLOS CANAIS DE ENTREGA DA MESMA FUNCIONALIDADE ............................. 36
6.1.5. RELATÓRIOS EM MÚLTIPLOS FORMATOS ..................................................................... 36
6.2. DATA WAREHOUSE..................................................................................................................... 36
6.3. AUTOMAÇÃO DE PROCESSOS DE NEGÓCIO (BPM) .............................................................. 46
6.3.1. FRONTEIRA DA APLICAÇÃO .............................................................................................. 47
6.3.2. Situação acesso ao BPMS: .................................................................................................. 47
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 3 de 65
Guia de Contagem APF
6.3.3. Cadastro de usuários e grupos organizacionais: .................................................................. 47
6.3.4. Funcionalidades da aplicação Ágiles .................................................................................... 48
6.3.5. Recebimento de dados de outras aplicações utilizando interface de integração ................. 48
6.3.6. Atualização de dados em outras aplicações utilizando interface de integração .................. 49
6.3.7. Dados de Código .................................................................................................................. 49
6.3.8. Processo Elementar .............................................................................................................. 49
6.3.9. Atividade com prazos ............................................................................................................ 51
7. LIÇÕES APRENDIDAS .............................................................................................................................. 52
7.1. REQUISITOS ................................................................................................................................. 52
7.1.1. GRANULARIDADE X QUANTIDADE DE REQUISITOS...................................................... 52
7.1.2. ATENÇÃO A REQUISITOS NÃO FUNCIONAIS .................................................................. 52
7.1.3. ATENÇÃO A RELATÓRIOS ................................................................................................. 53
7.2. DICAS NA DEFINIÇÃO DA FRONTEIRA ..................................................................................... 53
7.3. DICAS NA IMPLANTAÇÃO DO PROCESSO ............................................................................... 54
8. CONSIDERAÇÕES SOBRE A CONTAGEM DE PONTOS DE FUNÇÃO ................................................ 55
8.1. CONSIDERAÇÃO SOBRE MUDANÇAS DE REQUISITOS ......................................................... 55
8.2. CONSIDERAÇÃO SOBRE PROJETOS CANCELADOS ............................................................. 56
8.3. CONSIDERAÇÕES SOBRE REDUÇÃO DE CRONOGRAMA..................................................... 57
8.4. CONSIDERAÇÕES SOBRE A PRECIFICAÇÃO .......................................................................... 57
8.4.1. Tamanho Funcional x Esforço de Desenvolvimento ............................................................ 58
8.4.2. Valor do Ponto de Função .................................................................................................... 58
8.4.3. Preço Ideal do Ponto de Função na APE ............................................................................. 59
8.4.4. Considerações ...................................................................................................................... 61
8.5. CONSIDERAÇÕES SOBRE CICLO DE VIDA ITERATIVO INCREMENTAL ............................... 62
8.6. COMO UMA EMPRESA PÚBLICA PODE SE FILIAR AO IFPUG. ............................................... 62
8.7. CERTIFICAÇÃO CFPS ................................................................................................................. 63
9. PROCESSO DE REVISÃO DO GUIA DE CONTAGEM ............................................................................ 64
9.1. REVISÃO PARA CORREÇÃO DE INCONSISTÊNCIAS E SITUAÇÕES NÃO PREVISTAS ...... 64
9.2. REVISÃO PARA ADOÇÃO DE NOVAS VERSÕES DO CPM...................................................... 64
10. CONCLUSÃO ........................................................................................................................................... 64
REFERÊNCIAS BIBLIOGRAFIAS ................................................................................................................. 64
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 4 de 65
Guia de Contagem APF
1. INTRODUÇÃO
A Agência Estadual de Tecnologia da Informação do Estado de Pernambuco (ATI-PE) seguindo o
caminho de muitas empresas governamentais brasileiras têm iniciado a utilização da métrica de Pontos de
Função (PF) nas estimativas e dimensionamento de tamanho funcional de projetos de software, devido aos
diversos benefícios de utilização da métrica tais como a independência da solução tecnológica utilizada e às
recomendações dos órgãos de controle do governo federal brasileiro.
O Manual de Práticas de Contagem de Pontos de Função ou (CPM) que hoje se apresenta na
versão 4.3, publicado pela International Function Point User Group (IFPUG) em 201, define as regras de
contagem de Pontos de Função. No entanto, a contagem de Pontos de Função é baseada no projeto lógico
da aplicação e nas fases iniciais do ciclo de vida do software, o documento de requisitos para a estimativa e
elaboração do plano do projeto é um documento inicial de requisitos, por exemplo: Documento de Visão,
Formalização Simples de Requisitos ou algum outro tipo de especificação elaborada pelo analista de
negócios. Assim, torna-se importante o estabelecimento de métodos para estimar o tamanho funcional dos
projetos de software nas fases iniciais do ciclo de vida.
Outro ponto a ser destacado é a importância da definição de métodos para geração de estimativas
de prazo, esforço, custo e recursos computacionais dos projetos de software da empresa, visando melhorar
o gerenciamento dos projetos. Além disso, é importante ressaltar que a métrica de Pontos de Função foi
concebida como uma medida de tamanho funcional para projetos de desenvolvimento e de manutenção
evolutiva de software. No entanto, os projetos de software não estão limitados a projetos de
desenvolvimento e projetos de manutenção evolutiva ou Melhoria (enhancement), admitindo normalmente
manutenções corretivas e perfectivas, bem como os projetos com características diferentes dos sistemas de
informações tradicionais, como projetos de BI, automação de processos e portais WEB, por exemplo.
Assim, torna-se essencial a definição de métodos para dimensionar o tamanho de projetos
manutenção (maintenance) e demais projetos cujas características não estejam cobertas pelo manual do
IFPUG, baseados em Pontos de Função, para que estes projetos possam ser avaliados e gerenciados com
base em uma métrica. Observe que a INSTRUÇÃO NORMATIVA Nº 4 DE 12 DE NOVEMBRO DE 2010,
publicada pela SLTI/ MPOG, preconiza a utilização de métricas em contratos de software. Os Acórdãos do
Tribunal de Contas da União (TCU) recomendam a utilização da métrica Pontos de Função Não Ajustados.
A versão 4.3 do CPM também reconhece o PF Não Ajustado como método padrão do IFPUG.
1.1. Definições, Acrônimos e Abreviações
APF: Análise de Pontos de Função;
CMMI-Acq: Capability Maturity Model Integration for Aquisition
CPM: Manual de Práticas de Contagens do IFPUG;
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 5 de 65
Guia de Contagem APF
MPS.BR: Melhoria de Processo do Software Brasileiro
IFPUG: International Function Points Group User (www.ifpug.org);
PF: Pontos de Função.
2. OBJETIVOS DO DOCUMENTO
Este documento tem como propósito apresentar um roteiro contagem de Pontos de Função
aderente ao Manual de Práticas de Contagem (CPM 4.3) e definir os tipos de projetos de manutenção e
uma sistemática para dimensionar o tamanho de tais projetos, utilizando a métrica Pontos de Função. Além
da contagem de Pontos de Função, este roteiro apresenta um processo de estimativas com base na métrica
Pontos de Função, proposto por Cláudia Hazan (2008).
Além disto, estará contido neste manual um conjunto de práticas de contagens que são
institucionalizadas pela ATI. Outra seção deste mesmo manual será destinada a documentar as lições
aprendidas da ATI durante o contínuo aprendizado da utilização da técnica.
Alem destas seções introdutórias, este documento encontra-se organizado da seguinte maneira: A
Seção 3 define o processo de estimativas de projetos de software integrado ao processo de
acompanhamento de contratos de fornecedores da ATI, indicando o momento de realização das estimativas
e as análises a serem realizadas; A Seção 4 apresenta diretrizes para a estimativa e a contagem de Pontos
de Função de todos os tipos de projetos de manutenção de software; A Seção 5 descreve as atividades
associadas ao processo de contratação cujos itens não são mensuráveis pela IFPUG em Pontos de
Função; A Seção 6 apresenta alguns aspectos que não estão presentes no Manual de Práticas de
Contagem do IFPUG e como a ATI considera tais aspectos; A Seção 7 apresenta as lições aprendidas pela
ATI na utilização de pontos por função. Estas lições podem ser dirigidas as práticas de contagens ou até
mesmo a forma de escrever os requisitos; A Seção 8 apresenta algumas considerações importantes sobre a
utilização de métricas para dimensionar as mudanças de requisitos, redução de cronograma e atividades de
negócio. Também apresenta considerações sobre o preço do ponto de função, certificação CTFP e filiação
ao IFPUG; A Seção 9 apresenta o processo de revisão deste guia de contagem; Finalmente, a Seção 10
conclui o documento apresentando sugestões para trabalhos futuros.
3. ESTIMATIVAS DE PROJETO DE SOFTWARE
Este Capítulo tem como propósito descrever um processo de estimativas de projetos de software
aderente ao modelo Capability Maturity Model Integration for Aquisition (CMMI-Acq), ao modelo de Melhoria
de Processo do Software Brasileiro (MPS.BR) e baseado no modelo proposto por Hazan (2008). Neste
contexto, são apresentados os sete níveis de métodos Contagem de Pontos de Função e quando cada um
deles deve ser utilizado para estimar o tamanho dos projetos de software em PF, alguns modelos
simplificados de estimativas para estimar o esforço dos projetos em homem_hora (HH), a fórmula de Capers
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 6 de 65
Guia de Contagem APF
Jones para estimar os prazos dos projetos. Será apresentada também nesta seção a integração do modelo
de contagem da ATI ao seu processo de desenvolvimento.
A Figura 1 ilustra um processo de Estimativas de Projetos de Software aderente à área de processo
de Planejamento do Projeto de Aquisição do nível 2 do CMMI-ACq. Este processo é baseado no modelo da
Cláudia Hazan (2008) e será descrito em linhas gerais nos parágrafos seguintes.
Legenda
Identificar a necessidade
de contagem para
contrato em APF
Identificar usuários,
reunir documentação e
levantar requisitos iniciais
da solução.
Determinar escopo da
contagem, fronteiras e
identificar requisitos
funcionais do usuário
Etapas
Etapas antes
antes do
do
inicio
inicio da
da Sprint.
Sprint.
Etapas
Etapas Durante
Durante aa
Sprint
Sprint
Identificar demandas que
serão implementadas na
Sprint
Agrupar demandas
ligadas ao mesmo
requisito funcional.
Derivar Custo e Prazo da
entrega baseado no
tamanho funcional.
Realizar contagem
funcional da entrega
realizada pelo fornecedor
Realizar contagem
estimativa de tamanho
funcional da Sprint
Etapas
Etapas Após
Após
Recebimento
Recebimento da
da
Sprint
Sprint
Etapas
Etapas durante
durante aa
transação
transação entre
entre
Sprints
Sprints
Reavaliar Custo e Prazo
da entrega realizada pelo
fornecedor
Base Histórica
Atualizar Base Histórica
do Projeto baseado na
diferenças entre a
estimativa e a Medição
Base Histórica
Figura 1: Processo de Estimativas de Projetos de Software
Este processo está inserido no contexto do processo “Scrum” da ATI. As três primeiras etapas
acontecem no momento de planejar a contratação. Neste momento em que são verificadas soluções
existentes no mercado, busca por propostas e levantamento das principais características da solução, é o
momento de se dimensionar uma contagem estimativa (o processo de contagem estimativa será detalhado
mais a frente).
As etapas na Sprint (vermelho) tem como principal insumo (artefato de entrada) um documento de
requisitos. Como as estimativas devem ser realizadas no início do processo de desenvolvimento de
software, ou mesmo da Sprint então, o artefato utilizado é um documento inicial de requisitos, por exemplo:
Documento de Visão ou Formalização Simples de Requisitos utilizados no Mantis da própria ATI.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 7 de 65
Guia de Contagem APF
O estimador deve analisar os requisitos para garantir a qualidade bem como agrupar as demandas
no mesmo requisito para evitar a contagens múltiplas da mesma função para só assim estimar o tamanho
do projeto de software. Embora nas etapas iniciais possa existir a contagem estimada do sistema, a mesma
só serve para dimensionamento do contrato e não para acompanhamento de projeto.
Assim, o próximo passo é a derivação das estimativas de prazo (cronograma) e (orçamento) da
demanda com base na estimativa de tamanho e nos dados históricos de projetos concluídos da
organização. Neste ponto, as principais estimativas foram geradas e precisam ser documentadas. As
premissas e suposições utilizadas na geração das estimativas, dentre outras: complexidade do projeto,
plataforma de desenvolvimento, tipo do projeto, percentual de evolução de requisitos, também devem ser
documentadas.
A realização das estimativas por um analista de métricas que não atue na equipe do projeto
constitui uma prática recomendada. O analista de métricas deve analisar também a consistência da
documentação utilizada na estimativa. No decorrer do processo de desenvolvimento, as estimativas devem
ser acompanhadas conforme o refinamento dos requisitos. O projeto deve ser reestimado após a fase de
requisitos, quando for gerada a especificação de casos de uso, e sempre que ocorrerem mudanças
significativas nos requisitos funcionais ou não funcionais.
Quando o projeto ou Sprint for concluído, deve-se novamente aferir e documentar o tamanho, prazo
e custo, assim como outros atributos relevantes do projeto, visando a coleta de dados para a melhoria do
processo de estimativas. As lições aprendidas também devem ser documentadas e incorporadas a este
guia, bem como a base histórica.
A alimentação contínua desta base histórica (Última atividade) é que irá garantir a ATI uma melhoria
das estimativas ao longo do projeto.
Desta forma, para os contratos de projetos de software baseados na métrica Pontos de Função as
estimativas devem ser realizadas em três marcos do processo de desenvolvimento, a saber:
Estimativa inicial: Realizada após o fechamento do escopo do projeto. Geralmente, é baseada em
um documento inicial de requisitos, por exemplo: o Documento de Visão. Constitui uma boa prática a
previsão de evolução de requisitos, especialmente em projetos de desenvolvimento de médio ou grande
porte. Seu objetivo é quantificar uma ordem de grandeza para o total de pontos por função que serão
empregados para construir determinada solução.
Nessa etapa é importante destacar os seguintes conceitos na área de estimativas: Uma Estimativa
é obtida por meio de uma atividade técnica, utilizando métodos de estimativas. Não deve sofrer
interferências políticas. A Meta é um desejo, em função de necessidades de negócio, estabelecida
politicamente.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 8 de 65
Guia de Contagem APF
Em um cenário ideal os resultados da estimativa atendem as metas de negócio. Quando este
cenário não é real, é fundamental a redução de escopo do projeto, de modo que a meta se adapte aos
resultados da estimativa. Neste momento, dependendo do detalhe da documentação, serão permitidos 04
(quatro) níveis de detalhamento de contagem dos 06 (seis) apresentados pela totalmetrics (2004).
O Nível menos detalhado é conhecido por se basear apenas na base histórica. Considere a Figura 2
como um exemplo hipotético de base histórica.
Figura 2: Base histórica do ISBSG e do Meu projeto
O sexto nível de contagem é dado pela estimativa mais estável desta base histórica. Suponha que o
elemento que menos varia nas contagens históricas da ATI seja a pontuação dos ALIs em relação ao
projeto todo. Considerando o projeto acima, os ALIs representam cerca de 27% da pontuação total do
projeto. Então neste caso é apenas desejado se calcular a pontuação de todos os ALIS e aplicar a regra de
três.
Vale ressaltar que é importante escolher a estrutura que menos varia no processo. Suponha que
para o caso anterior as saídas externas, que representam em média 12% do total de pontuação dos
projetos da ATI, variem entre 0% e 40%, então, não é um elemento confiável para a escolha da regra de
três.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 9 de 65
Guia de Contagem APF
O quinto nível é conhecido como contagem indicativa, onde é necessário apenas identificar os ALIs
e AIEs da aplicação. Não é necessário detalhar as funções de dados, nem identificar as funções de
transação. Uma vez identificadas as funções de dados é utilizada a fórmula a seguir:
PF = 35*N° de ALIs + 15*N° de AIEs
Estes números de 35 e 15 podem ser calibrados para melhor representar as necessidades da
organização e devem ser guiados pela base histórica da mesma.
O quarto nível é conhecido como contagem estimativa da NESMA. Nesta contagem é necessário
identificar todas as funções de dados e todas as funções de transação. Para realizar esta contagem é
necessário considerar todas as funções de dados simples e todas as funções transacionais médias.
Vale ressaltar que estas contagens não devem ser utilizadas em conjunto com o fornecedor, estas
contagens são apenas para dimensionar um valor de pontos de função que um contrato pode precisar.
O segundo marco de contagem é a contagem intermediária que deve ser realizada antes da
execução de cada demanda. Neste marco já deve existir documentação dos requisitos suficientes para a
realização de uma contagem detalhada que é o 3° Nível de detalhamento proposto pela totalmetrics (2004)
e que coincide com a contagem IFPUG considerando as faixas de contagem.
Neste momento também pode ser realizada a contagem interligada e anotada (1° Nível) que tem
toda rastreabilidade da contagem bem como o detalhamento dos itens de dados.
O terceiro marco de contagem é a contagem final que deve ser realizada ao final da execução.
Este marco deve ser utilizado para emissão de fatura e pagamento ao fornecedor. Para tal deve-se utilizar
os níveis de detalhamento de contagem do 3 até o 1. Para fins de faturamento, que é realizado durante o
desenvolvimento, deve-se considerar a Contagem de Referência e posteriormente considerar os ajustes no
faturamento após a Contagem Final. É importante ressaltar que as mudanças de requisitos também serão
consideradas no tamanho projeto a ser faturado. Além disso, se estas mudanças forem significativas,
maiores que a evolução de requisitos prevista na estimativa inicial, o prazo do projeto deve ser reestimado.
Toda mudança de requisito deve passar por uma análise de impacto da ATI e ser aprovada pelo cliente.
3.1. DETALHAMENTO DO PROCESSO DE ESTIMATIVA
O processo de estimativa utilizado visa aferir o tamanho em PF podendo ser de maneira
simplificada para os níveis de detalhamento 4, 5 e 6. Estas contagens simplificadas são baseadas no
conhecimento dos requisitos iniciais do projeto e na documentação do contrato. Inicialmente, os requisitos
funcionais iniciais documentados nas propostas comerciais, nos documentos de visão, formalização simples
de requisitos ou em qualquer especificação inicial do sistema do usuário são mapeados nos tipos funcionais
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 10 de 65
Guia de Contagem APF
da Análise de Pontos de Função: Arquivo Lógico Interno (ALI), Arquivo de Interface Externa (AIE), Entrada
Externa (EE), Consulta Externa (CE) e Saída Externa (SE).
Posteriormente, os Pontos de Função são associados a cada função identificada, baseando-se nas
tabelas de complexidade e de contribuição funcional do CPM (Figura 3).
Figura 3: Modelo Lógico da Análise de Pontos de Função [SERPRO 2010]
O estimador deve realizar uma leitura no documento inicial de requisitos, buscando informações
relevantes para a identificação de processos elementares. O processo elementar é definido como a menor
unidade de atividade significativa para o usuário. O processo elementar deve ser completo em si mesmo,
independente e deixar a aplicação em um estado consistente [IFPUG, 2010]. Em outras palavras, os
processos elementares são funções transacionais independentes, isto é, funções seqüenciais pertencem a
um mesmo processo elementar e funções independentes constituem processos elementares diferentes.
Uma vez identificado o processo elementar, o estimador deve buscar o entendimento deste para
classificá-lo em Entrada Externa (EE), Consulta Externa (CE) ou Saída Externa (SE). Adicionalmente, o
estimador deve descobrir os dados associados ao processo elementar, visando a determinação da
complexidade funcional da função identificada. Na análise do processo elementar também são identificados
os grupos de dados lógicos da aplicação, que são classificados como Arquivos Lógicos Internos (ALI) ou
Arquivos de Interface Externa (AIE).
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 11 de 65
Guia de Contagem APF
A determinação do nível de detalhamento da contagem depende da documentação obtida. Caso
seja possível identificar todas as funções de AIE e ALI o ideal é utilizar o 5° Nível de detalhamento (AIE * 35
+ AIE * 15). Quando não existe detalhamento suficiente sobre alguma das informações como ALI, AIE é
mais difícil encontrar EE, SE e CE nestas condições, pois elas dependem do ALI e AIE. Neste caso, devese utilizar o 6º nível de detalhamento.
Caso não seja possível a identificação da complexidade das funcionalidades é melhor usar o
método da Nesma, ou 4° nível de detalhe em questão, recomenda-se a utilização da complexidade Média.
Na análise do processo elementar também são identificados, os grupos de dados lógicos da aplicação, que
são classificados como Arquivos Lógicos Internos ou Arquivos de Interface Externa. Caso não seja possível
a identificação da complexidade da função de dados em questão, recomenda-se a utilização da
complexidade Simples. É importante ressaltar que se o estimador identificar mais de um Registro Lógico no
Arquivo Lógico Interno,recomenda-se utilizar a complexidade Média.
A seguir são apresentadas dicas para ajudar no mapeamento dos requisitos funcionais da aplicação
nos tipos funcionais da APF. As necessidades e funcionalidades especificadas para o projeto, contidas no
documento inicial de requisitos, devem ser enquadradas em uma das seguintes categorias:
Arquivos Lógicos Internos (ALI): Banco de Dados Lógico da Aplicação (tabelas e arquivos
mantidos pela aplicação).
Considerações: Identifique os grupos de dados lógicos de aplicação nos modelos de dados ou
diagrama de classes ou a partir dos requisitos funcionais, descritos nos documentos de requisitos
(Documento de Visão, Relação de Casos de Uso, etc.). Não considere arquivos físicos, arquivos de índices,
arquivos de trabalho e tabelas de relacionamento sem atributos próprios (tabelas que existem para quebrar
o relacionamento nxn e apenas transportam as chaves estrangeiras).
As entidades fracas também não são consideradas um ALI. Se possível, tente descobrir os atributos
lógicos, campos reconhecidos pelo usuário, e subgrupos de dados existentes para obter a complexidade
funcional, segundo as regras de contagem do CPM. Caso não seja possível, a experiência tem mostrado
que a maioria dos ALIs dos sistemas são de complexidade Simples.
A pontuação destes elementos segundo o IFPUG está descrita na Tabela 1
Tabela 1: Pontuação dos Arquivos Lógicos Internos [IFPUG 2010]
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 12 de 65
Guia de Contagem APF
Arquivos de Interface Externa (AIE): Banco de Dados de outras Aplicações, apenas referenciados
pela aplicação que está sendo estimada (tabelas e arquivos mantidos por outra aplicação).
Considerações: Identifique os grupos de dados lógicos de outras aplicações referenciados pela
aplicação que está sendo estimada. Freqüentemente, a referência de dados ocorre para a validação de
informações em cadastros ou consultas. Algumas vezes, relatórios ou consultas referenciam dados
externos de outras aplicações, também considerados AIEs. Não são considerados arquivos físicos, arquivos
de índice, arquivos de trabalho, tabelas de relacionamento sem atributos próprios e entidades fracas.
Geralmente, os AIEs dos sistemas possuem a classificação de complexidade Simples. Porque, são
considerados para a determinação da complexidade funcional do AIE apenas os atributos referenciados
pela aplicação que está sendo contada.
A pontuação destes elementos segundo o IFPUG está descrita na Tabela 2
Tabela 2: Pontuação dos Arquivos de Interface Externa [IFPUG 2010]
Entradas Externas (EE): Funcionalidades que mantêm os Arquivos Lógicos Internos (ALIs) ou
alteram o comportamento da aplicação.
Considerações: Identifique as funcionalidades de manutenção de dados. Conte separadamente a
inclusão, alteração e exclusão de dados, isto é, cada função independente de inclusão ou alteração ou
exclusão deve ser contada separadamente. A aplicação possui funções de entrada de dados que alteram o
comportamento dela, por exemplo: processamentos batch, ou processamento de informações de controle?
Caso positivo, estas funções também devem ser identificadas como Entradas Externas. Se você
não possui conhecimento sobre o processo elementar (funcionalidade analisada), considere as Entrada
Externa identificada com complexidade Média.
A pontuação destes elementos segundo o IFPUG está descrita na Tabela 3
Tabela 3: Pontuação das Entradas Externas [IFPUG 2010]
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 13 de 65
Guia de Contagem APF
Consultas Externas (CE): funcionalidades que apresentam informações para o usuário sem a
utilização de cálculos ou algoritmos. São os processos elementares do tipo “lê - imprime”, “lê - apresenta
dados”, incluindo consultas, relatórios, geração de arquivos pdf, xls, downloads, entre outros.
Considerações: Uma funcionalidade é desenvolvida para apresentar informações para o usuário:
uma consulta, relatório, browse, listbox, download, geração de um arquivo, geração de arquivo psd, xls?
Esta função não possui cálculos ou algoritmos para derivação dos dados referenciados nem altera um
Arquivo Lógico Interno, nem muda o comportamento do sistema? Caso positivo, estas funções devem ser
identificadas como Consultas Externas.
Se você não possui conhecimento sobre o processo elementar (funcionalidade analisada),
considere as Consultas Externas com complexidade Média.
A pontuação destes elementos segundo o IFPUG está descrita na Tabela 4
Tabela 4: Pontuação das Consultas Externas [IFPUG 2010]
Saídas Externas (SE): Funcionalidades que apresentam informações para o usuário com utilização
de cálculos ou algoritmos para derivação de dados ou atualização de Arquivos Lógicos Internos ou
mudança de comportamento da aplicação. São as consultas ou relatórios com totalização de dados,
relatórios estatísticos, gráficos, geração de arquivos com atualização log, downloads com cálculo de
percentual, entre outros.
Considerações: Uma funcionalidade é desenvolvida para apresentar informações para o usuário:
uma consulta ou relatório com totalização de dados, etiquetas de código de barras, gráficos, relatórios
estatísticos, download com percentual calculado, geração de arquivo com atualização de log? Caso
positivo, estas funções devem ser identificadas como Saídas Externas. Observe que esta função deve ter
cálculos ou algoritmos para processar os dados referenciados nos arquivos lógicos ou atualizar campos
(normalmente indicadores) nos arquivos ou mudar o comportamento da aplicação.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 14 de 65
Guia de Contagem APF
Caso não haja conhecimento da aplicação de APF ou sobre o processo elementar (funcionalidade
analisada), considere as Saídas Externas com complexidade Média.
A pontuação destes elementos segundo o IFPUG está descrita na Tabela 5
Tabela 5: Pontuação das Consultas Externas [IFPUG 2010]
A Estimativa de tamanho do projeto em PFs deve ser gerada totalizando-se os PFs obtidos nas
Tabelas 1, 2, 3, 4, e 5.
A fórmula de contagem ou de estimativa de Pontos de Função para Projetos de Desenvolvimento é
a seguinte:
Quadro 1: Totalização da Pontuação em Desenvolvimento de Software [IFPUG 2010]
A fórmula de contagem ou de estimativa de Pontos de Função para Softwares Prontos é a seguinte:
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 15 de 65
Guia de Contagem APF
Quadro 2: Totalização da Pontuação para Aplicações Prontas [IFPUG 2010]
A fórmula de contagem ou de estimativa de Pontos de Função para Projetos de Melhoria é a
seguinte:
Quadro 3: Totalização da Pontuação para Aplicações Prontas [IFPUG 2010]
3.2. PAGAMENTO BASEADO NO CICLO DE VIDA DA ENTREGA
O próximo passo é a definição da forma de pagamento baseado pelas entregas, visando remunerar
o fornecedor pelos produtos liberados em cada entrega, tornando o processo menos oneroso para o mesmo
e incentivando a cumprir resultados. Está facultado a ATI decidir se irá utilizar este tipo de pagamento e em
qualquer granularidade, tais como editais ou contratos.
Assim a ATI pode inclusive pagar apenas uma porcentagem do valor cheio de uma determinada
demanda se “partes” das entregas não forem necessárias naquele contrato. Atualmente a ATI utiliza a
seguinte distribuição (Tabela 6).
Tabela 6: Remuneração da ATI por fase de Ciclo de Vida
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 16 de 65
Guia de Contagem APF
3.3. ESTIMATIVA DE PRAZO
As estimativas de prazo não são lineares com o tamanho do projeto. O melhor tempo de
desenvolvimento, no qual há uma melhor relação custo x benefício de alocação de recursos e menor prazo
de desenvolvimento, dado o tamanho de um projeto específico, é sugerido e utilizado nas estimativas de
prazo deste manual. Jones [Jones, 2007] propõe uma fórmula para o cálculo do melhor tempo de
desenvolvimento, denominado Td e de Região Impossível (RI) de desenvolvimento (Figura 4).
Na Região Impossível (RI), a adição de mais recursos ao projeto não implicará em redução no
prazo. Note que a curva mostra que quanto menor o prazo almejado para a conclusão do projeto, maior
será o esforço requerido e consequentemente maior o custo do projeto. O aumento do esforço para reduzir
o prazo acontece através da realização de horas extras e da inclusão de pessoal adicional, gerando
retrabalho. No entanto, a redução de prazo tem um limite, como demonstra a região impossível.
O método utilizado para estimar o prazo dos projetos (Td) é baseado na fórmula de Capers Jones
[Jones, 2007]. A fórmula de Capers Jones estima o prazo, baseando-se no tamanho do projeto em Pontos
de Função, da seguinte maneira:
Td = V t
Td: prazo de desenvolvimento
V: tamanho do projeto em Pontos de Função
t: o expoente t é definido de acordo com a Tabela 7
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 17 de 65
Guia de Contagem APF
Figura 4: Relação entre a Estimativa de Prazo e de Esforço [Jones 2007]
Tabela 7: Expoente t por tipo de Projeto
Tipo de Sistema
Expoente t
Sistema Comum – Mainframe (desenvolvimento de
sistema com alto grau de reuso ou manutenção evolutiva)
Sistema Comum – Web ou Cliente Servidor
Sistema OO (se o projeto OO não for novidade para
equipe, não tiver o desenvolvimento de componentes
reusáveis, considerar sistema comum)
Sistema Cliente/Servidor (com alta complexidade
arquitetural e integração com outros sistemas)
Sistemas Gerenciais complexos com muitas integrações,
Datawarehousing, Geoprocessamento, Workflow
Software Básico, Frameworks, Sistemas Comerciais
0,32 a 0,33
0,34 a 0,35
0,36
0,37
0,39
0,40
É importante destacar que o método só funciona para projetos com mais de 100 PFs. Caso o
projeto seja menor, o prazo deve ser obtido por meio de WBS. O prazo calculado considera todo o ciclo de
vida do projeto, desde a fase de requisitos até a implantação. Assim, caso a estimativa tenha sido realizada
ao final da fase de requisitos, descontar do prazo restante, o tempo gasto com a fase de requisitos.
Caso seja necessário receber o projeto em um prazo menor que o tudo calculado, recomenda-se
propor um processo de desenvolvimento incremental, priorizando funcionalidades em cada iteração de
acordo com a necessidade dele. Caso, ainda assim, a estimativa não atenda às necessidades do cliente,
então pode-se reduzir o Td em até 25%, observando-se a Região Impossível. No entanto, quanto mais perto
da Região Impossível, o esforço e o custo do projeto aumentam de maneira exponencial. Assim, de um
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 18 de 65
Guia de Contagem APF
modo geral, a redução de prazo de 10 % implica no aumento de esforço de 25%; a redução de prazo de
20% implica no aumento de esforço de 50% ; a redução de prazo de 25% implica em um aumento de
esforço de 60%.
Não é recomendada a redução de prazo em mais de 20%.
Os percentuais de aumento de esforço são estimados, podendo ser reajustados conforme
avaliação da base histórica dos serviços realizados no órgão.
3.4. ESTIMATIVA DE CUSTO
A estimativa de custo do projeto deve levar em consideração o custo de um ponto de função. A
contratada já deverá considerar o custo da hora de todos os profissionais envolvidos no desenvolvimento da
solução de software. O cálculo do custo do projeto (CP) será então da seguinte forma:
CP = QPF x CPF
Onde:
QPF: Tamanho do Projeto em PF
CPF: Custo para implementar um Ponto de Função na plataforma em questão
4. CONTAGEM DE PONTOS DE FUNÇÃO PARA PROJETOS DE MANUTENÇÃO
Esta seção tem como propósito descrever os diversos tipos de projetos de manutenção e mostrar
uma solução para o seu dimensionamento em Pontos de Função, visto que o manual de práticas de
contagem – CPM não contempla projetos de manutenção (maintenance) apenas o de Melhoria
(enhancement).
Quanto à documentação de projetos de manutenção pequenos (menores que 100 PF), deve-se
registrar a solicitação e documentar os requisitos da aplicação impactada pela demanda, de forma
detalhada, visando apoiar a contagem de Pontos de Função da demanda. É importante também
documentar as estimativas e a contagem de Pontos de Função.
4.1. PROJETOS DE MELHORIA
O Projeto de Melhoria (enhancement), também denominada de projeto de melhoria funcional, ou
manutenção evolutiva, está associado às mudanças em requisitos funcionais da aplicação, ou seja, a
inclusão de novas funcionalidades, alteração ou exclusão de funcionalidades em aplicações implantadas.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 19 de 65
Guia de Contagem APF
Segundo o padrão IEEE Std 1229 [IEEE 1998], esta manutenção seria um tipo de manutenção
adaptativa, definida como: modificação de um produto de software concluído após a entrega para mantê-lo
funcionando adequadamente em um ambiente com mudanças. O projeto de melhoria é considerado um tipo
de projeto de manutenção adaptativa com mudanças em requisitos funcionais da aplicação, ou seja, com
funcionalidades incluídas, alteradas ou excluídas na aplicação, segundo o CPM 4.3.
Este documento separa o projeto de melhoria, quando as mudanças são associadas aos requisitos
funcionais e a manutenção adaptativa quando as mudanças estão associadas aos requisitos não funcionais
da aplicação.
Um projeto de melhoria consiste em demandas de criação de novas funcionalidades (grupos de
dados ou processos elementares), demandas de exclusão de funcionalidades (grupos de dados ou
processos elementares) e demandas de alteração de funcionalidades (grupos de dados ou processos
elementares) em aplicações implantadas em produção.
Uma função de dados (Arquivo Lógico Interno ou Arquivo de Interface Externa) é considerada
alterada, quando a alteração contemplar mudanças de item de dados, inclusão ou exclusão de item de
dados. Ou mudança de tamanho (número de posições) ou tipo de campo (por exemplo: mudança de
numérico ou alfanumérico), sendo que esta ocorre por mudança de regra de negócio do usuário.
Uma função transacional (Entrada Externa, Consulta Externa e Saída Externa) é considerada
alterada, quando a alteração contemplar:
Mudança de itens de dados em uma função existente;
Mudança de arquivos referenciados;
Mudança de lógica de processamento, segundo as ações das lógicas e processamento do
CPM 4.3
A Lógica de Processamento é definida como requisitos especificamente solicitados pelo usuário
para completar um processo elementar. Esses requisitos devem incluir as seguintes ações:
Validações são executadas
Fórmulas matemáticas e cálculos são executados
Valores equivalentes são convertidos
Dados são filtrados e selecionados através da utilização de critérios
Condições são analisadas para verificar quais são aplicáveis
Um ou mais ALIs são atualizados
Um ou mais ALIs e AIEs são referenciados
Dados ou informações de controle são recuperados
Dados derivados são criados através da transformação de dados existentes, para criar
dados adicionais
O comportamento do sistema é alterado
Preparar e apresentar informações para fora da fronteira
Receber dados ou informações de controle que entram pela fronteira da aplicação
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 20 de 65
Guia de Contagem APF
Dados são reordenados
A contagem ou estimativa de Pontos de Função de projetos de manutenção evolutiva (projetos de
melhoria) seguirá conforme preconizada pela publicação "Function Point Analysis for Software
Enhancement Guidelines" da Nesma – Netherlands Software Metrics Users Association [NESMA, 2009],
entidade que aprofunda o tema e apresenta alternativas técnicas à proposta original do IFPUG. Contudo é
recomendado que para contratações sejam apenas definidas o padrões do IFPUG e que caso sejam
necessárias a adoção da NESMA (2009) como boas práticas de projetos de melhoria, que ela seja escrita
no edital e não citada como NESMA para que não haja confusão do fornecedor sobre quando usar NESMA
ou quando usar o IFPUG.
Pela NESMA temos:
TAMANHO EM PF = (PF INCLUIDO + PF EXCLUIDO + PF ALTERADO + PF CONVERSÃO)
Definições:
PF_INCLUÍDO = Pontos de Função associados às novas funcionalidades que farão parte da
aplicação.
PF_ALTERADO = Pontos de Função associados às funcionalidades existentes na aplicação que
serão alteradas no projeto de manutenção, incluso o fator de impacto conforme preconizada pela [NESMA,
2009].
PF_EXCLUÍDO = Pontos de Função associados às funcionalidades existentes na aplicação que
serão excluídas no projeto de manutenção, incluso o fator de impacto conforme preconizada pela [NESMA,
2009].
PF_CONVERSÃO = Pontos de Função associados às funcionalidades de conversão de dados dos
projetos de melhoria. Exemplos de funções de conversão incluem: migração ou carga inicial de dados para
popular as novas tabelas criadas e relatórios associados à migração de dados. Importante ressaltar que a
contagem dos PF_Conversão são efetuadas de forma separada da contagem dos PF_Não_Ajustados, por
serem de produtividades diferentes, ou seja, ao contar os PF_Conversão utilizar produtividade própria,
quando for o caso.
Na maioria casos, as operações de alteração e inclusão possuem um tratamento diferenciado em
relação à inclusão, alguns pesos podem ser atribuídos a tais tarefas como forma de compensar o esforço e
custo associado a tais tarefas. Esta prática é comum no mercado e conhecida como Deflator. A sugestão
da NESMA para tal aplicação e a que será seguida pela ATI é:
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 21 de 65
Guia de Contagem APF
PF_INCLUIDO = QPI;
PF_EXCLUIDO = QPE x 0.40;
PF_FD_ALTERADO = FD-QPA x FFD, sendo FFD entre 0,25 e 1,00, conforme Tabela 7 (para
funções de dados);
PF_FT_ALTERADO = FT-QPA x FFT, sendo FFT entre 0,25 e 1,50, conforme Tabela 8 (para
funções transacionais);
PF_ALTERADO = PF_FD_ALTERADO + PF_FT_ALTERADO.
Onde:
QPI = Quantidade de Pontos de Função incluídos;
QPE = Quantidade de Pontos de Função excluídos;
PF_FD_ALTERADO = Pontos de Função alterados para Funções de Dados;
PF_FT_ALTERADO = Pontos de Função alterados para Funções Transacionais;
FD-QPA = Quantidade de Pontos de Função alterados em funções de dados;
FT-QPA = Quantidade de Pontos de Função alterados em funções transacionais;
FFD = Fator de impacto de alterações em funções de dados;
FFT = Fator de impacto de alterações em funções transacionais
O cálculo dos fatores de impacto é obtido através dos percentuais de alterações conforme abaixo:
Funções de Dados:
Percentual de alterações em funções de dados (PFD) = QTDEA / (QTDET x 100)
QTDEA = Quantidade de Tipos de Dados Elementares Alterados
QTDET = Quantidade de Tipos de Dados Elementares Totais
Com o valor obtido em PFD, procura-se na tabela qual o valor do fator de impacto:
Tabela 7: Calculo do PFD para função de Dados [NESMA 2009]
PFD
Fator de
Impacto (FFD)
Fator de Impacto em Funções de Dados Alteradas (FFD)
Entre 33% e
Entre 66% e
Entre 0 e 33%
66%
100%
0,25
0,5
Maior que
100%
0,75
1
Funções Transacionais:
Percentual de alterações em funções transacionais (PFT1) = QTDEA / QTDET x 100
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 22 de 65
Guia de Contagem APF
Percentual de alterações em funções transacionais (PFT2) = QFDLA / QFDLT x 100
QTDEA = Quantidade de Tipos de Dados Elementares Alterados
QTDET = Quantidade de Tipos de Dados Elementares Totais
QFDLA = Quantidade de Funções de Dados Lógicos Alterados
QFDLT = Quantidade de Funções de Dados Lógicos Totais
Tabela 8: Calculo do FFT para função de Dados [NESMA 2009]
Fator de Impacto em Funções Transacionais Alteradas (FFT)
PFT2 / PFT1
Entre 0 e 66%
Entre 66% e
Maior que 100%
100%
Entre 0% e 33%
0,25
0,5
0,75
Entre 33% e 66%
0,5
0,75
1
Entre 66% e 100%
0,75
1
1,25
Maior que 100%
1
1,25
1,5
Caso FFT seja maior que 1, recomenda-se reconsiderar a melhoria.
4.2. PROJETOS DE MANUTENÇÃO CORRETIVA
Mesmo com a execução de atividades de garantia da qualidade, pode-se identificar defeitos na
aplicação entregue. A manutenção corretiva altera o software para correção dos defeitos. Encontra-se nesta
categoria, as demandas de correção de erros (bugs) em funcionalidades de sistemas em produção.
É importante destacar que as demandas de manutenção corretiva freqüentemente precisam ser
atendidas com urgência. Assim, o grau de criticidade do projeto poderá trazer impacto nas estimativas de
custo e esforço. O padrão IEEE [IEEE,1998] define um tipo de manutenção corretiva, denominado de
Manutenção Emergencial como “manutenção corretiva não programada executada para manter o sistema
em estado operacional”.
Quando o sistema em produção tiver sido desenvolvido pela contratada, a manutenção
corretiva será do tipo Garantia, conforme prazos e demais cláusulas do contrato em questão.
Quando o sistema não tiver sido desenvolvido pela contratada, deverá ser estimado e calculado o tamanho
do projeto de manutenção corretiva. A estimativa e dimensionamento de tamanho de projetos de
manutenção corretiva em Pontos de Função devem levar em consideração a documentação do sistema
disponível e os artefatos a serem mantidos sendo aplicados alguns deflatores. Seguem as fórmulas a serem
consideradas:
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 23 de 65
Guia de Contagem APF
a) Aplicação sem documentação ou com documentação desatualizada ou documentação
incompleta e sem redocumentação de requisitos
Nestes casos, a aferição do tamanho em Pontos de Função da funcionalidade ou das
funcionalidades corrigidas considera 70% do PF_Alterado, observando os conceitos do CPM 4.3,
apresentados na seção 4.1.
PF = PF_ALTERADO x 0,70
b) Aplicação sem documentação ou com documentação desatualizada ou incompleta ou
completa e com redocumentação de requisitos
Nestes casos, a aferição do tamanho em Pontos de Função da funcionalidade ou das
funcionalidades corrigidas considera 80% do PF_Alterado, seguindo os conceitos do CPM 4.3,
apresentados na seção 4.1.
Deve-se destacar que além da correção as funcionalidades em questão e da documentação do
projeto de manutenção corretiva realizado, a documentação das funcionalidades deve ser atualizada pela
contratada.
PF = PF_ALTERADO x 0,80
c) Aplicação com documentação completa
Nestes casos, a aferição do tamanho em Pontos de Função da funcionalidade ou das
funcionalidades corrigidas considera 60% do PF_Alterado, seguindo os conceitos do CPM 4.3, mostrados
na seção 4.1. Deve-se ressaltar que não há necessidade de correção da documentação do sistema, apenas
dos artefatos associados à correção do código.
PF = PF_ALTERADO x 0,60
Em todos os três itens acima, os percentuais de multiplicação são estimados, podendo ser
reajustados conforme avaliação da base histórica dos serviços realizados no órgão.
4.3. MANUTENÇÃO COSMÉTICA
São consideradas manutenções cosméticas ou Adaptativas – Mudança de Interface, as demandas
associadas à alterações de interface, por exemplo, fonte de letra, cores de telas, logotipos, mudança de
botões na tela, mudança de posição de campos ou texto na tela.
Nestes casos, a aferição do tamanho em Pontos de Função da funcionalidade ou das
funcionalidades corrigidas considera 10% do PF_Alterado, seguindo os conceitos do CPM 4.3. Não será
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 24 de 65
Guia de Contagem APF
contemplada a redocumentação das funcionalidades da aplicação impactadas pela manutenção nas
demandas desta categoria.
PF = PF_ALTERADO x 0,10
4.4. MANUTENÇÃO ADAPTATIVA EM REQUISITOS NÃO FUNCIONAIS
Seguindo os conceitos da IEEE, existem vários tipos de Manutenção Adaptativa. Quando há
mudança em requisitos funcionais, estes projetos são denominados de projetos de Melhoria, descritos na
seção 4.1. Quando há mudança em requisitos não funcionais de interface, estes projetos são denominados
de Manutenção Cosmética ou Manutenção Adaptativa – Mudança de Interface.
Esta seção visa apresentar alguns tipos de manutenções adaptativas associadas às mudanças em
requisitos não funcionais da aplicação, a saber: Redesenvolvimento de projetos em outra plataforma,
Atualização de plataforma, Adequação de funcionalidades às mudanças de negócio. Caso sejam
identificados outros tipos de projetos de manutenção adaptativa em requisitos não funcionais, estes devem
ser definidos e incorporados nesse Manual de Contagem.
4.4.1. REDESENVOLVIMENTO DE PROJETOS EM OUTRA PLATAFORMA
São considerados nesta categoria, projetos que precisam ser migrados para outra plataforma. Por
exemplo, um sistema legado em COBOL precisa ser redesenvolvido em JAVA.
Como estes projetos legados, freqüentemente, encontram-se sem documentação, então serão
considerados como novos projetos de desenvolvimento. Assim, será utilizada a fórmula de Projetos de
Desenvolvimento do CPM 4.3.
PF = PF_NÃO_AJUSTADO + PF_CONVERSÃO
PF_CONVERSÃO = Pontos de Função associados às funcionalidades de conversão de dados dos
projetos de desenvolvimento. Exemplos de funções de conversão incluem: migração ou carga inicial de
dados para popular as novas tabelas criadas e relatórios associados à migração de dados. Importante
ressaltar que a contagem dos PF_Conversão são efetuadas de forma separada da contagem dos
PF_Não_Ajustado, por serem de produtividades diferentes, ou seja, ao contar os PF_Conversão utilizar
produtividade própria, quando for o caso.
Neste caso, poderá ser criado um multiplicador conforme avaliação da base histórica dos serviços
realizados no órgão.
4.4.2. ATUALIZAÇÃO DE PLATAFORMA
São consideradas nesta categoria, demandas para uma aplicação existente ou parte de uma
aplicação existente executar em versões mais atuais de browsers (ex: versão atual do Internet Explorer,
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 25 de 65
Guia de Contagem APF
Mozila, Firefox,...) ou de linguagens de programação (ex: versão mais atual do JAVA ou do Banco de
Dados). Também são consideradas nesta categoria aplicações Web desenvolvidas para executar em
Internet Explorer que precisam executar também em browser em software livre. Nesta categoria foram
observadas demandas dos seguintes tipos:
a) Atualização de Plataforma com necessidade de redocumentação de requisitos
Nestes casos, a aferição do tamanho em Pontos de Função da aplicação ou da parte da aplicação
que sofreu impacto considera 50% dos PFs, seguindo a fórmula de projetos de desenvolvimento do CPM
4.3 e as funções de conversão de dados, se aplicável. Deve-se destacar que além da adequação as
funcionalidades em questão e da documentação do projeto de manutenção adaptativa realizado, a
documentação das funcionalidades deve ser atualizada.
PF = (PF_NÃO_AJUSTADO x 0,50) + PF_CONVERSÃO
b) Atualização de Plataforma sem necessidade de redocumentação de requisitos
Nestes casos, a aferição do tamanho em Pontos de Função da aplicação ou da parte da aplicação
que sofreu impacto considera 40% dos PFs, seguindo a fórmula de desenvolvimento do CPM 4.3 e as
funções de conversão de dados, se aplicável.
PF = (PF_NÃO_AJUSTADO x 0,40) + PF_CONVERSÃO
Nos dois itens acima, os percentuais de multiplicação são estimados, podendo ser reajustados
conforme avaliação da base histórica dos serviços realizados no órgão.
4.4.3. ADEQUAÇÃO DE FUNCIONALIDADES ÀS MUDANÇAS DE NEGÓCIO
São consideradas nesta categoria as demandas de manutenção adaptativa associadas à
adequação de funcionalidades às mudanças de regras de negócio ou de Legislação ou requisitos de
usabilidade que não se enquadram nas funções alteradas do Projeto de Melhoria, seguindo as regras de
contagem do CPM. Observe que tais solicitações envolvem aspectos não funcionais, sem alteração em
requisitos funcionais.
Por exemplo: replicação de funcionalidade (chamar uma consulta existente na aplicação de outra
tela, por demanda do usuário); replicação de base de dados ou criação de base temporária para resolver
problemas de performance ou segurança; Alteração no software para adaptação às alterações realizadas
em rotinas de integração com outros software (ex: alteração em sub-rotinas chamadas por este software).
Nesta categoria foram observadas demandas dos seguintes tipos:
a) Adequação de funcionalidades com necessidade de redocumentação
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 26 de 65
Guia de Contagem APF
Nestes casos, a aferição do tamanho em Pontos de Função da funcionalidade ou das
funcionalidades que sofreram impacto deve considerar 80% do PF_Alterado, seguindo os conceitos do CPM
4.3, apresentados na seção 4.1. Deve-se destacar que além da adequação das funcionalidades em questão
e da documentação do projeto de manutenção adaptativa realizado, a documentação das funcionalidades
deve ser atualizada.
PF = PF_ALTERADO x 0,80
b) Adequação de funcionalidades sem necessidade de redocumentação de requisitos
Nestes casos, a aferição do tamanho em Pontos de Função da funcionalidade ou das
funcionalidades que sofreram impacto deve considerar 70% do PF_Alterado, seguindo os conceitos do CPM
4.3, apresentados na seção 4.1. Não será contemplada a documentação das funcionalidades nas
demandas desta categoria.
PF = PF_ALTERADO x 0,70
Nos dois itens acima, os percentuais de multiplicação são estimados, podendo ser reajustados
conforme avaliação da base histórica dos serviços realizados no órgão.
Para outros tipos de projetos de manutenção adaptativa não definidos neste documento,
considerar um percentual do PF_Alterado, variando de 30% a 80%, de acordo com as características
do requisito não funcional alterado. Versões futuras deste Manual devem contemplar os novos tipos
não definidos neste documento.
4.4.4. APURAÇÃO ESPECIAL
São funcionalidades executadas apenas uma vez para: corrigir problemas de dados incorretos na
base dados das aplicações ou atualizar dados em bases de dados de aplicações, detalhado no item 4.3.4.1;
gerar um relatório específico ou arquivo para o usuário por meio de recuperação de informações nas bases
da aplicação.
Caso a apuração seja de correção de dados, devido a erros de funcionalidades de aplicações
desenvolvidas pela contratada, observar as cláusulas contratuais com relação a garantias e prazos de
correção.
4.3.4.1
APURAÇÃO ESPECIAL – BASE DE DADOS
Uma apuração especial é um projeto que inclui a geração de procedimentos para atualização da
base de dados. Deve-se destacar que estas funções são executadas apenas uma vez, não fazendo parte
da aplicação, visando a correção de dados incorretos na base de dados da aplicação ou atualização em
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 27 de 65
Guia de Contagem APF
função de modificação da estrutura de dados, por exemplo inclusão do indicador de matriz – sim ou não
para um CNPJ. Nestes casos, a contagem de Pontos de Função das funcionalidades desenvolvidas.
Geralmente, estas funcionalidades são classificadas como Entradas Externas.
PF = PF_NÃO_AJUSTADO
Deve-se ressaltar que as funções de conversão de dados (carga inicial de dados que ocorre na
implantação de projetos de desenvolvimento ou de melhoria) não são apurações especiais. Estas funções
fazem parte do projeto de desenvolvimento ou de melhoria em questão, portanto devem ser contadas junto
com estes projetos e não como apuração especial. Assim, nestes casos, considera-se as fórmulas de
contagem de Pontos de Função dos projetos em questão. Em alguns casos de Apuração Especial –
Atualização de dados, o usuário solicita uma consulta prévia das informações atualizadas para validação.
De fato, é uma prática interessante para evitar informações errôneas na base de produção dos sistemas.
Esta Consulta Prévia, classificada como Consulta Externa ou Saída Externa deve ser dimensionada,
considerando-se 60% do tamanho da funcionalidade em questão, conforme a fórmula abaixo:
PF = PF_NÃO_AJUSTADO x 0,60
4.3.4.2
APURAÇÃO ESPECIAL – GERAÇÃO DE RELATÓRIOS
Uma apuração especial é um projeto que inclui a geração de relatórios em uma ou mais mídias para
o usuário. Em alguns casos, são solicitadas extrações de dados e envio dos dados para outros sistemas.
Caso neste envio de dados sejam requisitadas atualizações no sistema de origem, então estas funções são
Saídas Externas, devido à atualização do Arquivo Lógico Interno.
Deve-se destacar que estas funções são executadas apenas uma vez, não fazendo parte da
aplicação. Nestes casos, considera-se contagem de Pontos de Função das funcionalidades desenvolvidas.
Freqüentemente, estas funcionalidades são classificadas como Saídas Externas. Também podem ser
classificadas como Consultas Externas, caso não possuam cálculos ou criação de dados derivados.
PF = PF_NÃO_AJUSTADO
4.4.5. MANUTENÇÃO EM PÁGINAS ESTÁTICAS DE INTRANET, INTERNET OU
PORTAL
Nesta seção são tratadas manutenções específicas em páginas estáticas de Portais, Intranets ou
Websites. A demanda consiste na publicação de páginas HTML. Estas demandas são consideradas como
desenvolvimento de consultas com a utilização de ferramentas para apoiar a publicação. Nestes casos,
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 28 de 65
Guia de Contagem APF
considera-se 50% dos Pontos de Função das consultas desenvolvidas. Cada página é contada como uma
consulta. As consultas são consideradas Consultas Externas Simples (3 PF).
QTD_SIMPLES: Quantidade de Páginas com complexidade Simples
PF_SIMPLES: QTD_SIMPLES X 0,5
QTD_INTERMEDIARIA: Quantidade de Páginas com complexidade Intermediária
PF_ INTERMEDIARIA: QTD_ INTERMEDIARIA X 0,8
QTD_COMPLEXAS: Quantidade de Páginas com complexidade Complexa
PF_ COMPLEXAS: QTD_ COMPLEXAS X 1,2
PF_TOTAL = PF_SIMPLES + PF_INTERMEDIARIA + PF_ COMPLEXAS
* Deve ser definido de forma clara como classificar cada página em uma das categorias.
Exemplo:
O Portal XXX será desenvolvido e foi verificado que o mesmo é composto de:
50 páginas simples
20 páginas intermediárias
10 páginas complexas
PF_SIMPLES = 50 * 0,5 = 25
PF_INTERMEDIARIA = 20 * 0,8 = 16
PF_COMPLEXA = 10 * 1,2 = 12
PF_TOTAL = 25 + 16 + 12 = 53
4.4.6. MANUTENÇÃO DE DOCUMENTAÇÃO DE SISTEMAS LEGADOS
Nesta seção são tratadas demandas de documentação ou atualização de documentação de
sistemas legados. Observe que o desenvolvedor deve realizar uma Engenharia Reversa da aplicação para
gerar a documentação. Para este tipo de projeto, caso a demanda seja apenas a documentação de
requisitos, devem ser considerados 20% dos Pontos de Função da aplicação em questão, conforme a
fórmula abaixo.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 29 de 65
Guia de Contagem APF
PF = PF_NÃO_AJUSTADO x 0,20
Caso a demanda seja a geração de artefatos de documentação de todas as fases do processo de
desenvolvimento, deve-se considerar um percentual mais alto de 30% a 50%, dependendo dos artefatos a
serem gerados. As premissas utilizadas devem ser conforme cláusulas contratuais e documentadas no
documento de estimativas do projeto.
4.4.7. VERIFICAÇÃO DE ERROS
São consideradas verificações de erro ou análise e solução de problemas as demandas referentes a
todo comportamento anormal ou indevido apontado pelo cliente nos sistemas aplicativos. Neste caso, a
equipe de desenvolvimento da ATI se mobilizará para encontrar a(s) causa(s) do problema ocorrido. Se for
constatado erro de sistema, a demanda será atendida como manutenção corretiva.
Entretanto, uma vez não constatado o problema apontado pelo cliente ou o mesmo for decorrente
de regras de negócio implementadas ou utilização incorreta das funcionalidades, será realizada a aferição
do tamanho em Pontos de Função das funcionalidades verificadas, e será considerado 25%.
PF = PF_NÃO_AJUSTADO x 0,25
4.4.8. FATOR DE CRITICIDADE DE SOLICITAÇÃO DE SERVIÇO
Em função da criticidade e da necessidade de alocação de recursos extras para atendimento da
demanda no prazo estipulado pelo cliente, poderá ser adotado um Fator de Criticidade de 1,35 (um vírgula
trinta e cinco), que deverá ser multiplicado pelo tamanho funcional da demanda considerada crítica, de
modo a remunerar adequadamente o aumento do esforço de atendimento.
Este fator é considerado para demandas que devem ser atendidas em finais de semana, feriados e
fora do horário comercial. Entende-se como horário comercial o horário local.
4.4.9. PONTOS DE FUNÇÃO DE TESTE
Muitas vezes, em projetos de manutenção o conjunto de funções de dados e funções transacionais
a serem testadas é maior do que a quantidade de funções a serem implementadas, i.e., além das
funcionalidades que são afetadas diretamente pelo projeto de manutenção, outras precisam ser testadas
[NESMA, 2009]. O tamanho das funções a serem testadas deve ser aferido em Pontos de Função de Teste
(PFT). Não considerar as funcionalidades incluídas, alteradas ou excluídas do projeto de manutenção na
contagem de Pontos de Função de Teste.
A contagem de PFT deve considerar o seguinte [NESMA, 2009]:
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 30 de 65
Guia de Contagem APF
Determinar o tamanho em Pontos de Função de cada função de dados ou transacional
envolvida no teste.
Calcular o tamanho em Pontos de Função de todas as funções de dados ou transacionais
envolvidas no teste.
A conversão do PFT em Ponto de Função deve ser feita de acordo com a fórmula abaixo:
PF = PFT x 0,20
É importante ressaltar que as funções testadas consideradas no PFT devem estar documentadas.
Observe que estas funções farão parte do escopo do projeto de manutenção.
Nos itens da seção 4 acima, os percentuais são estimados, podendo ser reajustados
conforme avaliação da base histórica dos serviços realizados no órgão. Em casos onde não há
percentuais, pode-se aplicar algum percentual, também conforme avaliação da base histórica dos
serviços realizados no órgão.
5. ITENS NÃO MENSURÁVEIS
Deve-se ressaltar que o processo de desenvolvimento de soluções possui várias atividades que
devem ser consideradas como um projeto separado, levando-se em conta as horas realizadas, dentre
outras:
Treinamentos em Tecnologia, Metodologias, Métricas, etc. encontram-se nesta categoria as
demandas de treinamentos em linguagens de programação, ferramentas de gestão, processos, modelos da
qualidade, métricas, etc. Estes serviços são executados por consultores de terceiros, especialistas no
assunto em questão. Assim, devem ser consideradas as horas de consultoria para preparação e execução
do curso e o custo do deslocamento do instrutor, se for o caso.
Mapeamento de Processos de Negócio: Encontram–se nesta categoria as demandas de
elaboração e levantamento de documentação contendo o mapeamento de processos de negócio de uma
organização ou de parte de uma organização. Estes serviços são executados por consultores da ATI ou
terceiros, especialistas em BPM (Business Process Modeling).
Elaboração de Plano Diretor de Tecnologia da Informação (PDTI): encontram-se nesta categoria
demandas para elaboração de PDTIs para clientes. Estes serviços são executados por consultores do ATI
ou terceiros com o apoio dos funcionários da ATI especialistas nas atividades associadas à elaboração de
um PDTI.
Definição de Processo de Desenvolvimento de Soluções: Encontram-se nesta categoria
demandas para definição de Processos de Software aderentes às necessidades da ATI e observando as
boas práticas de modelos como CMMI, Scrum ou normas como a IN 04. Estes serviços são executados por
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 31 de 65
Guia de Contagem APF
consultores da ATI ou terceiros, especialistas nas atividades de processos de software e na customização
de ferramentas para facilitação do processo.
Outros serviços prestados que também não possuem Pontos de Função associados são os
seguintes:
Administração de Dados: Este serviço requer uma equipe de ADs com um número de
profissionais definido junto ao Cliente/Fornecedor, dedicada para atender as demandas associadas à
definição e manutenção do modelo de dados de negócio. Esta equipe fica disponível em horário comercial
para atendimento das demandas. Assim, estes serviços não possuem contagem de PF associada.
É importante ressaltar que as atividades de banco de dados associadas ao projeto de
desenvolvimento ou de manutenção, por exemplo, preparação de ambiente (testes, homologação,
implantação), desempenhadas pelos DBAs da equipe de desenvolvimento, já estão consideradas dentro do
projeto de software, não cabendo cobrança adicional.
Análise de Solução: Serviço de apoio destinado à análise de regras de negócio implementadas em
soluções de TI. Estas demandas não possuem contagem de PF associada.
Consultoria: Serviço de apoio destinado à análise de regras de negócio a serem implementadas
em soluções de TI realizado por consultores especialistas da ATI. As demais modalidades de consultoria
também podem ser enquadradas neste item, por exemplo, Consultoria em Métricas. Estas demandas não
possuem contagem de PF associada. Outras atividades contidas em um processo de software devem ser
gerenciadas dentro do projeto de desenvolvimento ou de manutenção, no entanto o esforço deve ser
considerado separadamente da estimativa de esforço derivado da contagem de Pontos de Função.
Estas atividades também devem ser precificadas a parte. São elas:
Treinamento para Implantação: São demandas de treinamentos sobre utilização do sistema a ser
implantado para os gestores de solução do cliente e usuários. O esforço deste serviço deve ser considerado
separadamente da estimativa de esforço derivada da contagem de PF. O preço deste serviço deve ser
calculado, levando-se em conta o preço da hora dos consultores de terceiros que estarão realizando
atividades de preparação de treinamento e de instrutoria. Em alguns casos, pode ocorrer também o
deslocamento do instrutor, que também deve ser cobrado do cliente.
Especificação de Negócio: Esta atividade é a primeira atividade a ser executada em uma
demanda de projeto de desenvolvimento e/ou de manutenção. O objetivo desta atividade é gerar a
Especificação da demanda. O principal produto gerado nesta atividade é o artefato: Documento de Visão do
Projeto (DV), que deve ser validado pelo cliente, por meio da assinatura do termo de aceite. Além do DV
podem ser gerados outros documentos, tais como: atas de reunião, documento de requisitos não funcionais
e glossário da especificação de negócio. O esforço desta atividade deve ser considerado separadamente da
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 32 de 65
Guia de Contagem APF
estimativa de esforço derivada da contagem de PF. É importante ressaltar que esta atividade é de
responsabilidade dos Analistas de Negócios da empresa contratante, de acordo com as legislações em
vigor da ATI. Portanto. Caso o cliente demande para terceiros a realização desta atividade, esta deve ser
cobrada em horas de consultoria. Observe que o Documento de Visão gerado nessa atividade é o insumo
para o planejamento (estimativas) e a atividade de Engenharia de Requisitos do processo de
desenvolvimento de software.
Suporte: Esta atividade é realizada sob demanda para solucionar diversos tipos de problemas que
em sua maioria são com infra-estrutura ou de apoio a informação (suporte a usuário). A natureza destes
serviços não é o desenvolvimento de software não cabendo de forma alguma a aferição por ponto de
função.
Help Desk: Esta atividade é realizada com a alocação de pessoas cujo objetivo é atender seja por
telefone, internet ou presencialmente informações a respeito de determinados serviços da ATI. A forma
mais comum de pagamento por este serviço é por profissional contratado. E mesmo assim, a natureza
desse serviço também não é de desenvolvimento de software assim não cabendo pontos por função.
6. ASPECTOS NÃO CONSIDERADOS PELO IFPUG CONSIDERADOS PELA ATI
Algumas atividades que não estão presentes no Manual de Práticas de Contagem (CPM 4.3.1) do
IFPUG já estão resolvidas dentro do âmbito da ATI. Nesta seção iremos apresentar como a ATI considera
tais aspectos.
6.1. MÚLTIPLAS MÍDIAS
Esta subseção tem como propósito apresentar as diretrizes de Contagem de Pontos de Função
utilizadas na ATI em relação ao tema Múltiplas Mídias. Esta abordagem é reconhecida pelo IFPUG. As
definições apresentadas têm como base o artigo “Considerations for Counting with Multiple Midia” Release
1.0 publicado pelo IFPUG [IFPUG, 2009] e pelo Serpro (2010).
Considerando-se a contagem de PF de funcionalidades entregues em mais de uma mídia, a
aplicação das regras de contagem de Pontos de Função definidas no CPM tem levado a duas abordagens
alternativas, a saber: single instance e multiple instance.
A abordagem single instance considera que a entrega de uma função transacional em múltiplas
mídias não deve ser utilizada na identificação da unicidade da função.
A abordagem multiple instance leva em consideração que a mídia utilizada na entrega da
funcionalidade é uma característica de identificação da unicidade da função. Assim, funcionalidades únicas
são reconhecidas no contexto da mídia na qual elas são requisitadas para operar.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 33 de 65
Guia de Contagem APF
É importante enfatizar que o IFPUG reconhece ambas abordagens single instance e multiple
instance para a aplicação das regras definidas no CPM. A determinação da contagem de PF seguindo a
abordagem multiple instance ou single instance depende do gestor do contrato ou gestor do produto que
está relacionado com aquela contagem.
As estimativas e contagens de PF realizadas pelo ATI serão baseadas na abordagem multiple
instance, com exceção dos casos de consultas em .pdf, .doc, .xls e consultas idênticas em tela e papel, que
serão consideradas uma única funcionalidade.
A seguir são descritos os termos comuns definidos pelo IFPUG [IFPUG, 2009]:
Canal: também refere-se a mídia. Múltiplos canais é sinônimo de múltiplas mídias.
Mídia: descreve a maneira que os dados ou informações se movimentam para dentro e para fora de
uma fronteira de aplicação, por exemplo, apresentação de dados em tela, impressora, arquivo, voz. Este
termo é utilizado para incluir, dentre outros: diferentes plataformas técnicas e formatos de arquivos como
diferentes mídias.
Múltiplas Mídias: quando a mesma funcionalidade é entregue em mais de uma mídia.
Freqüentemente, somente uma mídia é requisitada para um usuário específico em um determinado
momento, por exemplo consulta de extrato bancário via internet como oposto a consulta de extrato bancário
via terminal do banco.
Multi-Midia: quando mais de uma mídia é necessária para entregar a função, por exemplo, uma
nova notícia publicada na Internet que é apresentada em vídeo e texto. Observe que a notícia completa só é
apresentada para o usuário se ele ler o texto e assistir o vídeo.
Abordagem Single Instance: esta abordagem não reconhece que a mídia utilizada na entrega da
função transacional é uma característica de diferenciação na identificação da unicidade da função
transacional. Se duas funções entregam a mesma funcionalidade usando mídias diferentes, elas são
consideradas a mesma funcionalidade em uma contagem de Pontos de Função.
Abordagem Multiple Instance: esta abordagem especifica que o tamanho funcional é obtido no
contexto de objetivo da contagem, permitindo uma função de negócio ser reconhecida no contexto das
mídias que são requisitadas para a funcionalidade ser entregue. A abordagem multiple instance reconhece
que a mídia para entrega constitui uma característica de diferenciação na identificação da unicidade da
função transacional.
Os cenários descritos nas seções seguintes não representam uma lista completa de situações de
múltiplas mídias. O entendimento destes exemplos facilitará o entendimento de outros cenários envolvendo
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 34 de 65
Guia de Contagem APF
múltiplas mídias. Este Roteiro deve ser atualizado considerando a publicação de novas diretrizes do IFPUG
e novos cenários que emergirão nas contagens de PFs dos projetos dos clientes do ATI.
Os cenários descritos nas seções seguintes não representam uma lista completa de situações de
múltiplas mídias. O entendimento destes exemplos facilitará o entendimento de outros cenários envolvendo
múltiplas mídias. Este Roteiro deve ser atualizado considerando a publicação de novas diretrizes do IFPUG
e novos cenários que emergirão nas contagens de PFs dos projetos dos clientes do ATI.
6.1.1. MÚLTIPLAS MÍDIAS
Neste cenário, uma aplicação apresenta uma informação em uma consulta em tela. A mesma
informação pode ser impressa caso requisitado pelo usuário na tela em questão. Nesses casos, a ATI utiliza
a abordagem single instance, considerando que dados idênticos sendo apresentados em tela e relatório
impresso devem ser contados como uma única função.
Caso as lógicas de processamento da consulta em tela e do relatório em papel sejam distintas, o
processo elementar não é único e, portanto, a funcionalidade será contada duas vezes. Observe que a
abordagem multiple instance considera que a contagem de PF de dados idênticos sendo apresentados
usando mais de um tipo de mídia deve incluir toda instância da função em cada tipo de mídia. Neste
exemplo, duas funções são contadas – apresentação de dados em tela; apresentação de dados impressos.
6.1.2. MESMOS DADOS DE SAÍDA COMO DADOS EM ARQUIVOS E RELATÓRIOS
IMPRESSO
Uma aplicação grava dados em um arquivo de saída e imprime um relatório com informações
idênticas as gravadas no arquivo. Nesses casos, a ATI utiliza a abordagem single instance considerando
que os dados impressos e os dados apresentados no arquivo de saída sejam idênticos.
Assim, apenas uma funcionalidade será incluída na contagem de Pontos de Função. Caso as
lógicas de processamento da geração do arquivo de saída e do relatório em papel sejam distintas, o
processo elementar não é único e, portanto a funcionalidade será contada duas vezes.
Observe que a abordagem multiple instance considera que dados idênticos estão sendo entregues
em mais de um tipo de mídia e a contagem de PF incluirá todas as instâncias de tipos de mídia. Neste
cenário, duas funções são contadas – geração arquivo e apresentação dos dados impressos.
6.1.3. MESMOS DADOS DE ENTRADA BATCH E ON-LINE
Uma informação pode ser carregada na aplicação por meio de dois métodos: arquivo batch e
entrada on-line. O processamento do arquivo batch executa validações durante o processamento. O
processamento on-line também executa validações das informações.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 35 de 65
Guia de Contagem APF
A abordagem utilizada pela ATI é a single instance conta apenas uma funcionalidade. Na ATI,
porém pode ser considerada a abordagem multiple instance que conta duas funcionalidades: a entrada de
dados batch e a entrada de dados on-line quando a lógica de processamento utilizada nas validações em
modo batch é diferente da lógica de processamento das validações nas entradas de dados on-line.
Portanto, fica a cargo do gestor de contrato ou produto da ATI definir se será uma ou duas funcionalidades.
6.1.4. MÚLTIPLOS CANAIS DE ENTREGA DA MESMA FUNCIONALIDADE
Uma funcionalidade deve ser disponibilizada em múltiplos canais, por exemplo, consulta de dados
em página Web e consulta de dados no telefone celular. A abordagem single instance conta apenas uma
funcionalidade. Na ATI novamente pode ser utilizada a abordagem multiple instance que conta duas
funcionalidades: a consulta de dados na Web e a consulta de dados via celular.
Considera-se que esta solução é justa quando a funcionalidade é desenvolvida duas vezes para os
dois canais. Algumas vezes, são até projetos de desenvolvimento distintos, um projeto relativo ao sistema
Web e outro para o sistema via celular. Portanto, nestes casos a ATI contará duas funcionalidades.
6.1.5. RELATÓRIOS EM MÚLTIPLOS FORMATOS
Um relatório deve ser entregue em diferentes formatos, por exemplo, em um arquivo html e um
formato de valores separados por vírgula. Nestes casos, conforme sugerido na abordagem multiple
instance, a ATI considera a ferramenta utilizada na geração dos relatórios. Se a equipe de desenvolvimento
precisar desenvolver o relatório nos dois formatos na ferramenta em questão, serão contadas duas
funcionalidades.
Isso porque a lógica de processamento de análise de condições para verificar quais são aplicáveis é
identificada. No entanto, se a ferramenta de desenvolvimento suportar um gerador de relatórios que o
usuário visualize o relatório em tela e o gerador permita ao usuário imprimir o relatório, salvar em html ou
salvar no formado de valores separados por vírgula, então a ATI contará apenas uma vez, observando que
a funcionalidade será da ferramenta e não da aplicação.
6.2. DATA WAREHOUSE
Esta subseção tem como propósito apresentar as diretrizes de Contagem de Pontos de Função
utilizadas na ATI em relação ao tema Data Warehouse. Esta abordagem é reconhecida pelo IFPUG. As
definições apresentadas têm como base o artigo “Function Points & Counting Enterprise Data Warehouses”
Release 1.0 publicado pelo IFPUG [IFPUG, 2007].
Um aspecto crucial da contagem de Data Warehouses que apresentou desafios significativos dos
contadores de ponto de função está em definir a fronteira da aplicação. Uma fronteira impropriamente
definida pode distorcer de forma considerável os resultados da análise de ponto de função. Com base
nessas regras de definição de fronteira, o que segue abaixo deve ser excluído dos limites da aplicação:
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 36 de 65
Guia de Contagem APF
Arquivos lógicos mantidos pelo(s) sistema(s) de origem, exceto se eles são referenciados
durante o processamento dos arquivos de chegada com os dados.
Tabelas Temporárias,
Staging Areas,
Tabelas de códigos
Data Marts. Estes podem ser contados como fronteiras de aplicações separadas.
Algumas considerações incluem:
O propósito da contagem,
Os usuários são um grupo distinto; ex.: um departamento específico como marketing,
diferente grupo de usuários do Data Warehouse e;
A existência de dados externos além daquele disponível dentro do Data Warehouse.
Figura 5 é uma representação gráfica de como a fronteira de um Data Warehouse pode ser definida.
Figura 5: Figura Ilustrativa de um Fronteira de DW
A Figura 5 esta mostrando um limite em volta das Staging Areas/Depósito de Dados
Operacionais/Data Warehouses e limites em torno de Data Marts específicos. É uma representação gráfica
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 37 de 65
Guia de Contagem APF
de como as fronteiras podem ser definidas. Embora este diagrama mostre todos os três Data Marts fora da
fronteira, esse nem sempre pode ser o caso.
Acrônimos comuns:
ETL = Extrair, Transformar & Carregar
ODS = Depósito de Dados Operacionais
EDW = Enterprise Data Warehouse
BO = Business Objects
Funcionalidade física
Muitos sistemas de Data Warehouse contêm várias áreas físicas onde os dados são armazenados
antes, durante e depois que os dados são recebidos do sistema de origem e são processados. Nesse
contexto, é importante diferenciar a funcionalidade do negócio das funções físicas e técnicas.
Os Data Warehouses geralmente usam tecnologia da web para tornar as suas informações mais
acessíveis aos usuários. Esses Websites podem incorporar informações nos relatórios ou consultas;
informação de metadados; dicionários de dados; ferramentas de Consulta; treinamento; e membros de
grupos de projetos em um local conveniente.
Quando esses Websites existem, o Analista do Ponto de Função precisa determinar se a fronteira
do Data Warehouse inclui ou exclui o Website que fornece acesso a ele. Segue algumas dicas para ajudar
nessa decisão:
Se um Website central é usado para acessar vários Data Warehouses dentro da empresa, e
este é mantido por uma equipe específica e não pela equipe que mantém os Data
Warehouses, essa é uma boa indicação que o Website é uma aplicação separada cuja
função primária é fornecer acesso aos Data Warehouses.
Se um serviço web foi construído para fornecer capacidades de relatório para um Data
Warehouse específico, e é mantido por esta equipe de Data Warehouse, provavelmente
seria contado como parte do aplicativo de Data Warehouse.
Observação: A fronteira do aplicativo não se baseia necessariamente em como a organização do
software é gerenciada. Porém, conhecer quem desenvolveu o Website que fornece acesso a um Data
Warehouse em particular pode ser útil quando se define a fronteira da aplicação.
Anatomia Física de uma Data Warehouse
Tipicamente, existem três segmentos físicos dentro do Data Warehouse; Staging Areas, o depósito
de dados operacionais e o Data Warehouse. Staging Areas. Essa Staging Area é usada para armazenar
uma versão atual do Data Warehouse que existe no sistema original. Esta cópia física é criada por várias
razões, inclusive:
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 38 de 65
Guia de Contagem APF
Desempenho – O sistema operacional pode reduzir a carga de processamento imposta
pelas leituras requeridas antes que a transformação dos dados comece.
Segurança – Sistemas origem podem controlar o que os programas têm acesso em suas
áreas. Ao fornecer uma exportação, o sistema de origem mantém controle sobre o que é
enviado.
Os dados armazenados nas Staging Areas são os mesmos ou muito similares aos do sistema
original, em suas estruturas e valores de dados. A Staging Area raramente é vista ou descrita por um
usuário do negócio ou um usuário administrador.
Depósito de Dados Operacionais (ODS)
O ODS contém dados transacionais detalhados que são (tipicamente), de alguma forma,
modificados. A fonte original desses dados é o sistema de origem via a área de etapas. Considere como os
dados podem ser modificados quando determinam se é um armazenamento de dados e o tipo de função de
dados (ALI ou AIE). Os dados nesse segmento do Data Warehouse podem ser descritos como:
Integrados
Validados
Freqüentemente atualizados
Detalhados
Voláteis
O segmento ODS suporta a habilidade para, via data mining, buscar informações sumarizadas para
as informações de nível transacional, detalhadas e atuais.
O Data Warehouse é a última área de acomodação (dentro do limite do aplicativo de Data
Warehouse) para os dados transformados. Quando dados são armazenados aqui, eles passaram por um
processamento via ETL (Extrair, Transformar e Carregar). Exemplos desse processamento incluem:
Validação
Integração
Limpeza
Verificações de qualidade
Sumarização
Projetos de Data Warehouse contêm muitos documentos que o Analista do Ponto de Função pode
usar para auxiliar na contagem do ponto de função. Alguns dos documentos mais úteis são os diagramas de
modelo de dados, que ajudar a determinar dados e funções transacionais para a contagem. Os diagramas
de modelo de dados incluem:
Tabelas Fato
Tabelas Agregadas
Tabelas de existência
Dimensões
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 39 de 65
Guia de Contagem APF
Tabelas de Visualização
Metadados
Tabela Fato
A tabela fato é a principal tabela de interesse em um modelo dimensional. Uma tabela fato contém
medidas relacionadas a negócios e cada tabela fato pode ser conectada a tabelas dimensionais ou a outras
tabelas fato. Os dados da fato no Data Warehouse se parecem tipicamente com aqueles contidos no
sistema de origem ou ODS, mas foram submetidas ao processo ETL e portanto seu significado pode ter
sido mudado drasticamente.
A estrutura de chave estrangeira na tabela fato permite que os campos definidos em entidades
dimensionais acessem informações adicionais. Uma contagem de DET (TDs) tipicamente incluirá campos
da entidade da tabela fato e da entidade dimensional.
Dependendo da abordagem de modelagem usada pela equipe do projeto, o esquema de estrela
representado pode incluir só os campos que são requeridos para definir a informação da entidade, do fato
ou pode incluir todos os campos que são definidos para a entidade dimensional, mas são requeridos para
uso em outras entidades do fato.
Em resumo, tabelas fato contêm agrupamentos identificáveis do usuário de dados e são geralmente
mantidos por um ou mais processos de ETL (processos elementares). Como tais, eles são contados como
Arquivos Lógicos Internos. Uma palavra final de advertência sobre contagem dos tipos de dados (DETs ou
TDs) – certifique-se de contar somente os requeridos para a entidade fato em análise.
Tabelas Agregadas
Tabelas Agregadas é um tipo especial de tabela fato. Tabelas Agregadas deveriam ser contadas?
Depende da razão para a existência da tabela agregada, que pode existir por razões de desempenho ou
negócios.
Razões de Desempenho
Um conjunto de medidas pode ser criado à medida que os dados são carregados, pois do tempo
requerido para que tais cálculos sejam feitos nos relatórios é muito grande. Nesse caso, estas tabelas
agregadas não devem ser contadas como ALIs ou AIEs.
Propósitos de Negócio
Os usuários podem requerer que as tabelas agregadas sejam construídas para satisfazer um
propósito funcional de negócios. Por exemplo, informações da fato nem sempre podem ser expressáveis no
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 40 de 65
Guia de Contagem APF
mesmo nível de detalhe; ou custos de remessa podem ser disponíveis ao nível de cliente da fatura de envio,
mas não no nível da linha da fatura ou o nível do produto.
Tabelas de Existência de Fato (Factless Fact Existence Table)
Esse tipo especial de tabela fato não contém medidas numéricas de negócio, mas ela documenta a
existência de um evento. Para determinar se deve ser incluído na contagem de pontos de função, faça a
análise funcional conforme esboçado nas regras do Manual de Práticas de Contagem. Vejamos um
exemplo na Figura 6.
Figura 6: Exemplo de Tabelas de Existência de Fatos
Essa tabela fato da Figura 6 é usada para definir quais produtos serão oferecidos, a quais
estabelecimentos e durante quais promoções. Essa tabela ajudará o analista na avaliação da eficácia de
promoções ao identificar os estabelecimentos e produtos participantes. Similar a tabelas associativas
encontradas no modelo relacional normalizado, tabelas de existência gerenciam exceções – onde certos
exemplos de uma tabela se relacionam a um ou mais outras tabelas.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 41 de 65
Guia de Contagem APF
Nesse exemplo, a entidade “Promotion Products” é uma tabela contável. A exigência em permitir
rastrear promoções fica satisfeita com essa entidade. Isso define que produtos serão oferecidos ou foram
oferecidos em quais estabelecimentos durante as promoções. A contagem resultante é um arquivo de baixa
complexidade – geralmente um ALI.
Tabelas dimensionais
Tabelas dimensionais contêm as informações descritivas necessárias para permitir uma análise da
informação relacionada a fato e contêm informações para permitir a verificação do carregamento dos dados.
Tipicamente, uma tabela fato só conterá DETs que permitam uma medição em particular (na tabela fato)
para ser considerada pelos campos nas tabelas dimensionais.
Dimensões e Fatos – Como eles Coexistem? Fisicamente, tabelas fato contêm só os DETs
requeridos para representar alguma medida de negócios e são rodeadas pela mesma tabela física por
DETs do tipo chave estrangeiras que conectam a dimensões de forma a permitir mais descrição de
qualquer evento em particular. Ao contar os elementos dos dados para a inclusão da tabela fato todos os
elementos de dados identificáveis do usuário na tabela de fato e os dados elementares das tabelas
dimensionais que são requeridos para definir o registro da tabela de fatos.
Tabelas de visualização
Como as tabelas de visualização podem ser contadas? Basicamente, existem duas formas em que
as tabelas de visualização podem ser “contadas” durante a análise do ponto de função.
Processos elementares – Se uma tabela de visualização é criada e enviada para fora do
Data Warehouse para consumo de outro aplicativo (fronteira diferente de aplicativo) assim a
transação pode ser contada como uma saída externa ou consulta externa para o aplicativo
do Data Warehouse.
Parte de um ou mais processos elementares – Se a tabela de visualização é criada para
uso do Data Warehouse então ela não deve ser contada como uma única função (processo
elementar). A tabela de visualização deve ser analisada para determinar a fonte desses
dados. As funções de dados usados para criar a tabela de visualização devem ser
consideradas como um FTRs em potencial para determinar a complexidade das funções
transacionais, que acessam aqueles dados em particular.
Metadados
A forma mais simples, talvez não a mais clara, de descrever metadados é: Dados sobre dados. Os
metadados proporcionam mais informação sobre o objeto que está sendo analisado. Os metadados são
usados por dois grupos de pessoas em uma organização: usuários que desempenham análise relacionada
a negócios e aqueles que desempenham análises relacionadas à técnica. Cada conjunto de usuários tem
diferentes necessidades desde a configuração da aplicação até a definição de campos usados em um
relatório específico.
Metadados técnicos incluem:
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 42 de 65
Guia de Contagem APF
Descrição de tabelas
Descrição de atributos
Relações da entidade
Regras de processamento de dados
Relacionamento de chaves
Categorias de metadados de negócios incluem:
Dicionário de dados
Proprietários de dados
Informação assuntos da área
Um dos elementos-chave, para ter em mente ao analisar os tipos de metadados para incluir em sua
análise é quem foi definido como os “usuários” do aplicativo. Isso afeta a quantidade de arquivos que
poderão existir.
Funções de Transação
Existem quatro categorias de transações/funções que são usados num Data Warehouse típico. São
eles:
Extrair, Transformar e Carregar dados
Relatórios
Funções Administrativas
Funções de Metadados.
ETL, ou Extrair Transformar e Carregar (ETL) é o conjunto de transações de banco de dados usado
para extrair informações de um banco de dados, transformá-los e carregá-los em um segundo banco de
dados. As fontes de dados para o Data Warehouse estão em aplicativos ou sistemas que são externos ao
Data Warehouse (fora da fronteira). Dados de origem são extraídos ou recuperados de bancos de dados
externos por processos no Data Warehouse.
Uma vez que os dados são buscados da origem, são transformados usando regras de negócios
fornecidas pelo usuário bem como pelo administrador do armazém de dados (Transform). Depois que os
dados são transformados, eles são então carregados no Data Warehouse (Carrega ou Transporta).
Conta-se uma EE para cada Carregamento/Transporte de dados de aplicativo de origem
que mantém um ou mais ALIs no Data Warehouse. Lembre-se que a intenção primeira
dessas transações é manter dados lógicos no Data Warehouse ou alterar o comportamento
do sistema. A lógica especial de processamento se aplica na transformação e carregamento
de dados.
Não conte três EEs separadas para cada passo do processo (ex.: uma EE de Extração,
uma EE de Transformação, e uma EE de Carregamento), uma vez que todos os três são
requeridos para completar o processo elementar.
Conta um Arquivo referenciado (FTR) para cada ALI mantido.
Conte um Arquivo referenciado (FTR) para cada leitura de ALI ou AIE durante o
processamento da entrada externa.
Conte só um Arquivo referenciado (FTR) para cada ALI que é mantido e lido.
Conte um AIE para cada grupo lógico de dados que é copiado de um sistema de origem
para o Data Warehouse sem nenhuma lógica especial de processamento. Nesse caso,
também não conte uma EE para a extração de dados. (A exigência lógica é referenciar os
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 43 de 65
Guia de Contagem APF
dados. Os dados existem no Data Warehouse devido ao desempenho ou outras
considerações de design/arquitetura do que uma necessidade do usuário de negócios.)
Relatório / Consulta
Consultar e fazer relatórios sobre os dados contidos no Data Warehouse são importantes funções
de negócios. O analista do ponto de função, precisa determinar quais funções de relatório ou consulta
fazem parte do Data Warehouse e quais são considerados fora da fronteira. Existem pelo menos duas
categorias de relatórios: relatórios adhoc e programados. Relatórios adhoc representam uma solicitação a
cada vez com parâmetros diferentes selecionados pelo usuário, enquanto relatórios programados são
criados periodicamente (diariamente, semanalmente, mensalmente) e, tipicamente, não podem ser
modificados pelos usuários.
Relatórios programados geralmente requerem uma análise formalizada e um ciclo de vida de
desenvolvimento. Como tal, relatórios programados são geralmente contados pelo contador do ponto de
função enquanto relatórios adhoc, criados por um usuário final, não podem ser contados. Uma exceção a
essa orientação seria contar a funcionalidade oferecida ao usuário para criar seus próprios relatórios adhoc.
Os dois exemplos seguintes de ferramentas de relatório podem ser usados para criar relatórios
adhoc e padrão.
1. Ferramenta de Relatório internamente desenvolvida: Essa ferramenta é criada por
desenvolvedores para suportar usuários do Data Warehouse.
A fronteira de contagem determina se a ferramenta de relatório desenvolvida é contada como um
componente do Data Warehouse ou um aplicativo separado. Se os usuários vêem a ferramenta como parte
do Data Warehouse, deve ser considerada estando dentro da fronteira do Data Warehouse. Outras áreas
que podem influenciar a decisão de incluir a ferramenta como componente do Data Warehouse são a lógica
de processamento e localização/manutenção dos dados lógicos que suportam os relatórios.
Supondo que a ferramenta de relatório desenvolvida se estabelece dentro dos limites do Data
Warehouse, conte pelo menos uma SE (EO) ou CE (EQ) para cada relatório ou consulta desenvolvida e/ou
suportada para satisfazer as necessidades do usuário. Siga as orientações CPM para determinar se o
relatório ou consulta é um processo elementar único.
2. Software Comercial de prateleira (COTS)/Ferramenta de Relatório Comprada (ex.:. Relatórios
Crystal, Cognos, Business Objects, etc): Para contagens de desenvolvimento e melhoria, um contador do
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 44 de 65
Guia de Contagem APF
ponto de função deve contar só as funções que foram personalizadas ou feitas para o usuário de negócios
ou administrativo.
Se há uma necessidade ou solicitação de negócios para contar todo o portfólio de funções do
software, (por exemplo, para avaliar as características ou funções proporcionadas pelo COTS), COTS e as
funções personalizadas podem ser contados, mas o portfólio deve ser considerado um limite de aplicativo
separado do Data Warehouse, contado como um aplicativo separado, e categorizado de acordo. Conte um
SE (EO) ou CE (EQ) para cada relatório ou consulta desenvolvida e/ou suportada para satisfazer as
necessidades do usuário. Siga as orientações CPM para determinar se o relatório ou consulta é um
processo elementar único.
Funções Administrativas
Data Warehouses possuem inúmeras funções administrativas. Enquanto muitas são técnicas por
natureza e requeridas para manter o Data Warehouse ativo e operante; algumas são de natureza de
negócios e podem ser contadas. Perguntas que o contador pode fazer para ajudar a determinar se uma
função administrativa é de lógica técnica ou de negócios incluem:
• As funções foram desenvolvidas para suportar um usuário do aplicativo (ex.: administrador do
sistema, arquiteto de dados)?
• Existem exigências únicas de segurança (ex.: logins, segmentação de acesso por permissões,
senhas)? Supondo que o contador possa responder as questões acima afirmativamente:
• Conte um EE (EI) para cada função única administrativa (ex.: segurança, questões do usuário) que
mantém um ALI ou modifica o comportamento do sistema
• Conte uma SE (EO) ou CE (EQ) para relatórios produzidos para suportar essas funções. Use
regras de CPM para determinar os tipos de transação
Metadados
Metadados são geralmente definidos como dados sobre dados. Em um Data Warehouse pode
haver pelo menos dois tipos:
• Informação que suporta as características, funções e dados de negócios (ex.: dicionário de dados)
• Informação que suporta as funções técnicas do Data Warehouse (ex.: programações para backups
ou ajustes de desempenho).
É importante revisar e entender o propósito e objetivos da Contagem do Ponto de Função, na
medida em que isso irá clarear quem são os usuários e que funcionalidade de usuário pode ser
considerada. Ambos os tipos de metadados exigem a assistência de um administrador. A partir de uma
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 45 de 65
Guia de Contagem APF
perspectiva de dados de negócios, pode-se incluir um arquiteto de dados. A partir de uma perspectiva
técnica que poderia incluir um administrador do sistema. Ao tentar analisar quais características e funções
desempenhadas nessas capacidades administrativas são contadas, é útil fazer as seguintes questões.
1. As funções de metadados foram desenvolvidas para apoiar um usuário do aplicativo? Se a
resposta é “sim”, conte um EE (EI) para cada função única mantendo os metadados, e conte uma SE (EO)
ou CE (EQ) para os relatórios de metadados produzidos.
2. As funções metadados foram desenvolvidas para suportar funções ou características técnicas
opostas à lógica de negócios?
Se a resposta é “sim”, essas funções não são contadas. Elas foram criadas por propósitos técnicos.
Conclusão
A única natureza dos Data Warehouses apresenta o Analista do Ponto de Função com um número
de desafios a fornecer essas empresas dados de tamanhos precisos e métricas relacionadas que podem
ser usados para tomar as melhores decisões possíveis.
6.3. AUTOMAÇÃO DE PROCESSOS DE NEGÓCIO (BPM)
Esta subseção tem como propósito apresentar as diretrizes de Contagem de Pontos de Função
utilizadas na ATI em relação ao contexto de processos automatizados em um ambiente BPMS. O principal
objetivo é fornecer uma referência comum que torne mais prática a contagem e aplicação dos conceitos e
regras definidos pelo IFPUG, com exemplos de situações particulares de processos automatizados em um
ambiente BPMS.
Visão Geral de Processos Automatizados em um Ambiente BPMS típico.
Sistema Legado
Aplicação Externa
BPMS
Processo
automatizado
Interface de
Integração
Interface de
Integração
Sistema Legado
Aplicação Externa
Processo
automatizado
Processo
automatizado
Guia de Contagem APF ATI – www.ati.pe.gov.br
Interface de
Integração
Interface de
Integração
Sistema Legado
Aplicação Externa
Pág. 46 de 65
Guia de Contagem APF
Figura 7: Visão Geral de Processos Automatizados em um Ambiente
Definições:
Um BPMS (Business Process Management System) é um Sistema no qual se pode
desenvolver aplicativos integrados para gerenciamento de processos de negócios
contemplando recursos como: documentação de processos, execução automatizada de
processos, possibilidade de criação de indicadores gerenciais de processos em painéis de
controle, upload e trâmite de documentos eletrônicos, com possibilidade de certificação
digital e integração com sistemas legados através da filosofia SOA (Service Oriented
Architecture).
Os processos organizacionais automatizados são executados dentro do ambiente BPMS.
Na ATI este ambiente é proporcionado pela ferramenta ÁGILES.
Interface de integração é a tecnologia utilizada para integrar aplicações possibilitando a
troca e atualização de dados. Exemplos dessas tecnologias são: webservice, broker ou
view, etc.
6.3.1. FRONTEIRA DA APLICAÇÃO
Na contagem de pontos de função um dos passos iniciais da análise é a determinação da fronteira
da aplicação. Para a contagem de pontos de função de automação de processos deve-se considerar como
fronteira da aplicação, apenas a interface conceitual do processo de negócio que será automatizado. Tendo
o cuidado para não considerar na contagem, as funcionalidades que já integram e fazem parte do ambiente
BPMS, no qual o mesmo será desenvolvido. Ou seja, as funcionalidades pertinentes à ferramenta BPMS
estão fora da aplicação a ser desenvolvida (aqui o processo de negócio a ser automatizado).
6.3.2. Situação acesso ao BPMS:
Para acessar as atividades de um processo automatizado o usuário deve se logar no ambiente
BPMS. Como a funcionalidade de login é uma característica do ambiente BPMS, essa NÃO deve ser
contada como função nos projetos de automação de processos de negócio.
6.3.3. Cadastro de usuários e grupos organizacionais:
O ambiente BPMS-Agiles disponibiliza algumas funcionalidades de cadastro como por exemplo:
usuários e grupos organizacionais. Onde os usuários podem ser alocados aos grupos organizacionais. Os
projetos de automação processos devem considerar essas funcionalidades de cadastro como um AIE que é
mantido pela aplicação Ágiles, e os processos automatizados acessarão seus dados, contando estes como
Tipos de Dados.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 47 de 65
Guia de Contagem APF
6.3.4. Funcionalidades da aplicação Ágiles
A ferramenta BPMS-Agiles disponibiliza de várias funcionalidades para a execução dos processos
automatizados dentro do seu ambiente de trabalho. Apesar de poderem ser utilizadas na automação de
processos NÃO devem ser contadas, pois fazem parte do escopo da aplicação Ágiles.
Exemplos:
Consulta: Minhas atividades, Meus Processos, Monitoramento de Processos
Entrada: Iniciar algum processo de negócio
6.3.5. Recebimento de dados de outras aplicações utilizando interface de integração
Em projetos de automação de processos que realizam integração e troca de informações com
outras aplicações externas, é comum se deparar com algumas situações durante a análise de pontos de
função:
Cenário 1:
O primeiro caso são situações onde o processo automatizado precisa ler/consultar um arquivo
mantido por uma aplicação externa. Exemplo: Um processo X precisa consultar os dados de um funcionário
através de sua matrícula que são mantidos num sistema de RH. O entendimento para esse cenário é de
contagem de um AIE no processo automatizado referente aos dados consultados e mantidos no sistema de
RH e tantos Tipos de Dados que foram consultados. Nesta situação o arquivo consultado já é contado como
um ALI na aplicação externa.
Acentuando que a interface de integração utilizada nessa transação é apenas a tecnologia para
acessar os dados mantidos em outras aplicações, assim não afetam a contagem.
Cenário 2:
O segundo caso são situações onde o processo automatizado necessita verificar ou consistir
alguma informação em uma aplicação externa que possui total domínio da regra de negócio envolvida na
transação. Exemplo: Um processo X necessita verificar se um determinado funcionário pode solicitar uma
licença sem vencimento. Toda regra envolvida para essa verificação é de responsabilidade e realizada na
aplicação externa, onde o processo X solicita essa verificação na aplicação externa. Para esse cenário onde
toda a regra de negócio esta fora do processo X não se justifica nenhuma contagem de pontos de função.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 48 de 65
Guia de Contagem APF
6.3.6. Atualização de dados em outras aplicações utilizando interface de integração
Os processos automatizados que necessitem manter dados em outra aplicação onde as regras de
negócio relativas à essa manutenção, estão presentes fora da fronteira, ou se seja, estão presentes na
interface de integração e/ou em outras aplicações externas (como por exemplo no banco de dados ou
sistema legado, no que se refere a contagem não deve ser considerado um ALI para o processo
automatizado. Os dados de entrada utilizados nessa transação que foram atualizados na aplicação externa
serão considerados Tipos de Dados.
Acentuando que a interface de integração utilizada nessa transação é apenas a tecnologia para
acessar os dados mantidos em outras aplicações, assim não afetam a contagem.
6.3.7. Dados de Código
Os dados de código são uma implementação de requisitos técnicos e não devem influenciar o
tamanho funcional da aplicação, apesar de poderem representar até metade do modelo de dados em
terceira forma normal, assim não devem ser contados.
As funcionalidades que existam exclusivamente para a manutenção de dados de código não devem
ser consideradas processos elementares, assim como os dados de código não devem ser considerados
como arquivos referenciados nos processos elementares que os leiam e/ou atualizem. Observação: essas
tabelas só serão contadas se possuírem atributos que são determinantes na definição de regras de negócio.
Para tal, essas regras de negócio, não devem basear-se apenas no código do registro.
6.3.8. Processo Elementar
Algumas atividades modeladas em BPMN, apesar de se apresentarem distintas no modelo, podem
constituir apenas uma transação completa para o negócio, com sentido de completude de determinado
requisito funcional para o usuário. Assim, devem ser contadas como apenas uma transação. Assim sendo, é
factível que se tenha na modelagem BPMN mais de uma atividade ou mesmo um conjunto de atividades
que sejam correspondentes a um único requisito funcional, sendo portanto considerado na contagem como
uma única transação
Atenção: Alguns modelos BPMN podem apresentar atividades que foram modeladas apenas para
melhor entendimento do negócio e, que não constitui um processo elementar para o sistema. Assim não
devem ser levadas em consideração na contagem.
Exemplo1:
Na figura 8 abaixo foram incluídas no modelo as atividades “Vistar Documentação e Pendências“ e
“Solicitar Resolução de Pendências”. Apesar de serem duas atividades no modelo, para o negócio elas
constituem apenas um processo elementar, individualmente elas não constituem uma transação completa.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 49 de 65
Guia de Contagem APF
A atividade “Vistar Documentação e Pendências” sem a “Solicitação de Resolução das Pendências” não é
considerado um processo completo para o usuário.
Figura 8: Exemplo de atividades distintas que compõem um único processo elementar
Exemplo2:
Uma mesma atividade que pode ser realizada por pessoas/entidades diferentes deve ser contada
apenas uma vez. Na Figura 9 abaixo a atividade “Resolver Pendência” constitui uma transação completa,
tem significado para o usuário, é autocontida e deixa o negócio da aplicação em um estado consistente.
Isso independente da entidade que a realiza. O mesmo ocorre com a atividade “Assinar Contrato”, conforme
podemos observar na Figura 10.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 50 de 65
Guia de Contagem APF
Figuras 9 e 10: Exemplos de atividades distintas que compõem um único processo elementar
6.3.9. Atividade com prazos
Atividades que tenham um prazo para serem realizadas, onde após a expiração do prazo uma
notificação/lembrete é disparada, essa notificação seja por e-mail, sms ou outro meio, não deve ser
contada, pois faz parte do negócio da atividade.
Exemplo:
Na figura 11 abaixo a atividade “Assinar Contrato” tem um prazo de 01 (um) dia para ser realizada.
Se o prazo expirar primeiro do que a conclusão da atividade, então será disparada uma atividade para
notificar o responsável avisando do ocorrido e solicitando a sua realização. A notificação em si seja por
email, sms ou algum outro meio, não tem sentido completo de negócio para o usuário, é apenas um
procedimento integrante deste.
Figura 11: Exemplo de atividade de notificação que não representa um processo elementar
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 51 de 65
Guia de Contagem APF
7. LIÇÕES APRENDIDAS
7.1. REQUISITOS
É primordial que os requisitos de software sejam escritos de forma coerente com a nova forma de
medição, que é Pontos de Função. Embora a engenharia de requisitos tradicional não aconselhe, o que
vemos na prática é que os requisitos devem ser fracionados de forma tal a representar a mínima unidade
funcional que seja compreendida pelo usuário e que seja testável pelo desenvolvedor.
Este fracionamento traz a organização e o controle dos requisitos de forma tal a conhecer o produto
da melhor maneira possível, além de que é mais fácil gerenciar mudanças em requisitos menores. O
Capability Maturity Model Integration (CMMI) não trata da forma como os requisitos serão escritos, mas
ainda assim, quando se trata de APF algumas observações devem ser consideradas.
7.1.1. GRANULARIDADE X QUANTIDADE DE REQUISITOS
Ponto de função aponta claramente o conceito de processo elementar que representa um “requisito”
do usuário. Isso quer dizer que ele é completo do ponto de vista de usuário, deixa o sistema consistente e a
funcionalidade entregue é reconhecida pelo usuário.
Desta forma, ao fracionar demais os requisitos várias funcionalidades são quebradas em partes que
sozinhas não tem valor de negócio algum, o que pode levar a um desentendimento sobre o “processo
elementar”.
Por exemplo, uma funcionalidade solicitada pelo usuário que é composta por 3 passos, realizadas
em momentos diferentes por pessoas diferentes, provavelmente será um ÚNICO requisito pois se mostra
como um único processo elementar que só faz sentido se os 3 passos forem dados. Assim, tanto faz
realizar 0, 1 ou 2 passos, para o usuário aquela parte não concluída é irrelevante.
Seguindo o exemplo anterior, suponha que a função é uma SE complexa (Que custa 7 PF) poderia
ser quebrada em 2 EE simples (3 pontos cada uma) e 1 SE simples (4 Pontos) o que levaria ao total de 10
PF, 3 Pontos mais caro em uma única funcionalidade. Então identificar o processo elementar é um passo
mais importante do que identificar requisitos e fluxo de serviços.
7.1.2. ATENÇÃO A REQUISITOS NÃO FUNCIONAIS
O Ponto por Função mede software de acordo com seu tamanho funcional (Requisitos funcionais) e
os requisitos não funcionais estão com preço “embutido” dentro do ponto de função (Ver a parte de
precificação na seção de considerações para a contagem). Então certos cuidados ao solicitar melhorias não
funcionais devem ser observados.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 52 de 65
Guia de Contagem APF
Por exemplo, um caso recente que houve na ATI, se tratava de um sistema que criava e gerenciava
documentos. Só que para motivos de usabilidade, foi solicitado que dois tipos especiais de documentos
fossem criados e gerenciados (Atas de Registro de Preço e Licitações). Esta solicitação visou o ganho de
tempo da criação de atas e licitações bem como preparar o sistema para trabalhar com estes dois modelos.
Desta forma, os dois tipos de documentos solicitados foram a criação do produto final do sistema,
criação de documentos, e não novas funcionalidades. Ou seja, um usuário do sistema poderia ter criado o
documento tipo Ata e o documento tipo Licitações e disponibilizar para o estado sem o ônus.
Parece pouca coisa, mas a interferência no sistema, uma vez que as atas e licitações eram
gerenciadas como quaisquer documentos, mas em locais específicos, o que tornou o sistema 40% maior do
que o necessário, implicando em aumento nos custos.
Então é pedido atenção neste aspecto, e alguns cuidados como solicitar as melhorias não
funcionais para TODO o sistema. Ou seja, se é necessário que um requisito de segurança seja aplicado em
uma transação, solicitar que este requisito seja estendido a todo sistema. Isso pode baratear o produto.
7.1.3. ATENÇÃO A RELATÓRIOS
Os relatórios são um dos pontos mais problemáticos em pontos de função uma vez que é
relativamente comum aparecer em um sistema relatórios parecidos, mas que são “diferentes” nos dados em
que apresentam. Isso significa que novas funcionalidades (Consultas ou Saídas Externas) surgem a cada
novo relatório e que relatórios parecidos significam funcionalidades diferentes embora parecidas.
Então neste ponto é recomendada a junção de vários relatórios parecidos em um único relatório que
atende a todas as demandas. Isto significa uma redução não só do pagamento, mas do tamanho do sistema
uma vez que manutenções no sistema ocorrerão uma vez só.
7.2. DICAS NA DEFINIÇÃO DA FRONTEIRA
A fronteira determina o que é interno e externo para uma aplicação, de acordo com a visão do
usuário, sendo de fundamental importância na medição funcional. Um erro nesta atividade pode ocasionar
duplicidade na identificação de funções, identificação incorreta ou até sua omissão. Em muitos casos isto
reflete no aumento da contagem, trazendo prejuízo para a instituição.
Seguem algumas dicas que podem auxiliar na identificação da fronteira:
•
A fronteira deve ser delineada de uma perspectiva de negócio, não devendo levar em
consideração detalhes técnicos ou de implementação.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 53 de 65
Guia de Contagem APF
•
Obtenha uma documentação do fluxo de dados do sistema e desenhe uma fronteira em
volta para destacar quais partes são internas e externas à aplicação.
•
Verifique como a aplicação é gerenciada; se é desenvolvida ou mantida em sua totalidade
ou em partes por equipes distintas.
•
Verifique se há usuários distintos especificando requisitos para cada parte do software. Isto
pode representar fronteiras entre os sistemas.
•
Identifique áreas funcionais atribuindo propriedade a certos tipos de objetos, como
entidades e processos.
•
Documente previamente as fronteiras de todas as aplicações que poderão ser objeto de
medição.
7.3. DICAS NA IMPLANTAÇÃO DO PROCESSO
A utilização de pontos de função na contratação de desenvolvimento de software têm crescido
bastante no mercado brasileiro. Entretanto este processo ainda não atingiu sua total maturidade. Por isso,
algumas empresas encontram dificuldade na utilização da técnica e acabam sendo mal sucedidas em seus
projetos. Seguem algumas dicas que podem minimizar ou até evitar problemas na implantação deste
processo:
•
Capacitação: conhecer corretamente a técnica de pontos de função é fundamental. Embora
seja óbvio, observa-se que muitas organizações erram neste passo básico.
•
Estabelecer objetivos iniciais modestos: começar com um projeto piloto em um sistema
simples. Avaliar os resultados, efetuar as correções necessárias, revisar os objetivos e
seguir em frente.
•
Esteja ciente das limitações da técnica: Existem domínios de problema em que a APF
não é indicada. Por exemplo, em sistemas de otimização a técnica não é adequada para
medir as partes com alta complexidade algorítmica. A técnica também não é recomendada
para estimativa de projetos muito pequenos (< 100) ou atividades pontuais, pois pode haver
distorções significativas.
•
Busque ajuda se necessário: Uma consultoria externa pode evitar "cabeçadas
desnecessárias" e agilizar o processo, trazendo experiências e ajudando a corrigir rumos.
Também existe um grupo de usuários muito ativo no Brasil, o BFPUG (Brazilian Function
Point Users Group) que possui um fórum de discussão ideal para este objetivo.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 54 de 65
Guia de Contagem APF
•
Cuidado com os conflitos de interesse: a medição do serviço em pontos de função nunca
deve ser realizada somente pelo fornecedor, pois ele será remunerado justamente pelo
resultado da medição! Observa-se esta prática indesejável em algumas organizações
(inclusive públicas). Pode-se utilizar pessoal interno para realizar a medição, ou na pior das
hipóteses validar por amostragem as medições realizadas. Outra opção é contratar uma
empresa externa para este serviço.
•
Esteja atento ao preço do ponto de função: este item é tão importante que vale abordá-lo
em mais detalhes.
8. CONSIDERAÇÕES SOBRE A CONTAGEM DE PONTOS DE FUNÇÃO
Esta seção apresenta considerações especiais sobre o dimensionamento em Pontos de Função de
mudança de requisitos, projetos cancelados e redução de cronograma. E sugere métricas para o
dimensionamento de atividades de negócio.
8.1. CONSIDERAÇÃO SOBRE MUDANÇAS DE REQUISITOS
Em projetos de desenvolvimento e manutenção de software é bastante comum as mudanças de
requisitos no decorrer do projeto, conforme o usuário e o desenvolvedor adquirem mais conhecimento sobre
o negócio [Sommerville, 2007]. O CPM denomina este fenômeno de Scope Creep. Como os requisitos não
podem ser congelados, então temos que gerenciá-los de forma efetiva.
Nas estimativas iniciais de tamanho de projetos de desenvolvimento, após a fase de especificação,
considerando-se o documento de visão inicial do projeto, recomenda-se utilizar um percentual para
evolução de requisitos de 30% a 40%. Nas estimativas, após a fase de requisitos, utilizando-se como
insumo as especificações de casos de uso, deve-se considerar um percentual de 20% a 30%.
Por exemplo, suponha que após a análise do Documento de Visão de um Projeto, aplicando-se a
CEPF, foi obtido o tamanho de 200 PFs, então o tamanho estimado do projeto considerado é de 270 PFs
(200 + 35%), utilizando-se a premissa de evolução de requisitos em 35%. Esta premissa deve ser
documentada.
Uma mudança de requisito gera retrabalho da equipe de desenvolvimento, aumentando assim o
esforço e o custo do projeto. Por exemplo, suponha um relatório de clientes em que no final da fase de
implementação foi solicitada a exibição de uma nova informação. A equipe de desenvolvimento terá um
retrabalho de várias fases do ciclo de vida. Para tratar o dimensionamento das mudanças de requisitos
torna-se importante definir a distribuição de esforço pelas macroatividades do projeto, visando definir o valor
agregado ao projeto após cada fase do ciclo de vida.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 55 de 65
Guia de Contagem APF
A Tabela 6 na Seção 3.2 estabelece os percentuais por atividade de forma a permitir a contagem de
mudança conforme o estágio do projeto. Esta distribuição percentual de pagamento deve ser definida no
contrato de software.
Por exemplo, suponha um relatório de clientes em que no final da fase de implementação foi
solicitada a exibição de uma nova informação. A equipe de desenvolvimento terá um retrabalho de várias
fases do ciclo de vida. Assim, o tamanho dessa mudança deve ser calculado da seguinte maneira:
Tamanho do relatório de clientes (original) – SE – M – 5 PF
Tamanho do relatório de clientes (alterado) – SE – M- 5 PF
O requisito alterado será considerado 100% do PF, supondo que este será entregue ao cliente sem
passar por novas alterações. Para o requisito original será considerado o seguinte:
Engenharia de Requisitos 25%
Design, Arquitetura 15%
Implementação 40%
Assim, o tamanho da mudança é de 4 PFs (5 PF x 80% = 4 PFs).
É importante alertar o cliente sobre o impacto das solicitações de mudança no esforço, prazo e
custo do projeto. Uma boa forma de apresentar esses valores é fazer uma nova estimativa com base nas
alterações e verificar a variação em termos percentuais (estimativa inicial x nova estimativa). Assim o cliente
ficará ciente e poderá adequar suas expectativas de prazo e custo, ou então, poderá reavaliar as alterações
solicitadas de acordo com as reais necessidades do negócio.
8.2. CONSIDERAÇÃO SOBRE PROJETOS CANCELADOS
Em alguns casos, devido às mudanças no ambiente do cliente, uma demanda ou parte de um
projeto de desenvolvimento ou manutenção pode ser cancelado pelo cliente ou fornecedor. Nestes casos, o
tamanho funcional do que foi cancelado será aferido por meio da contagem de Pontos de Função das
funcionalidades canceladas e um Fator de Impacto.
O Fator de Impacto é definido com base no percentual de esforço alocado a construção da
funcionalidade em questão, observando as tabelas de distribuição de esforço contidas na Seção 3.2 ou
alguma diretriz específica de distribuição de esforço do contrato em questão.
O Fator de Impacto deve ser aplicado na contagem de Pontos de Função das funcionalidades em
questão. É importante ressaltar que em um processo de desenvolvimento incremental uma funcionalidade
pode, por exemplo, estar em fase de requisitos e de testes, porque o plano de testes é construído na fase
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 56 de 65
Guia de Contagem APF
de requisitos. O Progresso das atividades executadas em cada funcionalidade do projeto deve ser obtido
por meio do acompanhamento do plano do projeto.
Este fator de impacto pode ser desconsiderado quando o cancelamento vem por parte do
fornecedor, sendo assim não será pago o que não foi entregue, e vale lembrar que este fator de impacto
pode ser substituído por multas em SLAs no edital.
8.3. CONSIDERAÇÕES SOBRE REDUÇÃO DE CRONOGRAMA
As estimativas de prazo não são lineares com o tamanho do projeto, assim pretende-se pesquisar
mais sobre o melhor tempo desenvolvimento (onde há uma melhor relação custo x benefício de alocação de
recursos e menor prazo de desenvolvimento), dado o tamanho de um projeto específico. Jones [Jones,
2007] propõe uma fórmula para o cálculo do melhor tempo de desenvolvimento, descrita na seção 3.3.
Alguns projetos devido à legislação e a outros fatores externos a ATI possuem um prazo imposto
pelo cliente. Se este prazo for igual ou superior ao prazo calculado pela Fórmula de Capers Jones (2007)
(expoente t) ou em caso de projetos pequenos (menores que 100 PF) ainda se faz necessário calcular o
prazo Máximo de entrega.
No entanto, se o projeto tiver um prazo imposto pelo cliente inferior ao prazo calculado, então se
deve considerar como risco de projeto.
Deve-se ressaltar que não é possível uma redução de prazo maior que 25 %, devido aos cálculos
de Região Impossível e ainda conforme nos aproximamos da região impossível, o esforço e o custo do
projeto aumentam de maneira exponencial.
Como os riscos da redução de cronograma também são altos, não é recomendada a redução de
cronograma. Deve-se tentar priorizar funcionalidades trabalhando com o ciclo de vida incremental. Caso o
contrato seja baseado em preço por Pontos de Função, este aumento de esforço será refletido na contagem
de PF.
8.4. CONSIDERAÇÕES SOBRE A PRECIFICAÇÃO
Nesta seção serão tratados aspectos referentes a precificação do ponto de função, apresentando os
fatores que influenciam no preço e que devem ser considerados na definição dos critérios de contratação
dos serviços de desenvolvimento e manutenção de software. Também serão apresentados alguns
exemplos onde os requisitos não funcionais e as características do projeto podem aumentar
significativamente o esforço de desenvolvimento, elevando assim os custos e o preço médio do ponto de
função.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 57 de 65
Guia de Contagem APF
8.4.1. Tamanho Funcional x Esforço de Desenvolvimento
Embora exista uma forte relação entre o tamanho funcional de um software (medido em Pontos de
Função) e o esforço gasto no seu desenvolvimento (medido em pessoas-hora), os Pontos de Função não
medem diretamente o esforço de desenvolvimento. Nesse sentido, os Pontos de Função são semelhantes
ao metro quadrado na construção civil: embora o metro quadrado influa consideravelmente no esforço de
construção e no custo de um imóvel, outros fatores poderão contribuir tanto ou mais quanto o metro
quadrado.
Exemplos de fatores são a localização do imóvel, a idade, o material utilizado na construção e
acabamento, o prestígio do arquiteto, etc. Da mesma forma, dois sistemas podem ter a mesma medida em
Pontos de Função e preços totalmente diferentes. Por exemplo, um sistema pode ser monousuário,
implementado em uma ferramenta como o Access; o outro pode ser uma aplicação web com várias
camadas, envolvendo um mainframe e sofisticados dispositivos de segurança. Neste caso, certamente a
quantidade de horas e o preço de cada um desses sistemas será completamente diferente.
A conclusão é que o tamanho em Pontos de Função é apenas um dos fatores que influem sobre o
esforço de desenvolvimento e sobre o custo de um sistema. Outros fatores importantes são a confiabilidade
desejada para o software, a metodologia de desenvolvimento utilizada, o nível de testes requerido, a
complexidade dos algoritmos, a dificuldade da plataforma computacional, o estilo de interface com o
usuário, o grau de reutilização desejado, a capacidade e experiência da equipe, a disponibilidade de
ferramentas de software adequadas e outros.
8.4.2. Valor do Ponto de Função
O valor R$/PF irá variar de acordo com o trabalho exigido para a entrega das funcionalidades do
software levando em consideração o padrão técnico e de qualidade solicitada pelo cliente, como também a
quantidade de entregáveis (artefatos, documentos, modelos, etc) exigidos. Em resumo, tudo aquilo que
afeta custo de forma significativa, mas que não tem relação direta com o tamanho medido pela APF acaba
sendo computado no preço do ponto de função.
Exemplo 1: ao se contratar uma empresa apenas para o trabalho de codificação e testes de um
sistema espera-se que o preço do ponto de função seja inferior ao caso da contratação da mesma empresa
para a realização de todo o ciclo de desenvolvimento do sistema, desde o levantamento de requisitos até a
implantação.
Exemplo 2: o preço do ponto de função para a entrega apenas do software certamente é inferior ao
preço do ponto de função onde, além do software, devem ser entregues vários documentos (subprodutos)
como: modelos da UML, manual de usuário, ajuda on-line, protótipos, casos e planos de testes, etc.
Exemplo 3: atualmente a gama de tecnologias disponíveis para desenvolvimento de sistemas é
enorme, cada uma delas podendo influenciar diretamente na produtividade (tanto positivamente quanto
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 58 de 65
Guia de Contagem APF
negativamente) do trabalho a ser realizado. Sendo assim é bastante comum no mercado a a diferenciação
do R$/PF de acordo com a plataforma tecnológica (mainframe, web, cliente-servidor, etc) e/ou linguagem de
programação (cobol, C, java, .net, etc).
Exemplo 4: A APF, segundo o padrão IFPUG, mede manutenções desconsiderando o tamanho da
manutenção que a função sofrerá. Geralmente o esforço para se manter uma função costuma ser inferior ao
de se desenvolvê-la. Sendo assim, pode haver diferenciação de preço do ponto de função em projetos de
melhoria para funcionalidades novas, alteradas e excluídas.
Exemplo 5: ao se contratar uma empresa de desenvolvimento de sistemas estabelecendo SLAs
(acordos de níveis de serviços) muito rígidos, relacionados à produtividade da equipe e qualidade do
produto, é de se esperar um preço do ponto de função superior ao de um contrato com um menor nível de
exigências.
Em resumo, não existe um preço único para ponto de função bem como não há atualmente uma
tabela de preços disponível publicamente onde se possa consultar valores para o preço do ponto de função.
Até mesmo porque esta é uma informação considerada reservada ou estratégica para muitas organizações.
Porém é possível obter informações de preço dos contratos governamentais através de uma pesquisa nas
licitações ocorridas, no diário oficial ou diretamente com o órgão do governo.
Outra possibilidade para se obter essa tabela de preços é recorrer às organizações que mantém
base histórica de projetos de software (exemplo: ISBG - www.isbsg.or) e efetuar uma conversão dos
indicadores de taxa de entrega (H/PF) para preço (R$/PF). Porém mesmo que se consiga obter uma tabela
de valores R$/PF, a variação dos números é tão significativa que facilmente se encontra uma faixa de
valores cuja variação entre o mínimo e o máximo pode ser de até 10 vezes, por exemplo, de R$100/PF a
R$1.000/PF.
Para obter uma informação mais realista do preço (ou custo) do PF é melhor buscar isto
internamente nos projetos já realizados. Para projetos já concluídos uma informação certamente disponível
é o quanto se pagou ou se cobrou por cada projeto e quais atividades estavam compreendidas. Caso o
tamanho funcional (PF) dos projetos não esteja disponível, pode-se obtê-lo rapidamente através de uma
medição ou de uma estimativa; basta analisar seus requisitos. Tendo o preço do projeto e o seu tamanho
em pontos de função, obtém-se o seu preço por ponto de função (R$/PF). No entanto é provável que sua
organização empreenda projetos de diferentes tipos. Neste caso deve-se proceder a análise do R$/PF para
cada categoria de projetos, pois dificilmente um preço único será representativo para projetos de tipos
distintos.
8.4.3. Preço Ideal do Ponto de Função na APE
No contexto das instituições públicas encontramos um cenário onde é necessário contratar serviços
de desenvolvimento e manutenção para vários projetos, muitas vezes de naturezas diferentes, de acordo
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 59 de 65
Guia de Contagem APF
com o planejamento estratégico e as diretrizes do governo. Porém, não é viável que as instituições realizem
uma contratação específica para cada projeto, devido aos altos custos de um processo licitatório, bem
como, a complexidade técnica de se gerenciar vários contratos de pequeno porte.
Por isso, uma boa prática que vem sendo adotada na APE é que projetos de características
semelhantes sejam atendidos por uma mesma contratação, salvo aqueles cuja natureza estratégica ou o
grande porte prescindam de uma contração específica. Desta forma, podemos obter alguns benefícios
como um maior controle dos projetos, através de uma gestão centralizada, e a redução de custos, através
de um maior volume de serviços contratados e também pela diminuição de processos licitatórios na APE.
Porém, é importante observar que, em se tratando de projetos de características diferentes,
dificilmente poderemos chegar a um preço ideal do ponto de função sem que haja grandes distorções. Isto
ocorre por conta do nível de esforço exigido em cada projeto, que acaba influenciando diretamente no preço
cobrado pelo fornecedor. Então, se não houver um planejamento eficaz da contratação, corremos o risco de
que os projetos mais simples saiam muito caros para a instituição, enquanto os projetos mais complexos
saiam de grande prejuízo para o fornecedor.
Para minimizar este problema, recomenda-se que os projetos de características similares (processo,
tecnologia, requisitos não funcionais, requisitos de qualidade, SLAs) sejam agrupados em categorias que
deverão ser licitadas separadamente (lotes diferentes de preço). Se observarmos estes projetos em um
nível macro perceberemos que as situações extremas se compensam e, em média, existe uma maior
linearidade na relação entre o esforço e o tamanho funcional, permitindo que o fornecedor estabeleça um
preço médio justo para ambas as partes.
O objetivo é manter o equilíbrio financeiro entre instituição x fornecedor num conjunto de projetos
realizados durante o período do contrato, numa relação que represente vantagem para ambos os lados.
Seguem alguns critérios de similaridade que causam impacto no esforço e podem ser utilizados para
categorização de projetos:
Aspectos não funcionais;
Complexidade e lógica de processamento;
Requisitos de disponibilidade e performance;
Mix de tecnologias envolvidas;
Processo de desenvolvimento utilizado;
Tamanho – ordem de grandeza – do projeto;
Artefatos construídos;
Nível de exigência dos Acordos de Níveis de Serviço;
Além de categorizar os projetos é importante manter uma base histórica de indicadores de esforço e
custo. Os indicadores devem estar associados aos objetivos estratégicos da instituição e devem ser
coletados e acompanhados de forma sistemática. Podemos citar como exemplo a taxa de entrega (H/PF) e
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 60 de 65
Guia de Contagem APF
o preço (R$/PF), que podem ser obtidos através de quanto se cobrou por cada projeto, a quantidade de
horas de trabalho reportada e quantos pontos de função foram entregues no período.
Estes números são de grande importância, pois refletem a experiência da própria organização nos
projetos medidos em pontos de função, podendo ser usados para acompanhamento dos contratos, melhoria
das estimativas, referências para futuras contratações e como base de comparação com outras instituições.
Desta forma, as instituições podem aproveitar as lições aprendidas para calibração do preço do ponto de
função, obtendo assim um valor mais adequado a sua realidade.
8.4.4. Considerações
Através dos exemplos podemos perceber o impacto direto do esforço de desenvolvimento sobre o
preço do ponto de função. Desta forma, é de extrema importância que os requisitos para contratação de
serviços sejam bem definidos, de acordo com as características dos projetos e baseados nas necessidades
dos clientes, para que a instituição não sobrecarregue o fornecedor com exigências que não agregarão
valor ao projeto e que, com certeza, irão aumentar o preço cobrado por ponto de função.
Por outro lado, a instituição não pode ser omissa na hora de estabelecer os critérios de contratação
buscando um menor preço, pois isso acarretará em baixa qualidade de serviços e insatisfação do cliente. A
melhor alternativa é buscar equilíbrio entre estes fatores, garantindo assim melhores contratações, bem
como, um melhor relacionamento entre contratante e contratada.
Uma iniciativa neste sentido foi a ata de registros de preço para desenvolvimento de sistemas em
pontos de função, elaborada pela ATI em outubro de 2010, cujos serviços foram divididos em lotes de
acordo com a tecnologia utilizada (JAVA Demoiselle, JAVA MakerAll e Dot Net).
Para esta contratação a ATI realizou um levantamento dos fatores necessários para a maioria dos
projetos de governo, como aderência a arquitetura padrão do estado, atividades do ciclo de vida de projetos
e SLAs de qualidade e produtividade. Estes fatores influenciam diretamente no esforço, por isso foram
incluídos no edital para formação do preço do ponto de função. Estima-se que esta primeira contratação
trouxe uma economia para a ATI algo em torno de 4.000.000 (Quatro Milhões) de R$
Desta forma, as instituições da APE que tiverem interesse poderão aderir a esta ata para
atendimento de suas demandas, garantindo assim os níveis de qualidade e produtividade padrão do
governo, desde que estes níveis atendam as necessidades de seus projetos. Além disso, estarão
respeitando os princípios da economicidade e eficiência, evitando os custos e a longa duração de um novo
processo licitatório, além da economia de escala no preço do ponto de função para um maior volume de
serviços.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 61 de 65
Guia de Contagem APF
Além disso, é fundamental que as instituições mantenham uma base histórica de indicadores dos
projetos para melhoria contínua das estimativas e controle das contratações. Isso vai refletir em resultados
positivos para a instituição e, conseqüentemente, melhores serviços para o cidadão.
8.5. CONSIDERAÇÕES SOBRE CICLO DE VIDA ITERATIVO INCREMENTAL
Segundo experiências obtidas pela própria ATI a soma das partes pode ser maior do que o todo. Ou
seja, se a ATI recebe de um fornecedor 3 Iterações de 300 Pontos não necessariamente o produto final
conterá 900 pontos.
Será necessário para a ATI identificar em cada um dos seus editais a compensação de ao fim das
iterações recuperar a diferença do tamanho do sistema (final) e da soma das partes que deve ser maior.
8.6. COMO UMA EMPRESA PÚBLICA PODE SE FILIAR AO IFPUG.
O que um órgão do governo deve fazer para obter a filiação ao IFPUG?
Normalmente as maiores dúvidas dizem respeito ao pagamento da filiação, que deve ser feito em
dólares no exterior. Contudo vários órgãos estaduais, federais e empresas estatais já se filiaram e
permanecem filiados. Os passos irão variar um pouco dependendo do órgão, mas basicamente são:
1. Dirigir-se à área de compras, suprimentos ou filiações a associações, com uma solicitação
devidamente embasada, justificando a necessidade de filiação ao IFPUG. Ressaltar que o único
fornecedor dos serviços almejados é o IFPUG (por exemplo, para ter acesso ao CPM e realizar o
exame CFPS o IFPUG é a única fonte).
2. Aprovado o pedido, a área de compras provavelmente solicitará ao IFPUG uma invoice (fatura, ou
instrumento de cobrança) que servirá de base ao pagamento e especificará o valor a ser pago. A
invoice pode ser solicitada via e-mail ao escritório do IFPUG, tendo-se o cuidado de enviar ao
IFPUG todos os dados necessários à identificação do órgão: razão social, endereço, CNPJ, etc.
Orientar o escritório do IFPUG sobre a necessidade de colocar todos os dados na invoice.
Normalmente a invoice virá através de e-mail.
3. Recebida a invoice, a área de compras estará ciente do valor a ser pago (conforme o tipo de filiação
solicitado) e dos dados bancários do IFPUG para remessa do dinheiro. Nesta data (10 de Dezembro
de 2010) esses dados são:
International Function Point Users Group
191 Clarksville Rd.
Princeton Junction, NJ 08550
Sovereign Bank
44 Princeton Hightstown Rd
Princeton Jct., NJ 08550
877-768-1145
ABA # 231372691
Account # 0741078090
Amount:______________
Swift Code: SVRNUS33
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 62 de 65
Guia de Contagem APF
Notar que o campo Amount (valor) acima deve ser preenchido com o valor da filiação acrescido de
US$ 50.00 (cinquenta dólares norte-americanos), correspondentes à taxa de remessa internacional
cobrada pelo banco e repassada ao filiado pelo IFPUG.
4. De posse dos dados bancários acima, um funcionário do órgão deve ir a uma agência do Banco do
Brasil, que realizará o serviço de remessa eletrônica ao exterior. Este serviço é uma operação de
câmbio, devendo existir uma taxa cobrada pelo BB e possivelmente impostos. Efetuada a remessa,
o BB fornecerá um comprovante em reais, que será contabilizado pelo órgão. Dessa forma, não
existirá contabilmente uma operação em dólar no órgão, mas sim um pagamento em reais ao BB
(esta é uma dúvida que costuma surgir - alguns colegas dizem "Meu órgão não pode realizar
pagamentos em dólares", mas isto não deve constituir impeditivo, já que o fato contábil será
registrado em reais).
5. Realizada a transferência, uma cópia do comprovante fornecido pelo BB deverá ser enviada via fax
ou e-mail ao IFPUG, juntamente com o formulário de filiação que pode ser baixado de
http://www.ifpug.org/membership/membershipApplication.pdf
(ver
http://www.ifpug.org/membership/). Notar que o nome do órgão deverá aparecer exatamente da
mesma maneira no comprovante do BB e no formulário de filiação - não colocar, por exemplo,
Agência Estadual de Tecnologia da Informação em um documento e ATI no outro, etc.).
6. Tudo isto feito, os contatos constantes do formulário de filiação receberão um e-mail de confirmação
com identificação de usuário e senha para acesso à área de filiados do site do IFPUG. Notar que
este retorno pode levar mais de uma semana. Se demorar demais, enviar ao IFPUG uma
mensagem em inglês solicitando explicação.
7. A filiação ao IFPUG vence sempre no dia 30 de junho de cada ano, independentemente da época
da filiação. Um indivíduo ou organização que se filie ao IFPUG como Regular Member entre
primeiro de maio e 30 de junho de qualquer ano pagará o preço normal da filiação. Contudo, tal
indivíduo ou organização terá sua filiação estendida até 30 de junho do ano seguinte. Ou seja, é
bom ter cuidado em quando realizar a filiação.
8.7. CERTIFICAÇÃO CFPS
O Exame CFPS - Administrado pela Prometric - acesse http://www.prometric.com,CFPS - Certified
Function Point Specialist - é a certificação conferida pelo International Function Point Users Group às
pessoas aprovadas no exame de certificação CFPS.
É necessário ser filiado ao IFPUG para obter e manter a certificação CFPS. A certificação CFPS é
reconhecida internacionalmente e é válida por até 3 (três) anos. A partir de julho de 2003, a certificação é
conferida por 1 (um) ano e revalidada anualmente, por até 3 anos, enquanto a pessoa permanecer filiada ao
IFPUG.
A interrupção da filiação implica na perda da certificação. Após 3 anos, é necessário fazer novo
exame (a menos que a pessoa utilize o programa de recertificação, ainda não implantado fora dos E.U.A.).
O custo do exame é U$250, pagos diretamente à Prometric, empresa que realiza o exame.
É possível confirmar se uma pessoa detém a certificação CFPS através de consulta ao IFPUG,
enviando um e-mail a [email protected]. ou consultando no site do IFPUG.
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 63 de 65
Guia de Contagem APF
A certificação é a garantia de que o profissional entende e utiliza corretamente as regras do IFPUG
para a contagem de pontos de função. Todos os profissionais de APF (Análise de Pontos de Função)
devem buscar a certificação.
9. PROCESSO DE REVISÃO DO GUIA DE CONTAGEM
9.1. REVISÃO PARA CORREÇÃO DE INCONSISTÊNCIAS E SITUAÇÕES NÃO
PREVISTAS
A revisão deste guia será feita sempre que a ATI, clientes e fornecedores verificarem
inconsistências entre uma definição do CPM e uma regra constante deste documento e situações não
previstas neste guia. Para situações não previstas neste guia, dever-se-á recorrer à equipe de contagem do
cliente e a coordenação da área de métricas da USG-GND da ATI que decidirão pela atualização deste guia
ou do contrato.
9.2. REVISÃO PARA ADOÇÃO DE NOVAS VERSÕES DO CPM
A adoção de nova versão do CPM como referência para este Guia de Contagem não será imediata
à sua publicação. Nesse caso deverá haver uma avaliação da nova versão pela ATI para se decidir sobre a
atualização do guia.
10. CONCLUSÃO
Este documento apresentou um guia para o dimensionamento de tamanho de todos os tipos de
projetos de software desenvolvidos pela ATI seguindo as diretrizes da Instrução Normativa – IN04. A
estimativa de tamanho utiliza a métrica de Pontos de Função Não Ajustados como unidade de medida,
conforme recomendado nos Acórdãos do Tribunal de Contas da União (TCU).
Como trabalho futuro recomenda-se a revisão e atualização deste roteiro sempre que se verificar
inconsistência entre alguma definição do IFPUG, seja publicada em versões futuras do CPM ou em White
Paper, ou quando for detectado um novo tipo de serviço associado ao desenvolvimento de software não
previsto neste trabalho.
REFERÊNCIAS BIBLIOGRAFIAS
[Hazan, 2008] HAZAN, C. Análise de Pontos de Função: Uma Aplicação nas Estimativas de
Tamanho de Projetos de Software. Engenharia de Software Magazine, Edição 2, Editora
Devmedia, pp.25-31. (2008).
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 64 de 65
Guia de Contagem APF
[IEEE,1998] IEEE Computer Society. IEEE Standard for Software Maintenance. IEEE Std 1219,
(1998).
[IFPUG, 2007] IFPUG. Function Points & Counting Enterprise Data Warehouses. Release 1.0,
September, (2009).
[IFPUG, 2009] IFPUG. Considerations for Counting with Multiple Media. Release 1.0,
September, (2009).
[IFPUG, 2010] IFPUG. Counting Practices Manual. Version 4.3, January, (2010).
[Jones, 2007] JONES, C. Estimating Software Costs. Second Edition, McGraw Hill, (2007).
[NESMA, 2009] NESMA. Function Point Analysis for Software Enhancement Guidelines.
Version 2.2.1, (2009).
[Serpro, 2010] SERPRO. Roteiro de Contagem de Pontos de Função. (2010).
[Sommerville, 2007] SOMMERVILLE, I. Software Engineering. Pearson Education Limited, 8th
Edition, (2007).
[TotalMetrics, 2004] TotalMetrics. Levels of Function Point Counting. (2004).
Guia de Contagem APF ATI – www.ati.pe.gov.br
Pág. 65 de 65