KEMBAR78
CS-217 Object Oriented Programming Course Outline | PDF | Relational Model | Databases
0% found this document useful (0 votes)
162 views54 pages

CS-217 Object Oriented Programming Course Outline

Uploaded by

usman.javed4076
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
162 views54 pages

CS-217 Object Oriented Programming Course Outline

Uploaded by

usman.javed4076
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 54

NATIONAL UNIVERSITY

of Computer & Emerging Sciences, Lahore

Department of Computer Science


CS-217 – Object Oriented Programming
Spring 2023
Instructor Name: Samin Iftikhar TA Name:
Email address: Samin.iftikhar@nu.edu.pk Email address:
Office Location: Exam Hall
Office Hours: Tue-Thurs: 11-12

Course Information
Program: BS (CS)
Credit Hours: 3 + 1 for Lab
Type: Core
Class Venue: CS - 3
Pre-requisites: Programming Fundamentals (CS-118)

Course Description/Objectives/Goals:
The core objectives of this course are to introduce,
● Object oriented programming with data abstraction and encapsulation.
● The classes, objects and relationship among different objects and classes in C++?
● Generic programming using templates, and template specializations.

Course Learning Outcomes (CLOs):


At the end of the course students will be able to:
Demonstrate the basic concepts of OOP
Apply OOP concepts (Encapsulation, Inheritance, Polymorphism, Abstraction)
to computing problems for the related program
Model an algorithmic solution for a given problem using OOP
Apply good programming practices

Course Textbooks:
th
1. C++ Programming: Program Design Including Data Structures, by D. S. Malik (8 Edition)
th
2. C++: How to Program? by Deitle & Deitle (9 Edition)
Additional references and books related to the course:
3. Problem Solving with C++, by Walter Savitch
4. https://www.learncpp.com

Course Contents Weekly and Lecture-wise Breakdown


Week Topic Lecture-1 Lecture-2
1 Pointers Introduction, Pointer variables Use of Constant with Pointers.
and Initialization, Address of Operator, Difference between a Pointer and a
Dereferencing Operator. Pointer Reference.
Operations (Relational, Arithmetic) Passing pointers to functions by value and
by reference.
2 Dynamic memory allocation using pointers Dynamic 1- dimensional arrays, Create,
and accessing dynamic memory. Dynamic Delete, Grow and Shrink.
Pointers
Variables new and delete operators. Example of programs using 1D dynamic
allocation: e.g., mathematical sets union
and intersection.
3 Memory Leak and Dangling Pointers, Pointers Indirection. Dynamic 2D,
Dynamic 1- dimensional char arrays for allocation, matrices, CStrings etc.
strings, string operations like search,
concatenation etc.
4 Structured Programming vs Object- Objects vs Class, state vs behavior, access
oriented Programming, Principles of specifiers (Public, Private), Member
modularization, abstraction and functions (accessors, utilities, mutators etc)
Object-oriented encapsulation.
basics
5 Constructors (default, overloaded), Dynamic memory allocation and Object
Function overloading. assignment, Parameter passing, Shallow vs
Deep copy,
6
Mid Term 1
7 Cascaded function calls, static members,
Object-oriented Copy constructor, Destructors, this
inline functions and other miscellaneous
basics pointer,
issues
8 Unary operators using member functions Binary operators using member functions
Operator
9 Binary operators using non-member Unary operators, Pre and post increment,
overloading
functions, concept of friendship, subscript operator.
10 Part-whole relationships, Composition
Object and Class Association/Aggregation Implementation issues (constructor call
relationships sequence, initializer list, etc)
11 Inheritance basics, Type of Inheritance, Function Overriding and sub-typing details
public, protected, private.
12
Mid Term 2
13 Polymorphism introduction Static vs Polymorphism vs down casting, run-time
dynamic binding details, virtual tables and type identification, dynamic cast
virtual pointers,
14 Object and Class Pure-virtual functions, Abstract classes, Multiple Inheritance and Diamond Problem
relationships Interfaces (optional) Multiplicity, Memory Management
Bi-directional relationships, Forward-class
declarations issues

15 Generic Template functions Template classes


Programming Template Specializations,
16
& Exception Handling.
Exception
Handling.
(Tentative) Grading Criteria:
1. Assignments + Project (15 %)
2. Quizzes (10 %)
3. Midterms (30 %)
4. Final Exam (45 %)

● Grading scheme for this course is Absolute under application of CS department's grading
policies.
● Minimum requirement to pass this course is to obtain at least 50% absolute marks

Course Policies:
o All assignments and homework must be done individually.
o Late Submissions of assignments will not be accepted.
o No retake of quizzes
o Plagiarism in any work (Quiz, Assignment, Midterms, Project and Final Exam) from any
source, Internet or a Student will result in deduction of absolute marks or F grade.
o Minimum 80% attendance is required for appearing in the Final exams.
Computer Networks-CS3001
Fall 2022

Course Outline

Instructor: Dr. Arshad Ali TA Name Ayesha Kanwal


Email: arshad.ali@lhr.nu.edu.pk Email: l190902@lhr.nu.edu.pk
Office location: Faculty Office (C-140) Civil Building LAB Instructor: Mr. Salman Shoaib
Office Timings: Monday & Wednesday after 2:30 pm Email: salman.shoaib@nu.edu.pk
LAB Instructor:
Email:
Course Information
Program: BS Course website: Google Classroom
Credit hours: 3+1 (LAB) Class Venue: CS-5 / Google Meet
Type: Core Pre-requisites: CS218 Data Structures, CL 218
Class meeting time: Sec 5C: Monday, Wednesday: 11:30 am – 01:00 pm
Sec 5D: Monday, Wednesday: 1:00 am – 02:30 pm

Objective of the Course


The objective of this course is to introduce the principles and practices of Computer Networking, specifically focusing
on the Internet. By the end of the course, students should be able to:
• Understand the anatomy of the Internet
• Understand fundamental layered structure, understand common offered layered services, examine protocols and
algorithms used to operate the network
• Create foundation for more advanced courses in computer networks
• Be able to write networking application with Socket programming in C/C++
• Design and test networks on network designing tools
• Simulate existing protocols along with designing new protocols in network simulators

Course Learning Outcomes


The objective of this course is to introduce the principles and practices of Computer Networking, specifically focusing
on the Internet. By the end of the course, students should be able to achieve the following CLOs:

CLO# CLO description BT Domain/ PLO #


BT Level
Describe the key terminologies and technologies of computer
CLO 1 C2 PLO 1
networks

CLO 2 Explain the services and functions provided by each layer in C2 PLO 1
the Internet protocol stack
C4
CLO 3 Identify and analyze various internetworking devices and PLO 2
protocols, and their functions in a network

CLO 4 Analyze working and performance of key technologies, C4 PLO 2


algorithms, and protocols

CLO 5 Build Computer Network on various Topologies P3 PLO 5


Text Book
Computer Networking: A Top Down approach featuring the Internet, 6th Edition James F. Kurose and Keith W. Ross

Reference book
Computer Networks, 5th Edition Andrew Tanenbaum
Data Communications and Networking, 4th Edition Behrouz A. Forouzan

Course Outline

Module No. Of Lectures Reference Text


Introduction and Overview 4 Chapter 1
Basic Concepts of Networking Supplement text
Circuit switching Packet switching from Forouzan
Multiplexing (TDM, FDM)
Throughput, Loss and delay
Internet Architecture
Protocol Layering
Application Layer 4 Chapter 2
Network application architectures
HTTP, FTP, Email, DNS
Basics of P2P applications

Transport Layer 7 Chapter 3


Multiplexing in UDP and TCP
Connectionless Transport: UDP
Reliable data transfer and TCP
Congestion avoidance and control
Network Layer 8 Chapter 4
The Internet Protocol
Routing algorithms
Routing protocols
Broadcasting and Multicasting
Link Layer and MAC Layer 5 Chapter 5
Functionalities Supplement text
Error Detection & Control, ARP from Tenanbaum
Link layer addressing
Bridges and Hubs LAN
Technologies
Multiple Access
Advanced Topics (subject to availability Chapter 7
of time) Supplement text
Introduction to Internet of things from Tenanbaum/
Multimedia networking Applications Network security:
Introduction to Network Security and private
Principles of Cryptography communication in
Introduction to 1 G, 2G and 3G a public world by
Radia Perlman

[Subject to the
availability of the
time]
Evaluation (Subject to change)
Assignments (4 to 6) 10%
Quizzes (4 to 6) 15%
Mid Exams (2) 30% (15% + 15%)
Final Exam (1) 45%
Total: 100 %

Grading Policy
Absolute Grading Scheme
Course Policies
• Course outline may change 10-20% as we proceed in the semester
• Important: It is strived & intended to have uniform & similar weightages of different course components &
grade assigning policy across all the sections for this course for the semester, but there may be variations owing
to various factors, for example different number / types of assessments like assignments, homework, quizzes
and/or projects.
• Assignment deadlines for both class and lab are hard.
• Quizzes might be announced or unannounced.
• There will be no re-take of quizzes or exams. Special consideration may be given only for mid or final exam
for an emergency on per case basis subject to approval from the department administration & the instructor.
• Integrity in the assignments/quizzes is expected; otherwise, result would be an F grade in the course, or the case
may be forwarded to the Disciplinary Committee.
• The lectures will be of 1.5 hours duration + there will be one 3 hours lab/week.
• (80%) Attendance for the student is a MUST which needs to be ensured according to the University policy to
avoid disqualification.
• You may request an appointment according to my schedule by emailing me on the email.
NATIONAL UNIVERSITY
of Computer & Emerging Sciences, Lahore

Department of Computer Science


CS302 – Design and Analysis of Algorithms
SPRING 2023
Instructor Name: Dr. Tahir Ejaz
Office Location/Number: C-137 (Civil Engineering Building)
Office Hours: Mondays, Wednesdays, and Fridays: 3:00-4:00 PM

