Design patterns reuse for real time embedded software development

Gabriel de Souza Pereira Moreira
Instituto Tecnológico de Aeronáutica - ITA
Denis Ávila Montini
Instituto Tecnológico de Aeronáutica - ITA
Daniela América da Silva
Instituto Tecnológico de Aeronáutica - ITA
Felipe Rafael Motta Cardoso
Instituto Tecnológico de Aeronáutica - ITA
Luiz Alberto Vieira Dias
Instituto Tecnológico de Aeronáutica - ITA
Adilson Marques da Cunha
Instituto Tecnológico de Aeronáutica - ITA

Abstract

This article describes software reuse components using C language on IBM-Rational Rose Real Time (RRRT) environment. In it a software development process becomes refined by means of a design pattern reuse. Its main contribution meets definition of a process for construction of a Data Logger Platform. Use of design pattern in an Integrated Computer Aided Software Engineering Environment allows definition of an industrial process aimed for future systematic reuse. Direction lines from Rational Unified Process (RUP) had recently helped undergraduate and graduate students from the Brazilian Aeronautics Institute of Technology (ITA) to create a fertile scene for practical applications of design pattern concepts. A Computer Software Component was constructed with attributes and generic methods in order to make possible its reuse. As a result of this process, members of ITA Software Engineering Research Group had generated a quality report previously improved to carry out classroom work, and proposed a specific data management design pattern for input and output.

Key words: CMMi, UML-RT, RUP, I-CASE-E, and Design Patterns.

1. INTRODUCTION

In second semester of 2007, members of Brazilian Aeronautics Institute of Technology Software Engineering Research Group (Grupo de Pesquisa de Engenharia de Software - GPES) had used Technological Development Laboratory of Casimiro Montenegro Filho Foundation (FCMF) to develop a Real Time Embedded Software (RTES).

Developed software used Problem Based Learning (PBL) methodology [1], IBM Rational Unified Process (IBM-RUP), an Integrated Computer Aided Software Engineering Environment (I-CASE-E), Rational Rose Real Time (RRRT) [2], and a design pattern [3] [4] [5] [6].

This work focuses on definition of a reuse process for design pattern in development of a RTES. RUP was modified in some key points to elaborate one design pattern. A case study, involving a Data Logger Platform – DLP was also developed, prototyped, and experimented as an IO Manager, using Microsoft Visual C++ compiler. Use of I-CASE-E represents significant initial investments, involving licenses acquisition, equipment, training, and qualifications.

Conceptualization of a new software development process named W-model represents main contribution of this article. It involves identification, documentation, and reuse of a design pattern, and a quantification of productivity profits and quality, obtained from software reuse, during development process.

2. SCENARIO

This research applies PBL methodology aiming to restrict scope of design patterns reuse for software development, during System Development Life Cycle (SDLC) analysis, shown in Figure 3.

Figure 1 - CSS Structure of VANT-EC-SAME Project Cunha (2007).

In an academic environment, SDLC study for RTES has adopted following nomenclature. On highest level of project it is placed Computer Software System - CSS. It was divided into some Computer Software Configuration - CSCI. Each one of them was divided into different Computer Software Components CSC. Finally, each CSC
was also divided into different Computer Software Units - CSU. All of them shown in Figure 1 as part of a project named VANT-TEC-SAME used as a case study.

CSC DLP is composed of following three different CSU: a Data Management Platform - DMP; a Storage Data Platform – SDP; and a Data Recovery Platform – DRP. They comprise CSS named VANT-EC-SAME (Veículo Aéreo Não-Tripulado – Estação de Controle – Satélite Artificial de Monitoramento Ecológico), an Unmanned Aircraft Vehicle together with a Control Station, and an Artificial Satellite for Ecological Monitoring [1].

3. I-CASE-E, OO, UML, AND DESIGN PATTERNS REUSE

IBM-RRRT integrated environment tools using Unified Modeling Language (UML) [7] was used to implement Object Orientation (OO) paradigms allowing components generation in C++ language in a design patterns project. UML has provided a visual language for modeling, building, and documenting OO complex software systems [5].

To evaluate use of design patterns it was necessary to analyze existing RUP, because reuse of patterns is not a natural phenomenon.

