Unit-2 Notes
Unit-2 Notes
SOFTWARE REQUIREMENTS
    What is a requirement?
●   The requirements for the system are the description of the services provided by the system and its
    operational constraints
●   It may range from a high-level abstract statement of a service or of a system constraint to a detailed
    mathematical functional specification.
● May be the basis for a bid for a contract - therefore must be open to interpretation;
●   May be the basis for the contract itself - therefore must be defined in detail; Both these statements
    may be called requirements
    Requirements engineering:
●   The process of finding out, analyzing documenting and checking these services and constraints is
    called requirement engineering.
●   The process of establishing the services that the customer requires from a system and the constraints
    under which it operates and is developed.
●   The requirements themselves are the descriptions of the system services and constraints that are
    generated during the requirements engineering process.
    Types of requirements:
●   User requirements
●   Statements in natural language plus diagrams of the services the system provides and its operational
    constraints. Written for customers.
● System requirements
●   A structured document setting out detailed descriptions of the system’s functions, services and
    operational constraints. Defines what should be implemented so may be part of a contract between
    client and contractor.
● Each external file type may have an associated tool which may be applied to the file.
● Each external file type may be represented as a specific icon on the user’s display.
● Facilities should be provided for the icon representing an external file type to be defined by the user.
●   When an user selects an icon representing an external file, the effect of that selection is to apply the
    tool associated with the type of the external file to the file represented by the selected icon.
           Requirements readers:
           Non-functional requirements
       •   Constraints on the services or functions offered by the system such as timing constraints, constraints
           on the development process, standards, etc.
           Domain requirements
       •   Requirements that come from the application domain of the system and that reflect characteristics of
           that domain.
• Depend on the type of software, expected users and the type of system where the software is used.
       •   Functional user requirements may be high-level statements of what the system should do but
           functional system requirements should describe the system services in detail.
       •   A library system that provides a single interface to a number of databases of articles in different
           libraries.
• Users can search for, download and print these articles for personal study.
• The system shall provide appropriate viewers for the user to read documents in the document store.
       •   Every order shall be allocated a unique identifier (ORDER_ID) which the user shall be able to copy
           to the account’s permanent storage area.
           Requirements imprecision
       •   Problems arise when requirements are not precisely stated.
• User intention - special purpose viewer for each different document type;
• Developer interpretation - Provide a text viewer that shows the contents of the document.
       •   There should be no conflicts or contradictions in the descriptions of the system facilities. In practice,
           it is impossible to produce a complete and consistent requirements document.
           NON-FUNCTIONAL REQUIREMENTS
       •   These define system properties and constraints e.g. reliability, response time and storage
           requirements. Constraints are I/O device capability, system representations, etc.
       •   Process requirements may also be specified mandating a particular CASE system, programming
           language or development method.
       •   Non-functional requirements may be more critical than functional requirements. If these are not met,
           the system is useless.
  •   E.g.: The user interface for LIBSYS shall be implemented as simple HTML without frames or Java
      applets.
      Organizational requirements
  •   Requirements which are a consequence of organizational policies and procedures e.g., process
      standards used, implementation requirements, etc.
  •   E.g.: The system development process and deliverable documents shall conform to the process and
      deliverables defined in XYZCo-SP-STAN-95.
      External requirements
  •   Requirements which arise from factors which are external to the system and its development process
      e.g. interoperability requirements, legislative requirements, etc.
  •   Eg: The system shall not disclose any personal information about customers apart from their name
      and reference number to the operators of the system.
    Goals and requirements:
•   Non-functional requirements may be very difficult to state precisely and imprecise requirements may
    be difficult to verify.
• Goal
•   The system should be easy to use by experienced controllers and should be organized in such a way
    that user errors are minimized.
•   Experienced controllers shall be able to use all the system functions after a total of two hours
    training. After this training, the average number of errors made by experienced users shall not
    exceed two per day.