Course Information
Program: BSCS Credit Hours: 3 Type: Core
Pre-requisites: Data Structures

Course Description:
The objective of this course is not to fill your brains with every algorithm that you would ever need. One
of the aims of this course is to teach you to reason about algorithms and describe them. In addition,
many known algorithms to solve known problems will be taught. At the end of the course, you should
be able to choose an appropriate algorithm from a set of algorithms for a given problem.

Course Learning Outcomes (CLOs):


1. Design algorithms using different algorithms design techniques
i.e., Brute Force, Divide and Conquer, Dynamic Programming, Greedy
Algorithms and apply them to solve problems in the domain of the
program
2. Analyze the time and space complexity of different algorithms by
using standard asymptotic notations for recursive and non-recursive
algorithms
3. Evaluate the correctness of algorithms by using theorem proving
or executing test cases

Course Textbook
• Introduction to Algorithms by Cormen, Leiserson, Rivest, and Stein, 3rd Ed., MIT Press, 2001.

Additional references and books related to the course:

• Jon Kleinberg, Éva Tardos, Algorithm Design, Pearson/Addison-Wesley


• Sanjoy Dasgupta, Christos Papadimitriou, Umesh Vazirani, Algorithms, McGraw-Hill Education
• Algorithms in C++ by Robert Sedgewick, Addison-Wesley, 1992.
• Data Structures and Algorithms by Aho, Hopcroft, and Ullman.
Weekly Schedule

Lectures Description Chapters of Text

Week -1 The role of algorithms in computers, Asymptotic 1, 2, 3


