What Are Functinoal and Non Functional Requirements in Software Enginering ?

Download as pdf or txt
Download as pdf or txt
You are on page 1of 4

Software Requirements are Descriptions and specifications of a system

A requirementis a condition or capability to which the system must conform and Define. A system is
designed with certain functionality in mind and to ome up with that functionality and its specification
right at the beginning is Requirement Engineering.

Requirements Engineering

Eliciting, organizing, and documenting the requirements of the system–The process of establishing the
services that the customer requires from a system and the constraints under which it operates and is
developed.

Software requirements should be

•Clear •complete •Unambiguous •Quantitative.

What are Functinoal and Non Functional Requirements in Software Enginering ?


Functional Requirements are the Expected functionality or services from the system.
Non - Functional Requirements are System property and constraints. Now Constraints can be on
requirements itself. Some examples are of Response time, 24X7 availability of the system etc.

What is SRS ?
SRS stands for Software Requirement Specification.
It establishes the basis for agreement between customers and contractors or suppliers on what the
software product is expected to do, as well as what it is not expected to do.
Some of the features of SRS are -
• It sets permits a rigorous assessment of requirements before design can begin.
• It sets the basis for software design, test, deployment, training etc. It also sets pre-requisite for a good
design though it is not enough.
• It sets basis for software enhancement and maintenance.
• It sets Basis for Project plans like Scheduling and Estimation.

What are the Different types of Architectures in Software Engineering ?


An architecture expresses a fundamental structural organization schema for software systems. It
provides a set of predefined subsystems, specifies their responsibilities, and includes rules and
guidelines for organizing the relationships between them.
* Object-Oriented/Abstract Data Style
* Layered Hierarchies
* Blackboard architecture
- involving shared access to data with loosely coupled agents
* Client/Server
* Three tier Client/Server architectures
* Peer-to-Peer Architecture
Use case
A use case in software engineering and systems engineering is a description of a system’s behavior as it
responds to a request that originates from outside of that system. In other words, a use case describes
"who" can do "what" with the system in question. The use case technique is used to capture a system's
behavioral requirements by detailing scenario-driven threads through the functional requirements.
What are use cases and class diagrams in Software Engineering ?
Use cases are graphical represenation of system parts and there interaction that is taking place.
Normally we depict
the part of the systems who are involved in some activity as actors.
Class Diagrams are a part of designing proess. After coming up with use cases of the system, we take
each use case and come up with the
classes that we need to perform that functionality. Each class will have Class Name, Attribues and
Operations associate with it.
Some of the features of the classes are -
- Each class should have well defined responsibilities
- These responsibilities should be cohesive i.e. the system as a whole looks sensible and looks together.

What are sequence diagram ? What are package diagram ? What are collaboration
diagram ?
Sequence Diagram
_
Shows how objects communicate with each other over time.
_
That is, sequence diagrams are used to model object interactions arranged in time sequence and to
distribute use case behavior to classes.
_
They can also be used to illustrate all the paths a particular use case can ultimately produce.
_

The sequence diagram consists of Active Objects, Messages represented as solid-line arrows, and Time
represented as a vertical progression.

Sequence Diagram – Time & Messages


_

Messages are used to illustrate communication between different active objects of a sequence diagram.

Types of Messages
_
Synchronous (flow interrupt until the message has completed.

Asynchronous (don’t wait for response)

Flat – no distinction between sysn/async

Return – control flow has returned to the caller.

Collaboration Diagrams
_

Class diagrams indicates what classes are part of our system, what they offer, how they relate,
but they don’t tell us how they communicate.
Collaboration diagrams show (used to model) how objects interact and their roles.
They are very similar to sequence diagrams.
Sequence Diagrams are arranged according to Time.
Collaboration Diagrams represent the structural organization of object.
[Both sequence and collaboration diagrams are called interaction diagrams]
What is RUP and PSP ?
RUP stands for Rational Unified Process
It deals with -
• Iterative software development process.
• Visual Modeling of Systems
• Quality Management
• Change Control Management
• Deals with the role, the activity, and the artifact
• For managing OO Software Development
Some Features of RUP are -
• Online Repository of Process Information and Description
• Templates for all major artifacts, including:
– Requirements tracking (RequisitePro templates)
– Use Cases (Word Templates )
– Project Management (Project Templates)
• Process Manuals describing key processes
PSP stands for Personal Software Process
PSP Objectives are -
– To introduce individuals to a process-based approach to developing software
– To show individuals how to measure, estimate, schedule, and track their work
– To show individuals how to improve the quality of their programs
– In general PSP improves quality and productivity
- The time saved in testing because of better quality reduces time across the project by 20-40%
Advantage of PSP -
– To manage your work & assess/build your talents/skills
– To plan better
– To track your performance precisely
– To measure the quality of your software products

SDLC:
Phases in SDLC are

1.Initiation:

Begins when sponsor identifies a need .Concept proposal is created .

2.System Concept Development:

Define scope or boundary of concept .includes cost benefit analysis, risk management and
feasibility study.

3.planning .

Develop a project management plan.

4. Requirement Analysis.

Analysis user needs and develop user requirements.

5. Design.

Transforms detail requirements into detail design .

6.Development.

In this phase designs are translated into code.

7.Integration and testing.

Demonstrate that developed system conforms to the requirements as specified in functional


requirement.

8.Implementation.

Implementation of a system into production environment.

9. Maintaince.

You might also like

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy