INDIAN STATISTICAL INSTITUTE COMPONENT

INDIAN STATISTICAL INSTITUTE COMPONENT BASED DEVELOPMENT APPLICATION IN SOFTWARE ENGINEERING DEBAYAN BOSE
Component Based Development 1. Introduction: Concept of re-use is not a rare phenomenon in core engineering branches. But the same concept in software engineering context has been introduced in early days of computing but its approach was ad hoc. But the introduction of object oriented programming with some advancement explores mew areas of software engineering. Today complex, high quality software systems are built efficiently using component based approach in a short period of time. But a number of questions arise about the feasibility of the component approach. But the concept of CBD successfully answers the arising questions. The importance of Component Based development lies in its efficiency. It takes only a few minutes to assemble the stereo system because the components are designed to be integrated with ease. Although software is considerably more complex, it follows that component-based systems are easier to assemble and therefore less costly to build than systems constructed from discrete parts. In addition, CBSE encourages the use of predictable architectural patterns and standard software infrastructure, thereby leading to a higher-quality result. 2. History of Component Based Development
The idea that software should be componentized - built from
prefabricated components - first became prominent with Douglas McIlroy's
address at the NATO conference on software engineering in Garmisch, Germany,
1968, titled Mass Produced Software Components. The conference set out to
counter the so-called software crisis. McIlroy's subsequent inclusion of pipes
and filters into the Unix operating system was the first implementation of an
infrastructure for this idea. Brad Cox of Stepstone largely defined the modern
concept of a software component. He called them Software ICs and set out to
create an infrastructure and market for these components by inventing the
Objective-C programming language. IBM led the path with their System Object
Model (SOM) in the early 1990s. Some claim that Microsoft paved the way for
actual deployment of component software with OLE and COM. As of 2010 many
successful software component models exist. 3. Definition of Component Based
Software Engineering: Component-based software engineering (CBSE) is a process
that emphasizes the design and construction of computer-based systems using
reusable software “components.” Clements *CLE95+ describes CBSE in the
following way: CBSE is changing the way large software systems are developed.
CBSE embodies the “buy,
don’t build” philosophy espoused by Fred Brooks and others. In the same way that early subroutines liberated the programmer from thinking about details, CBSE shifts the emphasis from programming software to composing software systems. Implementation has given way to integration as the focus. At its foundation is the assumption that there is sufficient commonality in many large software systems to justify developing reusable components to exploit and satisfy that commonality. Component-based software development approach is based on the idea to develop software systems by selecting appropriate off-the-shelf components and then to assemble them with a well-defined software architecture. Component-based software engineering (CBSE) is a branch of software engineering which emphasizes the separation of concerns in respect of the wide-ranging functionality available throughout a given software system.
This practice aims to bring about an equally wide-ranging degree of benefits in
both the short-term and the long-term for the software itself and for
organizations that sponsor such software. Software engineers regard components
as part of the starting platform for service- orientation. Components play this
role, for example, in Web Services, and more recently, in Service-Oriented
Architecture (SOA) - whereby a component is converted into a service and
subsequently inherits further characteristics beyond that of an ordinary
component. Components can produce events or consume events and can be used for
event driven architecture (EDA). 4. Objectives of Component Based Software
Engineering: The main objectives of component based software engineering are
given below. a) Reduction of cost and time for building large and complicated
systems: main objective of Component based approach is to build complicated
software systems using off the shelf component so that the time to build the
software diminish drastically. The cost effectiveness of the current method can
be analysed using function point or other methods. b) Improving the quality of
the software: The quality of the software can be improved by improving the
quality of the component. Though the concept is not true in general. Sometimes
quality of the assembled systems may not be directly related to quality of the
component in sense that improving the quality of the component does not
necessarily imply the improvement of the systems.
c) Detection of defect within the systems: Component approach helps the system to find its defect readily by testing the components. But the source of defects is difficult to find in case of component development approach. 5. Examples of Component Based Approach: To start with, let us give an example of simple stereo systems which consists of woofer, sub-woofer, sound box etc. if someone wants to build the stereo systems by assembling the off the shelf components like sound box etc then he might be experiencing some advantage than those who build the system from the basic circuit. In-fact, now a day, all the simple and complicated systems are built using the component approach where some components are already developed by some developer and they are stored in the library for their re-use. The main concept is that those off the shelf components need not be changed for their respective purposes.
 If we
want modify some of the components to fit according to their applicability, we
need to rebuild it and store them in the library. Example of some complex
system, where each components itself can be viewed as a system, is Naval Combat
system. The system consists of some radar for detection, Helicopter, submarine,
Rocket Launcher, some fighter plane etc. Each component here is some big
systems and association is also very complicated in such cases. 6. Software
Components: In most engineering disciplines, systems are designed by composing
existing components that have been used in other systems. Software engineering has
been more focused on original development but it is now recognised that to
achieve better software, more quickly and at lower cost, we need to adopt a
design process that is based on systematic “reuse”. So, typically, components
are rather small but independent parts of a system. But a large system as a
whole can be seen as a component as well. It is important to recognize
components are runtime entities. They exist while the system is running, in
fact: the system consists of components, and is a component itself. Components
are not just design entities like classes in object-orientation are. As said
earlier, at his moment everybody is raving about components, and seems to
expect a lot from it. What is expected form components, and why is everybody
that enthusiast? The expected advantages to be derived from the application of
components are summarized in later sections of this report. Components provide
a service without regard to where the component is executing or its programming
language. A component is an independent executable entity that can be made up
of one or more executable objects. The component interface is
published and all interactions are through the published interface. Components can range in size from simple functions to entire application systems 7. Engineering of Component Based Systems: On the surface, CBSE seems quite similar to conventional or object-oriented software engineering. The process begins when a software team establishes requirements for the system to be built using conventional requirements elicitation techniques. An architectural design is established, but rather than moving immediately into more detailed design tasks, the team examines requirements to determine what subset is directly amenable to composition, rather than construction. That is, the team asks the following questions for each system requirement: · Are commercial off the shelf components available to implement the requirement?
· Are internally reusable
components available to implement the requirement? · Are the interfaces of the
available components compatible with the architecture of the system to be
built? The team attempts to modify or remove those system requirements that
cannot be implemented with COTS or in-house components.1 If the requirement(s)
cannot be changed or deleted, conventional or object-oriented software
engineering methods are applied to develop those new components that must be
engineered to meet the requirement(s). But for those requirements that are
addressed with available components, a different set of software engineering
activities commences: Component Qualification, Component Adaptation, Component
Composition and Component Update. Now let us focus on few basic definition
regarding software components. Component—It is a nontrivial, nearly
independent, and replaceable part of a system that fulfills a clear function in
the context of a well-defined architecture. Run-time software component—It is a
dynamic bindable package of one or more programs managed as a unit and accessed
through documented interfaces that can be discovered in run time. Software
component—It is a unit of composition with contractually specified and explicit
context dependencies only. • Business component—It is the software
implementation of an “autonomous” business concept or business process. In
addition to these descriptions, software components can also be characterized
based on their use in the CBSE process. In addition to COTS components, the
CBSE process yields: Qualified components—assessed by software engineers to
ensure that not only functionality, but performance, reliability, usability,
and other quality factors (Chapter 19) conform to the requirements of the
system or product to be built.