functions and notations (Big-oh, big-omega,
theeta) best and worst case time complexity
Week – 2, 3, 4 Divide and Conquer (maximum subarray sum, 2, 3, 4, 7
counting inversions, quicksort, merge sort) +
Solving recurrences
Week – 5 Lower bound for comparison based sorting, Sorting 8
in linear time: Count Sort, radix sort
Midterm – I
Week – 6,7 Dynamic Programming ( maximum subarray, rod 15
cutting, longest common subsequence, binary
knapsack)
Week – 8, 9 Greedy Algorithms (Activity selection, fractional 16
knapsack and Huffman codes)
Week – 10 Introduction to graphs (revision of BFS, DFS) and 22
their application (topological sort, strongly
connected components)
Midterm – II
Week – 11 Minimum Spanning Trees (MST)(Prim's Algorithm 23
and Kruskal's Algorithm)
Week – 12, 13 Shortest Path Algorithms (Dijkstra's Algorithm, 24
Bellman-Ford and Floyd Warshall Algorithm
Week 14 Misc. Topics
Final Exam Comprehensive

Grading Criteria
1. Quizzes (15%)
2. Assignments (10%)
3. Midterm Exams (30%)
4. Final Exam (45%)

Grading Policy
Absolute Grading

Course Policies
1. Quizzes will be announced.
2. No makeup for missed quizzes and assignments.

Academic Integrity: All work MUST be done individually. Any copying of work from other person(s) or
source(s) (e.g., the Internet) will automatically result in at least an F grade in the course. It does not
matter whether the copying is done in an assignment, quiz, midterm exam, or final exam, it will be
considered equally significant.
NATIONAL UNIVERSITY
of Computer & Emerging Sciences, Lahore

F A S T S c h o o l o f C o m p u t i n g
AI2002 – Artificial Intelligence
Spring 2023
Instructor Name: Abeeda Akram TA Name: Ali Haider
Email: abeeda.akram@nu.edu.pk TA Email: l192327@lhr.nu.edu.pk
abeeda.akram@lhr.nu.edu.pk
Office Location: Old-Admin Block Exam Hall
Office Hours: Wednesday 11:30 to 1:00 PM, Friday 1:00 PM to 3:00 PM

Course Information
Program: BS(CS) Credit Hours: 3 and (1 for Lab) Type: Core Pre-requisites: Data Structures
Class Venue: E&M-16
Class Time: BCS-6E Wed-Fri 10:00 – 11:30
BCS-6F Wed 1:00 - 2:30 PM, Fri 11:30 - 1:00 PM

Course Learning Outcomes (CLOs):


The course learning outcomes of this course are:
1. Understand principles and techniques of artificial intelligence
2. Identify the problems and their solutions with respect to intelligent solutions
3. Model a solution for a given problem using artificial intelligence tools and techniques
4. Examine latest trends in AI and its applications
5. Able to propose and implement AI based state of the art solutions

Course Textbooks:
1. Stuart Russell, Peter Norvig - Artificial Intelligence a Modern Approach - (3rd Edition)
Additional references and books related to the course:
2. George F. Luger - Artificial Intelligence
3. Tom Mitchell Machine Learning

(Tentative) Grading Criteria:


Assignments (10%) Quizzes (10%) Project (10%) Midterms (25%) Final Exam (45%)
• Grading scheme for this course is Absolute under application of CS department's grading policies.
• Minimum requirement to pass this course is to obtain at least 50% absolute marks.

Course Policies:
• Quizzes may be announced or surprised. No Late Submissions or Makeup Quizzes.
• Students bear all the responsibility for protecting their assignments. In case of cheating, both parties
will be considered equally responsible.
• Plagiarism in any work (Labs, Quiz, Assignment, Midterms, and Final Exam) from any source,
Internet or a Student will result in F grade or deduction of absolute marks.
• 80% attendance is required for appearing in the Final exams.
Tentative Weekly Schedule
Topic Details Weak
− Introduction and Applications 1
− Knowledge and Reasoning
Introduction − Blocks world and Predicate Calculus
− Introduction to Agent and Agent Architectures
− PEAS
Blind/Uninformed/Brute-force Search 2
− Depth First Search (DFS)
− Breadth First Search (BFS)
− Iterative Deepening Search (IDS)
− Uniform Cost Search (UCS)
Direction of Search, Branching Factor
Heuristic/Informed Search 3
− Hill Climbing Search
− Best First Search
Strategies for − Algorithm A
State Space − A* Search
Search Informedness, Monotonicity, Admissibility, Optimality, Completeness,
Adversarial Search Algorithms (Game Playing) 4
− Minimax Search
− Alpha-Beta Pruning
− Evaluation Functions
− Move generators and evaluators
Problem Solving by Searching
Evolutionary Search: 5
− Genetic Algorithm
− Genetic Programming
− Automatic/Evolutionary Programming
Classification (ANN) 6-7
− Architecture: Feed-Forward Neural Network and Recurrent Network
− Activation Functions
− Types of Problems for Neural Networks
− Training Algorithms
Introduction − Perceptron Learning Rule
to Machine − Hebb Learning Rule
Learning, − Back Propagation Algorithm (Gradient Descent Learning)
Data Mining, − Issues of ANN
& Data − Recurrent Networks (Elman and Jordon)
Science Clustering 8-9
− k-means and k-medoids algorithm
− Cobweb
Regression 10-11
− Simple and Multiple Linear Regression
− Attribute/Feature Selection
− WEKA - Assignment
NATIONAL UNIVERSITY
of Computer & Emerging Sciences, Lahore

Department of Computer Science


EE-2003 – Computer Organization and Assembly Language
FALL 2023
Instructor Name: Aatira Anum Ahmad
Email address: aatira.anum@lhr.nu.edu.pk
Office Location/Number: Opposite Lab 4
Office Hours: Friday 11:00 am -1:00 pm

Course Information
Program: BS Credit Hours: 3 Type: Core
Pre-requisites (if any): DLD

Program Learning Outcomes:

PLO# PLO Name Description


2 Knowledge for Solving Apply knowledge of computing
Computing Problems fundamentals, knowledge of a
computing specialization, and
mathematics, science, and domain
knowledge appropriate for the
computing specialization to the
abstraction and conceptualization of
computing models from defined
problems and requirements.
3 Program Analysis Identify, formulate, research
literature, and solve complex
computing problems reaching
substantiated conclusions using
fundamental principles of
mathematics, computing sciences,
and relevant domain disciplines.
4 Design/Development of Design and evaluate solutions for
Solutions complex computing problems, and
design and evaluate systems,
components, or processes that meet
specified needs with appropriate
consideration for public health and
safety, cultural, societal, and
environmental considerations.
Course Learning Outcomes:

Course Learning Outcomes (CLOs) BT PLO Mapping


Level
1. Demonstrate the basic concepts of computer C2 2
organization including CPU, memories, and
input/output and explain their purposes and
interactions.
2. Describe the working of important x86 assembly C2 2
primitives, including arithmetic, branching, bit
manipulation, addressing modes and interrupt
handling.
3. Apply the knowledge of Intel x86 architecture to C3 4
develop moderately complex and well-modularized
assembly programs.
4. Analyze the performance enhancement of a C4 3
processor via cache and pipelining features.

Course Textbook
• Assembly Language Programming Lecture Notes by Bilal Hashmi.
• Assembly Language for x86 Processors Seventh Edition Kip R. Irvine
• Computer Organization and Architecture Designing for Performance Tenth Edition by William
Stallings (WS)
• David A. Patterson, John L. Hennessy, Computer Organization and Design: The
hardware/software interface, 4th Edition

Tentative Lecture Plan


Week Topics to be covered
1 Introduction to Assembly Language
2 Addressing Modes
3 Branching
4 Bit Manipulations
5 Subroutines
Midterm 1
6 Display Memory
7 String Instructions
8 Software Interrupts
9 Real Time Interrupts and Hardware Interfacing
10 Multitasking (Optional)
Midterm 2
11-14 Computer Architecture, Pipelining, Cache, Performance
(Tentative) Grading Criteria

1. Quizzes 10
2. Midterms 30
3. Final 45
4. Assignments/Project 15

Grading Scheme: Absolute

Course Policies
1. Quizzes may be un-announced.
2. No makeup for missed quiz or assignment.
3. 80% attendance
4. 50% passing marks

Academic Integrity
• Plagiarism and Cheating against academic integrity. Both parties involved in such cases will
face strict penalty (negative marking, F grade, DC)
• CODE/ ASSIGNMENT SHARING is strictly prohibited.
• Keep in mind that by sharing your code/assignment you are not helping anyone rather
hindering the learning process or the other person.
• No excuse will be entertained if your work is stolen or lost. To avoid such incidents
• Keep backup of your code on safe online storage, such as Google Drive, Dropbox or
One drive.
• Do not leave your work on university lab computer, transfer your work to online
storage and delete from the university lab computer (empty recycle bin as well)

Course Policies
1. Announcements related to different aspects of this course (e.g., lectures, quizzes, exams, etc.)
may be posted on SLATE (http://slate.nu.edu.pk/portal) and google classroom. Students are
expected to view the announcements section of SLATE and google classroom regularly.
2. All students are expected to attend all lectures from beginning to end. Partial or full absence
from a lecture without a valid reason may hamper chances for securing good grades.
University’s attendance requirements must be met in order to appear in the final exam.
3. Quizzes may be announced or unannounced. A quiz will usually be about 5 – 15 minutes long
and it may be given anytime during the lecture. Students missing a quiz will NOT be given a
make-up quiz.
4. Students can contest their grades on quizzes and assignments ONLY within a week of the
release of grades. Exams will be available for review according to university policies.
5. Students are expected to demonstrate the highest degree of moral and ethical conduct. Any
student caught cheating, copying, plagiarizing, or using any other unfair means will be strictly
dealt-with in accordance with university policies.
Software Engineering Course Outline

FAST-NU, Lahore
Course Code CS3009

Semester Spring 2022

Course Title Software Engineering

Credit Hours 3

Prerequisite OOAD

Grading Absolute

Class and Exam Schedule Class: Sec 6F (08:30-09:50 Tue & Fri)

Exam: See date sheet

Course Instructor Raheel Ahmad


raheel.ahmad@lhr.nu.edu.pk

Instructor Office Hours Tue & Fri (09:50 – 10:30)

Faculty Room

Course TA TBD

TA Office Hours TBD

Plagiarism Policy All the parties involved will be awarded negative or Zero in first
instance. Repeat of the same offense will result in (F) grade.

Textbook(s) 1. Software Engineering: A Practitioner’s Approach by Roger


Pressman (Selected Chapters)
2. Software Engineering by Ian Sommerville (Selected Chapters)
3. Software Engineering: Theory and Practice by Shari PFleeger and
Atlee (Selected Chapters)

Reference Material Will be provided as per requirement of the lecture

Course Goals  Familiarize the students with the term, “software


engineering,” and explain its meaning and importance.
 Introduce well‐ known software development process
models, their key practices, and their salient features to
students.
 Familiarize the students with common method (for example,
UML diagrams) to specify the requirements of a moderately
sized software product.
 Specify responsibilities of a Software Engineer to students
 Explain the steps involved in modeling of requirements
 Give the details required to design software
Learning Outcomes After successful completion of the course, the students will be able
to:

1. Differentiate among phases of software development


2. Appreciate the relative advantages and disadvantages of
well‐ known software development process models.
3. Model requirements.
4. Perform high level design of software
5. Describe tasks involved in UI design
6. Perform low level design of software.
7. Distinguish between different types and levels of testing (for
instance, unit, integration, systems, and acceptance) for
medium‐ sized software products.
8. Develop Work Breakdown Structure for a project.
9. Engineer reasonable sized software in team setting
Grading Criteria 1. Quizzes 3-4 (10%)
2. Assignments + Project + Class Activities (30%)
3. Mid Terms (20%)
4. Final Exam (40%)

Important Information Announcements


Announcements related to different aspects of this course (e.g.
lectures, quizzes, exams, etc.) will be posted on class forum (SLATE).
Students are expected to view the announcements section regularly.

Assignment/Project Submission Deadlines


Missed submission of a deliverable by deadline, irrespective of reason
(wrong soft/hard copy submitted/uploaded, absence from class, leave
etc.) will incur penalty starting from 25% marks deduction.

Attendance
All students are expected to attend all lectures from beginning to end.
Partial absence from the class during lecture will result in student
being marked absent.

Office Hours
Students are encouraged to take full advantage of instructor’s office
hours.
In case a student is not able to make it during office hours, he/she may
schedule an appointment with the instructor for another time slot.

Quizzes
Quizzes may be announced or unannounced. A quiz will usually be
about 20 – 30 minutes long and it may be given anytime during the
lecture. Students missing a quiz will NOT be given a make-up quiz or
marked with a course average (unless approved by the Academic
Office).

Revision of Grades
Students can contest their grades on quizzes and project deliverables
ONLY within a week of the release of grades. Exams will be available
for review according to university policies.

Unfair Means
Students are expected to demonstrate the highest degree of moral
and ethical conduct. Any student caught cheating, copying,
plagiarizing or using any other unfair means will be strictly dealt-with
in accordance with university policies.
Programming Assignments Done in Yes
the Course
Tentative Topics and Course Plan (*Course schedule is subject to minor changes)

Lecture
Week # Topics Covered
#

1 Course Introduction. SE Introduction


1
2 SE Introduction

3 Software Process Models


2
4 Software Process Models

5 Software Process Models


3
6 Requirements Engineering

7 Requirements Engineering
4
8 Requirements Engineering

9 Requirements Engineering
5
10 Requirements Engineering

6 Midterm 1 + Project Progress

11 Architecture Design
7
12 Architecture Design

8 13 Architecture Design

14 Architecture Design

15 UI Design
9
16 Detailed Design: Principles

17 Detailed Design: Principles


10 Component Based Design. Component Interfaces and Module
18
Contracts

11 19 Writing Programs
20 Testing

12 Midterm 2 + Project Progress

21 Testing
13
22 Testing

23 Delivering the System


14
24 Project Presentations

25 Project Management
15
26 Project Management

16 Final
NATIONAL UNIVERSITY
of Computer & Emerging Sciences, Lahore

F A S T S c h o o l o f C o m p u t i n g
CS2005 – Database Systems
Fall 2023
Instructor Name: Muhammad Ishaq Raza TA Name: TBA
Email address: ishaq.raza@nu.edu.pk Email address:
Office Location/Number: M-160 Office Location/Number:
Office Hours: Mon, Wed 1:00 - 2:30 PM Office Hours:

Course Information
Program: BS Credit Hours: 3 Type: Core
Pre-requisites (if any): CS2001 - Data Structures
Course Website (if any):
Class Meeting Time: Sec BCS-5A: M, W 11:30 AM BCS-5B: M, W 2:30 PM
Class Venue: CS-3

Course Description/Objectives/Goals
This course is an introduction to relational databases management Systems. The course will cover fundamental
concepts of databases with an emphasis on modeling, designing and implementation of database systems. The
theory will be augmented with hands-on exercises on database system. A project will be conducted in the database
system lab that runs in parallel with the course. In project, the students will develop a data-centric application
with complete set of business transactions and appropriate user interface using a popular programming language
and a popular database management system.

Course Learning Outcomes (CLOs)


At the end of the course students will be able to: Domain BT* Level
Describe how databases store and retrieve information using the basic C 2
concepts and terminology of relational databases.
Create a logical data model from an ER diagram to design a set of DB C 3
relations.
Normalize a set of attributes to eliminate update anomalies or C 4
redundancies from a set of relations.
Implement a logical data model using a DBMS. C 3
Write queries using formal query languages such as relational algebra. C 3
Write SQL statements to query a set of tables in a DBMS involving C 3
multiple conditions, ordering, aggregate functions, grouping, and group
selection, set operations, joins, and nested queries.
Write SQL statements to insert, delete and update a set of tables in a C 3
DBMS.
Write SQL statements to create, alter, drop, and rename a set of tables C 3
in a DBMS.
Write SQL statements to add and drop constraints on a set of tables in a C 3
DBMS.
Create an ER diagram (semantic model) about an enterprise (e.g., retail C 5
industry, airport, school, and library) that correctly describes the
entities, attributes, and relationships among the entities, for some of its
major business functions.
Comprehend the ACID properties of Transactions and recoverability C 2
schedules.
* BT= Bloom’s Taxonomy, C=Cognitive domain, P=Psychomotor domain, A= Affective domain.
Bloom's taxonomy Levels: 1. Knowledge, 2. Comprehension, 3. Application, 4. Analysis, 5. Synthesis, 6. Evaluation

Course Textbook
1. Ramez Elmasri, Fundamentals of Database Systems (7th Edition)

Additional references and books related to the course


1. Raghu Ramakrishnan, Database Management Systems (3rd Edition)
2. C. J. Date, An Introduction to Database Systems (8th Edition)

Tentative Weekly Schedule


Readings No of
Week Topics to be covered Topics Detail Asst.
(Textbook) Lec.

1 Introduction to • Databases and Database Users


Databases • Characteristics of the Database Approach
• Advantages of Using the DBMS Approach Ch 1,2 2
• Data Models, Schemas, Instances
• Architecture and Components of a DBMS

2-3 Relational Data RA SQL


Model
• Relational Model Concepts • Data Definition Statements (DDL)
o Domain, Attributes, Tuples, Relations o Create, Alter, Drop, Rename
o Characteristics of Relations • Specifying Constraints Ch 5, 6 4 A1
• Relational Model Constraints o Attribute, Key, Referential Integrity,
o Domain, Keys, Integrity Tuple-Based Using CHECK
• Update Operations and Dealing with • Data Modification Statements (DML)
Constraint Violation o Insert, Update, Delete

4-6 Formal Query RA SQL


Language: Relational
Algebra and The o Unary Relational Operations o Retrieval Queries
Database Language: o SELECT, PROJECT, RENAME o Basic Queries: SELECT-FROM-WHERE
SQL o Ordering, Arithmetic Operations,
Substring Comparison

o Binary Operations o Set Operations


o Union, Intersection, Difference,
Division A2,
Ch 6, 7, 8 6
A3
o Cartesian Product, JOIN o Joining, Full, outer, inner, Cross
o Outer Join, Outer Union, Full

o Aggregate Functions and Grouping o Aggregate Functions and Grouping

Query Tree o Nested Queries


o Correlated Nested Queries

-- o Views (Virtual Tables), Stores


Procedures, Assertions and Triggers
7-9 Database Design • Design Anomalies
Theory and • Informal Design Guidelines for Relational Databases
Normalization • Functional Dependencies (FDs)
o Convert Business statements into Dependencies
o Armstrong's Inference Rules for FDs
o Algorithm for computing Attribute Closure
o Minimal Cover of FDs Ch 14, 15 6 A4
o Equivalence of Sets of FDs
• Normalization for Relational databases
o Normalization and De-Normalization
o Normal Forms: 1NF, 2Nf, 3NF, BCNF, 4NF, 5NF
• Overview of Relational Database Design Algorithms

10-12 Data Modeling Using • Entity Types, Entity Sets, Attributes, Keys
Entity-Relationship • Relationship Types, Relationship Sets, Roles
(ER) Model • Constraints on Relationship Types
• Relationship Types of Degree Higher than Two
• Enhanced Entity-Relationship (EER) Model Concepts
• Subclasses, Superclasses, Inheritance
• Specialization and Generalization Ch 3, 4 5 A5
• Constraints and Characteristics of Specialization and Generalization
• Shared and UNION Type subclasses

12-13 Relational Database • Mapping ER Model Constructs to Relations


Design by • Mapping EER Model Constructs to Relations
Ch 9 2
ER- and EER-to-
Relational Mapping

13-14 Transaction • Issues in Transaction Processing


Processing Concepts • Why Concurrency Control is Needed
• Why Recovery is Needed
• Transaction States and Operations, System Log, Commit Point of a Transaction
• ACID Properties of Transactions Ch 20 3
• Characterizing Schedules based on Recoverability
• Characterizing Schedules based on Serializability
• Transactions Isolation Levels and Possible Violations
• Basic Two-Phase Locking Technique for Concurrency Control

(Tentative) Grading Criteria


1. Assignments (8%)
2. Quizzes (10%)
3. Class Participation (2%)
4. 2 Midterm Exams (30%)
5. Final Exam (50%)

Grading Scheme: Absolute

Course Policies
1. Quizzes may be un-announced.
2. No makeup for missed quiz or assignment.
3. Minimum eligibility to pass this course is to get 50% marks.

Project
Students will design, implement, demonstrate and document a database system. The project is to be done in
groups of 3/4 students. Pick your partner as soon as possible. The groups are self-policing (e.g. each group is
responsible for its own division of labor, scheduling, etc.). A separate handout will be provided describing the
project requirements in the 2nd Lab of the course.
FAST-NU Fraz Yousaf

Human Computer Interaction Fall 2022


Course Outline

Instructor: Fraz Yousaf (Sections 3A, 3B ,3C)


Contact Hours: 10:00 am – 12:00 pm Monday and Wednesday

Email: fraz.yousaf@nu.edu.pk
Text Books:
1. Human-Computer Interaction (3rd ed.) by Dix, Finlay, Abowd, and Beale (2004)
2. The Usability Engineering Lifecycle by Deborah J Mayhew (1999)
Reference Books:
1. The Design of Everyday Things, by Donald Norman. Currency/Doubleday, 1990
2. Interaction Design: Beyond Human - Computer Interaction (3rd ed.), by Yvonne Rogers, Helen Sharp, Jenny
Preece. Wiley, 2011
3. About FACE 3.0 – The Essential of Interaction Design by Alan Cooper & Robert Reimann (2007)
4. Designing the User Interface: Strategies for Effective Human-Computer Interaction, Ben Shneiderman and
Catherine Plaisant, 4th Edition, Addison-Wesley, 2005.

Course Objectives
1. The course provides an introduction to the fundamentals and dynamics of human-computer interaction. It
requires an understanding of the human behaviour who interacts with a computer system. After studying this
course, the students will:
a. become aware of the golden rules of HCI
b. be able to design and implement effective user interfaces from scratch
c. be able to critically examine and evaluate existing user interfaces

Course Contents
S# Topic Readings
1 Introduction and Overview (Including history of HCI) Introduction
2 The Human Book 1. Chapter 1
3 The Computer (Focusing on latest technology) Book 1. Chapter 2
4 Interaction (Introduction) and Touchscreens, LCDs, 3D Book 1. Chapter 3 + Extra
glasses, accelerometer Material
MIDTERM 1
5 Model of Interaction, Ergonomics and Interaction Styles Book 1. Chapter 3
6 User Profile Book 2. Chapter 2
7 Contextual Task Analysis Book 2. Chapter 3
8 Usability Goals Book 2. Chapter 4
9 Conceptual Model Design Book 2. Chapter 8
10 Navigational & Screen Designs Book 1. Chapter 5
MIDTERM 2
11 Screen Design Standards and Detailed Design Book 2. Chapter 11 and 15
12 Golden Rules Book 1. Chapter 7
13 Model Based Evaluation Extra material
14 Designing for Diversity, Universal design Book 1. Chapter 10
15 Planning and analyzing projects from HCI perspective Extra material

Evaluation:
Quizzes 10% Midterms 30% Assignment/Project 20% Final 40%

Important Notes:
There is no makeup for a missed class test or quizzes. Plagiarism is not tolerable in any of its form. Students bear all the
responsibility for protecting their assignments. In case of cheating, both parties will be considered equally responsible.

1
COURSE OUTLINE
CS4055 - DIGITAL IMAGE PROCESSING (ELECTIVE – 3 CRH)
INSTRUCTOR: DR. SYED ASIF MAHMOOD GILANI (asif.gilani@nu.edu.pk)
OFFICE: GROUND FLOOR (M 014)

For the latest information, study material and handouts please visit at: http://slate.nu.edu.pk/portal

Class Timetable – Spring 2022


Sections Start Date Sessional-I Sessional -II End Date Final Class Office Time
BS(BCS- 14-02-2022 6th Week 12th Week 06-2022 18th Mon & Wed Tue, Thu: 11:00-
6A) Week 8:30-10:00 12:00 Or by
BS(BCS- 14-02-2022 6th Week 12th Week 06-2022 18th Mon & Wed appointment/che
6B) Week 11:30-1:00 pm ck in the office

Digital Image Processing (DIP) Fundamentals; Imparting current trends. A reasonable level of Calculus,
Linear Algebra and Programming background is expected for the course.

The field itself combines ideas from several different areas including Machine Vision/Intelligence, statistics
and computer graphics. The focus of this course will be breadth knowledge acquisition with moderate level
of details of various algorithms and techniques.

This course is an elective for Under/graduate students from both Computer Science and Engineering.

Goals/Objectives
 Introduce the concepts in Digital Image Processing (DIP) and to provide an insight into the
problems, procedures and techniques in the field;
 Discuss the application and state of the art projects and research in DIP;
 To make students learn from programming assignments and get comfortable with DIP based
solutions to various problems. This will develop in them the confidence to deal with DIP
applications;
 Finally term project will be assigned to each/group student to implement and verify the results.

Text and Reference Books


Course Slides and lectures will be the primary reference material taken largely from the following books:

 [Umbaugh] Digital Image Processing and Analysis, Scott E Umbaugh, 2nd Edition, CRC
 [Gonzalez] Digital Image Processing, Gonzalez R.C., Woods R.E.,Pearson Education, 3rd Edition,
 [Castleman] Digital Image Processing, Kenneth R. Castleman, Prentice Hall
 [Parker] practical Computer Vision using C, J. R. Parker, Johan Wiley & Sons Inc.

Reference Web Links


[1]https://books.google.com.pk/books?id=7JXLBQAAQBAJ&printsec=frontcover&dq=Scott+Umbau
gh+books&hl=en&sa=X&redir_esc=y#v=onepage&q=Scott%20Umbaugh%20books&f=false
[2] https://cviptools.ece.siue.edu/
Grading (Tentative)
Instruments Weight
Quiz & Assignments 15%
Project 10%
Midterm 30%
Final 45%
NOTE: GRADING SCHEME WILL BE ABSOLUTE.

INTRODUCTION TO IMAGING  Digital Image Representation


 Fundamental Steps in Image Processing
 Preprocessing
(Week 1-2)
 Introduction and Overview
DIGITAL IMAGE PROCESSING  Image Fidelity Criteria
AND VISUAL PERCEPTION • Objective Fidelity Measures
• Subjective Fidelity Measures
(Week 3-4)
 Introduction and Overview
IMAGE ENHANCEMENT  Gray-Scale Modification
o Mapping Equations
o Histogram Modification
(Week 5-8) o Adaptive Contrast Enhancement
o Color
 Image Sharpening
o Highpass Filtering
o High Frequency Emphasis
o Directional Difference Filters
o Homomorphic Filtering
o Unsharp Masking.
o Edge Detector–Based Sharpening
Algorithms
 Image Smoothing
o Frequency Domain Lowpass Filtering
o Convolution Mask Lowpass Filtering
o Nonlinear Filtering

 Introduction and Overview


• System Model
 Noise Model
IMAGE RESTORATION AND • Noise Histograms
RECONSTRUCTION • Periodic Noise
• Estimation of Noise
(Week 9-11)  Noise Removal Using Spatial Filters
• Order Filters
• Mean Filters
• Adaptive Filters
 Introduction and overview
IMAGE COMPRESSION • Compression System Model
• Lossless Compression Methods
 Lossy Compression Methods
(Week 12-15)

Note:

 Assignments, Quizzes and projects should be done independently, in case of Plagiarism, the student will be
graded zero without any notice;
 The decorum of the class should be maintained at all times otherwise a severe penalty should be expected
but the class participation will be valued open-heartedly;
 The students are encouraged to discuss subject problems even beyond class timings.

BEST WISHES
Department of Computer Science
National University of Computer and Emerging Sciences
Lahore Campus

Course Outline Digital Logic Design EE1005


Spring 2023
Instructor Name: Tazeem Haider
Email address: tazeem.haider@nu.edu.pk
Program: BS
Credit Hours: 3+1
Type: Core
Course Group: DLD-Spring 2023
Class Code:
TA:
Office Hours: Tuesday 11:30 to 12:30, Wednesday 2:00 – 3:00pm
Class timings: Monday & Wednesday 10:00-11:30 (Section A)
Tuesday & Thursday 01:00-2:30 (Section B)
Monday & Wednesday 11:30-01:00 (Section C)
Course Description/Objectives/Goals:
This course introduces the fundamentals of digital computers. It covers the design and
analysis techniques for digital circuits – combinational as well as sequential.

Course Learning Outcomes (CLOs):


1. Understand different number systems and their conversion.
2. Recognize and use basic gates to implement logic circuits
3. Constructs optimized logic circuit design
4. Construct and utilize the basic functional blocks to design combinational circuits
5. Design and demonstrate synchronous/ asynchronous

Textbook Name: M. Morris Mano & Charles R. Kime, Logic and Computer Design
Fundamentals Edition: (5th Edition Updated, Prentice Hall)

Additional Reference Material Used (if any):


1. John F. Wakerly, Digital Design: Principles and Practices (5th Edition,
Pearson Education, 2001)
2. Thomas L. Floyd, Digital Fundamentals (7th Edition, Prentice Hall, 2000)

Percentage Grade Distribution:


QUIZZES 15%
MIDTERMS 30%
FINAL 45%
ASSIGNMENTS 10%
Lec.No. Course Contents Covered
1. Information Representation, Digital Computer
1 2. Number Systems (Binary, Octal, Hex) and Conversions
3. Data Ranges, Conventions (KB, MB, GB)
1. BCD
2. ASCII Code
2 3. Parity Bit
4. Arithmetic Operations (Addition, Subtraction using borrow method,
Multiplication)
1. Signed Unsiged Binary Numbers
2. Signed Magnitude Representation
3 3. 2’s Complement Representation
4. 1’s Complement
5. Subtraction using 2’s Complement
1. Logic Gates
2. Timing Diagram
3. Gate Delay
4. Boolean Equation, Logic Circuit, Truth Table
4
5. Boolean Identities and Laws (Commutative etc.)
6. Dual and Duality Principle
7. Proof of Distributive Law and Consensus Theorem
8. Complementing Function using DE Morgan’s Law and Dual
1. Boolean Functions and their implementation
 Definition of Combinational logic circuit.
 Examples of making truth table and circuit diagram from Boolean
equation.
2. Dual of a function
5
3. Complement of a function
4. Dual vs complement
5. Practice of questions reducing to particular number of literals.
6. Implementing functions with only OR and NOT gates.
7. Implementing functions with only AND and NOT gates.
1. Canonical and Standard Forms (Minterms, Maxterms, Conversions)
 How to write minterms/maxterms from truth table
 Writing a function in terms of its minterms/maxterms
6
 Properties of minterms /maxterms.
2. Literal cost
3. Gate input cost
1. Minimization of Boolean functions using K-Map
 How to build table and why there should be a difference of 1
7 between 2 cells?
 2 variables
 3 variables
1. Minimization of Boolean functions using K-Map
8 2. Implicants, prime implicants, essential prime implicants, Non
essential Prime implicants (just introduction)
3. 4 variables
4. 5 variables (just table)
5. Don't Care States
9 Universal gates, XOR, XNOR, Parity Generators/ Checkers
1. Implementation of Boolean functions using universal gates
2. Combinational circuits
3. Design Procedure
 a circuit that accepts 3-bit number and generates a 6 bit binary
10 number equal to square of the given number
 Code convertors
 2 bit multiplier
 BCD numbers
 BCD to 7 segment display
11 Mid I
1. Decoders + Examples
 1-to -2 line decoder
 2-to -4 line decoder
 3-to -8 line decoder
12 2. Decoders with enable input
3. Encoders
4. Priority encoder
 BCD to decimal example.
5. Decoders and combinational circuits
 Forming larger size decoder from smaller one (3-to-8 line decoder
13
from 1-to -2 line decoders and 2-to -4 line decoders)
14 1. Multiplexers + Examples
 2x1 Mux
 4x1 Mux
 8x1 Mux
2. Dual and Quad MUX
3. Forming functions using decoders and multiplexer.
4. Demultiplexer + Examples
15 1. Forming larger size MUX from smaller one
16 1. Binary Adders
 Half Adder
 Full Adders
 Binary Ripple Carry Adder
 Binary Multipliers
17 1. 1’s and 2’s Complements
2. Binary Adder/Subtractor
3. BCD Adder
4. 2-bit magnitude comparator
18 1. Introduction to Sequential Circuits
2. Introduction to Latches
 SR Latch
 S’R’ Latch
 SR Latch with a control
 Timing Diagram with Latches
19  Introduction to Flip Flops
 how flip flops are different from latches
 why we use flip flops
 D Flip flop

20 1. Types of flip flop


 Edge triggered Flip flop
 JK flip flop
 Characteristic table and equations of D and JK flip flop.
21 1. Flip-Flops with Direct Inputs
2. Sequential Analysis With examples
3. Given the circuit generate the state diagram
22 Mid II
23 Some more examples of Sequential Design (given the circuit generate the
state diagram)

24 1. Given description form state diagram and design the circuit


2. Excitation tables for flip flops, D and JK.
25 Sequential circuit design practice problems. 4.13, 4.14, 4.15
26 1. Registers implementation with flip flops
2. 4 bit register with parallel load
27 1. Shift register
2. Serial addition with registers
3. Shift register with parallel load
4. Bidirectional Shift Register
5. Serial In/Parallel Out
28 1. Microoperations, Register Transfers (briefly)
2. Counters (synchronous and asynchronous)
3. 4 bit Ripple counter
29 1. Serial and Parallel Counters
2. Parallel gating counter
3. upward and downward counters
30 1. RAM, ROM
2. Memory Access
 Random Access
 Sequential Access
3. RAM Operation
 Read
 Write
4. Chip select option in RAMS.
Grading Scheme: Absolute

Rules:

1. Plagiarism is not tolerable in any form. Cheating in any respect will be treated as
a big crime and your cases will be forwarded to DC. It is the responsibility of the
student to protect their assignments from being copied. In case of cheating, both
parties will be considered equally responsible.
2. Eligibility to pass this course, students should have to get at least 50% marks and
80% attendance.
3. Assignments should be submitted in due time.
4. Quizzes can be unannounced, covering contents of last two lectures. There will be
no makeup of missed quiz.
5. Students can contest their grades on quizzes and assignments ONLY within a
week of the release of grades. Exams will be available for review according to
university policies.
Course Outline
Data Structures CS-218
Semester Fall-2022, Section BDS-3C
Instructor: Hamad ul Qudous Office Hours: Monday and Wednesday
Email: hamad.ulqudous@nu.edu.pk 2:30-3:30 p.m.
Credit 3 Prerequisite Object Oriented
Hours: Programming
Course Objectives:
CS2001 is a core Computer Science course with Object Oriented Programming as its
prerequisite. The course learning outcomes of this course are:
• Understand basic concepts of data structure and algorithms.
• Evaluate different data structures in terms of memory and time requirement
• Design appropriate data structures to solve real world problems related to the program
• Determine bugs in programs and recognize required operations with data structures

Text Book:
Any one of these books is recommended as a text book:

• Mark Allen Weiss, Data structures and algorithm analysis, Pearson Education, 2007.
• Adam Drozdek, Data structures and algorithms in C++, Course technology, 2004.
• Nell Dale, C++ Plus Data Structures, 3rd Edition, Jones and Bartlett, 2003.
• Michael T. Goodrich, Roberto Tamassia and David M. Mount, Data structures and algorithms, 2nd
Edition, John Wiley & Sons, 2011.
LECTURES TOPICS
1 Introduction
2 Time Complexity Analysis and Asymptotic Bounds
5 Linked Lists
Review of pointers
Singly linked lists, doubly linked lists, circular lists and
corresponding iterators

2 Stacks and Queues


MIDTERM 1
2 Recursion
3 Trees
Binary trees and their traversals
Binary search trees (Insertion, Deletion and Search)
3 Height Balanced Binary Search Trees (AVL Trees)
2 Heaps and heap sort
MIDTERM 2
1
Data compression and Huffman coding
2 Hashing
Hash tables and hash functions
Collision resolution
3
Graph data structure, Breadth first search and Depth first search
2 Advanced Topics
Course Outline
Data Structures CS-218
Semester Fall-2022, Section BDS-3C
Tentative Grading Scheme:
Assignments (18 %)

Quizzes (12 %)

Midterms (30 %)

Final Exam (40 %)

Homework (0%)

Important Instructions:
o Quizzes may be announced or surprise
o There will be no make-up quiz
o Minimum requirement to pass this course is to obtain at least 50% marks.
o All assignments and course work must be done individually. Plagiarism in any work (Quiz,
Assignment, Midterms, and Final Exam) from any source (Internet or a Student) will result in F
grade.
o No Late assignment Submissions
o All the CS department’s grading policies apply.
National Computing Education Accreditation Council
NCEAC

NCEAC.FORM.001-D

COURSE DESCRIPTION FORM

INSTITUTION National University of Computer & Emerging Sciences

PROGRAM (S) TO BE BS (Computer Science)


EVALUATED

A. Course Description
(Fill out the following table for each course in your computer science curriculum. A filled out form should
not be more than 2-3 pages.)

Course Code CS 4037


Course Title Introduction to Cloud Computing
Credit Hours 3
Prerequisites by Course(s) and
Topics
Assessment Instruments with 1. 3-4 Assignments (10%)
Weights (homework, quizzes, 2. 5-6 Quizzes (10%)
midterms, final, programming
3. Course Presentation (05%)
assignments, lab work, etc.)
4. Class Participation (05%)
5. 2 Midterm Exams (30%)
6. Final Exam (40%)
Course Coordinator Danyal Farhat
URL (if any)
Current Catalog Description
Textbook (or Laboratory Manual  Student Handbook of the AWS Cloud Foundation Course.
for Laboratory Courses)  Cloud computing Concepts, Technology and Architecture by
Thomas Erl
 Cloud Computing: Principles and Paradigms by Buyya R.
Reference Material  Distributed and Cloud Computing by Kai Huwang, Geoffrey C.
Fox and Jack J. Dongarra
 Modern Operating Systems by Andrew S. Tanenbaum 4th
edition
 Architecting the cloud by Michael J. Kavis
 Mastering Cloud Computing by Buyya R.
Course Goals This course provides an introduction to cloud computing. It focuses on
how the cloud works, rather than how cloud is to be used. Some
seminal as well as recent research papers are included to provide the
coverage of basics as well as state of the art in cloud computing
research.

1 NCEAC.FORM.001.D
National Computing Education Accreditation Council
NCEAC

NCEAC.FORM.001-D

Topics Covered in the Course, Timeline Content Covered


with Number of Lectures on Each Lecture 1 Cloud Concepts Overview
Topic (assume 15-week instruction Lecture 2 Cloud Concepts Overview
and one-and-half-hour lectures)
Lecture 3 Cloud Economics and Billing
Lecture 4 Cloud Economics and Billing
Quiz 1
Lecture 5 AWS Global Infrastructure Overview
Lecture 6 AWS Global Infrastructure Overview
Lecture 7 AWS Cloud Security
Lecture 8 AWS Cloud Security
Lecture 9 AWS Cloud Security
Lecture 10 AWS Cloud Security
Quiz 2 + Assignment 1 + Revision
Lecture 11 Networking and Content Delivery
Lecture 12 Networking and Content Delivery
Lecture 13 Networking and Content Delivery
Lecture 14 Compute
Lecture 15 Compute
Lecture 16 Compute
Quiz 3 + Assignment 2
Lecture 17 Storage
Lecture 18 Storage
Lecture 19 Databases
Lecture 20 Databases
Quiz 4 + Assignment 3 + Revision
Lecture 21 Cloud Architecture
Lecture 22 Cloud Architecture
Lecture 23 Automatic Scaling and Monitoring
Lecture 24 Automatic Scaling and Monitoring
Quiz 5
Lecture 25 Machine Learning using AWS
Lecture 26 Machine Learning using AWS
Lecture 27 Machine Learning using AWS
Lecture 28 Machine Learning using AWS
Quiz 6 + Assignment 4 + Revision
Lecture 29 Course Presentation
Lecture 30 Course Presentation

Final Examination

Laboratory Projects/Experiments 5 to 6 Labs regarding Networking and Content Delivery, Compute,


Done in the Course Storage, Databases, and Machine Learning on Cloud.
Programming Assignments Done Yes
in the Course

2 NCEAC.FORM.001.D
National Computing Education Accreditation Council
NCEAC

NCEAC.FORM.001-D

Class Time Spent on (in credit Theory Problem Solution Social and Ethical
hours) Analysis Design Issues
45 20 30 5
Oral and Written Communications Every student is required to submit at least 1 written reports of
typically 10-15 pages and to make 1 oral presentations of typically 10
minute’s duration. Include only material that is graded for grammar,
spelling, style, and so forth, as well as for technical content,
completeness, and accuracy.

Instructor Name: Danyal Farhat

Instructor Signature:
Date: 30-01-2023

3 NCEAC.FORM.001.D
NATIONAL UNIVERSITY
of Computer & Emerging Sciences, Lahore

Department of Computer Science


Information Retrieval
Fall 2022
Instructor Name: Dr. Iqra Safder

TA Name (if any): Hassan Masood <l217212@lhr.nu.edu.pk> (Section A & B)

Email address: iqra.safder@nu.edu.pk


Office Location/Number: C-135
Office Hours: Tuesday 1pm-2pm, Thursday 1pm – 2 pm, Wednesday 12pm – 1pm

Course Information
Program: BSCS Credit Hours: 3 Type: CS Elective

Pre-requisites (if any): Programming competence, Data structures

Course Website (if any) : Google classroom


Class Meeting Time:

Course Description/Objectives/Goals:

Recent years have seen a dramatic growth of natural language text data, including web pages,
news articles, scientific literature, emails, enterprise documents, and social media such as
blog articles, forum posts, product reviews, and tweets. Text data are unique in that they are
usually generated directly by humans rather than a computer system or sensors, and are thus
especially valuable for discovering knowledge about people’s opinions and preferences, in
addition to many other kinds of knowledge that we encode in text.
This course will cover technologies, which play an important role in any data mining
applications involving text data for two reasons. First, while the raw data may be large for any
particular problem, it is often a relatively small subset of the data that are relevant, and a
search engine is an essential tool for quickly discovering a small subset of relevant text data
in a large text collection. Second, search engines are needed to help analysts interpret any
patterns discovered in the data by allowing them to examine the relevant original text data to
make sense of any discovered pattern. You will learn the basic concepts, principles, and the
major techniques in text retrieval, which is the underlying science of search engines.
Course Learning Outcomes (CLOs):
At the end of the course students will be able to: Domain BT* Level
Explain many basic concepts and multiple major algorithms in text C2
retrieval and search engines.
Explain how search engines and recommender systems work and C2
how to quantitatively evaluate a search engine.
Create a test collection, run text retrieval experiments, and C3
experiment with ideas for improving a search engine.
* BT= Bloom’s Taxonomy, C=Cognitive domain, P=Psychomotor domain, A= Affective domain.
Bloom's taxonomy Levels: 1. Knowledge, 2. Comprehension, 3. Application, 4. Analysis, 5. Synthesis, 6. Evaluation

Textbook(s) /Supplementary Readings:

The following book will be used as a primary text to guide some of the discussions, but it will be
heavily supplemented with lecture notes and reading assignments from other sources.

• C. Zhai and S. Massung, Text Data Management and Analysis: A Practical Introduction to
Information Retrieval and Text Mining, ACM Book Series, Morgan & Claypool Publishers,
2016.

Additional references and books related to the course:


• C. Zhai and S. Massung, Text Data Management and Analysis: A Practical Introduction to
Information Retrieval and Text Mining, ACM Book Series, Morgan & Claypool Publishers,
2016. Chapters 10 - Section 10.4, Chapter 11.

Tentative Weekly Schedule (Phase wise)


Phase Topics to be covered Readin Assignments
gs /Projects?
1 • Part of Speech tagging, syntactic analysis,
semantic analysis, and ambiguity
• “Bag of words” representation
• Push, pull, querying, browsing
• Probability ranking principle
• Relevance
• Vector space model
• Dot product
• Bit vector
Recommended Readings:
• N. J. Belkin and W. B. Croft. 1992. Information
filtering and information retrieval: Two
sides of the same coin? Commun. ACM
35, 12 (Dec. 1992), 29-38.
• C. Zhai and S. Massung, Text Data
Management and Analysis: A Practical
Introduction to Information Retrieval and
Text Mining, ACM Book Series, Morgan
& Claypool Publishers, 2016. Chapters 1
- 6.
2 • Term frequency (TF)
• Document frequency (DF) and inverse
document frequency (IDF)
• TF transformation
• BM25
• Inverted index and postings
• Binary coding, unary coding, gamma-coding,
and d-gap
Recommended Readings:
• C. Zhai and S. Massung, Text Data
Management and Analysis: A Practical
Introduction to Information Retrieval and
Text Mining, ACM Book Series, Morgan
& Claypool Publishers, 2016. Chapter 6 -
Section 6.3, and Chapter 8.
• Ian H. Witten, Alistair Moffat, and Timothy C.
Bell. Managing Gigabytes: Compressing
and Indexing Documents and Images,
Second Edition. Morgan Kaufmann, 1999.

3 • Evaluation methodology
• Precision and recall
• Average precision, mean average precision
(MAP), and geometric mean average
precision (gMAP)
• Reciprocal rank and mean reciprocal rank
• F-measure
• Normalized Discounted Cumulative Gain
(nDCG)
• Statistical significance test

Recommended Readings:
• Mark Sanderson. Test collection based
evaluation of information retrieval
systems. Foundations and Trends in
Information Retrieval 4, 4 (2010), 247-
375.
• C. Zhai and S. Massung, Text Data
Management and Analysis: A Practical
Introduction to Information Retrieval and
Text Mining, ACM Book Series, Morgan
& Claypool Publishers, 2016. Chapter 9

4 • p(R=1|q,d), query likelihood, and p(q|d)


• Statistical and unigram language models
• Maximum likelihood estimate
• Background, collection, and document language
models
• Smoothing of unigram language models
• Relation between query likelihood and TF-IDF
weighting
• Linear interpolation smoothing
Recommended Readings:
• C. Zhai and S. Massung, Text Data
Management and Analysis: A Practical
Introduction to Information Retrieval and
Text Mining, ACM Book Series, Morgan
& Claypool Publishers, 2016. Chapter 6 -
Section 6.4

5 • Relevance feedback
• Pseudo-relevance feedback
• Implicit feedback
• Rocchio feedback
• Scalability and efficiency
• Spams
• Crawler, focused crawling, and incremental
crawling
• Google File System (GFS)
• MapReduce
• Link analysis and anchor text
• PageRank and HITS
Recommended Readings:
• C. Zhai and S. Massung, Text Data
Management and Analysis: A Practical
Introduction to Information Retrieval and
Text Mining, ACM Book Series, Morgan
& Claypool Publishers, 2016. Chapters 7
& 10

6 • Learning to rank, features, and logistic


regression
• Content-based filtering
• Collaborative filtering
• Beta-Gamma threshold learning
• User profile
• Exploration-exploitation tradeoff

(Tentative) Grading Criteria


Quizzes 10%
Assignments/Homeworks/Project 15 - 25%
Midterms 25-30%
Final Exam 40 - 45%
Total: 100 %

Course Policies
• Course outline may change 10-20% as we proceed in the semester. We may add and
remove a few topics.
• Grading scheme: Relative
• Depending on the situation of COVID 19, this weightage of midterms can be reduced
and added in assignments/homeworks/project.
• Weightage of other evaluations can also be adjusted if needed.
• Assignment deadlines for assignment and Project are hard.
• NO Cell Phone usage in class, they must be turned off at all times.
• There will be no retake of quizzes or exams.
• Integrity in the assignments/quizzes is expected; otherwise result would be an F
grade in the course or may be the case is forwarded to Disciplinary committee.
• Attendance MUST be ensured according to the University policy to avoid
disqualification.
Course Title: Operating Systems
Semester: Spring
FALL 2022
Course Code: CS-220
Pre-requisite: Data Structures, and Computer Organization
Office Hours: Monday: 11:00 to 12:30, Wed: 10:00 to 12:00
Instructor: Razi Uddin(Email: razi.uddin@nu.edu.pk )

Objective
“Operating systems are essential part of any computer system. Similarly, a course on
operating systems is an essential part of any computer science education.” (Silberschatz et.
al.)

This course helps in understanding the behavior, role and scope of operating system, the
underlying hardware, and the application programmes. Secondly, in this course students
learn how to program in a multi-programmed and multithreaded environment. The course
also introduces important system development methodologies and algorithms in the areas
of CPU scheduling, process communication, memory management, concurrency,
synchronization, and file systems.

Text Book
Operating System Concepts (Tenth Edition)
By Silberschatz, Galvin, and Gagne

Additional Readings
Operating Systems (Third Edition)
By Gary Nutt

The Little Book of Semaphores (Second Edition)


By Allen B. Downey

Weightages (Tentative)

Quizzes 10%
Assignments 15%
Two Midterm Exams 30%
Final Exam 45%

Passing Criteria
A student must secure at least 50% marks to pass the course.

Attendance Policy
Students are expected to attend all sessions. However, they might avail 20% leaves in
emergency situations. Beyond this the student will not be allowed to appear in the final
exam.
Plagiarism
Plagiarism is not tolerable in any of its form. Minimum penalty would be an ‘F’ grade in
the course. Students bear all the responsibility for protecting their assignments. In case of
cheating, both parties will be considered equally responsible.

Late Submissions
Assignments must be submitted on time. Late submissions will not be accepted.

Lecture Plan (Tentative)

Topic
Introduction and Background
Introduction to Process Management
Fork, wait, execlp
Proceses, Process
Communication, Inter-process Communication
and Threads Linux pipeline
Multithreading Models
Thread Libraries
Expoiting processing and I/O in parallel
Process Scheduling
Basic Concepts
Scheduling Algorithms
Scheduling and
Synchronization
Synchronization
Critical Section Problem and its Solutions
Semaphores
Classical Problems
Memory Management
Challenges
Paging
Virtual Memory
Memory
Demand Paging
Management, and Page Replacement Algorithms
File Systems
File System – Introduction
Allocation Methods
Free-Space Management
Implementation

Some Optional Topics if time permits


(deadlocks, makefile, sockets, etc.)

Grading Scheme:
Absolute grading scheme will be used.
NATIONAL UNIVERSITY
of Computer & Emerging Sciences, Lahore

Department of Computer Science


CS4001 – Professional Practices
Fall 2022
Instructor Name: Muhammad Saifullah Tanvir TA Name (if any): TBA
Email address: Saifullah.tanvir@nu.edu.pk Email address: TBA
Office Location/Number: m-109 (In front of CS Lab 4)
Office Location/Number: NA
Office Hours: Monday and Wednesday from 12:00 – 1:00
(kindly, email me first before meeting)

Course Information
Program: BS Credit Hours: 3 Type: Core
Pre-requisites (if any): Software Engineering - CS303
Course Website (if any):
https://classroom.google.com/c/NTM5NDg2MzYyMjM0
Class Venue: CS-02

Course Description/Objectives/Goals:
The course is designed to prepare students for adequately responding to issues
faced during the professional life
Computing Profession, Computing Ethics, Philosophy of Ethics. The Structure of
Organizations, Finance and Accounting, Anatomy of a Software House, Computer
Contracts, Intellectual Property Rights, The Framework of Employee Relations Law
and Changing Management Practices, Human Resource Management and IT,
Health and Safety at Work, Software Liability, Liability and Practice, Computer
Misuse and the Criminal Law, Regulation and Control of Personal Information.
Overview of the British Computer Society Code of Conduct, IEEE Code of Ethics,
ACM Code of Ethics and Professional Conduct, ACM/IEEE Software Engineering
Code of Ethics and Professional Practice. Accountability and Auditing, Social
Application of Ethics.
Course Textbook
1. Professional Issues in Software Engineering by Frank Bott, Allison Coleman, Jack
Eaton and Diane Rowland, CRC Press; 3rd Edition (2000). ISBN-10: 0748409513
2. Computer Ethics by Deborah G. Johnson, Pearson; 4th Edition (January 3, 2009).
ISBN-10: 0131112414
3. A Gift of Fire: Social, Legal, and Ethical Issues for Computing and the Internet (3rd
Edition) by Sara Baase, Prentice Hall; 3rd Edition (2008). ISBN-10: 0136008488
4. Applied Professional Ethics by Gregory R. Beabout, University Press of America
(1993). ISBN-10: 0819193747.

Additional references and books related to the course:

a) Professional Issues in Information Technology (Second Edition) – Frank


Bott et al
b) Ethics in Information Technology - George W. Reynolds
c) The Art of Unix Programming
d) The Pragmatic Programmer
e) “The Art of Unix Programming”
f) Peopleware 3rd Edition" by Timothy Lister and Tom DeMarco.
g) "WINNING" by Jack Welch

