Personal Software Process

Descargar como docx, pdf o txt
Descargar como docx, pdf o txt
Está en la página 1de 5

Personal Software Process (PSP)

La disciplina del PSP provee un marco estructurado para desarrollar habilidades


personales y métodos que se necesitarán más adelante para ir forjando al ingeniero de
software. Es importante que la calidad del software desarrollado abarque hasta el más
mínimo detalle, por muy pequeño que éste sea, ya que, si no se hace así, puede dañar
el sistema entero.
El Personal Software Process, PSP, indica a los profesionales de software cómo:
•Administrar la calidad de los proyectos de desarrollo de software
•Reducir defectos en los productos
•Estimar y planear el trabajo PSP
Fue diseñado para ayudar al ingeniero de software a hacer bien el trabajo, aplicar
métodos avanzados de ingeniería en su labor diaria, a utilizar métodos detallados de
planificación y estimación y controlar rendimientos frente a los tiempos planeados.

PSP es la disciplina del trabajo con alta calidad. El trabajo del ingeniero de software
según PSP, se puede resumir en planificar el trabajo, hacer el trabajo de acuerdo al
plan y producir productos de máxima calidad.

El costo del personal representa más del 70% de los costos de un producto de
software, por esta razón la productividad y los hábitos de los ingenieros de software
determinan en un gran porcentaje el resultado del proceso de desarrollo de software. El
PSP puede ser usado por los ingenieros de software como una guía disciplinada y
estructurada para el desarrollo de software.

El PSP es un prerrequisito para una


compañía que planea introducir el
TSP. El PSP puede ser aplicado en
cualquier parte del proceso de
desarrollo de software, como por
ejemplo desarrollo de pequeños
programas, definición de
requerimientos, documentación,
aseguramiento de calidad y
mantenimiento de software.
Propósitos
 Ayudar al ingeniero de software a realizar mejor su trabajo.
 Proporcionar datos y técnicas de análisis que se pueden utilizar para
determinar que tecnología y métodos aplicar.
 Establecer la estructura que permita comprender por qué se cometen los
errores y cómo se pueden detectar.
 Motivaciones
 Demostrar los principios del proceso personal.
 Apoyar el desarrollo de planes más precisos.
 Determinar los pasos para lograr la mejora de la calidad de los productos.
 Establecer bases de comparación para medir la mejora del proceso personal.
 Determinar el impacto en el desempeño de los cambios del proceso.

Estructura 
Está formado por siete niveles incrementales. Cada nivel contiene todas las actividades
del nivel anterior más una o dos actividades nuevas y está enfocado hacia un problema
en particular. Cada actividad está acompañada de una o más formas que apoyan el
proceso.

Beneficios de PSP
 Los datos y su análisis permitirán determinar las fortalezas y debilidades.
 Los datos y su análisis posterior conducirán hacia nuevas ideas para la mejora
del proceso.
 Se tendrá control total sobre el calendario, aceptando sólo aquellos
compromisos que se puedan cumplir. Si se enfrenta con una presión no
razonable, puede recurrir a la base de datos histórica de desempeño y
demostrar que no es posible establecer el compromiso.
 Se gana un sentido de satisfacción personal.
 La parte de calidad ayudará a producir mejores productos de trabajo.
 El equipo de trabajo tendrá mayor confianza porque existe una disciplina para el
desarrollo de los productos.

Desventajas de PSP
 El uso de LOC como métrica de estimación tiene sus desventajas, es
dependiente del lenguaje, no todos los ingenieros están de acuerdo con lo que
es una LOC lógica y son difíciles de visualizar desde la planeación y diseño
 PSP sólo requiere un estimado del tiempo de interrupción, en lugar de obligar al
usuario a registrar el tiempo real. Esto hace que el tiempo de interrupción
estimado esta sujeto a las preferencias individuales.
 El método de estimación PROBE puede no ser efectivo si no existe suficiente
correlación entre los datos históricos.
 Los formatos de diseño de PSP2.1 pueden ser redundantes para programadores
que tienen acceso a otras herramientas de diseño.
 Es subjetivo determinar si una parte del software es reutilizable.
 No todos los ingenieros ven la definición de productividad de la misma manera.
 PSP esta especialmente enfocado al desarrollo de software y no toma en cuenta
el tiempo empleado en la negociación de los requerimientos con el cliente. La
fase de requerimientos es un componente clave en cualquier proyecto.
 Seguir PSP al pie de la letra no es viable para muchos ingenieros. Deben ver el
método como una estructura para el desarrollo de una práctica de desarrollo de
software con calidad. Cada uno de los métodos debe ser ajustado a la
tecnología, práctica, fortalezas y debilidades de cada desarrollador. Es
importante destacar que las métricas existen para evaluar el proceso no a las
personas.