3.1 RRRT using OO and UML-RT

In order to reflect technical characteristics of codification, some traditional OO concepts [8] [9] such as classes and packages for real time design patterns software had been improved from traditional UML to Real Time UML (UML-RT).

In this scope, RTES can be explained by Systems that need signals and data in specific time intervals to have its use accepted. UML-RT was developed in accordance with IEC Std. 61499 and introduced to adjust classic UML for Real Time Systems [6].

Main aspects of UML adaptation to UML-RT [7] in this work have focused on concepts of increasing traditional OO, so that it can be implemented in a real time system by using RRRT. This UML-RT research line has focused in definition of constructors that had included capsules, connectors, and ports in order to build components with less aggregation among other systems elements [6].

In order to provide a disciplinary approach to distribute tasks and responsibilities within organized vision of software construction developed by IBM-Rational [10], RUP represents a product whose functions are to describe a complete and standardized process of Software Engineering.

Relationship between UP disciplines and UML Models are shown in Figure 2. UP has the same disciplines but UML-RT has more models [6].

RUP defines a set of software artifacts that are organized according to UP. They are necessary for implementation of software projects using best practices of Software Engineering [11]. RRRT is a visual modeling tool for Real-time that has mechanisms to support processes, methodologies, standards, and frameworks following RUP.

![Figure 2 - UP and UML diagrams relationships](image)

According to a visual modeling of UML-RT in UP, the code generation by RRRT consists of a real-time framework. This abstraction originated from a universal modeling with UML-RT, made possible the generation of compatible source-codes for different languages, operating systems, and compilers [12].

The RRRT generates code to implement the projected system model [5]. Components generated by RRRT include packages, passive classes (with OO class’s standards), capsules (active classes with ports and connectors), and protocol classes [2].

The activities’ organization focused centrally in metamodels of classes and packages’ diagrams. These metamodels were useful to define the conceptual tests of components using the following diagrams: Use Case, Class, Sequence, Structure, and State. The effectiveness of OO was translated by modeling UML-RT during the creation of source code in the C language.

3.2 The I-CASE-E RRRT Framework Tool

The software components’ construction for real time systems has used a framework and the reutilization approach was top-down, allowing to select generic characteristics, hypothetically adaptable to other semantically similar components.

A framework is a collection of collaborative classes that provides specific functionalities. According to James Booch, frameworks are used to help the object orientation reuse [8] so that developers can customize them for new applications.

A design pattern project reuse application effect was gotten using I-CASE-E RRRT tool aiming to get a component architecture standard. This component had to be shaped according to UML-RT for an adaptive RUP [2] process.
A suggested and adaptive process model took place by the most convenient point of a construction process for design patterns’ reuse. An existing concept like “V model” was derived from Manufacture Cells Production Line [13] for adaptive SDLC aiming components’ reuse. Figure 3 shows a process represented by W-model.

The process was gotten through UP customization [14]. From this Figure 3, phases “one” trough “five” identify Business Requirements, Financial Requirements, Functional Requirements, Non Functional Requirements, and Detailed Requirements. Theses phases are represented by diagrams and more specifically by use cases.

SDLC’s framework study is composed of twelve conceptual phases for reuse. The main contribution of this article is the phase six, placed between phases five and seven, as shown in Figure 3.

Figure 3 – The “W” metamodel of Component Reuse. Source: Authors.

The W-model was organized in three views: semantical, logical, and physical, all of them based upon different concepts. It reuses a set of procedures to define specific points to analyze and customize components.

The semantical view of W-model defines how a design pattern process will be researched and constructed. The logical view focus on groups of requirements distributed on the first five phases of the W-model. It addresses reusability aspects and its potential of reutilization. The potential of reutilization is given by the needs of a specific interest area, by means of functions’ generalization. The physical view implements the construction, the adaptation, and components’ test of a computational language.

3.3. Components Reuse

The utilization of specific OO concepts, UML-RT, RUP, RRRT tools, and Microsoft C++ characterizes a backbone for a software component reuse project [8] [9] [6]. The use of design patterns for code generation and the description of its reuse were first proposed by Budd [9], who stated that software products should be organized into activities for reuse.