Tentative Weekly Schedule


S# Topic Week(s) 1Readings

1 1 Chapter 1 [1]
Profession, Computing
Profession, Professional Bodies Chapter 2 [a]

2 Organization, Legal Status of 2, 3, 4 Chapter 2[1]


organization, Structure and
Chapter 3,4[2]
management of Organization

Chapter 3[1]
Financing a startup-company, Finance
and Accounting, Accountability Chapter 5,6[a]
and Auditing

Chapter8[a]

Investment Appraisal

3 Anatomy of Software House 5 Chapter 4 [1]

1
Numbers in square brackets correspond to books numbered in “Reference Material”
section.
4 Computer Contracts 6 Chapter 5 [1]

Intellectual Property Rights 7 Chapter 6 [1]


Chapter 6 [b]

The Framework of Employee 8 Chapter 7 [1]


Relations Law and Changing
Management Practices

Human Resource Management 9 Chapter 8 [1]


and IT Chapter 10 [a]

Health and Safety at Work 10 Chapter 9 [1]

Software Liability, Liability and 11 Chapter 10 [1]


Practice, Chapter 7 [b]

Computer Misuse and the Chapter 11 [1]


Criminal Law Chapter 3 [b]

Regulation and Control of 12 Chapter 12 [1]


Personal Information Chapter 5 [b]