• Goals are helpful to developers as they convey the intentions of the system users.
Requirements measures:
               Property                 Measure
               Speed                    Processed transactions/second User/Event response time
                                        Screen refresh time
Size M Bytes
• Spacecraft system
• To minimize weight, the number of separate chips in the system should be minimized.
       •   However, using low power chips may mean that more chips have to be used. Which is the most
           critical requirement?
       •   A common problem with non-functional requirements is that they can be difficult to verify. Users or
           customers often state these requirements as general goals such as ease of use, the ability of the
           system to recover from failure or rapid user response. These vague goals cause problems for system
           developers as they leave scope for interpretation and subsequent dispute once the system is
           delivered.
•    Domain specialists understand the area so well that they do not think of making the domain
     requirements explicit.
2)   USER REQUIREMENTS
•    Should describe functional and non-functional requirements in such a way that they are
     understandable by system users who don’t have detailed technical knowledge.
•    User requirements are defined using natural language, tables and diagrams as these can be
     understood by all users.
• Precision is difficult without making the document difficult to read. Requirements confusion
     Requirement problems
•    Database requirements includes both conceptual and detailed information
•    However, it also includes the detail that managers can configure this system - this is unnecessary at
     this level.
• Structured presentation
    3)   SYSTEM REQUIREMENTS
•        More detailed specifications of system functions, services and constraints than user requirements.
• The system may inter-operate with other systems that generate design requirements;
•        The readers and writers of the requirement must interpret the same words in the same way. NL is
         naturally ambiguous so this is very difficult.
• Over-flexibility
•        The same thing may be said in a number of different ways in the specification. Lack of
         modularization
Alternatives to NL specification:
            Notation                    Description
Structurednatural             This approach depends on defining standard forms or
language                  templates to express the requirements specification.
                          specifications.
Graphical notations
●   The advantage is that the most of the expressiveness of natural language is maintained but a degree
    of uniformity is imposed on the specification.
    Form-based specifications
●   Definition of the function or entity.
    Tabular specification
●   Used to supplement natural language.
● Particularly useful when you have to define a number of possible alternative courses of action.
    Graphical models
●   Graphical models are most useful when you need to show how state changes or where you need to
    describe a sequence of actions.
    Sequence diagrams
●   These show the sequence of events that take place during some user interaction with a system.
● You read them from top to bottom to see the order of the actions that take place.
● Validate card;
● Handle request;
●   Complete transaction.
    Sequence diagram of ATM withdrawal
● Description
● Inputs
● Source
● Outputs
● Destination
●   Action
●    Requires
● Pre-condition
● Post-condition
● Side-effects
●    When a standard form is used for specifying functional requirements, the following information
     should be included:
●    If a functional approach is used, a pre-condition setting out what must be true before the function is
     called and a post-condition specifying what is true after the function is called
4)   INTERFACE SPECIFICATION
●    Most systems must operate with other systems and the operating interfaces must be specified as part
     of the requirements.
●    Procedural interfaces where existing programs or sub-systems offer a range of services that are
     accessed by calling interface procedures. These interfaces are sometimes called Application
     Programming Interfaces (APIs)
●    Data structures that are exchanged that are passed from one sub-system to another. Graphical data
     models are the best notations for this type of description
● Should include both a definition of user requirements and a specification of the system requirements.
●    It is NOT a design document. As far as possible, it should set of WHAT the system should do rather
     than HOW it should do it
● Introduction.
● References
● General description.
● Product perspective
● Product functions
● User characteristics
● General constraints
●   Specific requirements cover functional, non-functional and interface requirements. The requirements
    may document external interfaces, describe system functionality and performance, specify logical
    database requirements, design constraints, emergent system properties and quality characteristics.
● Appendices.
● Index.
●   Checking that the requirements actually define the system that the customer wants(validation) The
    process of managing the changes in the requirements is called requirement management.
