Design Programining Logic
Design Programining Logic
ADMAS UNIVERSITY
Learning Guide
       Unit of Competence: Design Program Logic
    Module Title: Designing Program Logic
        LG Code:                          EIS DBA3 050811
         TTLM Code:                        EIS DBA3M 050811
                                     1
                          Date: September, 2017
TLM Development Manual
                          Compiled by: ICT Department
                       Training, Teaching and Learning Materials (TTLM)
1. Select the        1.1 Design documentation is obtained and the requirements for the
   program logic         programs are reviewed and clarified.
   design            1.2 Design approach to be taken in coding and the modules and links
   approach              required is determined
2. Document the 2.1 Diagrams of program flow and modules are structured according to
   program logic      project standards
   or design     2.2 Program scope and limits are documented according to project
                      standards
                     2.3 Special routines or procedures are documented or referenced
                          according to project standards
                     2.4 References for tables, files, inputs, outputs, and other program
                          functionalities are identified and revised according to program
                          requirements
                     2.5 Templates are used as applicable
3. Validate the      3.1 Program flow, states or conditions are checked for interfaces and
   design                 compliance to design documentation requirements
                     3.2 Feedback/input is gained from appropriate person as needed
                                                 2
                                      Date: September, 2017
      TLM Development Manual
                                      Compiled by: ICT Department
                         Training, Teaching and Learning Materials (TTLM)
    Example 1: Write an algorithm to determine a student’s final grade and indicate whether it is passing
     or failing. The final grade is calculated as the average of four marks.
                                                    3
                                         Date: September, 2017
        TLM Development Manual
                                         Compiled by: ICT Department
                      Training, Teaching and Learning Materials (TTLM)
                                Flowchart Symbols
                                      Basic
Example 1                                              STAR
                                                         T
 Step 1:     Input M1,M2,M3,M4                         Input
 Step 2:     GRADE                        Example 2
                                                M1,M2,M3,
 (M1+M2+M3+M4)/4                                        M4
 Step 3:     if (GRADE <50) then                Write an algorithm and draw a flowchart to
                                             GRADE(M1+M2+M3+M
             Print “FAIL”                    4)/4 convert the length in feet to centimeter.
       else                                Pseudocode:
             Print “PASS”                  N  InputIS the length in Y
                                                                     feet (Lft)
       endif                                   Calculate
                                                    GRAD the length in cm (Lcm) by multiplying
    LFT with 30                                       E<50
   Print length in cm (LCM)                                           Flow chart
                                                                   PRINT
                                                                   “FAIL”
                                                                         START
                                              4
                                   Date: September, 2017                  Input
      TLM Development Manual                           STOP
                                   Compiled by: ICT Department              Lft
                                                                                   Lcm Lft x 30
                            Training, Teaching and Learning Materials (TTLM)
                                                                                        Print
                                                                                        Lcm
Algorithm
    Step 1: Input Lft
    Step 2:        Lcm ¬ Lft x 30                                                     STOP
    Step 3:        Print Lcm
Example 3
Write an algorithm and draw a flowchart that will read the two sides of a rectangle and calculate its area.
Pseudocode
    Input the width (W) and Length (L) of a rectangle
    Calculate the area (A) by multiplying L with W
                                                                           START
    Print A
                                                                             Input
                                                                              W, L
Algorithm
    Step 1:             Input W,L
    Step 2:             A¬L x W                                           A LxW
    Step 3:             Print A
                                                                              Print
                                                                               A
                                                                             STOP
Example4
    Write an algorithm and draw a flowchart that will calculate the roots of a quadratic equation
                                ax
                                     2
                                         +bx + c=0
                         (b −4 ac)
                            2
       Hint: d = sqrt               , and the roots are: x1 = (–b + d)/2a and x2 = (–b – d)/2a
                                                                                    START