Computing Ethics, 13 Chapter 1[2]

Chapter 2 [2]
Philosophy of Ethics

(Tentative) Grading Criteria


Assignments/Project/Presentation/Quizzes/class participation: 30
Mid Exams: 15 + 13
Final Exam: 40
Course Policies
Announcements
Announcements related to different aspects of this course (e.g. lectures, quizzes,
exams, etc.) will be posted on google classroom, students are expected to check
regularly.

Attendance
All students are expected to attend all lectures from beginning to end. Partial or full
absence from a lecture may hamper chances for securing good grades.

Exams
Exams will be closed-book and closed-notes. Syllabus for the final exam will be
comprehensive.

Office Hours
Students are encouraged to take full advantage of the instructor's office hours. Any
doubts regarding concepts covered in class or any questions regarding quizzes,
projects, etc. may be clarified during office hours. In case a student is not able to
make it during office hours, he/she may schedule an appointment with the instructor
for another time slot.

Quizzes
Quizzes may be announced or unannounced. A quiz will usually be about 5 – 10
minutes long and it may be given anytime during the lecture.

Reading Material
Students are encouraged to finish the assigned readings BEFORE the lecture. This
is likely to improve lecture comprehension and class participation.

Revision of Grades
Students can contest their grades on quizzes and project deliverables ONLY within a
week of the release of grades. Exams will be available for review according to
university policies.

