se program - Projekt e

Transcription

se program - Projekt e
MAPPING AN INDUSTRIAL IT PROJECT TO A 2ND SEMESTER
DESIGN-BUILD PROJECT
Mads Nyborg, Stig Høgh
DTU Informatics, Technical University of Denmark, 2800 Kgs. Lyngby, Denmark
ABSTRACT
CDIO means bringing the engineer's daily live and working practice into the educational system.
In our opinion this is best done by selecting an appropriate project from industry.
In this paper we describe how we have mapped an industrial IT project to a 2nd semester
design-build project in the Diploma IT program at the Technical University of Denmark. The
system in question is a weighing system operating in a LAN environment. The system is used in
the medical industry for producing tablets. We present the design of a curriculum to support the
development of major components of the weighing system. A simple teaching model for software
engineering is presented which combines technical disciplines with disciplines from section 2-4
in the CDIO syllabus.
The implementation of a joint project involving several courses supports the CDIO perspective.
Already the traditional IT-diploma education for decades has included many of the essential
features of the CDIO (for example, focus on teamwork, development of social skills, the open
nature of design problems).
The specific project has previously been conducted on 5th Semester
The project has now been brought forward to the 2nd semester of study. A successful
implementation at this level requires careful planning of activities through the semester.
Principles of the CDIO have been of great help in this regard.
Finally we draw conclusions and give our recommendations based on those.
KEYWORDS
Software Engineering, Design-Build project, Curriculum design, Team work
Proceedings of the 6th International CDIO Conference, École Polytechnique, Montréal, June 15-18, 2010
INTRODUCTION AND BACKGROUND
At the Technical University of Denmark it has been decided to introduce CDIO in the Diploma IT
program. The first 4 semesters each contain a CDIO project. This has an impact on students
who started their studies in 2008. This paper deals with the 2nd semester CDIO design-build
project. The project now runs for the second time. A project with a very similar technical content
has been used since 2003 in the 5th semester. The project here was associated with an
advanced networking course (10 ECTS). It has been a challenge to implement this now as a
CDIO design-build project, located in the 2nd semester. The project involves 17.5 of 30 ECTS
points in total for this semester. We discuss the project in general and the actions we have taken
to implement this successfully at such an early stage in the program. A key focus has been to
ensure that students will be familiar with development tools, with the understanding of normal
use of the current hardware and with the formation of a well-integrated social group.
THE PROJECT
The actual project is a weighing system used in the medical industry for producing tablets. The
weighing machine used is a Mettler precision electronic balance together with a terminal
operated in a LAN environment, see figure 1. The system has three actors: Operators, a
pharmacist and a foreman. The operators produce tablets in batches from recipes. Based on a
recipe, the machine informs the operators which ingredients to use and the quantity. The
operators take ingredients from the ingredients store, where they are stored in batches with a
unique ingredient number. For each ingredient batch, the system records the supplier and the
delivery date. Upon completion of a recipe, tablets are put in a pill bottle, assigned with unique
batch number. The role of the pharmacist is to define recipes, and the role of the foreman is to
distribute work to the operators on a daily basis.
Figure 1: The weighing machine
The system consists of several components, all of which require different engineering skills to be
developed. These components can be divided into three areas: A weighing control unit that
controls the operation of the weighing machine, a back-end component (database) that stores
data about users, recipes, ingredient suppliers and production events, and a web component for
administrative matters, i.e. definition of users, recipes, ingredients and concrete products.
The system context diagram is shown in figure 2.
Proceedings of the 6th International CDIO Conference, École Polytechnique, Montréal, June 15-18, 2010
Figure 2: System context diagram
The realization of the system can be divided into a number of components each running on its
own node. The overall architecture diagram for the system is shown in figure 3
Figure 3: Software architecture
Proceedings of the 6th International CDIO Conference, École Polytechnique, Montréal, June 15-18, 2010
A key requirement for the system is the ability to trace all events during the production process.
This comprises the registration of the operator who made the product, the recipe used and the
identification of batches that ingredients were taken from. The reason for this procedure is the
customer's requirements for full traceability in his production.
Quality control systems are often validated in the company where they are used. This may be
the GMP (Good Manufacturing Practice) standard. This is a requirement in the pharmaceutical
industry.
Validation can be implemented as a standard procedure with standard software. An example of
this is Mettler FreeWeigh Net, [8], which is a standard validation module that can be purchased
for implementation in the company. However, this is just an example, other methods and
procedures are also used.
A SIMPLE TEACHNING MODEL FOR SOFTWARE ENGINEERING
Numerous books have been written on software engineering, e.g. [3]. but these are very
comprehensive and in general not well-suited for teaching introductory courses.
Software engineering comprises all techniques in the construction of software systems. Overall
these can be divided into technical disciplines and supporting activities.
We introduce a simple visual teaching model, see figure 5.
Figure 5: A teaching model for software engineering
Proceedings of the 6th International CDIO Conference, École Polytechnique, Montréal, June 15-18, 2010
The left part of the model shows core technical disciplines and the right part are supporting
activities.
This model serves primarily as a simple one-page graphic overview of the following key parts:
Basis:
This part contains teaching in an object-oriented programming language (currently Java),
algorithms and data structures and their application for solving a given programming problem,
running on a CPU. The topics can be characterized as "classic computer science disciplines."
System modeling:
This part contains teaching in system modeling (currently object oriented system modeling), i.e.
analysis of a domain and its application and building models for final mapping to a programming
language
System distribution:
This part contains teaching of the issues arising from distributing a system to more than one
CPU (so called nodes). This includes teaching in technologies, such as data communication
protocols and frameworks used for implementation. Most IT systems today are distributed
systems and the weighing system is a good example of this.
Supporting activities:
The supporting activities comprise all activities related to project work, e.g. teamwork, time
planning, presentation etc. These are not directly taught as separate issues but integrated into
the projects.
The model is introduced in the 1st semester and in order to make a basic understanding and
acceptance of the key parts we start making comparison with a much more mature discipline,
namely the building industry.
The basis part can be compared to the building elements, e.g. Brick, tile, tubes, doors and
windows. However, knowing the function of these elements themselves is not enough to build a
house.
To successfully build a house there is a need of an architectural drawing. The System modelling
part of a software system is parallel to this.
The system distribution part can be compared to the challenge of building a city. In a city there
are roads, junctions, roundabouts and rules for using them. This can be compared with data
communication protocols in software systems. In addition, some of the buildings in the city have
a special responsibility, such as post office, hospital, petrol station etc. This can be compared
with the different responsibilities of the components in the weighing system.
The supporting activities are found in all engineering disciplines and hence also in software
engineering. For software engineering this comprises most of the activities in the CDIO syllabus
2-4
Proceedings of the 6th International CDIO Conference, École Polytechnique, Montréal, June 15-18, 2010
CURRICULUM STRUCTURE
The Diploma IT program at the Technical University of Denmark consists of 7 semesters each of
30 ECTS point. All courses in the first 4 semesters are compulsory.
The semester structure consists of a 13-week period followed by a 3-week period. In the 13week period courses are given in timeslots of 4 hours. Teachers may utilize these hour as they
see fit, but hours are usually divided between short lectures, in-class problem-solving sessions,
group exercises and project work. In the 3-week period the students work fulltime usually with
some kind of lab projects.
Before the introduction of the CDIO concept, mini-projects were assigned to the courses and
formed the basis of evaluation.
By the introduction of the CDIO concept we changed the curriculum structure to an integrated
structure (standard 3). Several courses now contribute to a joint project.
The challenge was to make the curriculum design fit into the overall semester structure at DTU.
We use a variant of the merged curriculum structure ([1], p. 91) in which the 3-week period is the
merging part where the students are supposed to finalize the project. The courses involved in
the 13-week period are the following: Advanced Programming (02324), Data Communication
(02325) and Discrete Mathematics and Databases for Diploma IT (only 2,5 ECTS of course
01917 comprising basic database technology are used directly in the project). Other courses in
the semester which indirectly provide knowledge to the project are: Digital systems (02311) and
Algorithms and Data Structures (02326).
From the 1st semester we utilize both technological and non technological skills (CDIO syllabus
2-4) obtained in the design-build project covered by Development methods for IT-Systems
(02313) and Introductory Programming (02312).
The overall curriculum structure for the first two semesters is shown in table 1. (Note: courses in
the 1st semester that do not serve as input to the 2nd Semester design-build project are omitted
for simplicity)
Table 1
Curriculum structure for 1st and 2nd semester
13 week period
5 ECTS
5 ECTS
2. Semester
1. Semester
5 ECTS
01917
Discrete
Mathematics
and
Databases for
Diploma IT
02311
Digital
systems
02325
Data
Communication
3 week period
5 ECTS
5 ECTS
5 ECTS
02313
Development
methods for
IT-Systems
02312
Introductory Programming
02326
Algorithms
and Data
Structures
02324
Advanced programming
Proceedings of the 6th International CDIO Conference, École Polytechnique, Montréal, June 15-18, 2010
DEVELOPMENT PROCESS MODEL
The development model we use is based on the Rational Unified Process [2] and focuses on
architecture and iterative development. Emphasis is put on team development, to strengthen
students’ social and interpersonal skills.
The students are divided into teams of approx. 6-8 persons formed by the teachers. The
following criteria are used to form the teams:


Students are not allowed in the same team as in the previous semester
Students are placed in teams according to grades achieved in the previous semester
(different grades in each team)
Each team appoints a project manager and a deputy, as applicable for the entire process. The
supervisor is responsible for overall management of the team. We do not allow the students to
form the teams themselves since this does not reflect normal working situations in industry.
Figure 4 illustrates how the projects are placed in the respective courses.
Figure 4: Timeline, projects and milestones
The overall project is presented in the beginning of the 13-week period. During the 13-week
period, the participating courses define a number of small projects, all of which contribute to the
development of the final system in the 3-week period.
Proceedings of the 6th International CDIO Conference, École Polytechnique, Montréal, June 15-18, 2010
The purpose of the projects in the 13-week period is:





To get a basic understanding of the overall domain
To get familiar with development tools that are used in the project
To make the students accustomed to the operation of the weighing machine
To have students play their specific roles in the team.
To get students to appoint a team leader
Projects have a duration of 2-3 weeks. The project descriptions are limited to 1-3 pages. Most of
the time spent in the lab will be related to the project.
The projects contribute to the understanding of the final system. The shaded areas mark periods
in which other activities not directly associated with the project, take place.
The final project description (problem statement) is presented to students at the end of the 13week period. This is a more comprehensive document which contains the requirements for the
final system.
The projects in the 13 week period are described in table 2.
Table 2: Project description, background information and purpose
Course
P#
02324
1
2
3
4
01917
02325
1
1
2
Project description / background
information
Create a program that authenticates users
based on username and password.
The students are supplied with a proposed
software architecture for the weighing system.
Create a program that simulates the operation
of the physical weighing machine.
Create a web application that defines a simple
user interface and validate input data according
to a specified set of rules.
Create a web application that authenticates
users based on username and password.
Create a program that is capable of retrieving
and storing data in a relational database using
embedded SQL.
The students are supplied with the project data
model, a database containing tables for the
project.
Create a standard communication program that
is able to communicate with the weighing
machine using a LAN connection.
Create a program that implements a weighing
procedure (Weighing Control Unit).
Purpose
Get a basic understanding on how to
work with layered software architecture.
Get a detailed understanding of the
weighing machine protocol.
Get an understanding of basic web
user interface design and validation
procedures.
Get familiar with a web authentication
framework
Get a basic understanding of the SQL
data manipulation language (DML) and
how to use embedded SQL
Get a basic understanding on how to
use socket programming and how the
application protocol of the weighing
machine operates.
Get a basic understanding of the
weighing procedure.
Proceedings of the 6th International CDIO Conference, École Polytechnique, Montréal, June 15-18, 2010
Design and implementation of the final system take place in the 3-week period.
The main objective during this period is for students to apply the general skills they have
acquired in the 13-week period.
The introductory projects support the students’ awareness of the functionality of subcomponents
and to a lesser degree, how the entire system operates.
Key points which the students should consider in the final design are:





User friendliness
Security regarding production errors and general error registration
Operator working speed when performing weighing procedure
Traceability of production events and of final product back to ingredient suppliers
System performance, including verification hereof by testing it with a generated full-scale
dataset
Some considerations that support the above points could be:




Entry procedures for miscellaneous identification numbers e.g. operator numbers,
ingredient numbers, batch numbers, give the opportunity to design user-friendly
procedures
To verify that the correct components are selected in the weighing process
General implementations of functions that handle error entries and incorrect operation
The actual order of adding the ingredients in the weighing process: Is this 100%
controlled by the system or is it possible for the operator to decide? When can the
weighing procedure be interrupted?
DELIVERIES, MILESTONES AND FINAL EXAMINATION
Deliverables:
There are 7 exercises in the 13-week period and a final report after the 3-week period. Each
task is documented with a report. Since it can be a challenging task to get software projects to
work outside the development environment, we have specified exact procedures for delivery. It
should be possible for teachers and examiners to import the projects on their own machines and
make it run outside the development environment. Test data is implemented as well. In our
experience quality is raised considerably and makes product evaluation possible. Usually you
only have code and documentation available. It is motivating for the students and it puts an
extra pressure that leads to a better completion of tasks.
Milestone presentations:
In the intensive part of the project (the 3-week period) there are 2 presentations (milestone M1
and M2, see figure 4). These presentations are role plays. In M1 the teachers play the role of the
development manager in a software production company and in M2 the client who is buying the
system. At times teaching assistants from courses may also be used. The teams have to
present their project with focus on the current status.
Final examination:
The exam consists of three parts:
Proceedings of the 6th International CDIO Conference, École Polytechnique, Montréal, June 15-18, 2010