Its main proposed directions for reuse have been defined by a set of fundamental characteristics for W-model functioning. The reuse process was constructed from definition of the following aspects described in Table 1.

Table 1 - Lines of direction for design patterns reuse.

<table>
<thead>
<tr>
<th>Line of direction for Design Patterns Reuse</th>
</tr>
</thead>
<tbody>
<tr>
<td>- Generic systems requirements are defined by minimum environment characteristics, ceteris paribus, in Objective, Context, and basic Structure.</td>
</tr>
<tr>
<td>- Generic functionalities.</td>
</tr>
<tr>
<td>- Classes and Communication Protocol.</td>
</tr>
<tr>
<td>- Definition of a Customization Procedure.</td>
</tr>
<tr>
<td>- Definition of Test and Homologation.</td>
</tr>
</tbody>
</table>

For design patterns’ reuse it is necessary to remodel it and to make it generic for researches’ use with class diagrams. Production of reusable code demanded a customization treatment, in order to create a more elaborated and generalized design pattern.

The adaptation of a component is not an innovative activity. The hypothesis tested was: “component’s reutilization will be faster and of better quality if a predefined systematic process does exist for generic services organized by application areas”.

From a semantically view how similar are Use Cases and Classes of the involved components under analysis.

The reuse process is faster than the normal programming process if the identification and redefinition of a design pattern is more specialized. And the reuse process is slower than the normal programming process if the identification and redefinition of a design pattern is less specialized. It means that if the component is generic the reprogramming effort will be greater than the normal programming’s process.

This reutilization hypothesis was verified with a test on semantic relationships in the UP framework using the RRRT. This standard was customized for a development process of components with adaptable and projected characteristics to allow these benefits to developers.

4. DESIGN PATTERN PROJECT

The GPES has considered the design pattern identified by the Research Group Gang of Four (GoF) that created a standard family among some available. The GoF has focused on object oriented programming languages and design pattern families in this research to accumulate generic class characteristics through attributes and methods [5].

GoF authors have considered initially the following standards’ families: Creation, Structural, Behavior, and General Responsibility Assignment Software Patterns (GRASP) [4]. The starting point for a standard choice was the identification of one type to be used for a new entity selection.

The selected concept for developing project was the “Creation” standard with “Prototypation” subtype. For the reuse study and design patterns customization it was necessary to convert it from a standard to a standard family creating another family adjusted for its reuse and
customization.

The choice criterion was the association between classes and objects represented by the Creation of standards’ families [2]. The design pattern was created by the GPES and classified under the name of IO Manager. This component fits in Behavior standards category. Therefore, it describes interactions’ modeling and responsibilities’ divisions between classes or objects.

4.1. The Design Pattern Identification Process

The identification process started with an existing research design pattern and its category. The standards’ catalogued by GoF [4] had been distinguished in order to shape the design pattern IO Manager, as a good practical project standard [15].

The “cloning” operation consists in removing one component from a library to be reused in other project. In order to do it, this research provided a transformation from the design pattern Creation Prototype class to the design pattern Composite class, following the previous formulated hypothesis. This design pattern has followed QoS requirements from the structure of the library of components reuse catalogue form.

The catalog form is an artifact that contains data and UML-RT modeling to register the functionalities of the CSC P-DLP presented in Figure 4.

The Data Loggers allows to the control of the transactions carried between its dependent objects of drive and the storage control and recovery of data, programmed or by external accesses. A Data Logger project is illustrated in Figure 4.

5. THE DESIGN PATTERNS REUSE

The applicability of the standard of IO Manager project in Components of Input and Output Data Management came of VANT-EC-SAME Project, and it was possible through the technician detailing of the described and registered standard in a Catalog Form. The frameworks standard meets established in the requirement of the QoS to structuralize a server for the catalogued components reuse.

The Catalog Form contains the data and the UML-RT modeling, to attend to the three CSC P-DTL, Data Logger functionalities, represented for Figure 05. This Catalog Form aims to organize the information, so that this can facilitate its localization and recovery of the registered and implemented standards by the framework.

5.1. The design pattern description for reuse

