Preliminary Software Engineering
Unit 1 - Programming Fundamentals
Unit 1 - Programming Fundamentals
  • 1 - Programming Fundamentals
    • Programming Fundamentals Content
  • 2 - Python
    • Expected Python Knowledge
    • GitHub
    • Learning Python
    • Data Structures and File Management
      • Data Structures
        • Lists
        • Arrays
          • Single and Multi-Dimensional Arrays
        • Lists vs Arrays
          • Activities
        • Tuples
        • Sets
        • Dictionaries
          • Activities
      • File Handling
        • Loops, Lists, Dictionaries
        • Activities
  • 3 - Theory Content
    • Theory Content Explained
      • NESA Directional Verbs
      • Responding to Directional Verbs
  • 4 - Software Development and Management
    • Approaches to Software Development
      • Waterfall Model
      • Agile Model
      • Summary: Waterfall vs Agile
      • Activities
    • Software Development Steps
      • Sample Exam Question
      • Requirements Definition
        • Understanding the Need
        • Key Questions to Ask
        • Examples
        • Activities
        • Sample Exam Question
      • Determining Specifications
        • Functional Specifications
        • Non-Functional Specifications
        • Activities
      • Design
        • Top-Down Design Approach
        • Bottom-Up Design Approach
      • Development
        • Optimising Code
      • Integration
        • Example: Payment Program
        • Activity
        • Application Programming Interface (API)
          • Example: OpenWeather API
          • Example: WeatherAPI
          • Activity: Prepare Spells
      • Testing and Debugging
        • Test Data
          • Activities
        • Testing the System
          • Activities
        • Debugging
          • Types of Errors
            • Activities
          • Python Debugger
            • Activities
          • VS Code Debugger
            • Activities
      • Installation
        • Activities
        • Sample Exam Question
      • Maintenance
  • Charts and Algorithms
    • Example: IPO Charts and Pseudocode
      • Activities
    • Algorithms, Flowcharts, Pseudocode
      • Pseudocode Activities
      • Flowchart Activities
      • Sample Exam Questions
    • Structure Charts
      • Activities
      • Sample Exam Questions
    • Data Flow Diagrams
      • Activities
    • Data Dictionaries
      • Activities
    • Decision Trees
      • Activities
      • Sample Exam Questions
    • Gantt Chart
    • Class Diagrams
      • Sample Exam Question
    • Storyboards
      • Sample Exam Question
  • Testing and Debugging
    • Test Data
      • Activities
    • Testing the System
      • Activities
    • Debugging
      • Types of Errors
        • Activities
      • Python Debugger
        • Activities
      • VS Code Debugger
        • Activities
  • Computational Thinking
    • Decomposition
    • Abstraction
    • Activities
  • Version Control
    • Git
    • GitHub
    • Activities
  • Number Systems
    • Binary Systems
    • Hexadecimal Numbers
    • Using Two's Complement
    • Activities
  • 5 - Assessment Task 1
    • Data Science Project
      • Before we Start
        • Setting up GitHub Repository
        • Setting Up Markdown Documentation
      • Examples of API Usage
        • Starter Code: NASA Scenario
        • Starter Code: Spell Book
        • Starter: Pokédex Explorer
        • Starter Code: Weather App
        • Example: OpenWeather API
        • Example: WeatherAPI
        • Example: Prepare Spells
    • Task Guide
      • Requirements Definition
      • Determining Specifications
        • Use Cases
      • Design
        • Gantt Chart
        • Structure Chart
        • Algorithms
        • Data Dictionary
      • Development
        • Comments vs DocStrings
        • UI - main.py
        • Create Python Module
          • Example: NASA Module
          • Example: WeatherFetch Module
          • Example: SpellBook Module
      • Integration
        • Example: Pokedex
      • Testing and Debugging
        • Commit Changes
      • Installation
      • Maintenance
    • Submitting Your Task
Powered by GitBook
On this page
  • Outcomes
  • Key Aspects
  1. 4 - Software Development and Management
  2. Software Development Steps
  3. Requirements Definition

Understanding the Need

The requirements definition phase aims to systematically gather, organise, and document the specific needs and functionalities of the software.

Outcomes

  • Understanding the client's needs and expectations for the software.

  • Gathering requirements through interviews, surveys, and discussions.

  • Analysing requirements to ensure clarity, feasibility, and completeness.

Key Aspects

Understanding the Purpose: Define the purpose of the software by understanding the needs and objectives of the end-users or stakeholders.

Gathering Requirements: Engage with stakeholders using techniques such as interviews, surveys, workshops, and observations to gather comprehensive requirements.

Documenting Requirements: Document the gathered requirements in a structured and understandable manner. Use tools like requirement specification documents, use cases, user stories, or visual models to represent these requirements.

Analysing and Prioritising Requirements: Analyse and evaluate the gathered requirements to ensure they are clear, complete, and feasible. Prioritise requirements based on their importance, dependencies, and impact on the overall software.

Managing Changes: Expect changes in requirements during the software development lifecycle. Implement a robust change management process to handle modifications effectively while maintaining the project scope and schedule.

Validation and Verification: Validate requirements by ensuring they align with the stakeholders' needs and expectations.

Communication and Collaboration: Foster open communication and collaboration among stakeholders, developers, testers, and other relevant parties to ensure a shared understanding of requirements.

Feedback Loop: Establish a feedback loop to continuously review and refine the requirements based on new insights, evolving needs, or changing circumstances.

Documentation: Regularly update and maintain requirement documentation throughout the development process to keep it synchronised with any changes or refinements.

PreviousRequirements DefinitionNextKey Questions to Ask