Unfair Means
Students are expected to demonstrate the highest degree of moral and ethical
conduct. Any student caught cheating, copying, plagiarizing, or using any other
unfair means will be strictly dealt-with in accordance with university policies.
-
NATIONAL UNIVERSITY
of Computer & Emerging Sciences, Lahore

Department of Computer Science


CS440 – Software for Mobile Devices
Spring 2023
Instructor Name: Farooq Ahmed TA Name:
Email address: farooq.ahmad@nu.edu.pk Email address:
Office Location/Number:
Office Hours: Friday 9 – 11 AM

Course Information:
Program: BS (CS) Credit Hours: 3 Course Type: Elective
Pre-requisites: Database Systems (CS-219),
Object-oriented Analysis and Design (CS-309) / Software Design and Analysis (CS-324)
Class Meeting Time:
Class Venue:

Course Description/Objectives/Goals:
 Understanding the challenges of application development for mobile devices
 Understanding the user experience issues associated with mobile application development,
 Designing, developing, testing and deploying mobile applications using various tools and technologies

Course Learning Outcomes (CLOs):


At the end of the course students will be able to: Domain BT* Level
Discuss different architectures and frameworks for Mobile C 1
Application Development
Develop mobile applications using current software C 3
development environments
Compare user experience, performance and other trade-offs C 3
in mobile application development,
* BT= Bloom’s Taxonomy, C=Cognitive domain, P=Psychomotor domain, A= Affective domain
Bloom's taxonomy Levels: 1. Knowledge, 2. Comprehension, 3. Application, 4. Analysis, 5. Synthesis, 6. Evaluation

