SA&D

advertisement
CSUN Information Systems
Systems Analysis & Design
http://www.csun.edu/~dn58412/IS431/IS431_SP16.htm
System
Development
Process
IS 431: Lecture 2
1
System Development
Process
 Value Chain and Innovation Cycle
 Principles of systems development.
 PIECES framework for categorizing problems,
opportunities, and directives.
 Systems development phases: purpose, inputs, and
outputs.
 Alternative “routes” through the basic phases of
system development.
 Computer-aided systems engineering (CASE) and
application development environments (ADEs)
IS 431 : Lecture 2
2
Value Chain & Five
Forces Model
IS 431 : Lecture 2
3
The Value Chain
VALUE
FIRM INFRASTRUCTURE
HUMAN RESOURCE MANAGEMENT
TECHNOLOGY DEVELOPMENT
PROCUREMENT
INBOUND
LOGISTICS
OPERATIONS
OUTBOUND
LOGISTIC
MARKETING
& SALES
LOGISTIC
COST
IS 431 : Lecture 2
SERVICE
MARGIN
4
The Value Chain
SUPPORT ACTIVITIES
FIRM INFRASTRUCTURE
HUMAN RESOURCES
TECHNOLOGY
PURCHASING
INBOUND
LOGISTICS
OPERATIONS
OUTBOUND
LOGISTICS
MARKETING
& SALES
SERVICE
PRIMARY ACTIVITIES
Receiving,
Storing,
Distributing
Raw Materials
Manufacturing
Distribution
Order Processing
IS 431 : Lecture 2
Advertising
Selling
Repair
Maintenance
5
Value-Added Activities
 Customer-Value-Added Activity (maximize)
– a business process generating a value (utility) that a
customer is willing to pay for
 Business-Value-Added Activity (minimize)
– a business process that is essential to managing an
organization (cost)
 Non-Value-Added Activity (eliminate)
– customer will not pay; business value will not be
increased (waste)
 Goals of a business system: effective (do right
thing), efficient (do thing right), competitive (do
thing differently).
IS 431 : Lecture 2
6
Information Systems in
Organization
STRATEGIC
EXECUTIVE INFORMATION SYSTEMS
TACTICAL
MANAGEMENT INFORMATION SYSTEMS
TRANSACTION PROCESSING SYSTEMS
OPERATIONAL
A
C
C
O
U
N
T
I
N
G
F
I
N
A
N
C
E
H
U
M
A
N
R
E
S
P
R
O
D
U
C
T
I
O
N
S
A
L
E
S
O
T
H
E
R
S
VALUE CHAIN
IS 431 : Lecture 2
7
Emerging Technology in
Business Innovation Cycle
IS 431 : Lecture 2
8
IS 431 : Lecture 2
9
System Development
Process
 System development process – a set of activities, methods,
best practices, deliverables, and automated tools that
stakeholders use to develop and continuously improve
information systems and software
 CMM Requirement
 A consistent process for system development assures
– Efficiencies to allow management to shift resources
between projects (best practices/ thorough procedures)
– Consistent documentation to reduce lifetime costs to
maintain the systems (by other developers/teams)
– Consistent quality across projects
IS 431 : Lecture 2
10
CMM Process
Management Model
Capability Maturity Model (CMM) – a standardized
framework for assessing the maturity level of an
organization’s information system development and
management processes and products. It consists of five levels
of maturity:
– Level 1—Initial: System development projects follow no prescribed
process.
– Level 2—Repeatable: Project management processes and practices are
established to track project costs, schedules, and functionality.
– Level 3—Defined: A standard system development process (a
“methodology”) is purchased or developed. All projects use a version of
this process to develop and maintain information systems and software.
– Level 4—Managed: Measurable goals for quality and productivity are
established.
– Level 5—Optimizing: The standardized system development process is
continuously monitored and improved based on measures and data analysis
established in Level 4.
IS 431 : Lecture 2
11
System Development
Process and Quality
CMM Project Statistics for a Project Resulting
in 200,000 Lines of Code
Organization’
s CMM Level
Project
Duration
(months)
Project
PersonMonths
Number of
Defects
Shipped
Median
Cost ($
millions)
Lowest
Cost ($
millions)
Highest
Cost
($ millions)
1
30
600
61
5.5
1.8
100+
2
18.5
143
12
1.3
.96
1.7
3
15
80
7
.728
.518
.933
IS 431 : Lecture 2
12
Life Cycle vs.Methodology
 System life cycle – the factoring of the lifetime of an
