Documente Academic
Documente Profesional
Documente Cultură
Software Projects
Software development is a complex process
involving such activities as domain analysis,
requirements specification, communication with the
customers and end-users, designing and producing
different artifacts, adopting new paradigms and
technologies, evaluating and testing software
products, installing and maintaining the application
at the end-user's site, providing customer support,
organizing end-user's training, envisioning potential
upgrades and negotiating about them with the
customers, and many more.
Software Development Process
One of the primary duties of the manager
of a software development project is to
ensure that all of the project activities
follow a certain predefined process, i.e. that
the activities are organized as a series of
actions conducing to a desirable end.
The activities are usually organized in
distinct phases, and the process specifies
what artifacts should be developed and
delivered in each phase.
waterfall model.
Spiral Model
Requirements Engineering
Requirements engineering is the discipline of gathering,
analyzing, and formally specifying the user's needs, in order
to use them as analysis components when developing a
software system .
Requirements must be oriented towards the user's real needs,
not towards the development team and the project
managers
It is necessary to manage requirements as well as possible
because a small change to requirements can profoundly
affect the project's cost and schedule, since their definition
underlies all design and implementation.
Requirements develop over time.
The intended result of this process is a structured but
evolving set of agreed, well understood, and carefully
documented requirements
Requirements Engineering (ctd)
This implies the need for requirements traceability,
i.e. the ability to describe and follow the life of a
requirement, in both a forward and backward
direction, ideally through the whole system's life
cycle.
We must constantly involve the users in the
process of requirements analysis and specifications
Only the users know their domain properly
They should certainly participate in defining the
system's functions, designing them, and evaluating
their implementation and testing.
Requirements Engineering (ctd)
There is a wide spectrum of techniques for requirements engineering
(involve the user to increase the correctness of the requirements
specification.):
Structured interviews and questionnaires, diagram-based requirements
analysis (using multiple diagrams to sketch relevant parts of the user's
work process and describe the requirements graphically).
Using metaphors of the user's work process (e.g., the office metaphor,
or the agent/agency metaphor)
Scenario analysis
Using special-purpose software tools for requirements gathering (some
of them can be simulation-based)
Requirements completeness and consistency checks
Using special-purpose requirements-specification languages in order to
describe requirements more formally and hence provide more
automated requirements tracing.
Prototype system development, in order to make the requirements
clear and to establish better mutual understanding with the users.
PROJECT SCHEDULING
Driving without any idea of how you're going to get there
is the same as working on a project without a schedule.
No matter the size or scope of your project, the schedule
is a key part of project management.
The schedule tells you when each activity should be done,
what has already been completed, and the sequence in
which things need to be finished.
Because of the uncertainty involved, the schedule is
reviewed regularly, and it is often revised while the project
is in progress.
The schedule essentially transforms the project from a
vision to a time based plan.
Schedules also help you do the following:
They provide a basis for you to monitor and
control project activities.
They help you determine how best to
allocate resources so you can achieve the
project goal.
They help you assess how time delays will
impact the project.
You can figure out where excess resources
are available to allocate to other projects.
They provide a basis to help you track
project progress.
Schedule Inputs:
You need several types of inputs to create a project schedule:
Personal and project calendars - Understanding
working days, shifts, and resource availability is critical to
completing a
Description of project scope - From this, you can
determine key start and end dates, major assumptions
behind the plan, and key constraints and restrictions.
Project risks - You need to understand these to
make sure there's enough extra time to deal with
identified risks – and with unidentified risks
Lists of activities and resource requirements - it's
important to determine if there are other constraints to
consider when developing the schedule. Understanding the
resource capabilities and experience you have available – as
well as company holidays and staff vacations
Scheduling Tools:
Tools and techniques for combining these inputs to develop the schedule
Schedule Network Analysis - This is a graphic representation of the
project's activities, the time it takes to complete them, and the sequence in
which they must be done. Project management software is typically used
to create these analyses - Gantt charts and PERT Charts are common
formats.
Critical Path Analysis - This is the process of looking at all of the
activities that must be completed, and calculating the 'best line' - or critical
path - to take so that you'll complete the project in the minimum amount
of time. The method calculates the earliest and latest possible start and
finish times for project activities, and it estimates the dependencies among
them to create a schedule of critical activities and dates.
Schedule Compression - This tool helps shorten the total duration
of a project by decreasing the time allocatted for certain activities. You can
use two methods here:
Crashing - This is where you assign more resources to an activity,
thus decreasing the time it takes to complete it.
Fast-Tracking - This involves rearranging activities to allow more
parallel work.
Example of SW tools used
1.Gantt Chart
2. WBS
3. Critical Path methods
The Early Start (ES) of the first activity is one. The Early Finish (EF) of an activity is its
ES plus its duration minus one. Using our earlier example, Activity 2 is the first activity on the
critical path:
ES = 1, EF = 1 + 5 -1 = 5.
If an activity has more than one predecessor, to calculate its ES you will use the activity with
the latest EF
The Late Finish (LF) for the last activity in every path is the same as the last activity's EF
in the critical path.The Late Start (LS) is the LF - duration + 1.
Activity 4 is the last activity on the critical path. Its LF is the same as its EF, which is 14. To
calculate the LS, subtract its duration from its LF and add one. LS = 14 - 2 + 1 = 13.
In the next activity in the path, Its LF is determined by subtracting one from the previous
activity's LS
keys to plan a successful project.
Allocate Resources to the Tasks:The first step in building the
project schedule is to identify the resources required to perform each
of the tasks required to complete the project. A resource is any person,
item, tool, or service that is needed by the project that is either scarce
or has limited availability.
Identify Dependencies: to identify dependencies between tasks. A
task has a dependency if it involves an activity, resource, or work
product that is subsequently required by another task.
Change is a process
Lewin(Kurt Lewin) proposed a three stage basic theory of
change includes Unfreeze, Change, Freeze (or Refreeze) as
shown in diagram.
1. becoming motivated to change (unfreezing)
2. change what needs to be changed (unfrozen and moving
to a new state)
3. making the change permanent (refreezing)
Change can be Emotional:
The six stages include:
Immobilization, Denial, Anger, Bargaining,
Depression, Acceptance
THE CHANGE MANAGEMENT
PLAN
Ready, Willing, and Able to Change:
This is the first step for developing a change management plan that is to assess the
organization‘s readiness, willingness and ability to change.
Several roles involved in a change management – the sponsor, change agents,
change advocate and targets.
Sponsor : an individual (or group) with the power to determine that change
will occur. (has the authority to make resources available and support the project)
Change Agents : individual (or group) responsible for seeing that a
previously determined change occurs to achieve project‘s goals. (They design and
implement or help to implement the change.)
Change Advocate :individual (or group) who want to achieve a change but
lacks the power to sanction it and require support from the appropriate sponsor
who can approve the change. (To have a good idea and the ability to communicate
it can be a change advocate.)
Targets: the individual or group that must change.
Leavitt's Model of Change