●   This spiral model accommodates approaches to development in which the requirements are
    developed to different levels of detail. The number of iterations around the spiral can vary, so the
    spiral can be exited after some or all of the user requirements have been elicited.
    Some people consider requirements engineering to be the process of applying a structured analysis
    method such as object-oriented analysis. This involves analyzing the system and developing a set of
    graphical system models, such as use-case models, that then serve as a system specification. The set
     of models describes the behavior of the system and are annotated with additional information
     describing, for example, its required performance or reliability.
     Spiral model of requirements engineering processes
1)   FEASIBILITY STUDIES
     A feasibility study decides whether or not the proposed system is worthwhile. The input to the
     feasibility study is a set of preliminary business requirements, an outline description of the system
     and how the system is intended to support business processes. The results of the feasibility study
     should be a report that recommends whether or not it worth carrying on with the requirements
     engineering and system development process.
•    A short-focused study that checks
–    If the system contributes to organizational objectives;
–    If the system can be engineered using current technology and within budget;
     If the system can be integrated with other systems that are used.
    Process activities
–   Requirements discovery
–   Interacting with stakeholders to discover their requirements. Domain requirements are also
    discovered at this stage.
–   Requirements classification and organization
–   Groups related requirements and organizes them into coherent clusters.
–   Prioritization and negotiation
–   Prioritizing requirements and resolving requirements conflicts.
–   Requirements documentation
–   Requirements are documented and input into the next round of the spiral.
–   The process cycle starts with requirements discovery and ends with requirements documentation.
    The analyst’s understanding of the requirements improves with each round of the cycle.
–   Requirements classification and organization is primarily concerned with identifying overlapping
    requirements from different stakeholders and grouping related requirements. The most common way
    of grouping requirements is to use a model of the system architecture to identify subsystems and to
    associate requirements with each sub-system.
–   Inevitably, stakeholders have different views on the importance and priority of requirements, and
    sometimes these view conflict. During the process, you should organize regular stakeholder
    negotiations so that compromises can be reached.
–   In the requirement documenting stage, the requirements that have been elicited are documented in
    such a way that they can be used to help with further requirements discovery.
    Effective interviewers:
–   Interviewers should be open-minded, willing to listen to stakeholders and should not have pre-
    conceived ideas about the requirements.
–   They should prompt the interviewee with a question or a proposal and should not simply expect
    them to respond to a question such as ‘what do you want’.
    Scenarios:
    Scenarios are real-life examples of how a system can be used.
•   They should include
–   A description of the starting situation;
–   A description of the normal flow of events;
–   A description of what can go wrong;
–   Information about other concurrent activities;
–   A description of the state when the scenario finishes.
    Use cases
•   Use-cases are a scenario-based technique in the UML which identify the actors in an
    interaction and which describe the interaction itself.
•   A set of use cases should describe all possible interactions with the system.
•   Sequence diagrams may be used to add detail to use-cases by showing the sequence of
    event processing in the system.
    •
2.2)   ETHNOGRAPHY:
•    A social scientist spends a considerable time observing and analyzing how people
     actually work.
•    People do not have to explain or articulate their work.
•    Social and organizational factors of importance may be observed.
•    Ethnographic studies have shown that work is usually richer and more complex than
     suggested by simple system models.
     Focused ethnography:
•    Developed in a project studying the air traffic control process
•    Combines ethnography with prototyping
•    Prototype development results in unanswered questions which focus the ethnographic
     analysis.
•    The problem with ethnography is that it studies existing practices which may have
     some historical basis which is no longer relevant.
     Scope of ethnography:
•    Requirements that are derived from the way that people actually work rather than the
     way I which process definitions suggest that they ought to work.
•    Requirements that are derived from cooperation and awareness of other people’s
     activities.
3)   REQUIREMENTS VALIDATION
•    Concerned with demonstrating that the requirements define the system that the
    customer really wants.