information system into two stages, (1) systems development
and (2) systems operation and maintenance.
 System development methodology – a standardized
development process that defines a set of activities, methods,
best practices, deliverables, and automated tools that system
developers and project managers are to use to develop and
continuously improve information systems and software.
IS 431 : Lecture 2
13
A System Life Cycle
IS 431 : Lecture 2
14
System Development
Methodologies
 Architected Rapid Application Development
(Architected RAD)
 Dynamic Systems Development Methodology
(DSDM)
 Joint Application Development (JAD)
 Information Engineering (IE)
 Rapid Application Development (RAD)
 Rational Unified Process (RUP)
 Structured Analysis and Design
 eXtreme Programming (XP)
IS 431 : Lecture 2
15
Principles of System
Development
 Get the system users involved.
 Use a problem-solving approach.
 Establish phases and activities.
 Document throughout the development.
 Establish standards.
 Manage the process and projects
 Justify systems as capital investments.
 Don’t be afraid to cancel or revise scope.
 Divide and conquer.
 Design systems for growth and change.
IS 431 : Lecture 2
16
A  Meeting Transcript
 System Developer:
– “I am going to build a P2P system [???] with killer apps in
PHP and CCC [???] running on cutting-edge technologies
DSL and XYZ [???].”
 System Owner/User:
– “Would YOUR system solve MY problem [in singular] or
it just introduce YOUR %&$# [unprintable term / bleep]
technology and leave ME to figure out the solutions for
new problems [in plural] created by YOU &%$# &c&c…
[again, longer and stronger unprintable terms / louder
bleep-bleep-bleep] ? ”
IS 431 : Lecture 2
17
Principles of System
Development …
 Principle 1: Get the owners and users involved in
all system development phases.
 User Participation/Involvement creates “System
Ownership” and leads to User Acceptance and
User Satisfaction .
 Bottom line: owners and users will live with the
system !!!
 “OUR system [owners + users + developers] will
be effective, efficient, competitive, user friendly
etc, etc [fiddles playing softly in the background…]”
IS 431 : Lecture 2
18
Principles of System
Development …
 Principle 2: Use a problem solving approach
– Study and understand the problem in its context
– Define the requirements of a suitable solution
– Identify candidate solutions and select the best available
– Design and /or implement the solution
– Observe and evaluate the solution impact, and refine the
solution accordingly
 Solve a WRONG problem with a WRONG
solution  !!!
IS 431 : Lecture 2
19
Principles of System
Development …
 Principle 3: Establish phases and activities (define
a process to follow)
– Scope definition
– Problem Analysis
– Requirement Analysis
– Logical Design
– Decision Analysis
– Physical Design and Integration
– Construction and Testing
– Implementation and Delivery
 These phases identify problems, evaluate, design,
and implement solution (Systems Development
Process)
IS 431 : Lecture 2
20
Principles of System
Development …
 Principle 4: Document throughout the system
development process
– Ongoing activity to reveal strength and weakness of the
system during the development process
– Enhance communication and acceptance among
stakeholders
– Agreements and Contracts between Owner/User and
Analyst/Designer on the Scope, Requirements, Resources
of the project.
IS 431 : Lecture 2
21
Principles of System
Development …
 Principle 5: Establish standards for consistency
– System development standards: documentation,
methodology
– Business standards: business rules and practices
– IT standards : common architecture and configuration for
a consistent system development
IS 431 : Lecture 2
22
Principles of System
Development …
 Principle 6: Manage the process and projects