Pseudocode:
    Input the coefficients (a, b, c) of the quadratic equation                        Input
    Calculate d
                                                                                       a, b, c
    Calculate x1
    Calculate x2
    Print x1 and x2                                                      d sqrt(b x b – 4 x a x c)
                                                           5                x1 (–b + d) / (2 x a)
                                                Date: September, 2017
         TLM Development Manual
                                                Compiled by: ICT Department X (–b – d) / (2 x a)
                                                                             2
                                                                            Print
                           Training, Teaching and Learning Materials (TTLM) x1 ,x2
      Algorithm:
                                                                                  STOP
      Step 1:          Input a, b, c
      Step 2:          d ¬ sqrt(               )
      Step 3:          x1 ¬ (–b + d) / (2 x a)
      Step 4:          x2 ¬ (–b – d) / (2 x a)
      Step 5:          Print x1, x2
DECISION STRUCTURES
     The expression A>B is a logical expression
     it describes a condition we want to test
     if A>B is true (if A is greater than B) we take the action on left
     print the value of A
     if A>B is false (if A is not greater than B) we take the action on right
print the value of B
IF–THEN–ELSE STRUCTURE                                               Y                     N
                                                                                  is
     The structure is as follows                                                A>B
If condition then
               true alternative
        else
               false alternative                               Print A                   Print B
endif
IF–THEN–ELSE STRUCTURE
                                                                         Print           Print
                                                                          A               B
                                  Relational Operators
             Operator                               Description
                 >              Greater than
                 <              Less than
                 =              Equal to
                >=        Greater than or equal to
                                                 6
              <=
         TLM Development  Less than orDate:
                         Manual        equalSeptember,
                                              to       2017
                                     Compiled by: ICT Department
              <>          Not equal to
                          Training, Teaching and Learning Materials (TTLM)
Example 5
    Write an algorithm that reads two values, determines the largest value and prints the largest value
        with an identifying message.
ALGORITHM                                                                         STA
Step 1:        Input VALUE1, VALUE2                                               RT
Step 2:        if (VALUE1 > VALUE2) then                                          Input
                              MAX ¬ VALUE1
                       else
                                                                              VALUE1,V
                              MAX ¬ VALUE2                                       ALUE2
                       endif                                             Y            is           N
Step 3:        Print “The largest value is”, MAX                             VALUE1>VALUE2
                                                     7
                                          Date: September, 2017
         TLM Development Manual
                                          Compiled by: ICT Department
                                Training, Teaching and Learning Materials (TTLM)
The cardinality defines the relationship between the entities in terms of numbers.The three main cardinal
relationships are: one-to-one, expressed as 1:1; one-to-many, expressed as 1:M; and many-to-many,
expressed as M:N.
The steps involved in creating an ERD are:
 Identify the entities.
 Determine all significant interactions.
 Analyze the nature of the interactions.
 Draw the ERD.
Entity Relationship Diagram Notations
developed ERDs in 1976. Since then Charles Bachman and James Martin have added some sligh refinements to the basic ERD
principles.
Entity
An entity is an object or concept about which you want to store information.
Weak Entity
A weak entity is an entity that must defined by a foreign key relationship with another entity as it cannot be uniquely identified by
its own attributes alone.
Key attribute
A key attribute is the unique, distinguishing characteristic of the entity. For example, an employee's social security number might
be the employee's key attribute.
Multivalued attribute
A multivalued attribute can have more than one value. For example, an employee entity can have multiple skill values.
Derived attribute
A derived attribute is based on another attribute. For example, an employee's monthly salary is based on the employee's annual
salary.
                                                               8
                                                    Date: September, 2017
              TLM Development Manual
                                                    Compiled by: ICT Department
                                 Training, Teaching and Learning Materials (TTLM)
Relationships
Relationships illustrate how two entities share information in the database structure.
Cardinality
Cardinality specifies how many instances of an entity relate to one instance of another entity.
Ordinality is also closely linked to cardinality. While cardinality specifies the occurences of a relationship, ordinality describes the
relationship as either mandatory or optional. In other words, cardinality specifies the maximum number of relationships and
ordinality specifies the absolute minimum number of relationships.
Recursive relationship
In some cases, entities can be self-linked. For example, employees can supervise other employees.
                                                                 9
                                                      Date: September, 2017
           TLM Development Manual
                                                      Compiled by: ICT Department
                              Training, Teaching and Learning Materials (TTLM)
