SlideShare a Scribd company logo
MedTech
Chapter 1 – Software Development
Methodologies
Methods and Methodologies for designing software
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 1
MedTech – Mediterranean Institute of Technology
Software Engineering
MedTech
MedTech
Summary of the Course
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 2
• Introduction to Software Development Methodoogies
• Software Development Models
• Software Development Methodologies
• Ad-hoc
• Waterfall
• Prototyping
• V-Model
• Spiral
• RAD
• Unified Process
• Agile
MedTech
Software Project
• A project is a set of actions planned and executed by a group of
people in order to reach a goal, limited by a deadline, and having a
certain cost
• To manage a project
• Define a methodology
• Manage concerned people
• Manage technical constraints
• Manage available means…
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 3
Introduction to Software Development Methodologies
MedTech
Software Development Methodology
• Also called:
• System Development Methodology
• Software Development Lifecycle
• Software Development Process
• A set f activities whose goal is the development or evolution of
software
• Generic activities in all software processes
• Specification
• Design
• Development
• Validation
• Evolution
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 4
Introduction to Software Development Methodologies
MedTech
Software Lifecycle
• Defines all the software development phases, starting from the
requirements specification of the client, to the final stages of
software creation
• These phases are organized with regard to models that guide the
engineer in his activities
• Linear models
• Iterative models
• Incremental models
• Adaptive models
• Extreme models
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 5
Introduction to Software Development Methodologies
MedTech
Summary of the Course
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 6
• Introduction to Software Development Methodoogies
• Software Development Models
• Software Development Methodologies
• Ad-hoc
• Waterfall
• Prototyping
• V-Model
• Spiral
• RAD
• Unified Process
• Agile
MedTech
Software Development Models
• Linear Model
• A number of dependent phases that are executed in a sequential order
with no feedback loops
• The solution is only produced at the final phase
• Well defined goals, requirements and solution, few scope change requests
• Incremental Model
• Same as the linear model, except that each phase releases a partial
solution or deliverable
• Well defined goals, requirements and solution, more agressive schedule
• Iterative Model
• A number of phases repeated in groups with a feedback loop after each
group is completed
• The last phase in a group might release a partial or final solution
• Well defined goals, not all features known, learn-by-doing strategy
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 7
Introduction to Software Development Methodologies
MedTech
Sw. Dev. Models : Incremental vs. Iterative
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 8
Introduction to Software Development Methodologies
MedTech
Sw. Dev. Models : Incremental and Iterative
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 9
Introduction to Software Development Methodologies
MedTech
Software Development Models
• Adaptive Model
• Progresses from iteration to iteration based on limited specification of the
solution
• Each iteration learns from the preceding ones
• Attempts to converge on an acceptable solution for the customer
• Well defined goals but frequent change requests
• Extreme Model
• Same as the adaptive model except that the specification of the solution is
minimal and the goals are not clearly defined
• Goals are unknown, typical R&D projects
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 10
Introduction to Software Development Methodologies
MedTech
Summary of the Course
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 11
• Introduction to Software Development Methodoogies
• Software Development Models
• Software Development Methodologies
• Ad-hoc
• Waterfall
• Prototyping
• V-Model
• Spiral
• RAD
• Unified Process
• Agile
MedTech
Ad-hoc (Big Bang) Methodology
• Typically, no methodology at all!
• The client states his needs, and the developer
just does the work!
• Pros
• Simple and straightforward
• Adequate for small and simple systems
• Cons: A big problem if:
• The client doesn’t express his needs correctly
• The developer doesn’t know how to proceed with the implementation
• … and it does not support any changes in the requirements
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 12
Software Development Methodologies
MedTech
Waterfall
Analysis
Design
Development
Testing
Implementation
Maintenance
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 13
Software Development Methodologies
• Linear Model
• Requirementshould be clear before the next step
• Testing is done once the code fully developed
• A time period is defined for eachstep
MedTech
Waterfall
• Pros
• Requirement is clear before development starts
• Each phase is completed in specific period of time, after that it moves to
the next phase
• As a linea model, it is easy to implement
• The amount of required resources are minimal
• Each phase requires a proper documentation
• Cons
• Some phases problems appear when going through the next phases
• It is not flexible and does not support any requirements changes
• The client sees the resulting product once all the phases are over
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 14
Software Development Methodologies
MedTech
Prototyping
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 15
Software Development Methodologies
MedTech
Prototyping
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 16
Software Development Methodologies
• Remedies to the problem of the waterfall methodology, where we are
never sure if the specification will work until you are at the last stage
• Creates a prototype of the application:
• Incomplete versions of the program
• Simulates only a few aspects of the final product
• Pros
• The customer can be reassured with a sample of his application way before
the development is achieved
• Cons
• A prototype mostly cannot cover all the problems a real application does!
• You spend a significant time creating the prototype
• Sometimes, the customer is happy with the prototype, and doesn’t go
further with the real application!!
MedTech
V-Model
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 17
Software Development Methodologies
Analysis
High	Level
Design
Low Level
Design
Implementation
Acceptance
Testing
System	Testing
Integration
Testing
Unit	Testing
MedTech
V-Model
• Modified version of the waterfall method (linear model)
• The stages turn back upwards to verify and validate every step
• The test cases are prepared with every step
• Tester et developer work in parallel
• Pros
• Same as those of the waterfall + the tester is involved from the
requirement phase
• Cons
• Rigid
• If changes happen midway, not only the requirements documentation, but
also the test documentation need to be changed
• Is not adequate for short term projects as it requires reviews at each stage
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 18
Software Development Methodologies
MedTech
Spiral
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 19
Software Development Methodologies
MedTech
Spiral
• Linear and Incremental Model + Prototyping
• Big emphasis on risk assessment
• 4 main phases:
• Objective Setting, Risk Analysis, Engineering and Planning
• Pros
• High amount of risk analysis
• Software produced early in the lifecycle
• Cons
• Can be costly
• Risk analysis requires highly specific expertise
• Is not adequate for small projects
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 20
Software Development Methodologies
MedTech
RAD: Rapid Application Development
• First method that fundamentally breaks with the waterfall-based methods
• Iterative, incremental and adaptative
• Uses minimal planning in favor of rapid prototyping
• Massive use of computarized development tools (CASE, GUI builders, DBMS…)
• Gathers customer requirements through:
• Workshops or focus groups
• Early testing of the prototypes using iterative concept
• Reuse of existing prototypes
• Continuous integration
• Used if:
• There is a need to produce the system in a short span of time (2-3 months)
• There is a high availabilityof designers and a high budget for code generating
tools
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 21
Software Development Methodologies
MedTech
RAD: Rapid Application Development
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 22
Software Development Methodologies
MedTech
RAD: Rapid Application Development
• Pros
• Reduced development time
• Increased reusability of components
• Quick initial reviews
• Encourages customer feedback
• Iteration time can be short using RAD tools
• Cons
• Depends on a strong team and individual performance
• Only applicable for modularizable systems
• Inapplicable to cheaper projects as cost of modeling and automated code
generation is very high
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 23
Software Development Methodologies
MedTech
Unified Process
• Iterative and incremental model, use case driven and architecture
centered
• A software engineering process based on best practices in software
development
• A disciplines approach to assigning and managing tasks and
responsabilities in a development organization
• Focused on high-quality software that meets the needs of its end users
• Uses the UML notation
• Consists of five core workflows and four phases
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 24
Software Development Methodologies
MedTech
Unified Process
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 25
Software Development Methodologies
MedTech
Unified Process : Terminology
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 26
Software Development Methodologies
• Development Cycle
• Period of time that elapses from the start of the project until product release
• Artifact
• Piece of information produced, modified or used by a process
• Workflow
• Sequence of activities that produces a result of observable value
• Phase
• Each cycle is broken down into a sequence of four phases
• Time during which a well-defined set of objectives is met, artifacts are
completed and decisions whether to move to the next step or not are made
• Iteration
• Inside eahc phase, there may be one or more iterations
• Software is developed in each iteration, concluded by a minor milestone
• The software product grows incrementally as you iterate over the activities
• Milestone
• Release point at which an iteration formally ends
MedTech
Unified Process : Phases
• Inception: 10% Time, 5% Effort
• Helps determine the project feasibility,
what the customer wants and how to get there
• Understand what to build
• A vision document
• Optional business model
• Initial project glossary
• Identify key system functionality
• An initial use case model (10-20% complete)
• One or several prototypes
• Understand costs, schedule and risks
• Decide what process to follow and what tools to use
• Project plan
• First Major Milestone: Lifecyle Objective Milestone
• Is the project doomed to fail?
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 27
Software Development Methodologies
MedTech
Unified Process : Phases
• Elaboration : 30% Time, 20% Effort
• Define and baseline the architecture of the
System to provide a stable basis for the design
• Deeper requirements understanding
• At least 80% complete use case model
• Non functional requirements capturing
• Architect consideration
• Software architecture description
• Executable architectural prototype
• Revised risk list and business case
• Development case refinement
• Coarse grained project plan
• Defining iterations & evaluation criteria for each one
• Major Milestone: Lifecycle Architecture
• Is the project’s plane, vision, architecture are good enough to achieve project
goals?
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 28
Software Development Methodologies
MedTech
Unified Process : Phases
• Construction: 50% Time, 65% Effort
• Targets a cost-efficient development of a
complete product
• Minimize development costs and achieve
some degree of parallelism
• Iteratively develop a complete product
• Software product integrated on the adequate
platforms
• User manuals
• Desciption of the current release
• Major Milestone: Initial Operational Capability
• Is the product ready to be deployed to a beta test env.?
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 29
Software Development Methodologies
MedTech
Unified Process : Phases
• Transition: 10% Time, 30% Effort
• Transition the software product to the user
community
• Think about next releases, finish postponed
features
• Beta testing to validate the new system
against user experience
• Conversion of operational databases
• Training of users and maintainers
• Marketing, distribution
• Improve performance
• Major Milestone: Product Release
• Are the objectives met and should we start another development cycle?
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 30
Software Development Methodologies
MedTech
Two Track Unified Process
• Declination of the Unified Process Methodology
• Takes into account the continuous contraints changes during the
development
• Considers two risks:
• Functional inaccuracy: inadequacy to the requirements
• Unability to integrate technologies
• General principle
• Every possible evolution of the system can be decomposed and managed
separately, following a functional axis and a technical axis
• 2TUP
• Unified process (iterative, archi-centered and UC driven)
• Two branches (technical and functional), merged into a realization branch
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 31
Software Development Methodologies
MedTech
Two Track Unified Process
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 32
Software Development Methodologies
Capture ofBusiness
requirements
Analysis
Capture ofTechnical
requirements
Generic Design
Preliminary Design
Detailed Design
Coding and Tests
Recipe
Functional Branch Technical Branch
Design and Development Branch
MedTech
Two Track Unified Process
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 33
Software Development Methodologies
MedTech
Agile Approach
• Agile movement seeks alternatives to traditional project management
• Uses the incremental and iterative model
• Regular cadences of work (sprints or iterations) at the end of which
the team must present a product increment
• Every aspect of development (requirements, design, …) is continually
revisited throughout the lifecycle
• Possible changes of direction while the project is running: Agility!
• Inspect-and-adapt approach
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 34
Software Development Methodologies
MedTech
Agile Manifesto : agilemanifesto.org
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 35
Software Development Methodologies
Through this work, we have come to value:
Individuals and interactions over processes and tools
Working software over comprehensive documentation
Customer collaboration over contract negotiation
Responding to change over following a plan
That is, while there is value in the items on the right,
we value the items on the left more
MedTech
Agile Approach : 12 Principles
1. Our highest priority is to satisfy the customer through early and
continuous delivery of valuable software.
2. Welcome changing requirements, even late in development. Agile
processes harness change for the customer's competitive advantage.
3. Deliver working software frequently, from a couple of weeks to a
couple of months, with a preference to the shorter timescale.
4. Business people and developers must work together daily throughout
the project.
5. Build projects around motivated individuals. Give them the
environment and support their need, and trust them to get the job
done.
6. The most efficient and effective method of conveying information to
and within a development team is face-to-face conversation.
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 36
Software Development Methodologies
MedTech
Agile Approach : 12 Principles
7. Working software is the primary measure of progress.
8. Agile processes promote sustainable development. The sponsors,
developers, and users should be able
to maintain a constant pace indefinitely.
9. Continuous attention to technical excellence and good design
enhances agility.
10. Simplicity--the art of maximizing the amount of work not done--is
essential.
11. The best architectures, requirements, and designs emerge from self-
organizing teams.
12. At regular intervals, the team reflects on how to become more
effective, then tunes and adjusts its behavior accordingly.
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 37
Software Development Methodologies
MedTech
Agile Approach
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 38
Software Development Methodologies
MedTech
Extreme Programming (XP)
• Is an Agile Methodology
• Iterative, Incremental and Extreme
• Key principles (see http://www.extremeprogramming.org/ )
1. Planning
• User stories are written
• Release planning creates the release schedule
• Divide the project iterations and start each one with a planning step
2. Managing
• Give the team a dedicated workspace
• Set a sustainable pace
• A stand up meeting starts each day
• The project velocity is measured
• Move people around
• Fix XP when it breaks
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 39
Software Development Methodologies
MedTech
Extreme Programming (XP)
• Key principles
3. Designing
• Simplicity
• Choose a system metaphor
• Never add functionalities early
• Refactor whenever and wherever possible
4. Coding
• Customer always available
• Code the unit test first
• All production code is pair programmed
• Integrate often, with a dedicated computer
5. Testing
• All code must have unit tests, and must pass them before it is released
• When a bug is found, tests are created
• Acceptance tests are run often and the score is published
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 40
Software Development Methodologies
MedTech
Extreme Programming (XP)
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 41
Software Development Methodologies
MedTech
SCRUM
A little story to kick it off
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 42
Software Development Methodologies
MedTech
SCRUM
• Agile Methodology
• SCRUM is a team pack in Rugby, everybody in the pack acts together
with everyone else to move the ball down the field
• A framework for complex software development projects (but not
only…)
• Actors:
• The Scrum Master: is responsible to deliver the expected deliverables. Know
how to get things done.
• The Product Owner: represent stakeholders in meetings. Know what has to
get done. Can prioritize.
• The Team: includes (but is not limited to) developers. They commit to
deliver.
• The Stakeholders: are the sponsor of the project. They might not know what
has to be done, they know (most of the times) what they need.
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 43
Software Development Methodologies
MedTech
SCRUM
• A product owner creates a prioritized wish list called a product backlog.
• During sprint planning, the team pulls a small chunk from the top of that
wish list, a sprint backlog, and decides how to implement those pieces.
• The team has a certain amount of time — a sprint (usually two to four
weeks) — to complete its work, but it meets each day to assess its
progress (daily Scrum).
• Along the way, the ScrumMaster keeps the team focused on its goal.
• At the end of the sprint, the work should be potentially shippable: ready to
hand to a customer, put on a store shelf, or show to a stakeholder.
• The sprint ends with a sprint review and retrospective.
• As the next sprint begins, the team chooses another chunk of the product
backlog and begins working again.
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 44
Software Development Methodologies
MedTech
SCRUM
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 45
Software Development Methodologies
MedTech
References
Dr. Lilia SFAXI
www.liliasfaxi.wix.com/liliasfaxi
Slide 46
• A.U. Hakizabera and al. Linear Models vs Agile Models: Making the right model
decision, 2010
• S. Balaji and al. WATEERFALL Vs V-MODEL Vs AGILE: A COMPARATIVE STUDY ON SDLC,
JITBM, 2012
• N. Munassar and al. A Comparison Between Five Models Of Software Engineering,
IJCSI, 2010
• M. Kalali, RUP Overview, 2004
• K. Beck, Extreme Programming Explained, 2000

More Related Content

PPTX
Layered Software Architecture
PDF
Software Engineering - chp3- design
PDF
Software Engineering - chp8- deployment
PDF
Software Engineering - chp4- design patterns
PPTX
Project Scheduling
PPTX
SDLC - Software Development Life Cycle
PPTX
4.software management
PPT
SDLC Models and Their Implementation
Layered Software Architecture
Software Engineering - chp3- design
Software Engineering - chp8- deployment
Software Engineering - chp4- design patterns
Project Scheduling
SDLC - Software Development Life Cycle
4.software management
SDLC Models and Their Implementation

What's hot (20)

PDF
Software Engineering - chp0- introduction
PPTX
Introduction to GitHub, Open Source and Tech Article
PDF
¿Qué es DevOps y por qué es importante en el Ciclo de Software? por michelada.io
PDF
Software Development Life Cycle (SDLC)
PPTX
Introduction to DevOps
PPTX
Introduction to Gitlab | Gitlab 101 | Training Session
PDF
Platform Engineering
PDF
Introduction to CICD
PPTX
GitHub Basics - Derek Bable
PDF
Streaming Cyber Security into Graph: Accelerating Data into DataStax Graph an...
PPTX
Git and GitHub
PDF
What is agile model?Working of agile model
PPTX
Git branching strategies
PDF
Git Tutorial | Git Basics - Branching, Merging, Rebasing | Learn Git | DevOps...
PDF
SDLC-Phases
PDF
Introduction to GitHub Actions
PPTX
Salesforce DevOps using GitHub Action
PPTX
Introduction to devops
PPTX
DevOps culture
Software Engineering - chp0- introduction
Introduction to GitHub, Open Source and Tech Article
¿Qué es DevOps y por qué es importante en el Ciclo de Software? por michelada.io
Software Development Life Cycle (SDLC)
Introduction to DevOps
Introduction to Gitlab | Gitlab 101 | Training Session
Platform Engineering
Introduction to CICD
GitHub Basics - Derek Bable
Streaming Cyber Security into Graph: Accelerating Data into DataStax Graph an...
Git and GitHub
What is agile model?Working of agile model
Git branching strategies
Git Tutorial | Git Basics - Branching, Merging, Rebasing | Learn Git | DevOps...
SDLC-Phases
Introduction to GitHub Actions
Salesforce DevOps using GitHub Action
Introduction to devops
DevOps culture
Ad

Similar to Software Engineering - chp1- software dev methodologies (20)

PPT
SW Development Methodologies
PPT
PROCESS MODELS.ppt
PPTX
Introduction to software Engineering slides
PPTX
Unit1_Software_EngineeringGGGGGGGGGG.pptx
PDF
Software Development Methodologies Pros, Cons, & Use Cases.pdf
PDF
FSE Chap 2.pdf fundamental of software engineering for second year software e...
PPTX
Software development methodologies
PDF
DOC-20250502-WA0001..pdfjejsjjsjsjsjsjsjjsjs
PDF
DOC-20250502-WA0001..pdfjsjsjsjsjhsgsgfsgstd
PDF
Software Development Methodologies Pros, Cons, & Use Cases
PPTX
Software Process Models - Types - Explanations.pptx
PPT
Process models
PDF
Software Engineering - chp6- development phase
PDF
Who cares about Software Process Modelling? A First Investigation about the P...
PPTX
SDLC Models in Software Engineering
PDF
Software Process Models
PPTX
Software engineering Computer science and engineering unit 1 remaining part ...
PPTX
SE - L02 - Software Developmnet Process Model.pptx
PPT
Chapter 1- Introduction to software engineering for CS.ppt
SW Development Methodologies
PROCESS MODELS.ppt
Introduction to software Engineering slides
Unit1_Software_EngineeringGGGGGGGGGG.pptx
Software Development Methodologies Pros, Cons, & Use Cases.pdf
FSE Chap 2.pdf fundamental of software engineering for second year software e...
Software development methodologies
DOC-20250502-WA0001..pdfjejsjjsjsjsjsjsjjsjs
DOC-20250502-WA0001..pdfjsjsjsjsjhsgsgfsgstd
Software Development Methodologies Pros, Cons, & Use Cases
Software Process Models - Types - Explanations.pptx
Process models
Software Engineering - chp6- development phase
Who cares about Software Process Modelling? A First Investigation about the P...
SDLC Models in Software Engineering
Software Process Models
Software engineering Computer science and engineering unit 1 remaining part ...
SE - L02 - Software Developmnet Process Model.pptx
Chapter 1- Introduction to software engineering for CS.ppt
Ad

More from Lilia Sfaxi (20)

PDF
chp1-Intro à l'urbanisation des SI.pdf
PDF
Plan d'études_INSAT_2022_2023.pdf
PDF
Lab3-DB_Neo4j
PDF
Lab2-DB-Mongodb
PDF
Lab1-DB-Cassandra
PDF
TP2-UML-Correction
PDF
TP1-UML-Correction
PDF
TP0-UML-Correction
PDF
TD4-UML
PDF
TD4-UML-Correction
PDF
TD3-UML-Séquences
PDF
TD3-UML-Correction
PDF
TD2 - UML - Correction
PDF
TD1 - UML - DCU
PDF
TD1-UML-correction
PDF
Android - Tp1 - installation et démarrage
PDF
Android - Tp2 - Elements graphiques
PDF
Android - Tp3 - intents
PDF
Android - TPBonus - web services
PDF
Android - Tp4 - graphiques avancés
chp1-Intro à l'urbanisation des SI.pdf
Plan d'études_INSAT_2022_2023.pdf
Lab3-DB_Neo4j
Lab2-DB-Mongodb
Lab1-DB-Cassandra
TP2-UML-Correction
TP1-UML-Correction
TP0-UML-Correction
TD4-UML
TD4-UML-Correction
TD3-UML-Séquences
TD3-UML-Correction
TD2 - UML - Correction
TD1 - UML - DCU
TD1-UML-correction
Android - Tp1 - installation et démarrage
Android - Tp2 - Elements graphiques
Android - Tp3 - intents
Android - TPBonus - web services
Android - Tp4 - graphiques avancés

Recently uploaded (20)

PPTX
Big Data Technologies - Introduction.pptx
PDF
CIFDAQ's Market Insight: SEC Turns Pro Crypto
PDF
KodekX | Application Modernization Development
PDF
Chapter 3 Spatial Domain Image Processing.pdf
PPTX
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
PDF
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
PDF
Approach and Philosophy of On baking technology
PPTX
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
PDF
Per capita expenditure prediction using model stacking based on satellite ima...
PDF
Peak of Data & AI Encore- AI for Metadata and Smarter Workflows
PDF
Advanced methodologies resolving dimensionality complications for autism neur...
PDF
Building Integrated photovoltaic BIPV_UPV.pdf
PDF
Mobile App Security Testing_ A Comprehensive Guide.pdf
PDF
Machine learning based COVID-19 study performance prediction
PDF
Spectral efficient network and resource selection model in 5G networks
PDF
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
PDF
Reach Out and Touch Someone: Haptics and Empathic Computing
PDF
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
PDF
Unlocking AI with Model Context Protocol (MCP)
PDF
Review of recent advances in non-invasive hemoglobin estimation
Big Data Technologies - Introduction.pptx
CIFDAQ's Market Insight: SEC Turns Pro Crypto
KodekX | Application Modernization Development
Chapter 3 Spatial Domain Image Processing.pdf
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
Approach and Philosophy of On baking technology
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
Per capita expenditure prediction using model stacking based on satellite ima...
Peak of Data & AI Encore- AI for Metadata and Smarter Workflows
Advanced methodologies resolving dimensionality complications for autism neur...
Building Integrated photovoltaic BIPV_UPV.pdf
Mobile App Security Testing_ A Comprehensive Guide.pdf
Machine learning based COVID-19 study performance prediction
Spectral efficient network and resource selection model in 5G networks
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
Reach Out and Touch Someone: Haptics and Empathic Computing
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
Unlocking AI with Model Context Protocol (MCP)
Review of recent advances in non-invasive hemoglobin estimation

Software Engineering - chp1- software dev methodologies

  • 1. MedTech Chapter 1 – Software Development Methodologies Methods and Methodologies for designing software Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 1 MedTech – Mediterranean Institute of Technology Software Engineering MedTech
  • 2. MedTech Summary of the Course Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 2 • Introduction to Software Development Methodoogies • Software Development Models • Software Development Methodologies • Ad-hoc • Waterfall • Prototyping • V-Model • Spiral • RAD • Unified Process • Agile
  • 3. MedTech Software Project • A project is a set of actions planned and executed by a group of people in order to reach a goal, limited by a deadline, and having a certain cost • To manage a project • Define a methodology • Manage concerned people • Manage technical constraints • Manage available means… Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 3 Introduction to Software Development Methodologies
  • 4. MedTech Software Development Methodology • Also called: • System Development Methodology • Software Development Lifecycle • Software Development Process • A set f activities whose goal is the development or evolution of software • Generic activities in all software processes • Specification • Design • Development • Validation • Evolution Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 4 Introduction to Software Development Methodologies
  • 5. MedTech Software Lifecycle • Defines all the software development phases, starting from the requirements specification of the client, to the final stages of software creation • These phases are organized with regard to models that guide the engineer in his activities • Linear models • Iterative models • Incremental models • Adaptive models • Extreme models Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 5 Introduction to Software Development Methodologies
  • 6. MedTech Summary of the Course Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 6 • Introduction to Software Development Methodoogies • Software Development Models • Software Development Methodologies • Ad-hoc • Waterfall • Prototyping • V-Model • Spiral • RAD • Unified Process • Agile
  • 7. MedTech Software Development Models • Linear Model • A number of dependent phases that are executed in a sequential order with no feedback loops • The solution is only produced at the final phase • Well defined goals, requirements and solution, few scope change requests • Incremental Model • Same as the linear model, except that each phase releases a partial solution or deliverable • Well defined goals, requirements and solution, more agressive schedule • Iterative Model • A number of phases repeated in groups with a feedback loop after each group is completed • The last phase in a group might release a partial or final solution • Well defined goals, not all features known, learn-by-doing strategy Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 7 Introduction to Software Development Methodologies
  • 8. MedTech Sw. Dev. Models : Incremental vs. Iterative Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 8 Introduction to Software Development Methodologies
  • 9. MedTech Sw. Dev. Models : Incremental and Iterative Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 9 Introduction to Software Development Methodologies
  • 10. MedTech Software Development Models • Adaptive Model • Progresses from iteration to iteration based on limited specification of the solution • Each iteration learns from the preceding ones • Attempts to converge on an acceptable solution for the customer • Well defined goals but frequent change requests • Extreme Model • Same as the adaptive model except that the specification of the solution is minimal and the goals are not clearly defined • Goals are unknown, typical R&D projects Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 10 Introduction to Software Development Methodologies
  • 11. MedTech Summary of the Course Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 11 • Introduction to Software Development Methodoogies • Software Development Models • Software Development Methodologies • Ad-hoc • Waterfall • Prototyping • V-Model • Spiral • RAD • Unified Process • Agile
  • 12. MedTech Ad-hoc (Big Bang) Methodology • Typically, no methodology at all! • The client states his needs, and the developer just does the work! • Pros • Simple and straightforward • Adequate for small and simple systems • Cons: A big problem if: • The client doesn’t express his needs correctly • The developer doesn’t know how to proceed with the implementation • … and it does not support any changes in the requirements Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 12 Software Development Methodologies
  • 13. MedTech Waterfall Analysis Design Development Testing Implementation Maintenance Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 13 Software Development Methodologies • Linear Model • Requirementshould be clear before the next step • Testing is done once the code fully developed • A time period is defined for eachstep
  • 14. MedTech Waterfall • Pros • Requirement is clear before development starts • Each phase is completed in specific period of time, after that it moves to the next phase • As a linea model, it is easy to implement • The amount of required resources are minimal • Each phase requires a proper documentation • Cons • Some phases problems appear when going through the next phases • It is not flexible and does not support any requirements changes • The client sees the resulting product once all the phases are over Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 14 Software Development Methodologies
  • 16. MedTech Prototyping Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 16 Software Development Methodologies • Remedies to the problem of the waterfall methodology, where we are never sure if the specification will work until you are at the last stage • Creates a prototype of the application: • Incomplete versions of the program • Simulates only a few aspects of the final product • Pros • The customer can be reassured with a sample of his application way before the development is achieved • Cons • A prototype mostly cannot cover all the problems a real application does! • You spend a significant time creating the prototype • Sometimes, the customer is happy with the prototype, and doesn’t go further with the real application!!
  • 17. MedTech V-Model Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 17 Software Development Methodologies Analysis High Level Design Low Level Design Implementation Acceptance Testing System Testing Integration Testing Unit Testing
  • 18. MedTech V-Model • Modified version of the waterfall method (linear model) • The stages turn back upwards to verify and validate every step • The test cases are prepared with every step • Tester et developer work in parallel • Pros • Same as those of the waterfall + the tester is involved from the requirement phase • Cons • Rigid • If changes happen midway, not only the requirements documentation, but also the test documentation need to be changed • Is not adequate for short term projects as it requires reviews at each stage Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 18 Software Development Methodologies
  • 20. MedTech Spiral • Linear and Incremental Model + Prototyping • Big emphasis on risk assessment • 4 main phases: • Objective Setting, Risk Analysis, Engineering and Planning • Pros • High amount of risk analysis • Software produced early in the lifecycle • Cons • Can be costly • Risk analysis requires highly specific expertise • Is not adequate for small projects Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 20 Software Development Methodologies
  • 21. MedTech RAD: Rapid Application Development • First method that fundamentally breaks with the waterfall-based methods • Iterative, incremental and adaptative • Uses minimal planning in favor of rapid prototyping • Massive use of computarized development tools (CASE, GUI builders, DBMS…) • Gathers customer requirements through: • Workshops or focus groups • Early testing of the prototypes using iterative concept • Reuse of existing prototypes • Continuous integration • Used if: • There is a need to produce the system in a short span of time (2-3 months) • There is a high availabilityof designers and a high budget for code generating tools Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 21 Software Development Methodologies
  • 22. MedTech RAD: Rapid Application Development Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 22 Software Development Methodologies
  • 23. MedTech RAD: Rapid Application Development • Pros • Reduced development time • Increased reusability of components • Quick initial reviews • Encourages customer feedback • Iteration time can be short using RAD tools • Cons • Depends on a strong team and individual performance • Only applicable for modularizable systems • Inapplicable to cheaper projects as cost of modeling and automated code generation is very high Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 23 Software Development Methodologies
  • 24. MedTech Unified Process • Iterative and incremental model, use case driven and architecture centered • A software engineering process based on best practices in software development • A disciplines approach to assigning and managing tasks and responsabilities in a development organization • Focused on high-quality software that meets the needs of its end users • Uses the UML notation • Consists of five core workflows and four phases Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 24 Software Development Methodologies
  • 25. MedTech Unified Process Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 25 Software Development Methodologies
  • 26. MedTech Unified Process : Terminology Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 26 Software Development Methodologies • Development Cycle • Period of time that elapses from the start of the project until product release • Artifact • Piece of information produced, modified or used by a process • Workflow • Sequence of activities that produces a result of observable value • Phase • Each cycle is broken down into a sequence of four phases • Time during which a well-defined set of objectives is met, artifacts are completed and decisions whether to move to the next step or not are made • Iteration • Inside eahc phase, there may be one or more iterations • Software is developed in each iteration, concluded by a minor milestone • The software product grows incrementally as you iterate over the activities • Milestone • Release point at which an iteration formally ends
  • 27. MedTech Unified Process : Phases • Inception: 10% Time, 5% Effort • Helps determine the project feasibility, what the customer wants and how to get there • Understand what to build • A vision document • Optional business model • Initial project glossary • Identify key system functionality • An initial use case model (10-20% complete) • One or several prototypes • Understand costs, schedule and risks • Decide what process to follow and what tools to use • Project plan • First Major Milestone: Lifecyle Objective Milestone • Is the project doomed to fail? Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 27 Software Development Methodologies
  • 28. MedTech Unified Process : Phases • Elaboration : 30% Time, 20% Effort • Define and baseline the architecture of the System to provide a stable basis for the design • Deeper requirements understanding • At least 80% complete use case model • Non functional requirements capturing • Architect consideration • Software architecture description • Executable architectural prototype • Revised risk list and business case • Development case refinement • Coarse grained project plan • Defining iterations & evaluation criteria for each one • Major Milestone: Lifecycle Architecture • Is the project’s plane, vision, architecture are good enough to achieve project goals? Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 28 Software Development Methodologies
  • 29. MedTech Unified Process : Phases • Construction: 50% Time, 65% Effort • Targets a cost-efficient development of a complete product • Minimize development costs and achieve some degree of parallelism • Iteratively develop a complete product • Software product integrated on the adequate platforms • User manuals • Desciption of the current release • Major Milestone: Initial Operational Capability • Is the product ready to be deployed to a beta test env.? Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 29 Software Development Methodologies
  • 30. MedTech Unified Process : Phases • Transition: 10% Time, 30% Effort • Transition the software product to the user community • Think about next releases, finish postponed features • Beta testing to validate the new system against user experience • Conversion of operational databases • Training of users and maintainers • Marketing, distribution • Improve performance • Major Milestone: Product Release • Are the objectives met and should we start another development cycle? Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 30 Software Development Methodologies
  • 31. MedTech Two Track Unified Process • Declination of the Unified Process Methodology • Takes into account the continuous contraints changes during the development • Considers two risks: • Functional inaccuracy: inadequacy to the requirements • Unability to integrate technologies • General principle • Every possible evolution of the system can be decomposed and managed separately, following a functional axis and a technical axis • 2TUP • Unified process (iterative, archi-centered and UC driven) • Two branches (technical and functional), merged into a realization branch Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 31 Software Development Methodologies
  • 32. MedTech Two Track Unified Process Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 32 Software Development Methodologies Capture ofBusiness requirements Analysis Capture ofTechnical requirements Generic Design Preliminary Design Detailed Design Coding and Tests Recipe Functional Branch Technical Branch Design and Development Branch
  • 33. MedTech Two Track Unified Process Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 33 Software Development Methodologies
  • 34. MedTech Agile Approach • Agile movement seeks alternatives to traditional project management • Uses the incremental and iterative model • Regular cadences of work (sprints or iterations) at the end of which the team must present a product increment • Every aspect of development (requirements, design, …) is continually revisited throughout the lifecycle • Possible changes of direction while the project is running: Agility! • Inspect-and-adapt approach Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 34 Software Development Methodologies
  • 35. MedTech Agile Manifesto : agilemanifesto.org Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 35 Software Development Methodologies Through this work, we have come to value: Individuals and interactions over processes and tools Working software over comprehensive documentation Customer collaboration over contract negotiation Responding to change over following a plan That is, while there is value in the items on the right, we value the items on the left more
  • 36. MedTech Agile Approach : 12 Principles 1. Our highest priority is to satisfy the customer through early and continuous delivery of valuable software. 2. Welcome changing requirements, even late in development. Agile processes harness change for the customer's competitive advantage. 3. Deliver working software frequently, from a couple of weeks to a couple of months, with a preference to the shorter timescale. 4. Business people and developers must work together daily throughout the project. 5. Build projects around motivated individuals. Give them the environment and support their need, and trust them to get the job done. 6. The most efficient and effective method of conveying information to and within a development team is face-to-face conversation. Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 36 Software Development Methodologies
  • 37. MedTech Agile Approach : 12 Principles 7. Working software is the primary measure of progress. 8. Agile processes promote sustainable development. The sponsors, developers, and users should be able to maintain a constant pace indefinitely. 9. Continuous attention to technical excellence and good design enhances agility. 10. Simplicity--the art of maximizing the amount of work not done--is essential. 11. The best architectures, requirements, and designs emerge from self- organizing teams. 12. At regular intervals, the team reflects on how to become more effective, then tunes and adjusts its behavior accordingly. Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 37 Software Development Methodologies
  • 38. MedTech Agile Approach Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 38 Software Development Methodologies
  • 39. MedTech Extreme Programming (XP) • Is an Agile Methodology • Iterative, Incremental and Extreme • Key principles (see http://www.extremeprogramming.org/ ) 1. Planning • User stories are written • Release planning creates the release schedule • Divide the project iterations and start each one with a planning step 2. Managing • Give the team a dedicated workspace • Set a sustainable pace • A stand up meeting starts each day • The project velocity is measured • Move people around • Fix XP when it breaks Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 39 Software Development Methodologies
  • 40. MedTech Extreme Programming (XP) • Key principles 3. Designing • Simplicity • Choose a system metaphor • Never add functionalities early • Refactor whenever and wherever possible 4. Coding • Customer always available • Code the unit test first • All production code is pair programmed • Integrate often, with a dedicated computer 5. Testing • All code must have unit tests, and must pass them before it is released • When a bug is found, tests are created • Acceptance tests are run often and the score is published Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 40 Software Development Methodologies
  • 41. MedTech Extreme Programming (XP) Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 41 Software Development Methodologies
  • 42. MedTech SCRUM A little story to kick it off Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 42 Software Development Methodologies
  • 43. MedTech SCRUM • Agile Methodology • SCRUM is a team pack in Rugby, everybody in the pack acts together with everyone else to move the ball down the field • A framework for complex software development projects (but not only…) • Actors: • The Scrum Master: is responsible to deliver the expected deliverables. Know how to get things done. • The Product Owner: represent stakeholders in meetings. Know what has to get done. Can prioritize. • The Team: includes (but is not limited to) developers. They commit to deliver. • The Stakeholders: are the sponsor of the project. They might not know what has to be done, they know (most of the times) what they need. Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 43 Software Development Methodologies
  • 44. MedTech SCRUM • A product owner creates a prioritized wish list called a product backlog. • During sprint planning, the team pulls a small chunk from the top of that wish list, a sprint backlog, and decides how to implement those pieces. • The team has a certain amount of time — a sprint (usually two to four weeks) — to complete its work, but it meets each day to assess its progress (daily Scrum). • Along the way, the ScrumMaster keeps the team focused on its goal. • At the end of the sprint, the work should be potentially shippable: ready to hand to a customer, put on a store shelf, or show to a stakeholder. • The sprint ends with a sprint review and retrospective. • As the next sprint begins, the team chooses another chunk of the product backlog and begins working again. Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 44 Software Development Methodologies
  • 46. MedTech References Dr. Lilia SFAXI www.liliasfaxi.wix.com/liliasfaxi Slide 46 • A.U. Hakizabera and al. Linear Models vs Agile Models: Making the right model decision, 2010 • S. Balaji and al. WATEERFALL Vs V-MODEL Vs AGILE: A COMPARATIVE STUDY ON SDLC, JITBM, 2012 • N. Munassar and al. A Comparison Between Five Models Of Software Engineering, IJCSI, 2010 • M. Kalali, RUP Overview, 2004 • K. Beck, Extreme Programming Explained, 2000