– Process management : ongoing activity that documents,
manages, oversees the use of, and improves an
organization’s chosen methodology (the “process”) for
system development. Process management is concerned
with phases, activities, deliverables, and quality
standards should be consistently applied to all projects.
– Project management : the process of scoping, planning,
staffing, organizing, directing, and controlling a project
to develop an information system at a minimum cost,
within a specified time frame, and with acceptable
quality.
IS 431 : Lecture 2
23
Principles of System
Development …
 Principle 7: Justify Systems as Capital Investments
– Strategic Information System Plan fits in and
supports Strategic Enterprise Plan
– There are several possible solutions, the first one is not
necessary the best *
– Feasibility of each solution in terms of
 Cost Effectiveness: Cost/benefit analysis
 Risk management: Identification, evaluation, and
control of potential threat to the completion of a
system
* In fact, there is a saying “ If you have two alternatives to solve a problem,
the third one is the best ” (See Murphy’s Laws)
IS 431 : Lecture 2
24
Principles of System
Development …
 Principle 8: Don’t be Afraid to Cancel and Revise
Scope: Creeping Commitment
– Expectation and scope of a project may be growing up
– Development process has checkpoints for its phases: all
costs committed so far are sunk costs.
 Cancel the project if it is no longer feasible (ORGANIZATION)
 Reevaluate/adjust cost/schedule if the scope expanding
(ANALYST)
 Reduce the scope if budget/schedule shrinking (ANALYST)
IS 431 : Lecture 2
25
Principles of System
Development …
 Principle 9: Divide and Conquer
– Divide a complex system into simpler subsystems
/components
– Problem solving process could be simplified for
smaller problems
– Different subsystems for different stakeholders
IS 431 : Lecture 2
26
Principles of System
Development …
 Principle 10: Design Systems for Growth and Change
– The entropy of a system
– Changes of technology, user requirements
– Flexibility and adaptability should be built into the system
IS 431 : Lecture 2
27
Where Do Systems
Development Projects
Come From?
Problem – an actual undesirable situation that
prevents the organization from fully achieving its
purpose, goals, and/or objectives.
Opportunity – a chance to improve the
organization even in the absence of an identified
problem (using PIECES framework).
Directive - a new requirement that is imposed by
management, government, or some external
influence/parties.
IS 431 : Lecture 2
28
Where Do Systems
Development Projects
Come From?
 Planned Projects
– An information systems strategy plan has examined the
business as a whole to identify those system development
projects that will return the greatest strategic (long-term)
value to the business
– A business process redesign has thoroughly analyzed a
series of business processes to eliminate redundancy and
bureaucracy and to improve efficiency and value added.
Now it is time to design/redesign the supporting
information system for those redesigned business
processes.
IS 431 : Lecture 2
29
Where Do Systems
Development Projects
Come From?
 Unplanned projects