1.1.4 DFD
                                                            10
                                                 Date: September, 2017
          TLM Development Manual
                                                 Compiled by: ICT Department
                                   Training, Teaching and Learning Materials (TTLM)
Process
A process transforms incoming data flow into outgoing data flow.
Datastore Notations
DataStore
Datastores are repositories of data in the system. They are sometimes also referred to as files.
Dataflow Notations
Dataflow
Dataflows are pipelines through which packets of information flow. Label the arrows with the name of the data that moves through
it.
                                                               11
                                                    Date: September, 2017
           TLM Development Manual
                                                    Compiled by: ICT Department
                                Training, Teaching and Learning Materials (TTLM)
External Entity
External entities are objects outside the system, with which the system communicates. External entities are sources and
destinations of the system's inputs and outputs.
DFD levels
The first level DFD shows the main processes within the system. Each of these processes can be broken into further processes until
you reach pseudocode.
A completed HIPO package has two parts. A hierarchy chart is used to represent the top-down
structure of the program. For each module depicted on the hierarchy chart, an IPO (Input-
Process-Output) chart is used to describe the inputs to, the outputs from, and the process
performed by the module.
                                                              12
                                                   Date: September, 2017
           TLM Development Manual
                                                   Compiled by: ICT Department
                             Training, Teaching and Learning Materials (TTLM)
1.0  Manage inventory
      2.0  Update stock
            2.1  Process sale
            2.2  Process return
            2.3  Process shipment
      3.0  Generate report
            3.1  Respond to query
            3.2  Display status report
      4.0  Maintain inventory data
            4.1  Modify record
            4.2  Add record
            4.3  Delete record
In computer science, a data structure is a particular way of storing and organizing data in a computer so that it can be
used efficiently.
Data structures provide a means to manage large amounts of data efficiently, such as large databases and
internet indexing services. Usually, efficient data structures are a key to designing efficient algorithms.
Some formal design methods and programming languages emphasize data structures, rather than algorithms,
as the key organizing factor in software design. Storing and retrieving can be carried out on data stored in
both main memory and in secondary memory.
     An array data structure stores a number of elements in a specific order. They are accessed using an
        integer to specify which element is required (although the elements may be of almost any type).
        Arrays may be fixed-length or expandable.
     Record (also called tuple or struct) Records are among the simplest data structures. A record is a
        value that contains other values, typically in fixed number and sequence and typically indexed by
        names. The elements of records are usually called fields or members.
                                                          13
                                               Date: September, 2017
          TLM Development Manual
                                               Compiled by: ICT Department
                            Training, Teaching and Learning Materials (TTLM)
       A hash or dictionary or map is a more flexible variation on a record, in which name-value pairs can
        be added and deleted freely.
       Union. A union type definition will specify which of a number of permitted primitive types may be
        stored in its instances, e.g. "float or long integer". Contrast with a record, which could be defined to
        contain a float and an integer; whereas, in a union, there is only one value at a time.
       A tagged union (also called a variant, variant record, discriminated union, or disjoint union) contains
        an additional field indicating its current type, for enhanced type safety.
       A set is an abstract data structure that can store specific values, without any particular order, and no
        repeated values. Values themselves are not retrieved from sets, rather one test a value for
        membership to obtain a boolean "in" or "not in".
       An object contains a number of data fields, like a record, and also a number of program code
        fragments for accessing or modifying them. Data structures not containing code, like those above,
        are called plain old data structure.
Basic principles
 Data structures are generally based on the ability of a computer to fetch and store data at any place in its
   memory, specified by an address—a bit string that can be itself stored in memory and manipulated by
   the program. Thus the record and array data structures are based on computing the addresses of data
   items with arithmetic operations; while the linked data structures are based on storing addresses of data
   items within the structure itself.
 The implementation of a data structure usually requires writing a set of procedures that create and
   manipulate instances of that structure. The efficiency of a data structure cannot be analyzed separately
   from those operations. This observation motivates the theoretical concept of an abstract data type, a data
   structure that is defined indirectly by the operations that may be performed on it, and the mathematical
   properties of those operations (including their space and time cost).