The RUP process is generic and meets improvement chances in its procedures to accomplish design pattern processes identification, elaboration, and reutilization. During its definition, the RUP cannot be established without a previous definition of duties and responsibilities for each specialized activity.

The reusing process and the improvement change of RUP were identified and added in phase 6 of Figure 3 to modify the original “V model”. Figure 4 presents this modification from the “V model”, step by step, mapped to the “W-model”. Following, all details are described as a complementary set of activities carried out for the design pattern reuse, characterizing the main contribution of this article.

The RUP tailoring for the design pattern process is shown in Table 2. It represents an original and adaptive way to solve implementation, verification, and validation for component reuse. A technique of implementation review is known as Final Inspection (FI) was carried out at the end of each SDLC project phase. It followed the concept of model Entry, Task, Verify, and eXit (ETVX) [16].

<table>
<thead>
<tr>
<th>Reuse procedure</th>
<th>Activities</th>
<th>Actions</th>
<th>Objectives</th>
</tr>
</thead>
<tbody>
<tr>
<td>Table 2 – The pattern process to design pattern reuse activities.</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
1. **Business Identification.**
   2. Create Requirements Attributes Matrices.

2. **Candidate Components Selection in the Library.**
   1. Search components in library to identify requirements.
   2. Analyze Requirements Traceability Matrices.

3. **Components Test.**
   1. Analyze and test the infrastructure documentation.

4. **Iteration and Customization for Planning.**
   1. Customize details for planning.
   2. Create the requirements traceability tree.

5. **Components Distribution for Customization.**
   1. Make available documentation and customization to team members.

6. **Customization Process.**
   1. Measure, select and execute component customization from the library.

7. **Identification of a Candidate Design Pattern.**
   1. Propose a new pattern to the library.

8. **Cataloguing of Design Pattern.**
   1. Execute design pattern to the catalog process.

9. **Finalization of Reuse Project.**
   1. Review the documentation.

### 6. ANALYSIS OF PRODUCTIVITY REUSE

A productivity analysis was performed by Use Case Points Effort Estimation using the same criteria shown in Figure 5.

An estimate was performed right in the beginning of the project for forecasting what would be the necessary effort for the development of the CSC P-DLP. A group of three developers with low monthly availability was considered for this academic project. In this case, the efforts estimation for the software development was equal to 5.5 months, as shown in Figure 5.

The effective time for the development of the CSC P-DLP Prototype in the CE-235 RTES discipline was very close to the previously estimated time. Three developers had dedicated about 600 working hours to elaborate the: Requirements Survey, Use Case Modeling, Sequence Diagrams, Classes Modeling, Capsules States Machines, and C Language Codification from the tools environment.

![Figure 5. The P-DLP development effort using UCP.](image-url)

Out off these 600 hours and considering only the RUP construction phase, about 300 hours had been dedicated for effective modeling, implementation and prototype tests. About 50 hours had been used for component generalization in a verification process using the results for functional validation characteristics of two inputs and outputs data components. In both CSC P-DLP and CSC P-COM, the same constructive process has been applied.
reusing the IO Manager design pattern. At the end of the implementation process in the same construction phase development times have been compared.

For this calculation, the time for developing CSC P-DLP and CSC P-COM was taking into account, according to the ceteris paribus condition [19] [20] [21]. Data tabulation is presented next, demonstrating self productivity profits in the construction phase reusing the IO Manager design pattern.

**Table 3 - CSC P-DLP and CSC P-COM time construction using IO Manager.**

<table>
<thead>
<tr>
<th>Component</th>
<th>P-DLP</th>
<th>P-COM</th>
</tr>
</thead>
<tbody>
<tr>
<td>Original construction time</td>
<td>300 h</td>
<td>230 h</td>
</tr>
<tr>
<td>Construction time using IO Manager design pattern</td>
<td>50 h</td>
<td>40 h</td>
</tr>
<tr>
<td>Productivity profit</td>
<td>85%</td>
<td>82%</td>
</tr>
</tbody>
</table>

**Table 4 - CSC P-DLP project case study analysis.**