Proceso
La entrada de PSP son los requerimientos; el documento de requerimientos es
completado y entregado al ingeniero.

PSP0, PSP0.1 (Introduce la disciplina y la medición al proceso)


PSP0 tiene 3 fases: planeación, desarrollo (diseño, codificación, pruebas) y un post
mortem. Se establece una base del proceso normal de medición: tiempo tomado
programando, fallos inyectados/removidos, tamaño de un programa. En un post
mortem el ingeniero asegura que todos los datos del proyecto hayan sido registrados y
analizados correctamente. PSP0.1 agrega un estándar de código, una medida de
tamaño y el desarrollo de un plan de mejora personal PIP. En el PIP el ingeniero
registra ideas para mejorar su propio proceso.

PSP1, PSP1.1 (Introduce estimación y planeación)


Teniendo como base los datos recolectados en PSP0 y PSP0.1, el ingeniero estima el
tamaño que tendrá el nuevo programa y prepara un reporte de pruebas (PSP1). Los
datos recolectados para proyectos previos se usan para estimar el tiempo total. Cada
proyecto nuevo registrará el tiempo gastado actualmente. Esta información es usada
para tareas de agendamiento, planeación y estimación(PSP1.1).

PSP2, PSP2.1 (Introduce manejo de calidad y diseño)


PSP2 agrega dos fases nuevas: revisión de diseño y de código. Se enfoca en la
prevención de defectos y su remoción. Los ingenieros aprenden a evaluar y mejorar su
proceso midiendo la extensión de sus tareas y la cantidad de defectos inyectados y
removidos en cada fase de desarrollo. Los ingenieros construyen y usan listas de
chequeo para diseño y revisión de código.
PSP2.1 introduce especificaciones de diseño y técnicas de análisis.
(PSP3 es un legado de PSP que ha sido sustituido por TSP.)
Los niveles son:

 PSP 0:
o Proceso actual.
o Registro de tiempos.
o Registro de defectos.
 PSP 0.1 :
oEstándares de código.
o Medición de tamaño.
 PSP 1 - Inicial:
o Estimación de tamaño.
o Reporte de pruebas.
 PSP 1.1:
o Calendario de planeación de
tareas.
 PSP 2 - Repetible:
o Revisión de diseño y código.
 PSP 2.1:
o Plantillas de Diseño.

PSP requiere de herramientas que permitan:


 Simplificar el proceso de recolección de los datos de tiempo y defectos.
 Automatizar los cálculos requeridos.
 Facilitar el acceso a cada una de las formas.
 Llenar automáticamente cada una de las formas con los datos registrados,
eliminando la necesidad de copiar la información a mano.
 El control de tiempo puede hacerse más preciso en segundos en lugar de
minutos.
 Implementar una guía de tareas automatizada.
 Cada usuario pueda adecuar la herramienta a sus prácticas.
 Salvar automáticamente los datos históricos y dejarlos listos para su análisis.
PSP en el aula
La implementación de la metodología PSP, en el proceso de enseñanza permite
establecer criterios para valorar el rendimiento en los procesos de desarrollo utilizados
para la construcción de productos de software. Teniendo en cuenta que PSP es una
metodología que se deriva del Modelo de capacidad y madurez, ambos desarrollados
por Watts S. Humphrey en el Instituto de Ingeniería del Software SEI, adscrito a la
Universidad de Carnegie Mellon.
Los métodos de calidad lleva tiempo aprenderlos y practicarlos, pero ayudaran al
educando durante su carrera a mejorar consistentemente la calidad del desarrollo. La
estrategia es implementar esta metodología en forma paralela con los cursos
relacionados con el área de conocimiento de herramientas de programación
autoevaluando contantemente su desempeño para evidenciar su aprendizaje y la
madurez en los procesos asociados a la construcción de productos de software.
El objetivo primordial es la ejercitación y desarrollo, por parte de los estudiantes, de los
roles, habilidades y funciones que deberán desplegar en su vida como profesional de la
informática. Es por ello que el acercamiento a las técnicas de PSP se realiza de forma
vivencial en las asignaturas que le permiten la construcción de productos de software,
que se incrementan en complejidad en forma paralela a su experiencia y conocimiento.
En los cursos iniciales se busca solo que los estudiantes se familiaricen con el control
del tiempo, no solo de trabajos de programación sino de la vida en general, que
interioricen la necesidad de gestionar el tiempo, los compromisos y las programaciones
como una vía para mejorar la calidad del software. Con esta iniciación se pretende que
los estudiantes reconozcan el valor de registrar los datos de esfuerzo y tamaño y que
puedan usar estos datos en la planificación de sus proyectos y analizar su efectividad
personal. La estimación de trabajos futuros estaría basada precisamente en la
referencia de trabajos anteriores. En las asignaturas de ingeniería de software se
implementarían metodologías a nivel grupal y corporativo.

También podría gustarte