•   Requirements error costs are high so validation is very important
–   Fixing a requirements error after delivery may cost up to 100 times the cost of fixing
    an implementation error.
    Requirements checking:
•   Validity: Does the system provide the functions which best support the customer’s
    needs?
•   Consistency: Are there any requirements conflicts?
•   Completeness: Are all functions required by the customer included?
•   Realism: Can the requirements be implemented given available budget and
    technology
•   Verifiability: Can the requirements be checked?
    Requirements reviews:
•   Regular reviews should be held while the requirements definition is being formulated.
•   Both client and contractor staff should be involved in reviews.
•   Reviews may be formal (with completed documents) or informal. Good
    communications between developers, customers and users can resolve problems at an
     early stage.
     Review checks:
•    Verifiability: Is the requirement realistically testable?
•    Comprehensibility: Is the requirement properly understood?
•    Traceability: Is the origin of the requirement clearly stated?
•    Adaptability: Can the requirement be changed without a large impact on other
     requirements?
4)   REQUIREMENTS MANAGEMENT
•    Requirements management is the process of managing changing requirements during
     the requirements engineering process and system development.
•    Requirements are inevitably incomplete and inconsistent
–    New requirements emerge during the process as business needs change and a better
     understanding of the system is developed;
–    Different viewpoints have different requirements and these are often contradictory.
     Requirements change
•    The priority of requirements from different viewpoints changes during the
     development process.
•    System customers may specify requirements from a business perspective that conflict
     with end-user requirements.
•    The business and technical environment of the system changes during its
     development.
     Requirements evolution:
4.1)   Enduring and volatile requirements:
•      Enduring requirements: Stable requirements derived from the core activity of the
       customer organization. E.g., a hospital will always have doctors, nurses, etc. May be
       derived from domain models
•      Volatile requirements: Requirements which change during development or when the
       system is in use. In a hospital, requirements derived from health-care policy
       Requirements classification:
       Requirement            Description
          Type
          Mutable             Requirements that change because of changes to the
          requirements        environment in which the
                              organization is operating. For example, in hospital systems,
                              the funding of patient care may change and thus require
                              different treatment information to be collected.
          Emergent            Requirements that emerge as the customer's understanding
          requirements        of the system develops
                              during the system development. The design process may
                              reveal new emergent requirements.
          Consequential       Requirements that result from the introduction of the
          requirements        computer system. Introducing
                              the computer system may change the organizations
                               processes and open up new ways of working which generate
                               new system requirements
          Compatibility        Requirements that depend on the particular systems or
          requirements         business processes within an organization. As this change,
                               the compatibility requirements on the commissioned
                                     or delivered system may also have to evolve.
       Traceability:
       Traceability is concerned with the relationships between requirements, their sources
       and the system design
•      Source traceability
–      Links from requirements to stakeholders who proposed these requirements;
•      Requirements traceability
–      Links between dependent requirements;
•      Design traceability - Links from the requirements to the design;
Change management:
    SYSTEM MODELLING
●   System modelling helps the analyst to understand the functionality of the system and
    models are used to communicate with customers.
●   Different models present the system from different perspectives
1)   CONTEXT MODELS:
●    Context models are used to illustrate the operational context of a system - they show
     what lies outside the system boundaries.
●    Social and organizational concerns may affect the decision on where to position
     system boundaries.
●    Architectural models show the system and its relationship with other systems.
       The context of an ATM system:
       Process models:
●      Process models show the overall process and the processes that are supported by the
       system.
●      Data flow models may be used to show the processes and the flow of information
       from one process to another.
2)     BEHAVIOURAL MODELS:
●      Behavioral models are used to describe the overall behavior of a system.
o      Data processing models that show how data is processed as it moves through the
       system;
o      State machine models that show the systems response to events.
●      These models show different perspectives so both of them are required to describe the
       system’s behavior.
