Unit 1 Project Structure
Unit 1 Project Structure
Unit 1 Project Structure
1.0 INTRODUCTION
The project report should be documented with an engineering approach to the solution
of the problem that you have sought to address. The project report should be prepared
in order to solve the problem in a methodical and professional manner, making due
references to appropriate techniques, technologies and professional standards. You
should start the documentation process from the first step of software development so
that you can easily identify the issues to be focused upon in the ultimate project
report. You should also include the details from your project notebook, in which you
would have recorded the progress of your project throughout the course. The project
report should contain enough details to enable examiners to evaluate your work. The
details, however, should not render your project report as boring and tedious. The
important points should be highlighted in the body of the report, with details often
relegated to appendices. This unit covers all the details on the structure of mini project
report contents; it also contains detailed explanations on each of these contents.
1.1 OBJECTIVES
After going through this unit, you should be able to:
The project report is an extremely important aspect of the project. It serves to show
what you have achieved and should demonstrate that:
5
Elements of Project • You understand the wider context of computing by relating your choice of the
Development
project, and the approach you take, to existing products or research.
• You can apply the theoretical and practical techniques taught in the course to
the problem you are addressing and that you understand their relevance to the
wider world of computing.
• You are capable of objectively criticising your own work and making
constructive suggestions for improvements or further work based on your
experiences so far.
• You can explain your thinking and working processes clearly and concisely to
others through your project report.
Title Page
CHAPTER 1: INTRODUCTION
1.1 Background
1.2 Objectives
1.3 Purpose, Scope, and Applicability
1.3.1 Purpose
1.3.2 Scope
1.3.3 Applicability
1.4 Achievements
1.5 Organisation of Report
6
4.2 Data Design Project Structure
4.2.1 Schema Design
4.2.2 Data Integrity and Constraints
4.3 Procedural Design
4.3.1 Logic Diagrams
4.3.2 Data Structures
4.3.3 Algorithms Design
4.4 User interface design
4.5 Security Issues
4.6 Test Cases Design
CHAPTER 7: CONCLUSIONS
7.1 Conclusion
7.2 Limitations of the System
7.3 Future Scope of the Project
REFERENCES
GLOSSARY
APPENDIX A
APPENDIX B
7
Elements of Project Abstract
Development
This should be one/two short paragraphs (100-150 words total), summarising the
project work. It is important that this is not just a re-statement of the original project
outline. A suggested flow is background, project aims and main achievements. From
the abstract, a reader should be able to ascertain if the project is of interest to them
and, it should present results of which they may wish to know more details.
Acknowledgements
This should express your gratitude to those who have helped you in the preparation of
your project.
Table of Contents: The table of contents gives the readers a view of the detailed
structure of the report. You would need to provide section and subsection headings
with associated pages. The formatting details of these sections and subsections you
will find in unit 2 of this block.
Table of Figures: List of all Figures, Tables, Graphs, Charts etc. along with their
page numbers in a table of figures.
Chapter 1: Introduction
The introduction has several parts as given below:
Background: A description of the background and context of the project and its
relation to work already done in the area. Summarise existing work in the area
concerned with your project work.
Objectives: Concise statement of the aims and objectives of the project. Define
exactly what you are going to do in the project; the objectives should be about 30 /40
words.
• Applicability: You should explain the direct and indirect applications of your
work. Briefly discuss how this project will serve the computer world and
people.
Achievements: Explain what knowledge you achieved after the completion of your
work. What contributions has your project made to the chosen area? Goals achieved -
describes the degree to which the findings support the original objectives laid out by
the project. The goals may be partially or fully achieved, or exceeded.
8
Chapter 2: Survey of Technologies Project Structure
In this chapter Survey of Technologies you should demonstrate your awareness and
understanding of Available Technologies related to the topic of your project. You
should give the detail of all the related technologies that are necessary to complete
your project. You should describe the technologies available in your chosen area and
present a comparative study of all those Available Technologies. Explain why you
selected the one technology for the completion of the objectives of your project.
Requirements Specification: In this phase you should define the requirements of the
system, independent of how these requirements will be accomplished. The
Requirements Specification describes the things in the system and the actions that can
be done on these things. Identify the operation and problems of the existing system.
Software and Hardware Requirements: Define the details of all the software and
hardware needed for the development and implementation of your project.
Conceptual Models: You should understand the problem domain and produce a
model of the system, which describes operations that can be performed on the system,
and the allowable sequences of those operations. Conceptual Models could consist of
complete Data Flow Diagrams, ER diagrams, Object-oriented diagrams, System
Flowcharts etc.
Basic Modules: You should follow the divide and conquer theory, so divide the
overall problem into more manageable parts and develop each part or module
separately. When all modules are ready, you should integrate all the modules into one
system. In this phase, you should briefly describe all the modules and the functionality
of these modules.
9
Elements of Project
Development
Data Design: Data design will consist of how you organise, managing and manipulate
the data.
• Schema Design: Define the structure and explanation of schemas used in your
project.
• Data Integrity and Constraints: Define and explain all the validity checks and
constraints you are providing to maintain data integrity.
• Logic Diagrams: Define the systematical flow of procedure that improves its
comprehension and helps the programmer during implementation. e.g.,
Control Flow Chart, Process Diagrams etc.
• Data Structures: Create and define the data structure used in your procedures.
• Algorithms Design: With proper explanations of input data, output data, logic
of processes, design and explain the working of algorithms.
User Interface Design: Define user, task, environment analysis and how you intend
to map those requirements in order to develop a “User Interface”. Describe the
external and internal components and the architecture of your user interface. Show
some rough pictorial views of the user interface and its components.
Security Issues: Discuss Real-time considerations and Security issues related to your
project and explain how you intend avoiding those security problems. What are your
security policy plans and architecture?
Test Cases Design: Define test cases, which will provide easy detection of errors and
mistakes with in a minimum period of time and with the least effort. Explain the
different conditions in which you wish to ensure the correct working of your software.
Coding Details and Code Efficiency: Students not need include full source code,
instead, include only the important codes (algorithms, applets code, forms code etc).
The program code should contain comments needed for explaining the work a piece of
code does. Comments may be needed to explain why it does it, or, why it does a
particular way.
You can explain the function of the code with a shot of the output screen of that
program code.
• Code Efficiency: You should explain how your code is efficient and how you
have handled code optimisation.
10
• Unit Testing: Unit testing deals with testing a unit or module as a whole. This Project Structure
would test the interaction of many functions but, do confine the test within
one module.
• Integrated Testing: Brings all the modules together into a special testing
environment, then checks for errors, bugs and interoperability. It deals with
tests for the entire application. Application limits and features are tested here.
Modifications and Improvements: Once you finish the testing you are bound to be
faced with bugs, errors and you will need to modify your source code to improve the
system. Define what modification you implemented in the system and how it
improved your system.
Test Reports: Explain the test results and reports based on your test cases, which
should show that your software is capable of facing any problematic situation and that
it works fine in different conditions. Take the different sample inputs and show the
outputs.
User Documentation: Define the working of the software; explain its different
functions, components with screen shots. The user document should provide all the
details of your product in such a way that any user reading the manual, is able to
understand the working and functionality of the document.
Chapter 7: Conclusions
Limitations of the System: Explain the limitations you encounterd during the testing
of your software that you were not able to modify. List the criticisms you accepted
during the demonstrations of your software.
Future Scope of the Project describes two things: firstly, new areas of investigation
prompted by developments in this project, and secondly, parts of the current work that
were not completed due to time constraints and/or problems encountered.
REFERENCES
It is very important that you acknowledge the work of others that you have used or
adapted in your own work, or that provides the essential background or context to
your project. The use of references is the standard way to do this. Please follow the
given standard for the references for books, journals, and online material.
GLOSSARY
If you use any acronyms, abbreviations, symbols, or uncommon terms in the project
report then their meaning should be explained where they first occur. If you go on to
use any of them extensively then it is helpful to list them in this section and define the
meaning.
APPENDICES
11
Elements of Project In particular, if there are technical details of the work done that might be useful to
Development
others who wish to build on this work, but that are not sufficiently important to the
project as a whole to justify being discussed in the main body of the project, then they
should be included as appendices.
1.5 SUMMARY
Project development usually involves an engineering approach to the design and
development of a software system that fulfils a practical need. Projects also often form
an important focus for discussion at interviews with future employers as they provide
a detailed example of what you are capable of achieving. In this course you can
choose your project topic from the lists supplied in Unit 4: Category-wise Problem
Definition. The next Unit Guidelines and Suggestions will provide you detailed
guidelines and suggestions, which will be useful for you during project development
and the preparation of the report.
1. Modern Systems Analysis and Design; Jeffrey A. Hoffer, Joey F. George, Joseph
S. Valacich; Pearson Education; Third Edition; 2002.
5. http://www.sce.carleton.ca/squall.
6. http://en.tldp.org/HOWTO/Software-Release-Practice-
HOWTO/documentation.html.
7. http://www.sei.cmu.edu/cmm/
12