– Triggered by a specific problem, opportunity, or directive
that occurs in the course of doing business.
– Steering committee – an administrative body of system
owners and information technology executives that
prioritizes and approves candidate system development
projects.
– Backlog – a repository of project proposals that cannot
be funded or staffed because they are a lower priority
than those that have been approved for system
development.
IS 431 : Lecture 2
30
PIECES Framework for
Systems Improvement
P
the need to improve performance
I
the need to improve information (and data)
E
the need to improve economics, control costs, or
increase profits
C
the need to improve control or security
E
the need to improve efficiency of people and
processes
S
the need to improve service to customers, suppliers,
partners, employees, etc.
(They are Opportunities for New System Development
Projects)
IS 431 : Lecture 2
31
Classic Project Phases
IS 431 : Lecture 2
32
System Building Blocks
IS 431 : Lecture 2
33
1. Scope Definition
• Purpose: define perceived problems, opportunities,
and directives (POD); assess the risk of project;
establish scope, preliminary requirements and
constraints, participants, budget and schedule
(preliminary study)
• Issues: Is the project worthwhile? (using PIECES
framework) Define the scope of project
• Deliverable: Project charter/plan
•Feasibility check: Cancel project / Approve to
continue / Reduce or expanse the scope with budget
and schedule modification
IS 431 : Lecture 2
34
2. Problem Analysis
• Purpose: to study and analyze the existing system
from the users’ perspectives as they see Data,
Processes, and Interfaces
• Issue: Cost/benefits of building new system to
solve these problems
• Deliverable: system improvement objectives
(business criteria to evaluate the new system)
• Feasibility check: Cancel project / Approve to
continue / Reduce or expanse the scope with
budget and schedule modification
IS 431 : Lecture 2
35
3. Requirement Analysis
• Purpose: discover users’ needs or expectations
out of the new system in terms of Data, Processes,
and Interfaces
• Issue: Specify requirements for the new system
(WHAT TO BE DONE) without prematurely
expressing technical details (HOW)
• Errors and omissions in requirement analysis
result in user dissatisfaction of final system and
costly modifications
• Deliverable: business requirements statement
IS 431 : Lecture 2
36
4. Logical Design
• Purpose: translating business user requirements into
a system model that depicts only WHAT TO DO
without specifying any possible technical design or
implementation of those requirements (conceptual
design).
• Issue: using graphical model of a system to
represent user requirements in terms of Data,
Processes and Interfaces, and to facilitate improved
communication between system stakeholders.
•Caution: Analysis paralysis – excessive system
modeling dramatically slows progress toward
implementation of the intended system solution.
•Deliverable: Logical Systems Models (DFD, ERD
etc)
IS 431 : Lecture 2
37
5. Decision Analysis
• Purpose: identify all candidate solutions, analyze
the feasibility of each candidate, recommend a
candidate system as the target solution
• Issue: Feasibility analysis in terms of technical,
operational, economic, schedule (TOES), and risk
•Deliverable: approved system proposal
•Feasibility check: Cancel project / Approve system
proposal with budget and schedule modification /
Reduce the scope of proposed solution with budget
and schedule modification
IS 431 : Lecture 2
38
Decision Analysis Preview
 Candidate solutions evaluated in terms of TOES and Risks:
– Technical feasibility – Is the solution technically practical? Does
our staff have the technical expertise to design and build this
solution?
– Operational feasibility – Will the solution fulfill the users’
requirements? To what degree? How will the solution change the
users’ work environment? How do users feel about such a solution?
– Economic feasibility – Is the solution cost-effective?
– Schedule feasibility – Can the solution be designed and
implemented within an acceptable time?
– Risk feasibility – What is the probability of a successful
implementation using the technology and approach? (Risk
Management)
IS 431 : Lecture 2
39
6. Physical Design
• Purpose: to transform business requirements into
technical design specifications for construction
• Issue: HOW technology will be used to build the
system in terms of Data, Processes, and Interfaces
• Design by Specifications vs. Design by Prototyping
• Deliverable: System design specifications
(blueprints)
•Feasibility check: Continue/ Reduce or expanse the
scope with budget and schedule modification
IS 431 : Lecture 2
40
7. Construction Phase
• Purpose: to build and test a system that fulfill
business requirements and design specs; implement
interfaces between new and existing systems
• Issue: Construct database, application programs,
user/system interfaces, implement purchased or
leased software
• Deliverable: proposed system within budget and
schedule
IS 431 : Lecture 2
41
8. Implementation Phase
• Purpose: deliver the production system into
operation
• Issue: Train users, write manuals, load files,
populate database, final test
• Conversion plan: parallel systems, switch point
• Deliverable: system up and running
IS 431 : Lecture 2
42
Operation and Support
• Ongoing system support would be provided until
the system becomes obsolete and is replaced by a
new one
• Issues: technical support for user, fixing bugs,
recovering plan, adapt to emerging requirements
• When a system has reached entropy, new project
for new system should be initiated
IS 431 : Lecture 2
43
Summary: Systems
Development Process
 Scope Definition Phase: What Business Problem
 Problem Analysis Phase: What System Issues
(Info/Data, Processes, Communications/Interfaces)
 Requirement Analysis Phase: What User Needs
 Logical Design: Conceptual Model – What to Do
 Decision Analysis Phase: What Solution
 Design Phase: Physical Model: How to Do
 Construction Phase: Do It
 Implementation Phase: Use It