Course Textbook:
None
Additional references and books related to the course:
1. Android Developer Resources (http://developer.android.com)
2. Professional Android, Fourth Edition (2018) by Reto Meier, Ian Lake
3. Android Internals by Jonathan Levin
4. Android Notes for Professionals (https://books.goalkicker.com/AndroidBook/)
5. Mobile Developer's Guide to Galaxy, 18th Edition by Open Exchange
https://www.open-xchange.com/resources/mobile-developers-guide-to-the-galaxy/
Tentative Weekly Schedule
Week 1 Lecture 1 Lecture 2
Introduction Mobile Application Android Fundamentals
Development
Week 2 Lecture 1 Lecture 2
Android UI Programming and Patterns UI Programming and Patterns
Week 3 Lecture 1 Lecture 2
Android UI Programming and Patterns UI Programming and Patterns
Week 4 Lecture 1 Lecture 2
Android UI Programming and Patterns UI Programming and Patterns
Week 5 Lecture 1 Lecture 2
Engineering Issues HCI Issues Responsive Design
MID 1
Week 6 Lecture 1 Lecture 2
Engineering Issues / Android Responsive Design Gesture Handling

Week 7 Lecture 1 Lecture 2


Android Data Storage (Files) Data Storage (Databases)
Week 8 Lecture 1 Lecture 2
Android Application Architecture Application Architecture (Content
(Intents) Providers)
Week 9 Lecture 1 Lecture 2
Android Application Architecture Application Architecture (Broadcast
(Services) Receivers)
Week 10 Lecture 1 Lecture 2
Android Processes, Threads and Processes, Threads and
Asynchronous Programming Asynchronous Programming
MID 2
Week 11 Lecture 1 Lecture 2
Android Inter-process Communication Web connectivity
Week 12 Lecture 1 Lecture 2
Android / Engineering Issues Web Connectivity Hybrid Applications
Week 13 Lecture 1 Lecture 2
Android / Engineering Issues Location-based services Network Programming / Bluetooth
Week 14 Lecture 1 Lecture 2
Miscellaneous Monetization and Analytics Cross-platform development

(Tentative) Grading Criteria:


Assignments & Project (30%) Quiz (5 %) Midterms (25 %) Final Exam (40 %)

Course Policies:
o Plagiarism in any work (Quiz, Assignment, Midterms, and Final Exam) from any source, Internet or
a Student may result in F grade or deduction of absolute marks.
o 80% attendance is required for appearing in the Final exams.
o Absolute Grading will be done, inline with department policies.
NATIONAL UNIVERSITY
of Computer & Emerging Sciences, Lahore

Department of Computer Science


CS301 – Theory of Automata
Spring 2022
Instructor Name: Hamad ul Qudous TA Name (if any):
Email address: hamad.ulqudous@nu.edu.pk Email address:
Office Location/Number: M122 (Opposite Lab 4) Office Location/Number:
Office Hours: TBA

Course Information
Program: BS (CS)
Credit Hours: 3
Type: Core
Pre-requisite: CS211 Discrete Structures
Course Website: N/A
Class Meeting Time: TBA
Class Venue: TBA

Course Description/Objectives/Goals
This core course belongs to an important branch of computer science known as Theoretical
Computer Science (TCS). TCS deals with, among other concepts, the theory of computation which
focuses on automata theory, computability theory, and complexity theory. Students are gradually
familiarized with different types of increasingly more powerful mathematical models of computers
known as automata (plural of automaton) and the languages they can recognize.

Course Learning Outcomes (CLOs)


At the end of the course, students will be able to:
understand the main concepts of automata theory using rigorously formal mathematical methods
appreciate the difference between various classes of automata, languages, and grammars
analyze and design different types of automata, REs, and CFGs
transform between equivalent NFAs, DFAs and REs
define Turing machines capable of performing simple tasks.

Textbook and Reference Book


1. Introduction to the Theory of Computation, Michael Sipser, 3rd Edition, Cengage Learning,
2012.
2. Introduction to Automata Theory, Languages, and Computation, John E. Hopcroft, Rajeev
Motwani, and Jeffrey D. Ullman, 3rd Edition, Pearson, 2006.

Page 1 of 3
Tentative Weekly Schedule
Week Topics Readings
1 Introduction and Revision of Basic Concepts [1] Chapter 0
2 Finite Automata: DFA [1] Chapter 1
3 Finite Automata: NFA [1] Chapter 1
4 Finite Automata: NFA-DFA Conversion [1] Chapter 1
5 Regular Languages: Regular Expressions, [1] Chapter 1
Equivalence with FA. Minimal DFA
6 MIDTERM EXAM 1
6 Regular Languages: Pumping Lemma [1] Chapter 1
7 Context-Free Languages: CFGs [1] Chapter 2
8 Context-Free Languages: PDA [1] Chapter 2
9 Context-Free Languages: PDA-CFG [1] Chapter 2
Equivalence
10 Context-Free Languages: Pumping Lemma [1] Chapter 2
11, 12 Context-Free Languages: DCFLs [1] Chapter 2
12 MIDTERM EXAM 2
13 Turing Machines: Introduction [1] Chapter 3
14 Turing Machines: Variants [1] Chapter 3
15, 16 Decidability [1] Chapter 4

Page 2 of 3
(Tentative) Grading
1. Quizzes & Assignment (20%) Quizzes can be unannounced
2. Midterm Exams (35%)
3. Final Exam (45%)

Grading Scheme: Absolute

Academic Integrity
• Plagiarism and Cheating against academic integrity. Both parties involved in such cases will
face strict penalty (negative marking, F grade, DC)
• CODE/ ASSIGNMENT SHARING is strictly prohibited.
• Keep in mind that by sharing your code/assignment you are not helping anyone rather
hindering the learning process or the other person.
• No excuse will be entertained if your work is stolen or lost. To avoid such incidents
• Keep back up of your code on safe online storage, such as Google Drive, Drop box or
One drive.
• Do not leave your work on university lab computer, transfer your work to online
storage and delete from the university lab computer (empty recycle bin as well)

Page 3 of 3
NATIONAL UNIVERSITY
of Computer & Emerging Sciences, Lahore

Department of Computer Science


CS406 – Web Programming
Spring 2023
Instructor Name: Muhammad Saifullah
Email address: saifullah.tanvir@lhr.nu.edu.pk
Office Location: m-109 (in front of CS Lab 4)
Tuesday and Thursday 12:00 PM –
Office Hours:
01:00 PM
(Kindly, email me to schedule a meeting)

Course Information:
Program: BS (CS) Credit Hours: 3 Course Type: Elective

Course Description/Objectives/Goals:
• To introduce the fundamental concepts of web architecture and programming.
• To learn basics of client and server-side programming along with prevalent technologies and
frameworks
• To introduce modern practices such as AJAX and Web services
• To discuss Web Engineering issues such as Performance and Security

Course Learning Outcomes (CLOs):


At the end of the course students will be able to: Domain BT* Level
Understand concepts of web architecture and programming C 2
Learn basics of client and server side programming C 3
Learn modern practices such as AJAX and Web services, C 3
along with prevalent technologies and frameworks
Learn Web Engineering issues such as Performance and C 3
Security
* BT= Bloom’s Taxonomy, C=Cognitive domain, P=Psychomotor domain, A= Affective domain
Bloom's taxonomy Levels: 1. Knowledge, 2. Comprehension, 3. Application, 4. Analysis, 5. Synthesis, 6. Evaluation
(Tentative) Weekly Schedule
Week 1 Lecture 1 Lecture 2
Principles of Web Architecture HTTP Protocol and HTML
Week 2 Lecture 1 Lecture 2
CSS + HTML CSS + HTML + JavaScript
Week 3 Lecture 1 Lecture 2
Bootstrap and JavaScript Basics of JavaScript Language
Week 4 Lecture 1 Lecture 2
Application of JavaScript in Application of JavaScript in DOM
DOM manipulation manipulation and Ajax
Week 5 Lecture 1 Lecture 2
jQuery and Ajax jQuery
MID 1
Week 6 Lecture 1 Lecture 2
Introduction to web servers and Client-side programming
client-side programming
Week 7 Lecture 1 Lecture 2
State management techniques State management techniques and
and issues issues
Week 8 Lecture 1 Lecture 2
Server-side Frameworks Server-side Frameworks
Week 9 Lecture 1 Lecture 2
Server-side Frameworks Deployment issues
Week 10 Lecture 1 Lecture 2
Request / Response cycle Cross-domain issues
MID 2
Week 11 Lecture 1 Lecture 2
MVC Architecture Web services
Week 12 Lecture 1 Lecture 2
Performance and scalability Performance and scalability issues
issues
Week 13 Lecture 1 Lecture 2
Security issues Security issues
Week 14 Lecture 1 Lecture 2
Security issues Templates

(Tentative) Grading Criteria:


Assignments/Project (25%) Quiz (10 %) Midterms (25 %) Final Exam (40 %)

Course Policies:
o Plagiarism in any work (Quiz, Assignment, Midterms, and Final Exam) from any source, Internet or
a Student may result in F grade or deduction of absolute marks.
o 80% attendance is required for appearing in the Final exams.
o Minimum requirement to pass this course is to obtain at least 50% marks under application of CS
department's grading policies.
o Absolute grading scheme will be used.

You might also like