<table>
<thead>
<tr>
<th>SDLC</th>
<th>Other Phases</th>
<th>Construction Phase</th>
<th>Project Totals</th>
</tr>
</thead>
<tbody>
<tr>
<td>P-DLP Project executed during CE-235</td>
<td>250h (42%)</td>
<td>350 h (58%)</td>
<td>600 h</td>
</tr>
<tr>
<td>P-DLP Project executed in FCMF, using IO Manager design pattern</td>
<td>250 h (83%)</td>
<td>50 h (17%)</td>
<td>300 h</td>
</tr>
</tbody>
</table>

The collected data analysis from Tables 3 and 4 allows concluding the significant earned value accomplished by reusing design pattern in case study as listed below:

1 - The effort in Project Total hours for the CSC P-DLP was 50% lower with the reuse of the IO Manager design pattern;
2 - In the Construction Phase of the CSC P-DLP, the gain with its reuse was 83% higher as compared with the previous estimation; and
3 - The Construction Phase duration was reduced from 58% to 17% as related to the Project Total hours.

**7. CONCLUSION**

This article presented a framework implementation, named “W-model”, based upon a specialized process for identification, registration, and design pattern reuse for real time systems, based on Unified Modeling Language Real Time (UML-RT). Design patterns reuse for RTES development used Problem Based Learning (PBL) [1] within the software quality line of research. The main contribution from this paper was the “W-process” elaboration derived from the defined process of design pattern construction.

According to the last VANT-EC-SAME project survey, 15,096 Lines Of Code (LOCs) in C language have been generated by the Rational Rose Real Time (RRRT) tool CASE. These LOCs have been distributed in 56 archives, using visual modeling components and reusing patterns with a minimum of manual codification. An RRRT framework was used to plan activities and requirements for the components construction. The proper reutilization of components and design patterns allows may represent gains in effort, time, and costs throughout projects.

In this case study, the use of design patterns has required specific knowledge about Modeling, UML-RT, and RRRT. Technical knowledge in programming, as well as familiarity with test planning, abstraction capability, catalog, and design pattern was also required.

The catalog form creation and the UML-RT for RUP organization were fundamental for fulfilling design pattern test.

The construction and reutilization of the IO Manager design pattern have proved the hypothesis previously stated, allowing faster and better quality systematic for the construction of the W-process.

A significant earned value was accomplished on the case study application by using design pattern in a production line during the development of an RTES [13].

**8. RECOMMENDATIONS**

In order to continue this research, it is recommended:

1 - The reuse of the systematic Catalog Form concept on larger software scale components;
2 - The reuse of the “W-process” to support design pattern and Catalog Form in production lines of manufacture cells [13] [17];
3 - The refinement and review of the “W-process” to allow the customization for each new production line; and
4 - This model to be applied on software houses and factories [18] [19] [20] [21] [22] to scale profits in RTES production cells.

Finally, it is suggested that the results of this research be used as an alternative to improve technological implementation aspects using I-CASE-E for design pattern maximization.

**9. ACKNOWLEDGEMENTS**

Authors of this paper would like to acknowledge:

1 - The ITA for the opportunity of providing the course of CE-235 Real-time Embedded Systems for projects involving PBL;
2 - The GPES for its research environment;
3 - The FCMF for its software engineering infrastructure for research; and
4 - The Tata Consultancy Services (TCS) as well as for its partnerships with productive sector companies.

**10. REFERENCES**


[18] Montini, Denis Ávila; Spinola, Mauro de Mesquita; Sacomano, José Benedito; Nascimento, Marcos Ribeiro Do; Battaglia, Danilo. Application of model PSP manual and supported by tool in a study of case of brazilian plant of software. Revista produção on line, Florianópolis - SC - Brazil, 2006.


[22] Montini, Denis Ávila; Moreira, Gabriel de Souza; Vieira, Luiz Albert; Battaglia, Danilo; Gnatuc, Carlos Eduardo; Cunha, Adilson Marques da; In: Global TACTICS 4th Global Conference, Study of case of a strategy of middleware integration for SOA service of administration and control of factory of software: TCS – Tata Consultancy Services – Intranet website Corporative Knowledge Data Base KnowMax: Global TACTICS 4th Global Conference, India, Kerala, Thiruvananthapuram. 16-19/January/2008.