IS 431 : Lecture 2
44
Systems Development
Process in Practice
IS 431 : Lecture 2
45
System Development
Documentations
IS 431 : Lecture 2
46
Cross Life-Cycle
Activities
Cross life-cycle activity – any activity that overlaps
many or all phases of the systems development process.
– Fact-finding
 Fact-finding - the formal process of using research, interviews,
meetings, questionnaires, sampling, and other techniques to collect
information about system problems, requirements,and preferences.
– Documentation and presentation
 Documentation – the ongoing activity of recording facts and
specifications for a systems for current and future reference.
 Presentation – the ongoing activity of communicating findings,
recommendations, and documentation for review by interested users
and mangers.
 Repository – a database and/or file directory where system
developers store all documentation, knowledge, and artifacts for one
or more information systems or projects.
– Feasibility analysis
– Process and project management
IS 431 : Lecture 2
47
System Analysis &
Design Approaches
 DEVELOPMENT
• Modeling
• Prototyping (RAD)
 IMPLEMENTATION
• Build (In-house)
• Buy (COTS)
IS 431 : Lecture 2
48
Model-Driven
Development
IS 431 : Lecture 2
49
Model-Driven
Development
Model-driven development – a system development strategy
that emphasizes the drawing of system models to help
visualize and analyze problems, define business requirements,
and design information systems.
– Process Modeling – a process-centered technique popularized by the
structured analysis and design methodology used models of
business process requirements to derive effective software designs for
a system.
– Data Modeling – a data-centered technique to model business data
requirements and design appropriate database systems.
– Object Modeling – a technique to merge the data and process
concerns into singular constructs called objects. Object models are
diagrams that document a system in terms of its objects and their
interactions.
IS 431 : Lecture 2
50
Model-Driven
Development …
 Advantages:
– Planning ahead
– Extensive modeling current system and requirement
analysis
– Analyze many alternative technical solutions
– Suitable for well understood systems
IS 431 : Lecture 2
51
Model-Driven
Development …
 Disadvantages:
– Long duration
– Passive participation of user as they don’t see the product
– Requirements in each phase should be fully addressed:
impractical and/or inflexible
IS 431 : Lecture 2
52
Rapid Application
Development
IS 431 : Lecture 2
53
Rapid Application
Development
 Rapid application development (RAD) techniques
emphasize extensive user involvement in the rapid and
evolutionary construction of working prototypes of a system
to accelerate the system development process.
RAD is based on building prototypes that evolve into finished
systems (often using time boxing)
– A prototype is a smaller-scale, representative or working model of
the users’ requirements or a proposed design for an information
system.
– A time box is a non-extendable period of time, usually 60-120 days,
by which a candidate system must be placed into operation.
Improvements will be released in later versions
IS 431 : Lecture 2
54
Rapid Application
Development …
 Advantages:
– Handle uncertain or imprecise user requirements
– Active user participation in building physical product:
increase enthusiasm, support
– Early detection of errors and omissions: with testing and
modifying prototype
– Reduce risk with iterative prototyping
IS 431 : Lecture 2
55
Rapid Application
Development …
 Disadvantages:
– Increase lifetime costs to operate, support, and maintain
the system (constantly doing and fixing)
– Short problem analysis may result in solving wrong
problems
– Discourage an analyst from considering other technical
alternatives than the one being used in prototyping
IS 431 : Lecture 2
56
Commerce
Application Package
IS 431 : Lecture 2
57
Commerce
Application Package
 Commercial application package – a software
application that can be purchased and customized to
meet the business requirements of a large number of
organizations or a specific industry. A synonym is
commercial off-the-shelf (COTS) system.
– Request for proposal (RFP) for all potential vendors
– Request for quotation (RFQ) for some selected vendors
– Gap analysis – a comparison of business and technical
requirements against the capabilities and features of a
specific commercial application package for the purpose of
defining the requirements that cannot be met.
IS 431 : Lecture 2
58
Commercial Off-the-Shelf
Software …
 Advantages
– Fast implementation of new system (many functions are
similar across businesses, no need to build them from
scratch.)
– No need for expertise and staff for in-house development
– Low development costs (but expensive to customize and
implement !!!)
– Vendors are responsible for software improvements and
error corrections
IS 431 : Lecture 2
59
Commercial Off-the-Shelf
Software …
 Disadvantages