1.1.7 RAD
Rapid application development (RAD) is a software development methodology that uses minimal planning in favor
of rapid prototyping. The "planning" of software developed using RAD is interleaved with writing the software itself.
The lack of extensive pre-planning generally allows software to be written much faster, and makes it easier to change
requirements.
Rapid application development (RAD) is a software development methodology that uses minimal planning
in favor of rapid prototyping. The "planning" of software developed using RAD is interleaved with writing
the software itself. The lack of extensive pre-planning generally allows software to be written much faster,
and makes it easier to change requirements. RAD is not appropriate when technical risks are high.
                  Phases of RAD
    1. Requirements Planning phase – combines elements of the system planning and systems analysis
        phases of the Systems Development Life Cycle (SDLC). Users, managers, and IT staff members
        discuss and agree on business needs, project scope, constraints, and system requirements. It ends
        when the team agrees on the key issues and obtains management authorization to continue.
    2. User design phase – during this phase, users interact with systems analysts and develop models and
        prototypes that represent all system processes, inputs, and outputs. The RAD groups or subgroups
        typically use a combination of Joint Application Development (JAD) techniques and CASE tools to
        translate user needs into working models. User Design is a continuous interactive process that allows
        users to understand, modify, and eventually approve a working model of the system that meets their
        needs.
    3. Construction phase – focuses on program and application development task similar to the SDLC. In
        RAD, however, users continue to participate and can still suggest changes or improvements as actual
        screens or reports are developed. Its tasks are programming and application development, coding,
        unit-integration and system testing.
    4. Cutover phase – resembles the final tasks in the SDLC implementation phase, including data
        conversion, testing, changeover to the new system, and user training. Compared with traditional
                                                         14
                                              Date: September, 2017
         TLM Development Manual
                                              Compiled by: ICT Department
                               Training, Teaching and Learning Materials (TTLM)
           methods, the entire process is compressed. As a result, the new system is built, delivered, and placed
           in operation much sooner.
                      Practical implications
    When organizations adopt rapid development methodologies, care must be taken to avoid role and
    responsibility confusion and communication breakdown within a development team, and between team and
    client. In addition, especially in cases where the client is absent or not able to participate with authority in
    the development process, the system analyst should be endowed with this authority on behalf of the client to
    ensure appropriate prioritization of non-functional requirements. Furthermore, no increment of the system
    should be developed without a thorough and formally documented design phase.
                                                          15
                                               Date: September, 2017
             TLM Development Manual
                                               Compiled by: ICT Department
                              Training, Teaching and Learning Materials (TTLM)
    Reprints
    CASE (computer-aided software engineering) is the use of a computer-assisted method to organize and
    control the development of software, especially on large, complex projects involving many software
    components and people. Using CASE allows designers, code writers, testers, planners, and managers to
    share a common view of where a project stands at each stage of development. CASE helps ensure a
    disciplined, check-pointed process. A CASE tool may portray progress (or lack of it) graphically. It may also
    serve as a repository for or be linked to document and program libraries containing the project's business
    plans, design requirements, design specifications, detailed code specifications, the code units, test cases
    and results, and marketing and service plans.
    Computer-aided software engineering (CASE) is the scientific application of a set of tools and methods to a
    software system with the desired end result of high-quality, defect-free, and maintainable software products.
    It also refers to methods for the development of information systems together with automated tools that can
    be used in the software development process
    Components
      1. Diagrammatic Tools
      2. Information Repository
      3. Interface Generators
      4. Management Tools
    Tools
    CASE tools are a class of software that automates many of the activities involved in various life cycle
    phases. For example, when establishing the functional requirements of a proposed application, prototyping
    tools can be used to develop graphic models of application screens to assist end users to visualize how an
    application will look after development. Subsequently, system designers can use automated design tools to
    transform the prototyped functional requirements into detailed design documents. Programmers can then use
    automated code generators to convert the design documents into code. Automated tools can be used
    collectively, as mentioned, or individually. For example, prototyping tools could be used to define
    application requirements that get passed to design technicians who convert the requirements into detailed
    designs in a traditional manner using flowcharts and narrative documents, without the assistance of
    automated design software.
                                                          16
                                               Date: September, 2017
             TLM Development Manual
                                               Compiled by: ICT Department
