Specialised Process Models

Download as pdf or txt
Download as pdf or txt
You are on page 1of 2

Specialised Process Models

Specialized process models take on many of the characteristics of one or more of the traditional models
However, these models tend to be applied when a specialized or narrowly defined software engineering
approach is chosen.

There are 3 types of specialized process models:

1. Component Based Development


2. Formal Methods Model
3. Aspect Oriented Software development

1. Component Based Development : Commercial off-the-shelf (COTS) software


components, developed by vendors who offer them as products, provide targeted
functionality with well-defined interfaces that enable the component to be integrated into
the software that is to be built. The component-based development model incorporates
many of the characteristics of the spiral model. It is evolutionary in nature, demanding an
iterative approach to the creation of software. However, the component-based
development model constructs applications from prepackaged software component.
Modeling and construction activities begin with the identification of candidate components.
These components can be designed as either conventional software modules or object-
oriented classes or packages of classes. Regardless of the technology that is used to create
the components, the component-based development model incorporates the following
steps:
1. Available component-based products are researched and evaluated for the application
domain in question.
2. Component integration issues are considered.
3. A software architecture is designed to accommodate the components.
4. Components are integrated into the architecture.
5. Comprehensive testing is conducted to ensure proper functionality

The component-based development model leads to software reuse, and reusability provides
software engineers with a number of measurable benefits. software engineering team can
achieve a reduction in development cycle time as well as a reduction in project cost if
component reuse becomes part of your culture.

2. Formal Methods Model : The formal methods model encompasses a set of


activities that leads to formal mathematical specification of computer software. Formal
methods enable to specify, develop, and verify a computer-based system by applying a
rigorous, mathematical notation. A variation on this approach, called cleanroom software
engineering is currently applied by some software development organizations. When formal
methods are used during development, they provide a mechanism for eliminating many of
the problems that are difficult to overcome using other software engineering paradigms.
Ambiguity, incompleteness, and inconsistency can be discovered and corrected more easily,
through the application of mathematical analysis. When formal methods are used during
design, they serve as a basis for program verification and therefore enable you to discover
and correct errors that might otherwise go undetected. The formal methods model offers
the promise of defect-free software.There are some of the disadvantages too:
• The development of formal models is currently quite time consuming and expensive.
• Because few software developers have the necessary background to apply formal
methods, extensive training is required.
• It is difficult to use the models as a communication mechanism for technically
unsophisticated customers
3. Aspect Oriented Software Development : Regardless of the software process
that is chosen, the builders of complex software invariably implement a set of localized
features, functions, and information content. These localized software characteristics are
modeled as components and then constructed within the context of a system architecture.
As modern computer-based systems become more sophisticated certain concerns span the
entire architecture. Some concerns are high-level properties of a system, Other concerns
affect functions, while others are systemic.
When concerns cut across multiple system functions, features, and information, they are
often referred to as crosscutting concerns. Aspectual requirements define those
crosscutting concerns that have an impact across the software architecture. Aspect-oriented
software development (AOSD), often referred to as aspect-oriented programming (AOP), is
a relatively new software engineering paradigm that provides a process and methodological
approach for defining, specifying, designing, and constructing aspects.
A distinct aspect-oriented process has not yet matured. However, it is likely that such a
process will adopt characteristics of both evolutionary and concurrent process models. The
evolutionary model is appropriate as aspects are identified and then constructed. The
parallel nature of concurrent development is essential because aspects are engineered
independently of localized software components and yet, aspects have a direct impact on
these components. It is essential to instantiate asynchronous communication between the
software process activities applied to the engineering and construction of aspects and
components.

You might also like