Assessment of the final report and produced programs
Oral presentation of final report and demonstration of the finished product followed by
questions. All team members participate. The team determines who takes the floor
during the presentation and who answers questions
Finally, there is an individual oral examination of each student in the team. The student is
asked question about the team's report and general issues within the curriculum
Grades are based on an overall assessment of these parts. Students are graded individually.
CONCLUSIONS AND FINAL REMARKS
It is our experience that the best teams are able to design systems at the same level as the ones
being used in industry. The quality of the produced software is quite comparable to what is used
in industry today. Within the business area of quality control using intelligent scales is a very
beneficial solution.
Many companies, especially in the pharmaceutical industry, require that the systems are
validated against different standards. This has not been a part of our project because it falls
outside the focus of the syllabus.
We believe that the approach to introduce the 7 sub-assemblies is very important for a
successful outcome.
It also provides knowledge of:


The supplied software development tool. In practice this is a prerequisite for
implementing the project
The functionality of the weighing machine, especially how the software works in the
operation of the weighing machine
Furthermore a good integration of the teams is obtained over a long process.
Having teams make presentation for each other may be considered. This will certainly be very
useful for the students. Yet we have not selected this option. The argument for this is that we
believe that it would be quite time consuming. In our experience weaker teams need help to
prioritize between quality and quantity.
Overall the project described may seem to be very controlled. However, it is our experience that
this is a necessity at this introductory level. Students at 2nd semester have little or no knowledge
of architecture-matters of a distributed system. If we leave it up to the students to design for
example the architectural model it would be time consuming and will also typically result in
unmanageable systems. It is our experience that the few positive things that may be resulting
from this is not in proportion to the time spent. Instead, we are trying to plan in such a way that
students have the opportunity for a successful experience in terms of getting a complete system
to work.
Proceedings of the 6th International CDIO Conference, École Polytechnique, Montréal, June 15-18, 2010
REFERENCES
[1]
Crawley, E. F., Malmqvist, J., Östlund, S., & Brodeur, D. R., Rethinking Engineering Education:
The CDIO Approach. New York: Springer, 2007.
[2]
Kruchten, Philippe, The Rational Unified Process: An Introduction. Addison-Wesley , 2004 (3rd
Ed.).
[3]
Ian Sommerville, Software Engineering, Addison Wesley (7th Ed.)
[4]
Sparsø, Jens ; Klit, Peder ; May, Michael ; Mohr, Gunnar ; Vigild, Martin Etchells, Towards CDIObased B.Eng. studies at the Technical University of Denmatk, Proceedings of the 3rd International
CDIO Conference
[5]
Technical University of Denmark, Course description 02324: Advanced programming,
http://www.kurser.dtu.dk/02324.aspx?menulanguage=en
[6]
Technical University of Denmark, Course description 02325: Data Communication,
http://www.kurser.dtu.dk/02325.aspx?menulanguage=en
[7]
Technical University of Denmark, Course description 01917: Discrete Mathematics and Databases
for Diplom IT,
http://www.kurser.dtu.dk/01917.aspx?menulanguage=en
[8]
Mettler Toledo, Validation Manual Volume 2,
http://us.mt.com/global/en/home/supportive_content/product_documentation/product_brochures/Inh
altsverzeichnis_ValidierungsHB_2_FWN.rxHgAwXLuMvM.ExternalFileComponent.html/FWN_Validation_Manual2.pdf
Biographical Information
Mads Nyborg is associate professor in software engineering at DTU informatics. He has several
years of experience in teaching in software engineering and has governed industrial projects
both as consultant and as supervisor for student projects. He was the main responsible for
introducing the CDIO concept at the diploma education at DTU informatics.
Stig Høgh is associate professor in software engineering at DTU informatics. He has several
years of experience in teaching in software engineering and has governed industrial projects
both as consultant and as supervisor for student projects. He has in the period 1985-2005
produced software for quality control. This is sold in cooperation with the company Mettler
Toledo Denmark.
Proceedings of the 6th International CDIO Conference, École Polytechnique, Montréal, June 15-18, 2010