MODULE TITLE:    Designing Program Logic
              Integration dimension
 Three main CASE Integration dimensions have been proposed CASE Framework
  1. ICASE Tools
  2. Integrated Project Support Environment(IPSE)
                 Applications
 All aspects of the software development life cycle can be supported by software tools, and so the use of
  tools from across the spectrum can, arguably, be described as CASE; from project management software
  through tools for business and functional analysis, system design, code storage, compilers, translation tools,
  test software, and so on.
 However, tools that are concerned with analysis and design, and with using design information to create
  parts (or all) of the software product, are most frequently thought of as CASE tools. CASE applied, for
  instance, to a database software product, might normally involve:
   Modeling business / real-world processes and data flow
   Development of data models in the form of entity-relationship diagrams
   Development of process and function descriptions
                                                      17
MODULE TITLE:       Designing Program Logic
1.1.9 Prototyping
Software prototyping, refers to the activity of creating prototypes of software applications, i.e., incomplete versions of
the software program being developed. It is an activity that can occur in software development and is comparable
to prototyping as known from other fields, such as mechanical engineering or manufacturing.
A prototype typically simulates only a few aspects of, and may be completely different from, the final product.
Prototyping has several benefits: The software designer and implementer can get valuable feedback from the users early in the
project. The client and the contractor can compare if the software made matches the software specification, according to which
the software program is built. It also allows the software engineer some insight into the accuracy of initial project estimates and
whether the deadlines and milestones proposed can be successfully met.
A prototype is an early sample or model built to test a concept or process or to act as a thing to be replicated or
learned from. It is a term used in a variety of contexts, including semantics, design, electronics, and software
programming. A prototype is designed to test and trial a new design to enhance precision by system analysts
and users.
                                                                18
MODULE TITLE:    Designing Program Logic
 5. Functional Prototype (Model) (also called a working prototype) will, to the greatest extent practical,
    attempt to simulate the final design, aesthetics, materials and functionality of the intended design. The
    functional prototype may be reduced in size (scaled down) in order to reduce costs. The construction of a
    fully working full-scale prototype and the ultimate test of concept is the engineers' final check for design
    flaws and allow last-minute improvements to be made before larger production runs are ordered.
A module is a separate software component. It can often be used in a variety of applications and functions with
other components of the system. Similar functions are grouped in the same unit of programming code and separate
functions are developed as separate units of code so that the code can be reused by other applications.
                                                      19
MODULE TITLE:        Designing Program Logic
Object-oriented programming (OOP) is compatible with the modular programming concept to a large extent.
Modular programming enables multiple programmers to divide up the work and debug pieces of the program
independently.
The benefits of using modular programming include:
The Scope Statement is an essential element of any project. Project managers use the Scope Statement as a written confirmation of
the results your project will produce and the constraints and assumptions under which you will work. Both the people who requested
the project and the project team should agree to all terms in the Scope Statement before actual project work begins.
    Justification: A brief statement regarding the business need your project addresses. (A more detailed discussion of the
     justification for the project appears in the project charter.)
    Product scope description: The characteristics of the products, services, and/or results your project will produce.
    Acceptance criteria: The conditions that must be met before project deliverables are accepted.
    Deliverables: The products, services, and/or results your project will produce (also referred to as objectives).
    Project Exclusions: Statements about what the project will not accomplish or produce.
    Constraints: Restrictions that limit what you can achieve, how and when you can achieve it, and how much achieving it can
     cost.
    Assumptions: Statements about how you will address uncertain information as you conceive, plan, and perform your project.
                                                                      20
MODULE TITLE:     Designing Program Logic
2.4 Identifying and revising references for tables, inputs, outputs other programs
21