– Dependent on the vendors
– Future upgrade/customization is expensive
– A COTS rarely reflects ideal solution developed in-house
– Changing current business processes to fit the COTS
IS 431 : Lecture 2
60
Hybrid Strategies
IS 431 : Lecture 2
61
Hybrid: Multiple
Implementation
IS 431 : Lecture 2
62
Hybrid: Staged
Implementation
IS 431 : Lecture 2
63
System Maintenance
IS 431 : Lecture 2
64
Automated Tools and
Technology
 Computer-aided systems engineering (CASE)
 Application development environments (ADEs)
 Process and project managers
IS 431 : Lecture 2
65
Computer-Assisted
Software Engineering
Computer-aided systems engineering (CASE) – the
use of automated software tools that support the
drawing and analysis of system models and associated
specifications. Some CASE tools also provide
prototyping and code generation capabilities.
– CASE repository – a system developers’ database where
developers can store system models, detailed descriptions and
specifications, and other products of system development.
Synonyms include dictionary and encyclopedia.
– Forward engineering – a CASE tool capability that can
generate initial software or database code directly from
system.
– Reverse engineering – a CASE tool capability that can
generate initial system models from software or database
code.
IS 431 : Lecture 2
66
CASE Tool Architecture
IS 431 : Lecture 2
67
Application Development
Environments
Application development environments (ADEs) – an
integrated software development tool that provides all the
facilities necessary to develop new application software with
maximum speed and quality. A common synonym is integrated
development environment (IDE)
– ADE facilities may include:







Programming languages or interpreters
Interface construction tools
Middleware
Testing tools
Version control tools
Help authoring tools
Repository links
IS 431 : Lecture 2
68
Process and Project
Managers
 Process manager application – an automated tool that helps
document and manage a methodology and routes, its
deliverables, and quality management standards. An
emerging synonym is methodware (e.g., Visio, Visible
Analyst, Rational Rose etc.).
 Project manager application – an automated tool to help
plan system development activities (preferably using the
approved methodology), estimate and assign resources
(including people and costs), schedule activities and
resources, monitor progress against schedule and budget,
control and modify schedule and resources, and report project
progress (e.g., MS Project etc.).
IS 431 : Lecture 2
69
Strategic Management
IS 431 : Lecture 2
70
Strategic Management
IS 431 : Lecture 2
71
Strategic Planning
 Creative and interactive ongoing process to
determine what an organization wants to be in the
future and how it will get there.
 Development of a comprehensive long-range plan
for guiding the activities and operations of an
organization.
IS 431 : Lecture 2
72
The Mission
 Purpose for the organization’s existence
 Represents fundamental and unique aspirations that
make the organization different from others: who we
are, what we do
 Guides the planning process
 All sub-units should be focused on the organization’s
mission and how they contribute toward
accomplishments.
IS 431 : Lecture 2
73
Scope of the Mission
 Defines the type of activities and services that will
be performed
 Should be clearly identified in details to help
employees and customers understand the priorities
of the organization
 Serves as basis for development of certain goals and
objectives
IS 431 : Lecture 2
74
The Vision
 A future view of what an organization would like to
become
– Be national recognized as a best producer,
service provider, etc…
IS 431 : Lecture 2
75
Goals and Objectives
 Goals—explains how the mission will be realized ;
describes what is to be accomplished
 Objectives—specify how and when goals will be
met
IS 431 : Lecture 2
76
The Strategy
 Strategy is a comprehensive plan on how its
mission, goals, and objectives will be achieved.
 Understanding the endpoint (mission, goals, and
objectives) is critical to the development of the plan.
IS 431 : Lecture 2
77
Strategic Management
IS 431 : Lecture 2
78
Strategic Planning
Process
 Define the corporate vision and mission.
 Specify achievable goals and objectives.
 Develop strategies.
 Set policy guidelines.
 Determine products, services, and markets.
 Supporting technology (IS) must be factored into
the strategic plan.
IS 431 : Lecture 2
79
Download