●   Tracking and documenting how the data associated with a process is helpful to
    develop an overall understanding of the system.
●   Data flow diagrams may also be used in showing the data exchange between a system
    and other systems in its environment.
●   They show the system’s responses to stimuli so are often used for modelling real-time
    systems.
●   State machine models show system states as nodes and events as arcs between these
    nodes. When an event occurs, the system moves from one state to another.
●   State charts are an integral part of the UML and are used to represent state machine
    models.
    State charts:
●   Allow the decomposition of a model into sub-models (see following slide).
● A brief description of the actions is included following the ‘do’ in each state.
       State        Description
       Waiting      The oven is waiting for input. The display shows the current time.
       Half         The oven power is set to 300 watts. The display shows ‘Half power’.
       power
Full       The oven power is set to 600 watts. The display shows ‘Full power’.
power
Set time   The cooking time is set to the user’s input value. The display shows
           the cooking time selected and is updated as the time is set.
Disabled   Oven operation is disabled for safety. Interior oven light is on.
           Display shows ‘Not ready’.
Enabled    Oven operation is enabled. Interior oven light is off. Display shows
           ‘Ready to cook’.
        Operatio Oven in operation. Interior oven light is on. Display shows the timer
        n           countdown. On completion of cooking, the buzzer is sounded for 5
                    seconds. Oven light is on. Display shows ‘Cooking complete’ while
                    buzzer is sounding.
        Stimulus     Description
        Half         The user has pressed the half power button
        power
        Full         The user has pressed the full power button
        power
        Timer        The user has pressed one of the timer buttons
        Number       The user has pressed a numeric key
        Door         The oven door switch is not closed
        open
        Door         The oven door switch is closed
        closed
        Start        The user has pressed the start button
        Cancel       The user has pressed the cancel button
●    An entity-relation-attribute model sets out the entities in the system, the relationships
     between these entities and the entity attributes
●    Widely used in database design. Can readily be implemented using relational
     databases.
●    No specific notation provided in the UML but objects and associations can be used.
     Data dictionaries
●    Data dictionaries are lists of all of the names used in the system models. Descriptions
     of the entities, relationships and attributes are also included.
●    Advantages
4)   OBJECT MODELS:
●    Object models describe the system in terms of object classes and their associations.
●    An object class is an abstraction over a set of objects with common attributes and the
     services (operations) provided by each object.
●    Various object models may be produced
o    Inheritance models;
o    Aggregation models;
o    Interaction models.
●    Natural ways of reflecting the real-world entities manipulated by the system
● More abstract entities are more difficult to model using this approach
●   Object classes inherit their attributes and services from one or more super-classes.
    these may then be specialized as necessary.
● Notation
o   Object classes are rectangles with the name at the top, attributes in the middle section
    and operations in the bottom section;
o   Relationships between object classes (known as associations) are shown as lines
    linking objects;
o   Inheritance is referred to as generalization and is shown ‘upwards’ rather than
    ‘downwards’ in a hierarchy.
Library class hierarchy:
Multiple inheritance
    Object aggregation:
●   An aggregation model shows how classes that are collections are composed of other
    classes.
●   Aggregation models are similar to the part-of relationship in semantic data models.
4.2) Object   aggregation
     Object behavior modelling
●    A behavioral model shows the interactions between objects to produce some particular
     system behavior that is specified as a use-case.
●    Sequence diagrams (or collaboration diagrams) in the UML are used to model
     interaction between objects.
5)   STRUCTURED METHODS:
●    Structured methods incorporate system modelling as an inherent part of the method.
●    Methods define a set of models, a process for deriving these models and rules and
     guidelines that should apply to the models.
●    CASE tools support system modelling as part of a structured method.
     Method weaknesses:
●    They do not model non-functional system requirements.
●    They do not usually include information about whether a method is appropriate for a
     given problem.
●    They may produce too much documentation.
● The system models are sometimes too detailed and difficult for users to understand.