Latest UNIPUNE Syllabus. (Comp Engg Wrf. June 2016)
Latest UNIPUNE Syllabus. (Comp Engg Wrf. June 2016)
Latest UNIPUNE Syllabus. (Comp Engg Wrf. June 2016)
Syllabus
of
Second Year of Computer Engineering
(Course 2015)
(with effect from June 2016 )
Faculty of Engineering
#1/65
Faculty of Engineering
Program Outcomes
Students are expected to know and be able 1. To apply knowledge of mathematics, science, engineering fundamentals,
2. To analyze the problem by finding its domain and applying domain specific
skills
suitable techniques.
on global aspect.
12. To keep in touch with current technologies and inculcate the practices of
lifelong learning.
#2/65
Faculty of Engineering
Semester I
Course
Code
Course
Name
210241
Discrete
Mathematics
210242
210243
210244
210245
210246
210247
210248
Digital
Electronics
and Logic Design
Data Structures
and Algorithms
Computer
Organization
and Architecture
Object Oriented
Programming
Digital
Electronics Lab
Data Structures
Lab
Object Oriented
Programming
Lab
210249
Soft Skills
Teaching Scheme
Hours / Week
--
--
--
50
50
--
--
--
100
04
--
--
50
50
--
--
--
100
04
--
04
--
--
50
50
--
--
--
100
04
--
04
--
--
50
50
--
--
--
100
04
--
04
--
--
50
50
--
--
--
100
04
--
--
--
02
--
--
25
50
--
75
--
01
--
--
04
--
--
25
50
--
75
--
02
--
--
02
--
--
25
50
--
75
--
01
--
--
02
--
--
25
--
--
25
--
01
20
05
Total
210250 Audit Course 1
--
--
--
Total
20
--
10
--
--
--
--
--
--
Grade
750
25
Abbreviations:
TW:
OR:
PR:
Term Work
Oral
Practical
TH: Theory
TUT: Tutorial
Sem: Semester
#3/65
Faculty of Engineering
Semester II
Course
Code
Course
Name
207003
Engineering
Mathematics III
210251
210252
210253
210254
210255
210256
210257
210258
Computer
Graphics
Advanced Data
Structures
Microprocessor
Principles of
Programming
Languages
Computer
Graphics Lab
Advanced Data
Structures Lab
Microprocessor
Lab
Audit Course 2
Total
Teaching Scheme
Hours / Week
Credits
TH+
TUT
04
01
--
50
50
25
--
--
125
05
04
--
--
50
50
--
--
--
100
04
04
--
--
50
50
--
--
--
100
04
--
--
50
50
--
--
--
100
04
--
--
50
50
--
--
--
100
03
--
--
--
02
--
--
25
50
--
75
--
01
--
--
04
--
--
25
50
--
75
--
02
--
--
04
--
--
25
50
--
75
--
02
20
05
19
Total
-01
04
03
-10
-750
-----
Grade
25
Abbreviations:
TW:
OR:
PR:
PR
Term Work
Oral
Practical
TH: Theory
TUT: Tutorial
Sem: Semester
#4/65
Faculty of Engineering
SEMESTER I
#5/65
Faculty of Engineering
Teaching Scheme:
TH: 04 Hours/Week
04
Examination Scheme:
In-Sem (online): 50 Marks
End-Sem (paper): 50 Marks
Course Contents
Unit I
09 Hours
09 Hours
Relations and Their Properties, n-ary Relations and Their Applications, Representing Relations ,
Closures of Relations, Equivalence Relations, Partial Orderings, partitions, Hasse Diagram,
Lattices, Chains and Anti-Chains, Transitive Closure and Warshalls Algorithm, n-Ary Relations
and their Applications.
Functions- Surjective, Injective and Bijective functions, Inverse Functions and Compositions of
Functions, The Pigeonhole Principle.
#6/65
Faculty of Engineering
Unit III
Counting
09 Hours
The Basics of Counting, rule of Sum and Product, Permutations and Combinations, Binomial
Coefficients and Identities, Generalized Permutations and Combinations, Algorithms for
generating Permutations and Combinations.
Unit IV
Graph Theory
09 Hours
Graphs and Graph Models, Graph Terminology and Special Types of Graphs, Representing
Graphs and Graph Isomorphism, Connectivity, Euler and Hamilton Paths, Single source shortest
path- Dijkstra's Algorithm, Planar Graphs, Graph Colouring. Case Study- Web Graph, Google
map.
Unit V
Trees
09 Hours
Introduction, properties of trees, Binary search tree, decision tree, prefix codes and Huffman
coding, cut sets, Spanning Trees and Minimum Spanning Tree, Kruskals and Prims algorithms,
The Max flow- Min Cut Theorem (Transport network). Case Study- Game Tree, Mini-Max Tree.
Unit VI
Algebraic Structures and Coding Theory
09 Hours
The structure of algebra, Algebraic Systems, Semi Groups, Monoids, Groups, Homomorphism and
Normal Subgroups, and congruence relations, Rings, Integral Domains and Fields, coding theory,
Polynomial Rings and polynomial Codes, Case Study- Brief introduction to Galois Theory Field
Theory and Group Theory.
Books:
Text:
1. Kenneth H. Rosen,
Discrete Mathematics and its Applications, Tata McGraw-Hill, ISBN
#7/65
Faculty of Engineering
Teaching Scheme:
04
TH: 04 Hours/Week
Examination Scheme:
In-Sem (online): 50 Marks
End-Sem (paper): 50 Marks
Course Contents
09 Hours
Logic minimization: Representation of truth-table, Sum of Product (SOP) form, Product of Sum
(POS) form, Simplification of logical functions, Minimization of SOP and POS forms using KMaps up to 4 variables and Quine-McCluskey Technique, realization of logic gates.
Design of Combinational Logic: Code converter - BCD, Excess-3, Gray code, Binary Code.
Half- Adder, Full Adder, Half Subtractor, Full Subtractor, Binary Adder (IC 7483), BCD adder,
Look ahead carry generator, Multiplexers (MUX): MUX (IC 74153, 74151), MUX tree,
Demultiplexers (DEMUX)- Decoder. (IC 74138, IC 74154). DMUX Tree, Implementation of SOP
and POS using MUX, DMUX, Comparators, Parity generators and Checker, Priority Encoders.
Unit II
09 Hours
Flip- flop: SR, JK, D, T; Preset & Clear, Master and Slave Flip Flops, Truth Tables and Excitation
tables, Conversion from one type to another type of Flip Flop. Registers: Buffer register, shift
register, Applications of shift registers. Counters: Asynchronous counter. Synchronous counter,
ring counters, BCD Counter, Johnson Counter, Modulus of the counter (IC 7490).
Synchronous Sequential Circuit Design: Models Moore and Mealy, State diagram and State
Tables, Design Procedure, Sequence generator and detector. Asynchronous Sequential Circuit
Design: Difference with synchronous circuit design, design principles and procedure, applications.
Syllabus for Second Year of Computer Engineering
#8/65
Faculty of Engineering
Unit III
09 Hours
Algorithmic State Machines: Finite State Machines (FSM) and ASM, ASM charts, notations,
construction of ASM chart and realization for sequential circuits, Sequence Generator, Types of
Counters. VHDL: Introduction to HDL, Data Objects & Data Types, Attributes., VHDL- Library,
Design Entity, Architecture, Modeling Styles, Concurrent and Sequential Statements,
Design Examples: VHDL for Combinational Circuits-Adder, MUX, VHDL for Sequential
Circuits, Synchronous and Asynchronous Counter.
Unit IV
Programmable Logic Devices
09 Hours
ROM as PLD, Programmable Logic Array (PLA), Programmable Array Logic (PAL), Designing
combinational circuits using PLDs.
Unit V
Logic Families
09 Hours
Classification of logic families: Unipolar and Bipolar Logic Families, Characteristics of Digital
ICs: Speed, power dissipation, figure of merits, fan-out, Current and voltage parameters, Noise
immunity, operating temperature range, power supply requirements. Transistor-Transistor
Logic: Operation of TTL, Current sink logic, TTL with active pull up, TTL with open collector
output, Schottkey TTL, TTL characteristics, TTL 5400/7400 series, CMOS: CMOS Inverter,
CMOS characteristics, CMOS configurations- Wired Logic, Open drain outputs, Interfacing: TTL
to CMOS and CMOS to TTL. Tristate Logic and Tristate TTL inverter.
Unit VI
Microcontrollers
09 Hours
Comparison of typical microprocessor and microcontroller. Microcontroller 8051: Features,
architecture, Pin description, Programming model Special Function Registers, addressing
modes, instruction set, Timers and Counters, serial communication, interrupts, interfacing with
ADC and DAC.
Books:
Text:
McGraw-Hill, ISBN13:978-1-25-902597-6.
3. Muhammas Mazidi, Janice Mazidi and Rolin McKinlay,
The 8051 Microcontroller and
Embedded Systems using Assembly and C, Pearson Education,
ISBN-13: 9788131758991
References:
1. John Yarbrough,
Digital Logic applications and Design, Cengage Learning, ISBN 13:
978-81-315-0058-3
2. D. Leach, Malvino, Saha,
Digital Principles and Applications, Tata McGraw Hill, ISBN
13:978-0-07-014170-4.
3. Anil Maini,
Digital Electronics: Principles and Integrated Circuits, Wiley India Ltd,
ISBN:978-81-265-1466-3.
4. Norman B & Bradley,
Digital Logic Design Principles, Wiley India Ltd, ISBN:978-81265-1258-4.
5. Scott Mackenzie,
The 8051 Microcontroller, Prentice Hall India, ISBN-13: 9780130195623
#9/65
Faculty of Engineering
Teaching Scheme:
TH: 04 Hours/Week
Credit
04
Examination Scheme:
In-Sem (online): 50 Marks
End-Sem (paper): 50 Marks
Course Objectives:
To understand the standard and abstract data representation methods.
To acquaint with the structural constraints and advantages in usage of the data.
To understand the memory requirement for various data structures.
To operate on the various structured data.
To understand various data searching and sorting methods with pros and cons.
To understand various algorithmic strategies to approach the problem solution.
Course Outcomes:
On completion of the course, student will be able to
To discriminate the usage of various structures in approaching the problem solution.
To design the algorithms to solve the programming problems.
To use effective and efficient data structures in solving various Computer Engineering
domain problems.
To analyze the problems to apply suitable algorithm and data structure.
To use appropriate algorithmic strategy for better efficiency
Course Contents
Unit I
09 Hours
Linked Lists
09 Hours
#10/65
Faculty of Engineering
#11/65
Faculty of Engineering
Teaching Scheme:
TH: 04 Hours/Week
Credit
04
Examination Scheme:
In-Sem (online): 50 Marks
End-Sem (paper): 50 Marks
Course Contents
09 Hours
Computer Organization and Architecture, Structure and Function, Evolution (a brief history) of
computers, Designing for Performance, Evolution of Intel processor architecture- 4 bit to 64 bit,
performance assessment. A top level view of Computer function and interconnectionComputer Components, Computer Function, Interconnection structure, bus interconnection,
Computer Arithmetic- The Arithmetic and Logic Unit, addition and subtraction of signed
numbers, design of adder and fast adder, carry look ahead addition, multiplication of positive
numbers, signed operand multiplication, booths algorithm, fast multiplication, integer division.
Floating point representation and operations IEEE standard, arithmetic operations, guard bits
and truncation.
Unit II
Computer Memory System
09 Hours
Characteristics of memory system, The memory hierarchy. Cache Memory- Cache memory
principles, Elements of cache design- cache address, size, mapping functions, replacement
algorithms, write policy, line size, number of cache, one level and two level cache, performance
characteristics of two level cache- locality & operations. Case Study- PentiumIV cache
organization. Internal Memory- semiconductor main memory, advanced DRAM organization.
External Memory- Hard Disk organization, RAID- level 1 to level 6.
#12/65
Faculty of Engineering
Unit III
09 Hours
External devices, I/O modules- Module function and I/O module structure, Programmed I/Ooverview, I/O commands, I/O instructions, Interrupt driven I/O- interrupt processing, design
issues. Case Study- Study of Programmable Interrupt Controller Intel 82C59A in brief. Direct
Memory Access- drawbacks of programmed and interrupt driven I/O, DMA functions, Case
Study- DMA Controller Intel 8237A-study in brief, I/O channels and processors- evolution and
characteristics, The external Interface- Thunderbolt and Infinite Band.
Unit IV
Instruction Sets
09 Hours
Characteristics and Functions- machine instruction characteristics, types of operands, Case
Study-Intel 8086, Types of operations- data transfer, arithmetic, logical, conversion, input-output,
system control, and transfer of control, Case Study-Intel 8086 operation types. Addressing modes
and Formats- Addressing modes- immediate, direct, indirect, register, register indirect,
displacement and stack, Case Study-8086 addressing modes, Instruction Formats- instruction
length, allocation of bits, variable length instructions. Case Study- 8086 instruction formats.
Unit V
Processor Organization
09 Hours
Processor organization, Register organization- user visible registers, control and status registers,
Case Study- register organization of microprocessor 8086. Instruction Cycle- The machine cycle
and Data flow. Instruction Pipelining- Pipelining Strategy, pipeline performance, pipeline
hazards, dealing with branches, Case Study- pipelining in Pentium.
Instruction level parallelism and superscalar processors- Super scalar verses super pipelined,
constraints, Design Issues- instruction level and machine parallelism, Instruction issue policy,
register renaming, machine parallelism, branch prediction, superscalar execution and
implementation. Case study- Pentium IV.
Unit VI
Basic Processing Unit
09 Hours
Fundamental Concepts- register transfer, performing arithmetic or logic operations, fetching a
word from memory, storing a word in memory, Execution of a complete instruction- branch
instructions,
Hardwired control, Micro-programmed control- micro instructions, micro program sequencing,
wide branch addressing, microinstruction with next address field, pre-fetching microinstructions
and emulation.
Books:
Text:
1. W. Stallings,
Computer Organization and Architecture: Designing for performance,
Pearson Education/ Prentice Hall of India, 2003, ISBN 978-93-325-1870-4, 7th Edition.
2. Zaky S, Hamacher,
Computer Organization, 5th Edition, McGraw-Hill Publications,
2001, ISBN- 978-1-25-900537-5, 5th Edition.
References:
1. John P Hays,
Computer Architecture and Organization, McGraw-Hill Publication, 1998,
ISBN:978-1-25-902856-4, 3rd Edition.
2. Miles Murdocca and Vincent Heuring,
Computer Architecture and Organization- an
integrated approach, Wiley India Pvt. Ltd, ISBN:978-81-265-1198-3, 2nd Edition
3. A. Tanenbaum,
Structured Computer Organization, Prentice Hall of India, 1991 ISBN:
81 203 1553 7, 4th Edition
4. Patterson and Hennessy,
Computer Organization and Design, Morgan Kaufmann
Publishers In, ISBN 978-0-12-374750-1, 4th Edition.
#13/65
Faculty of Engineering
Teaching Scheme:
TH: 04 Hours/Week
Credit
04
Examination Scheme:
In-Sem (online): 50 Marks
End-Sem (paper): 50 Marks
Course Objectives:
To explore the principles of Object Oriented Programming (OOP).
To understand object-oriented concepts such as data abstraction, encapsulation,
inheritance, dynamic binding, and polymorphism.
To use the object-oriented paradigm in program design.
To lay a foundation for advanced programming.
Provide programming insight using OOP constructs.
Course Outcomes:
On completion of the course, student will be able to
Analyze the strengths of object oriented programming
Design and apply OOP principles for effective programming
Develop programming application using object oriented programming language C++
Percept the utility and applicability of OOP
Course Contents
Unit I
09 Hours
09 Hours
#14/65
Faculty of Engineering
Unit III
Virtual Functions
09 Hours
Virtual Functions- Pointers- indirection Operators, Memory Management: new and delete,
Pointers to Objects, A Linked List Example, accessing Arrays using pointers, Function pointers,
Pointers to Pointers, A Parsing Example, Debugging Pointers, Dynamic Pointers, smart pointers,
shared pointers, Case Study : Design of Horse Race Simulation.
Virtual Function- Friend Functions, Static Functions, Assignment and Copy Initialization, this
Pointer, virtual function, dynamic binding, Virtual destructor.
Unit IV
09 Hours
09 Hours
Data hierarchy, Stream and files, Stream Classes, Stream Errors, Disk File I/O with Streams, File
Pointers, and Error Handling in File I/O, File I/O with Member Functions, Overloading the
Extraction and Insertion Operators, memory as a Stream Object, Command-Line Arguments,
Printer output, Early vs. Late Binding.
Unit VI
09 Hours
Introduction to STL, Containers, algorithms and iterators, Containers- Sequence container and
associative containers, container adapters, Algorithms- basic searching and sorting algorithms,
min-max algorithm, set operations, heap sort, Iterators- input, output, forward, bidirectional and
random access. Object Oriented Programming a road map to future
Books:
Text:
1. Bjarne Stroustrup,
The C++ Programming language, Third edition, Pearson Education.
ISBN 9780201889543.
2. Deitel,
C++ How to Program, 4th Edition, Pearson Education, ISBN:81-297-0276-2
References:
1. Robert Lafore,
Object-Oriented Programming in C++, fourth edition, Sams Publishing,
ISBN:0672323087 (ISBN 13: 9780672323089)
2. Herbert Schildt,
C++ The complete reference, Eighth Edition, McGraw Hill
Professional, 2011, ISBN:978-00-72226805
3. Matt Weisfeld,
The Object-Oriented Thought Process, Third Edition Pearson ISBN13:075-2063330166
4. Cox Brad, Andrew J. Novobilski,
Object Oriented Programming: An Evolutionary
Approach, Second Edition, AddisonWesley, ISBN:13:978-020-1548341
#15/65
Faculty of Engineering
Credit
01
Examination Scheme:
TW: 25 Marks
PR: 50 Marks
#16/65
Faculty of Engineering
Sr
Group A
No
1. Realize Full Adder and Subtractor using a) Basic Gates and b) Universal Gates
2. Design and implement Code converters-Binary to Gray and BCD to Excess-3
Design of n-bit Carry Save Adder (CSA) and Carry Propagation Adder (CPA). Design and
3.
Realization of BCD Adder using 4-bit Binary Adder (IC 7483).
Realization of Boolean Expression for suitable combination logic using MUX 74151 /
4.
DMUX 74154
5. Verify the truth table of one bit and two bit comparators using logic gates and comparator IC
6. Design & Implement Parity Generator using EX-OR.
Group B
7. Flip Flop Conversion: Design and Realization
Design and implement a system using flip-flops, to monitor number of vehicles entering and
8. exiting from a car parking area with maximum capacity of 15 and having separate entry and
exit gates.
9. Design of Ripple Counter using suitable Flip Flops
a. Realization of 3 bit Up/Down Counter using MS JK Flip Flop / D Flip Flop
10.
b. Realization of Mod -N counter using ( 7490 and 74193 )
Assume a scenario of a hall where students are entering to attend seminar. Design and
11. implement a system which will increment count if student is entering in the hall and will
decrement count if student is exiting the hall. Assume seating capacity of a hall is 63.
12. Design and Realization of Ring Counter and Johnson Ring counter.
13. Design and implement Sequence generator using JK flip-flop.
14. Design and implement pseudo random sequence generator.
15. Design and implement Sequence detector using JK flip-flop
16. Design of ASM chart using MUX controller Method.
Group C
17. Design and Implementation of Combinational Logic using PLAs.
Design and simulation of - Full adder , Flip flop, MUX using VHDL (Any 2)
18.
Use different modeling styles.
19. Design & simulate asynchronous 3- bit counter using VHDL.
20. Design and Implementation of Combinational Logic using PALs.
Group D (Study Assignments)
21. Study of Shift Registers ( SISO,SIPO, PISO,PIPO )
22. Study of TTL Logic Family: Feature, Characteristics and Comparison with CMOS Family
23. Study of Microcontroller 8051 : Features, Architecture and Programming Model
#17/65
Faculty of Engineering
Credit
02
Examination Scheme:
TW: 25 Marks
PR: 50 Marks
#18/65
Faculty of Engineering
2.
3.
4.
5.
6.
Group A
In Second year Computer Engineering class of M students, set A of students play cricket and
set B of students play badminton. Write C/C++ program to find and displayi.
Set of students who play either cricket or badminton or both
ii.
Set of students who play both cricket and badminton
iii. Set of students who play only cricket
iv.
Set of students who play only badminton
v.
Number of students who play neither cricket nor badminton
(Note- While realizing the set duplicate entries are to avoided)
Write C/C++ program to store marks scored for first test of subject 'Data Structures and
Algorithms' for N students. Compute
I. The average score of class
ii. Highest score and lowest score of class
iii. Marks scored by most of the students
iv. list of students who were absent for the test
Department library has N books. Write C/C++ program to store the cost of books in array in
ascending order. Books are to be arranged in descending order of their cost. Write function
for
a) Reverse the contents of array without using temporary array.
b) Copy costs of books those with cost less than 500 in new array
c) Delete the duplicate entries using temporary array
d) Delete duplicate entries without using temporary array
e) Count number of books with cost more than 500.
Set A=(1,3, a, s, t, i} represent alphanumeric characters permitted to be used to set the
password of length 4. Write C/C++ program to generate all possible passwords.
A magazine committee is to be formed that consists of any 3 members to be selected from
{ Nikhita, Aboli, Megha, Sanika, Pratik, Saurabh}. Write C/C++ program to list all possible
committees.
It is decided that weekly greetings are to be furnished to wish the students having their
birthdays in that week. The consolidated sorted list with desired categorical information is
#19/65
Faculty of Engineering
to be provided to the authority. Write C++ program for array of structures to store students
PRNs with date and month of birth. Let Array_A and Array_B be the two arrays for two SE
Computer divisions. Arrays are sorted on date and month. Merge these two arrays into third
array Array_SE_Comp_DOB resulting in sorted information about Date of Birth of SE
Computer students.
7.
A magic square is an n * n matrix of the integers 1 to n2 such that the sum of each row,
column, and diagonal is the same. The figure given below is an example of magic square for
case n=5. In this example, the common sum is 65. Write C/C++ Program for magic square.
15
8
1
24
17
16
14
7
5
23
22
20
13
6
4
3
21
19
12
10
9
2
25
18
11
8.
An m x n matrix is said to have a saddle point if some entry a[i][j] is the smallest value in
row i and the largest value in j. Write C/ C++ function that determines the location of a
saddle point if one exists.
9.
Write C/C++ program for storing matrix. Write functions for
a) Check whether given matrix is upper triangular or not
b) Compute summation of diagonal elements
c) Compute transpose of matrix
d) Add, subtract and multiply two matrices
10. Write C++ program with class for String. Write a function
frequency that determines the frequency of occurrence of particular character in the
string.
delete that accepts two integers, start and length. The function computes a new string
that is equivalent to the original string, except that length characters being at start have
been removed.
chardelete that accepts a character c. The function returns the string with all occurrences
of c removed.
replace to make an in-place replacement of a substring w of a string by the string x. note
that w may not be of same size of x
palindrome to check whether given string is palindrome or not
11. Write C++ program for sparse matrix realization and operations on it- Transpose, Fast
Transpose and addition of two matrices
12. Write C++ program for string operations- copy, concatenate, check substring, equal, reverse
and length
13. Write a C++ program to realize polynomial equation and perform operations. Write function
a) To input and output polynomials represented as bmxem+ bm-1xem-1 +.. +b0xe0.
Your functions should overload the << and >> operators.
1. b) Evaluates a polynomial at given value of x
2. c) Add two polynomials
3. d) Multiplies two polynomials
Group B
14. Department of Computer Engineering has student's club named 'Pinnacle Club'. Students of
Second, third and final year of department can be granted membership on request. Similarly
one may cancel the membership of club. First node is reserved for president of club and last
node is reserved for secretary of club. Write C++ program to maintain club members
information using singly linked list. Store student PRN and Name. Write functions to
Syllabus for Second Year of Computer Engineering
#20/65
Faculty of Engineering
a)
b)
c)
d)
15.
16.
17.
18.
19.
20.
21.
#21/65
Faculty of Engineering
22.
23.
24.
25.
26.
27.
#22/65
Faculty of Engineering
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
8 by 8 grid. The board normally alternates between black and white square, but this is not
relevant for the present problem. The queen can move as far as she wants in any direction,
as long as she follows a straight line, Vertically, horizontally, or diagonally. Write C++
program with recursive function for generating all possible configurations for 4-queen's
problem.
Group D
Queues are frequently used in computer programming, and a typical example is the creation
of a job queue by an operating system. If the operating system does not use priorities, then
the jobs are processed in the order they enter the system. Write C++ program for simulating
job queue. Write functions to add job and delete job from queue.
Write program to implement a priority queue in C++ using an inorder List to store the items
in the queue. Create a class that includes the data items(which should be template) and the
priority (which should be int)The inorder list should contain these objects ,with operator <=
overloaded so that the items with highest priority appear at the beginning of the list (which
will make it relatively easy to retrieve the highest item.)
A double-ended queue(deque) is a linear list in which additions and deletions may be made
at either end. Obtain a data representation mapping a deque into a one-dimensional array.
Write C++ program to simulate deque with functions to add and delete elements from either
end of the deque.
Pizza parlor accepting maximum M orders. Orders are served in first come first served
basis. Order once placed cannot be cancelled. Write C++ program to simulate the system
using circular queue using array.
Group E
Write C++ program to store roll numbers of student in array who attended training program
in random order. Write function fora) Searching whether particular student attended training program or not using linear search
and sentinel search. b) Searching whether particular student attended training program or
not using binary search and Fibonacci search.
Write C++ program to store names and mobile numbers of your friends in sorted order on
names. a) Search your friend from list using binary search (recursive and non recursive).
Insert friend if not present in phonebook. b) Search your friend from list using Fibonacci
search. Insert friend if not present in phonebook.
Write C++ program to maintain club members, sort on roll numbers in ascending order.
Write function Ternary_Search to search whether particular student is member of club.
Ternary search is modified binary search that divides array into 3 halves instead of two.
Write C++ program to store first year percentage of students in array. Write function for
sorting array of floating point numbers in ascending order using
a) Selection Sort b) Bubble sort and display top five scores.
Write C++ program to store second year percentage of students in array. Write function for
sorting array of floating point numbers in ascending order using
a) Insertion sort b) Shell Sort and display top five scores.
Write C++ program to store first year percentage of students in array. Sort array of floating
point numbers in ascending order using quick sort and display top five scores.
Write C++ program to store XII percentage of students in array. Sort array of floating point
numbers in ascending order using bucket sort and display top five scores.
Write C++ program to store X percentage of students in array. Sort array of floating point
numbers in ascending order using radix sort and display top five scores.
#23/65
Faculty of Engineering
Credit
01
Examination Scheme:
TW: 25 Marks
PR: 50 Marks
#24/65
Faculty of Engineering
Instructor may also set one assignment or mini-project that is suitable to respective branch beyond
the scope of syllabus.
Operating System recommended :64-bit Open source Linux or its derivative
Programming tools recommended: - Open Source C++ Programming tool like G++/GCC.
First assignment is compulsory. Set of suggested assignment list is provided in 3 groups- A, B, and
C. Instructor is suggested to design assignments list by selecting/designing at least 12 suitable
assignments from group A, B, and C- compulsory assignment, 5 from group A, 4 from group B,
3 from group C.
Suggested List of Laboratory Assignments
Compulsory Assignment
1.
Install, Configure 64 bit Linux Operating Systems, study basic architecture, memory system,
and learn basic administration.
Group A
Implement a class Complex which represents the Complex Number data type. Implement the
following operations:
1. Constructor (including a default constructor which creates the complex number 0+0i).
2.
2. Overloaded operator+ to add two complex numbers.
3. Overloaded operator* to multiply two complex numbers.
4. Overloaded << and >> to print and read Complex Numbers.
Implement a class Quadratic that represents degree two polynomials i.e., polynomials of type
ax2+bx+c. The class will require three data members corresponding to a, b and c. Implement
the following operations:
1. A constructor (including a default constructor which creates the 0 polynomial).
2. Overloaded operator+ to add two polynomials of degree 2.
3.
3. Overloaded << and >> to print and read polynomials. To do this, you will need to
decide what you want your input and output format to look like.
4. A function eval that computes the value of a polynomial for a given value of x.
5. A function that computes the two solutions of the equation ax2+bx+c=0.
Implement a class CppArray which is identical to a one-dimensional C++ array (i.e., the index
set is a set of consecutive integers starting at 0) except for the following :
1. It performs range checking.
4.
2. It allows one to be assigned to another array through the use of the assignment
operator (e.g. cp1= cp2)
3. It supports a function that returns the size of the array.
4. It allows the reading or printing of array through the use of cout and cin.
Write a C++ program create a calculator for an arithmetic operator (+, -, *, /). The program
should take two operands from user and performs the operation on those two operands
depending upon the operator entered by user. Use a switch statement to select the operation.
Finally, display the result.
Some sample interaction with the program might look like this:
5. Enter first number, operator, second number: 10 / 3
Answer = 3.333333
Do another (y/n)? y
Enter first number, operator, second number: 12 + 100
Answer = 112
Do another (y/n)? n
Syllabus for Second Year of Computer Engineering
#25/65
Faculty of Engineering
7.
8.
9.
10.
11.
Create a class template to represent a generic vector. Include following member functions:
To create the vector.
To modify the value of a given element
To multiply by a scalar value
To display the vector in the form (10,20,30,)
Create a class Rational Number (fractions) with the following capabilities:
a) Create a constructor that prevents a 0 denominator in a fraction, reduces or simplifies
fractions that are not in reduced form and avoids negative denominators.
b) Overload the addition, subtraction, multiplication and division operators for this class.
c) Overload the relational and equality operators for this class.
Imagine a publishing company which does marketing for book and audiocassette versions.
Create a class publication that stores the title (a string) and price (type float) of a publication.
From this class derive two classes: book, which adds a page count (type int), and tape, which
adds a playing time in minutes (type float).
Write a program that instantiates the book and tape classes, allows user to enter data and
displays the data members. If an exception is caught, replace all the data member values with
zero values.
Write a function in C++ to count and display the number of lines not starting with
alphabet 'A' present in a text file "STORY.TXT".
Example:
If the file "STORY.TXT" contains the following lines,
The roses are red.
A girl is playing there.
There is a playground.
An aeroplane is in the sky.
Numbers are not allowed in the password.
The function should display the output as 3.
Write C++ Program with base class convert declares two variables, val1 and val2, which
hold the initial and converted values, respectively. It also defines the functions getinit( ) and
getconv( ), which return the initial value and the converted value. These elements of convert
are fixed and applicable to all derived classes that will inherit convert. However, the function
that will actually perform the conversion, compute( ), is a pure virtual function that must be
defined by the classes derived from convert. The specific nature of compute( ) will be
determined by what type of conversion is taking place.
#26/65
Faculty of Engineering
12.
13.
14.
15.
16.
17.
18.
A book shop maintains the inventory of books that are being sold at the shop. The list includes
details such as author, title, price, publisher and stock position. Whenever a customer wants a
book, the sales person inputs the title and author and the system searches the list and displays
whether it is available or not. If it is not, an appropriate message is displayed. If it is, then the
system displays the book details and requests for the number of copies required. If the
requested copies book details and requests for the number of copies required. If the requested
copies are available, the total cost of the requested copies is displayed; otherwise the message
Required copies not in stock is displayed. Design a system using a class called books with
suitable member functions and Constructors. Use new operator in constructors to allocate
memory space required. Implement C++ program for the system.
Create employee bio-data using following classes i) Personal record ii))Professional record iii)
Academic record Assume appropriate data members and member function to accept required
data & print bio-data. Create bio-data using multiple inheritance using C++.
Group B
Crete User defined exception to check the following conditions and throw the exception if the
criterion does not meet.
a. User has age between 18 and 55
b. User stays has income between Rs. 50,000 Rs. 1,00,000 per month
c. User stays in Pune/ Mumbai/ Bangalore / Chennai
d. User has 4-wheeler
Accept age, Income, City, Vehicle from the user and check for the conditions mentioned
above. If any of the condition not met then throw the exception.
Write a menu driven program that will create a data file containing the list of telephone
numbers in the following form
John 23456
Ahmed 9876
..
Use a class object to store each set of data, access the file created and implement the following
tasks
I.
Determine the telephone number of specified person
II.
Determine the name if telephone number is known
III.
Update the telephone number, whenever there is a change.
Write a C++ program that creates an output file, writes information to it, closes the file and
open it again as an input file and read the information from the file.
Write a C++ program using command line arguments to search for a word in a file and replace
it with the specified word. The usage of the program is shown below.
$ change <old word> <new word> <file name>
Write a function template selection Sort. Write a program that inputs, sorts and outputs an
integer array and a float array.
#27/65
Faculty of Engineering
You are the owner of a hardware store and need to keep an inventory that can tell you what
different tools you have, how many of each you have on hand and the cost of each one. Write
a program that initializes the random-access file hardware.dat to 100 empty records, lets you
input the data concerning each tool, enables you to list all your tools, lets you delete a record
for a tool that you no longer have and lets you update any information in the file. The tool
identification number should be the record number. Use the following information to start
19. your file:
Record #
Tool name
Quantity
Cost
3
Electric sander
7
57.98
17
Hammer
76
11.99
24
Jig saw
21
11.00
39
Lawn mower
3
79.50
56
Power saw
18
99.99
Group C
20. Write C++ program using STL for implementation of Singly, doubly and circular linked list.
21. Write C++ program using STL for implementation of stack & queue using SLL
22.
Write C++ program using STL to add binary numbers (assume one bit as one number); use
STL stack.
23. Write C++ program using STL for Dqueue (Double ended queue)
Write C++ program using STL for Sorting and searching with user-defined records such as
24. Person Record (Name, birth date, telephone no), item record (item code, item name, quantity
and cost)
Mini-projects
25. Design and develop the Tic-Tac-Toe Game using C++
26.
27.
28.
29.
Develop a Supermarket Billing System using C++. The key features of this application are
listed below :
Bill Report: It shows the bill report of all the items added in supermarket billing
system.
Add, Remove or Edit items: With this feature one can add, remove and modify item
details. In add items, one can add information or details such as item no., item name,
manufacturing date, price, quantity, tax percent, and many more.
Show item details: This feature allows users to see the items and the corresponding
details given for the item while adding the item.
Use file to store the data.
Design an E-mail Verifier which accepts the email address from the user. Depending upon the
input given by user display appropriate results. Use the following concepts in the Project
Constructor, Destructor, new, delete, exceptional handling, string handling functions, etc.
Design and Develop Library Management system using OOP Concepts.
Write a C++ program to implement a small database mini project to understand persistent
objects and operations on sequential files (ex- library information, inventory systems,
automated banking system, reservation systems etc.) For example, write a program to create a
database for reservation system using information such as Name, sex, age, starting place of
journey and destination. Program should have following facilities a) To display entire
passenger list b) To display particular record c) To update record d) To delete and sort record.
Use Exception Handling for data verification
#28/65
Faculty of Engineering
Credit
01
Examination Scheme:
TW: 25 Marks
Course Objectives:
To encourage the all round development of students by focusing on soft skills.
To make the engineering students aware of the importance, the role and the content of soft
skills through instruction, knowledge acquisition, demonstration and practice.
To develop and nurture the soft skills of the students through individual and group
activities.
To expose students to right attitudinal and behavioral aspects and to build the same through
activities
Course Outcomes:
On completion of the course, student will be able to
Effectively communicate through verbal/oral communication and improve the listening
skills
Write precise briefs or reports and technical documents.
Actively participate in group discussion / meetings / interviews and prepare & deliver
presentations.
Become more effective individual through goal/target setting, self motivation and practicing
creative thinking.
Function effectively in multi-disciplinary and heterogeneous teams through the knowledge
of team work, Inter-personal relationships, conflict management and leadership quality.
Course Contents
Unit I
Self-Development
Introduction to soft skills, Self-Management: Self-Evaluation, Self-Discipline, Self-Criticism, SelfAwareness, Self-Esteem, Positive Thinking, Perceptions and Attitudes, Values and Belief
Systems, Personal success factors, Handling failure, Knowing Yourself, identifying ones
strengths and weaknesses, SWOT analysis, Joharis Window, Career Planning & Goal setting,
prioritization, Managing self emotions, ego, pride, stress; Personality development.
Unit II
Communication Skills
#29/65
Faculty of Engineering
Vocabulary: One - Word Substitutes, Words often Confused - Pairs of Words, Synonyms and
Antonyms, Foreign Phrases, Phrasal verbs derived from the dynamic verbs, Business Writing:
Note Making, Letter writing, Writing Formal Letters. Technical Report Writing, Memo,
Notices/Circulars Agenda and Minutes of a Meeting, E-Mail, Essay writing. Employment
Communication: Job Application, Preparation of CV and Resume writing. Presentation skills:
Professional Presentation, Nature of Oral Presentation, Planning a Presentation, Preparing the
Presentation, Delivering the Presentation.
Unit IV
Introduction, Leader and Leadership, Leadership Traits, Culture and Leadership: Salient Features
of Corporate Culture, Leadership Styles, Leadership Trends, Team Building: Team Development
Stages, Types of Teams: Cross-functional Team, Problem-solving Team, Inter- personal relations:
Types of feelings, steps to deal with complex feelings. Assertiveness and Confidence building.
Types of Conflict and resolutions. Emotions, emotional empathy and emotional intelligence.
Unit V
Introduction, Stress in Todays Time: Identify the Stress Source, Signs of Stress, Ways to Cope
with Stress : Healthier Ways to Combat Stress, Steps to be Taken in the Organizations : Open
communication, Time Management, Working towards Your Goals, Smart Work, Prioritize your
Tasks,4 Ds of Decision Making.
Unit VI
#30/65
Faculty of Engineering
References:
1. Indrajit Bhattacharya,
An Approach to Communication Skills, Delhi, Dhanpat Rai, 2008.
2. Simon Sweeney,
English for Business Communication, Cambridge University Press,
ISBN 13:978-0521754507.
3. Sanjay Kumar and Pushpa Lata,
Communication Skills, Oxford University Press, ISBN
10:9780199457069.
4. Atkinson and Hilgard's,
Introduction to Psychology, 14th Edition, Geoffrey Loftus,
ISBN-10:0155050699 2003
5. Kenneth G. Mcgee,
Heads Up: How to Anticipate Business Surprises & Seize
Opportunities First, Harvard Business School Press, Boston, Massachusetts, 2004, ISBN
10:1591392993.
6. Krishnaswami, N. and Sriraman, T,
Creative English for Communication, Macmillan.
Guidelines for Instructor's Manual
The instructors manual is to be developed as a hands-on resource and reference. The instructor's
manual
need
to
include
prologue
(about
University/program/
institute/
department/foreword/preface etc), University syllabus, conduction & Assessment guidelines,
topics under consideration concept objectives, outcomes, guidelines, references.
Guidelines for Student's Lab Journal and TW Assessment
The student must prepare the journal in the form of report elaborating the activities performed in the
lab. Continuous assessment of laboratory work is to be done based on overall performance and lab
assignments performance of student. Each lab assignment assessment will assign grade/marks
based on parameters with appropriate weightage. Suggested parameters for overall assessment as
well as each lab assignment assessment include- timely completion, performance, punctuality,
neatness, enthusiasm, participation and contribution in various activities-SWOT analysis,
presentations, team activity, event management, group discussion, Group exercises and interpersonal
skills and similar other activities/assignments.
Guidelines for Soft skills Lab Conduction
The instructor may frame assignments to enhance skills supporting career aspects. Multiple set of
activity based assignments can be prepared and distributed among batches. Every student must be
given adequate opportunity to participate actively in each activity. An exercise can be designed to
allow multiple skills exposure for example a group task encouraging discussions, team building, value
sharing, leadership and role play all at the same time.
Suggested List of Laboratory Assignments
1.
2.
SWOT analysis
The students should be made aware of their goals, strengths and weaknesses, attitude, moral
values, self confidence, etiquettes, non-verbal skills, achievements etc. through this activity.
SWOT Analysis, Confidence improvement, values, positive attitude, positive thinking and
self esteem. The concern teacher should prepare a questionnaire which evaluate students in
all the above areas and make them aware about these aspects.
Personal & Career Goal setting Short term & Long term
The teacher should explain to them on how to set goals and provide template to write their
short term and long term goals.
#31/65
Faculty of Engineering
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
Public Speaking
Any one of the following activities may be conducted :
1. Prepared speech (Topics are given in advance, students get 10 minutes to prepare the
speech and 5 minutes to deliver.) 2. Extempore speech (Students deliver speeches
spontaneously for 5 minutes each on a given topic) 3. Story telling (Each student narrates a
fictional or real life story for 5 minutes each) 4. Oral review ( Each student orally presents a
review on a story or a book read by them)
Reading and Listening skills
The batch can be divided into pairs. Each pair will be given an article (any topic) by the
teacher. Each pair would come on the stage and read aloud the article one by one. After
reading by each pair, the other students will be asked questions on the article by the readers.
Students will get marks for correct answers and also for their reading skills. This will
evaluate their reading and listening skills. The teacher should give them guidelines on
improving their reading and listening skills. The teacher should also give passages on
various topics to students for evaluating their reading comprehension.
Group discussion
Group discussions could be done for groups of 5-8 students at a time Two rounds of a GD
for each group should be conducted and teacher should give them feedback.
Letter/Application writing
Each student will write one formal letter, and one application. The teacher should teach the
students how to write the letter and application. The teacher should give proper format and
layouts.
Report writing
The teacher should teach the students how to write report .The teacher should give proper
format and layouts. Each student will write one report based on visit / project / business
proposal etc.
Resume writing- Guide students and instruct them to write resume.
Presentation Skill
Students should make a presentation on any informative topic of their choice. The topic may
be technical or non-technical. The teacher should guide them on effective presentation skills.
Each student should make a presentation for at least 10 minutes.
Team games for team building - Students should make to participate in team activity.
Situational games for role playing as leaders
Faculty may arrange one or more sessions from following:
Yoga and meditation. Stress management, relaxation exercises, and fitness exercises.
Time management and personal planning sessions.
Mock interviews- guide students and conduct mock interviews
#32/65
Faculty of Engineering
In addition to credits, it is recommended that there should be audit course in preferably in each
semester from second year to supplement knowledge and skills. A student will be awarded the
bachelors degree if he/she earns 190 credits and clears all the audit courses specified in the
syllabus. The student will be awarded grade as AP on successful completion of audit course.
The student may opt for one of the audit courses per semester, starting from second year first
semester. Though not mandatory, such a selection of the audit courses helps the learner to explore
the subject of interest in greater details resulting in achieving the very objective of audit course's
inclusion. List of options offered is provided. Each student has to choose one audit course from the
list per semester. Evaluation of audit course will be done at institute level itself. Method of
conduction and method of assessment for audit courses are suggested.
Criteria:
The student registered for audit course shall be awarded the grade AP (Audit Course Pass) and
shall be included such AP grade in the Semester grade report for that course, provided student has
the minimum attendance as prescribed by the Savitribai Phule Pune University and satisfactory insemester performance and secured a passing grade in that audit course. No grade points are
associated with this 'AP' grade and performance in these courses is not accounted in the calculation
of the performance indices SGPA and CGPA. Evaluation of audit course will be done at institute
level
itself.
(Refhttp://www.unipune.ac.in/Syllabi_PDF/revised2015/engineering/UG_RULE_REGULATIONS_FOR_CREDIT_SYSTEM-2015_18June.pdf)
Guidelines for Conduction and Assessment (Any one or more of following but not limited to)
Surveys
Mini Project
Hands on experience on
specific focused topic
Guidelines for Assessment (Any one or more of following but not limited to)
Written Test
IPR/Publication
Demonstrations/ Practical Test
Report
Presentations
Audit Course 1 Options
Course Code
AC1-I
Road Safety
AC1-II
AC1-III
Environmental Studies
AC1-IV
Smart Cities
AC1-V
#33/65
Faculty of Engineering
#34/65
Faculty of Engineering
human kind, social change and evolution. Industrial revolution. National policy on
education, health and health care and human development.
#35/65
Faculty of Engineering
Water & Air Pollution, Global Warming, Control Strategies, International Treaties.
Energy Sources: Renewable & Non Renewable, Hydro power, Biomass, Ocean,
Geothermal & Tidal. Global Environmental Issues: Population Growth, Soil Degradation,
Loss of Biodiversity.
References:
1. Krugman, International Economics, Pearson Education, ISBN-13:000-01334-23646
2. Prakash, T
he Indian Economy, Pearson Education, ISBN-8131758931
3. Thursen Gerald, E
ngineering Economics, Prentice Hall, ISBN-10:0138221227
4. C.S. Rao,
Environmental Pollution Control Engineering, New Age International Pvt. Ltd,
ISBN-812241835X
5. Rangarajan,
Environmental Issues in India, Pearson Education, ISBN-10:8131708101
6. University of Delhi,
The Individual & Society, Pearson Education. ISBN-8131704173
7. Wikipedia.org / wiki /social studies.
8. M. N. Srinivas,
Social change in modern India, 1991, Orient Longman, ISBN10:812500422X
9. David Mandelbaum,
Society in India, 1990, Popular, ISBN-10:8171540139
10. David Newman,
Exploring the architecture of everyday life, Pine Forge Press, 7th
edition, ISBN-10:1452275947
#36/65
Faculty of Engineering
#37/65
Faculty of Engineering
Understanding how citizens can benefit from data-informed design to develop smart and
responsive cities
Course Contents:
Urbanization and Ubiquity - The slow emergence of learning cities in an urbanizing world
Cities as collective learners, what do we know?- Framing a view -A gamut of learning types Secrets of knowing and accelerating change - Why some cities learn and others do not.
References:
1. Anthony M. Townsend, W. W. Norton & Company
Smart Cities: Big Data, Civic Hackers,
and the Quest for a New Utopia, ISBN: 0393082873, 9780393082876.
2. Tim Campbell, Routledge
Beyond Smart Cities: How Cities Network, Learn and
Innovate, Routledge, ISBN: 9781849714266.
3. Stan Geertman, Joseph Ferreira, Jr. Robert Goodspeed, John Stillwell,
Planning Support
System ms and Smart Cities, Lecture notes in Geo information and Cartography, Springer.
Syllabus for Second Year of Computer Engineering
#38/65
Faculty of Engineering
#39/65
Faculty of Engineering
SEMESTER II
#40/65
Faculty of Engineering
Teaching Scheme:
TH: 04 Hours/Week
TUT: 01 Hour/Week
Credit
05
Examination Scheme:
In-Sem(online): 50 Marks
End-Sem(paper): 50 Marks
TW: 25 Marks
Prerequisites:
Differential and Integral Calculus, Taylor series and Infinite series, Differential equations of first
order and first degree, Fourier series, Measures of Central tendency and dispersion, Vector algebra,
Algebra of complex numbers.
Course Objectives:
After completing this course, student will have adequate mathematical background, conceptual
clarity, computational skills and algorithm design for problem solving related to:
Linear differential equations of higher order applicable to Control systems, Computer vision
and Robotics.
Transform techniques such as Fourier transform, Z-transform and applications to Image
processing.
Statistical methods such as correlation, regression analysis and probability theory to analyze
data and to make predictions applicable to machine intelligence.
Vector calculus necessary to analyze and design complex electrical and electronic devices as
appropriate to Computer engineering.
Complex functions, conformal mappings and contour integration applicable to Image
processing, Digital filters and Computer graphics.
Course Outcomes:
On completion of the course, student will be able to
Solve higher order linear differential equation using appropriate techniques for modeling and
analyzing electrical circuits.
Solve problems related to Fourier transform, Z-Transform and applications to Signal and
Image processing.
Apply statistical methods like correlation, regression analysis and probability theory for
analysis and prediction of a given data as applied to machine intelligence.
Perform vector differentiation and integration to analyze the vector fields and apply to
compute line, surface and volume integrals.
Analyze conformal mappings, transformations and perform contour integration of complex
functions required in Image processing, Digital filters and Computer graphics.
Course Contents
Unit I
09 Hours
th
LDE of n order with constant coefficients, Method of variation of parameters, Cauchys &
Legendres DE, Simultaneous & Symmetric simultaneous DE. Modeling of Electrical circuits.
Unit II
Transforms
09 Hours
Fourier Transform (FT): Complex exponential form of Fourier series, Fourier integral theorem,
Fourier Sine & Cosine integrals, Fourier transform, Fourier Sine and Cosine transforms and their
inverses, Discrete Fourier Transform.
Z - Transform (ZT): Introduction, Definition, Standard properties, ZT of standard sequences and
their inverses. Solution of difference equations.
Syllabus for Second Year of Computer Engineering
#41/65
Faculty of Engineering
Unit III
Statistics
09 Hours
Measures of central tendency, Standard deviation, Coefficient of variation, Moments, Skewness and
Kurtosis, Curve fitting: fitting of straight line, parabola and related curves, Correlation and
Regression, Reliability of Regression Estimates.
Unit IV
Probability and Probability Distributions
09 Hours
Probability, Theorems on Probability, Bayes Theorem, Random variables, Mathematical
Expectation, Probability density function, Probability distributions: Binomial, Poisson, Normal and
Hypergometric, Test of Hypothesis: Chi-Square test, t-distribution.
Unit V
Vector Calculus
09 Hours
Vector differentiation, Gradient, Divergence and Curl, Directional derivative, Solenoid and
Irrigational fields, Vector identities. Line, Surface and Volume integrals, Greens Lemma, Gausss
Divergence theorem and Stokes theorem.
Unit VI
Complex Variables
09 Hours
Functions of Complex variables, Analytic functions, Cauchy-Riemann equations, Conformal
mapping, Bilinear transformation, Cauchys integral theorem, Cauchys integral formula, Laurents
series, and Residue theorem.
Books:
Text:
1. Erwin Kreyszig,
Advanced Engineering Mathematics. 9e, Wiley India, ISBN - 10:
9780470458365, 13: 978-0470458365.
2. Peter V. O'Neil,
Advanced Engineering Mathematics, 7e, Cengage Learning, ISBN - 10:
1111427410.
References:
1. M. D. Greenberg,
Advanced Engineering Mathematics, 2e, Pearson Education, ISBN: 10:
0133214311, 13: 978-0133214314.
2. Wylie C.R. & Barrett L.C.,
Advanced Engineering Mathematics, McGraw-Hill, Inc.,
ISBN: 0-07-072188-2.
3. B. S. Grewal, Higher Engineering Mathematics, Khanna Publication, Delhi, ISBN : 92
803-11026
4. P. N. Wartikar & J. N. Wartikar, Applied Mathematics, Vidyarthi Griha Prakashan, Pune,
ISBN: 0-7923-0594-9.
5. B.V. Ramana,
Higher Engineering Mathematics, Tata McGraw-Hill, ISBN: 007063419X.
6. Thomas L. Harman, Dabney and Norman Richert,
Advanced Engineering Mathematics
with MATLAB, 2e, Thomson Learning, ISBN: 13: 978-0534371647
Guidelines for Tutorial and Term Work:
Tutorial shall be engaged in four batches (batch size of 20 students maximum) per division
Term work shall be based on continuous assessment of six assignments (one per each unit)
and performance in internal tests
#42/65
Faculty of Engineering
Teaching Scheme:
TH: 04 Hours/Week
Credit
04
Examination Scheme:
In-Sem(online): 50 Marks
End-Sem(paper): 50 Marks
Prerequisite:
Data Structures and algorithms
Basic Mathematics, Geometry, linear algebra, vectors and matrices.
Course Objectives:
To acquaint the learner with the basic concepts of Computer Graphics
To learn the various algorithms for generating and rendering graphical figures
To get familiar with mathematics behind the graphical transformations
To understand and apply various methods and techniques regarding projections, animation,
shading, illumination and lighting
Course Outcomes:
On completion of the course, student will be able to
Apply mathematics and logic to develop Computer programs for elementary graphic
operations
Develop scientific and strategic approach to solve complex problems in the domain of
Computer Graphics
Develop the competency to understand the concepts related to Computer Vision and Virtual
reality
Apply the logic to develop animation and gaming programs
Unit I
Course Contents
09 Hours
Concepts, applications of computer graphics, pixel, frame buffer, resolution, aspect ratio.
Plotting Primitives: Scan conversions, lines, line segments, vectors, pixels and frame buffers,
vector generation
Scan Conversion: Line and line segments, qualities of good line drawing algorithms,
line drawing algorithms: Digital Differential Analyzer (DDA), Bresenham and parallel line
algorithms, Line styles: thick, dotted and dashed. Circle drawing algorithm: DDA, Bresenham.
Character generating methods: stroke and bitmap method.
Display Files: display file structure, algorithms and display file interpreter. Primitive operations
on display file.
Unit II
Polygons and Clipping Algorithms
09 Hours
Introduction to polygon, types: convex, concave and complex. Representation of polygon, Inside
test, polygon filling algorithms flood fill, seed fill, scan line fill and filling with patterns.
Windowing and clipping: viewing transformations, 2-D clipping: Cohen Sutherland algorithm,
Polygon clipping: Sutherland Hodgeman algorithm, generalized clipping.
#43/65
Faculty of Engineering
Unit III
09 Hours
#44/65
Faculty of Engineering
Teaching Scheme:
TH: 04 Hours/Week
Credit
04
Examination Scheme:
In-Sem(online): 50 Marks
End-Sem(paper): 50 Marks
Prerequisite:
Data Structures and algorithms
Basic Mathematics, Geometry, linear algebra, vectors and matrices.
Course Objectives:
To develop a logic for graphical modelling of the real life problems.
To suggest appropriate data structure and algorithm for graphical solutions of the problems.
To understand advanced data structures to solve complex problems in various domains.
To operate on the various structured data
To build the logic to use appropriate data structure in logical and computational solutions.
To understand various algorithmic strategies to approach the problem solution.
Course Outcomes:
On completion of the course, student will be able to
To apply appropriate advanced data structure and efficient algorithms to approach the
problems of various domain.
To design the algorithms to solve the programming problems.
To use effective and efficient data structures in solving various Computer Engineering
domain problems.
To analyze the algorithmic solutions for resource requirements and optimization
To use appropriate modern tools to understand and analyze the functionalities confined to
the data structure usage.
Unit I
Course Contents
Trees
09 Hours
Tree- basic terminology, General tree and its representation, representation using sequential and
linked organization, Binary tree- properties, converting tree to binary tree, binary tree traversalsinorder, preorder, post order, level wise -depth first and breadth first, Operations on binary tree.
Binary Search Tree (BST), BST operations, Threaded binary tree- concepts, threading, insertion
and deletion of nodes in in-order threaded binary tree, in order traversal of in-order threaded binary
tree. Case Study- Use of binary tree in expression tree-evaluation and Huffman's coding
Unit II
09 Hours
Graphs
Basic Concepts, Storage representation, Adjacency matrix, adjacency list, adjacency multi list,
inverse adjacency list. Traversals-depth first and breadth first, Introduction to Greedy Strategy,
Minimum spanning Tree, Greedy algorithms for computing minimum spanning tree- Prims and
Kruskal Algorithms, Dikjtra's Single source shortest path, Topological ordering.
Case study- Data structure used in Webgraph and Google map.
#45/65
Faculty of Engineering
Unit III
Hashing
09 Hours
Hash Table- Concepts-hash table, hash function, bucket, collision, probe, synonym, overflow,
open hashing, closed hashing, perfect hash function, load density, full table, load factor, rehashing,
issues in hashing, hash functions- properties of good hash function, division, multiplication,
extraction, mid-square, folding and universal, Collision resolution strategies- open addressing and
chaining, Hash table overflow- open addressing and chaining, extendible hashing.
Dictionary- Dictionary as ADT, ordered dictionaries.
Skip List- representation, searching and operations- insertion, removal.
Unit IV
09 Hours
Search Trees
Symbol Table-Representation of Symbol Tables- Static tree table and Dynamic tree table,
Introduction to Dynamic Programming, Weight balanced tree, Optimal Binary Search Tree
(OBST), OBST as an example of Dynamic Programming, Height Balanced Tree- AVL tree.
Unit V
09 Hours
Indexing and Multiway Trees
Indexing and Multiway Trees- Indexing, indexing techniques, Types of search tree- Multiway
search tree, B-Tree, B+Tree, Trie Tree, Splay Tree, Red-Black Tree, K-dimensional tree, AA tree.
Set- Set ADT, realization of Set and operations.
Heap-Basic concepts, realization of heap and operations, Heap as a priority queue, heap sort
Unit VI
09 Hours
File Organization
Sequential file organization- concept and primitive operations, Direct Access File- Concepts and
Primitive operations, Indexed sequential file organization-concept, types of indices, structure of
index sequential file, Linked Organization- multi list files, coral rings, inverted files and cellular
partitions.
External Sort- Consequential processing and merging two lists, multiday merging- a k way merge
algorithm.
Books:
Text:
1. Horowitz, Sahani, Dinesh Mehata,
Fundamentals of Data Structures in C++, Galgotia
Publisher, ISBN: 8175152788, 9788175152786.
2. M Folk, B Zoellick, G. Riccardi,
File Structures, Pearson Education, ISBN:81-7758-37-5
3. Peter Brass,
Advanced Data Structures, Cambridge University Press, ISBN: 978-1-10743982-5
References:
1. A. Aho, J. Hopcroft, J. Ulman,
Data Structures and Algorithms, Pearson Education, 1998,
ISBN-0-201-43578-0.
2. Michael J Folk,
File Structures an Object Oriented Approach with C++, Pearson
Education, ISBN: 81-7758-373-5.
3. Sartaj Sahani,
Data Structures, Algorithms and Applications in C++, Second Edition,
University Press, ISBN:81-7371522 X.
4. G A V Pai,
Data Structures and Algorithms, The McGraw-Hill Companies, ISBN 9780070667266.
5. Goodrich, Tamassia, Goldwasser,
Data Structures and Algorithms in Java, Wiley
Publication, ISBN: 9788126551903.
Syllabus for Second Year of Computer Engineering
#46/65
Faculty of Engineering
Teaching Scheme:
TH: 04 Hours/Week
Credit
04
Examination Scheme:
In-Sem(online): 50 Marks
End-Sem(paper): 50 Marks
Course Contents
09 Hours
Memory Organization and Segmentation- Global Descriptor Table, Local Descriptor Table,
Interrupt Descriptor Table, Data Types, Registers, Instruction Format, Operand Selection,
Interrupts and Exceptions
Applications Instruction Set- Data Movement Instructions, Binary Arithmetic Instructions,
Decimal Arithmetic Instructions, Logical Instructions, Control Transfer Instructions, String and
Character Transfer Instructions, Instructions for Block Structured Language, Flag Control
Instructions, Coprocessor Interface Instructions, Segment Register Instructions, Miscellaneous
Instructions.
Unit II
09 Hours
Systems Architecture and Memory Management
Systems Architecture- Systems Registers, Systems Instructions.
Memory Management- Segment Translation, Page Translation, Combining Segment and Page
Translation.
Unit III
09 Hours
#47/65
Faculty of Engineering
Unit IV
09 Hours
#48/65
Faculty of Engineering
Teaching Scheme:
TH: 03 Hours/Week
Credit
TH: 03
Examination Scheme:
In-Sem(online): 50 Marks
End-Sem(paper): 50 Marks
Prerequisite: Data Structures & Algorithms and Object Oriented Programming
Course Objectives:
To learn principles of programming language
To understand structural, computational and logical implications regarding programming
languages
To explore main programming paradigms
To understand and apply Object Oriented Programming (OOP) principles using C++ and Java
Course Outcomes:
On completion of the course, student will be able to
To analyze the strengths and weaknesses of programming languages for effective and efficient
program development.
To inculcate the principles underlying the programming languages enabling to learn new
programming languages.
To grasp different programming paradigms
To use the programming paradigms effectively in application development.
Unit I
Course Contents
07 Hours
Software development process, language and software development environments, language and
software design methods, languages and computer architecture, programming language qualities,
languages and reliability, languages and maintainability, languages and efficiency, a brief historical
perspective and early high level languages, a bird's eye view of programming language concepts.
Syntax and semantics-language definition, syntax, abstract syntax, concrete syntax, and
pragmatics, semantics, an introduction to formal semantics, languages, language processing,
interpretation, translation, the concept of binding, variables, name and scope, Type, l-value, r-value,
reference and unnamed variables, routines, generic routines, aliasing and overloading, an abstract
semantic processor, run time structure. Case study- run time structure of C.
Unit II
Structuring the Data, Computations and Program
07 Hours
Structuring of Data- Built in and primitive types, Data aggregates and type constructors, Cartesian
product, Finite mapping User-defined types and abstract data types, Type systems, Static versus
dynamic program checking, Strong typing and type checking, Type compatibility, Type
conversions, Types and subtypes, Generic types, monomorphic versus polymorphic type systems,
Case Study- The type structure of C++, Java. Structuring of Computations- Structuring the
computation, Expressions and statements, Conditional execution and iteration, Routines, Style
issues: side effects and aliasing, Exceptions, Case Study-Exception handling in C++.
Unit III
Structuring of Program
07 Hours
#49/65
Faculty of Engineering
Structuring of ProgramSoftware design method, Concepts in support of modularity, Encapsulation, Interface and
implementation, Separate and independent compilation, Libraries of modules, Language features
for programming in the large, Program organization, Grouping of units, Encapsulation, Interface
and implementation, Abstract data types, classes, and modules, Generic units, Generic data
structures, Generic algorithms, Generic modules, Higher levels of genericity.
Programming paradigms- Introduction to programming paradigms, Introduction to four main
Programming paradigms- procedural, object oriented, functional, and logic & rule based.
Study of Java as Object oriented programming language.
Unit IV
Java as Object Oriented Programming Language-Overview
07 Hours
Java History, Java Features, Java and Internet, Java and Word Wide Web, Web Browsers, Java
Virtual Machine, Data Types and Size (Signed vs. Unsigned, User Defined vs. Primitive Data
Types, Explicit Pointer type) Arrays: one dimensional array, multi-dimensional array, alternative
array declaration statements. Control Statements Revision of identical selection Statements in
brief (if, else if, Nested if, Switch, Nested Switch), Iterative Statements For Each version of For
Loop, Declaring Loop Control Variables Inside the for loop, Using comma in for loop), Jump
Statements (Labeled Break and Labeled Continue), String Handling: String class methods.
Unit V
Inheritance, Polymorphism, Encapsulation using Java
07 Hours
Classes and Methods: class fundamentals, declaring objects, assigning object reference variables,
adding methods to a class, returning a value, constructors, this keyword, garbage collection,
finalize() method, overloading methods, argument passing, object as parameter, returning objects,
access control, static, final, nested and inner classes, command line arguments, variable-length
arguments. Inheritances: member access and inheritance, super class references, Using super,
multilevel hierarchy, constructor call sequence, method overriding, dynamic method dispatch,
abstract classes, Object class. Packages and Interfaces: defining a package, finding packages and
CLASSPATH, access protection, importing packages, interfaces (defining, implementation,
nesting, applying), variables in interfaces, extending interfaces, instance of operator.
Unit VI
Exception Handling in Java
07 Hours
fundamental, exception types, uncaught exceptions, try, catch, throw, throws, finally, multiple catch
clauses, nested try statements, built-in exceptions, custom exceptions (creating your own exception
sub classes). Managing I/O: Streams, Byte Streams and Character Streams, Predefined Streams,
Reading console Input, Writing Console Output, Print Writer class, Applet: Applet Fundamental,
Applet Architecture, Applet Skeleton, Requesting Repainting, status window, HTML Applet tag,
passing parameters to Applets, Difference between Applet and Application Program.
Books:
Text:
1. Carlo Ghezzi, Mehdi Jazayeri,
Programming Language Concepts,3rd Ed, Wiley
Publication ISBN : 978-81-265-1861-6.
2. Herbert Schildt, "The Complete Reference Java", 9th Ed, TMH,ISBN: 978-0-07-180856-9.
References:
1. Sebesta R., "Concepts of Programming Languages", 4th Edition, Pearson Education, ISBN81-7808-161-X.
2. Deugo,
Java Gems, Cambridge University Press, ISBN 10: 0521648246 ISBN 13:
9780521648240
3. T. W. Pratt, M. V. Zelkowitz, "Programming Languages Design and Implementation, 4th
Ed, PHI, ISBN 81-203-2035-2.
Syllabus for Second Year of Computer Engineering
#50/65
Faculty of Engineering
Lab Scheme:
PR: 02 Hours/Week
Credit
01
Examination Scheme:
TW: 25 Marks
PR: 50 Marks
#51/65
Faculty of Engineering
Use of open source software is encouraged. In addition to these, instructor may assign one real life
application in the form of a mini-project. Based on the concepts learned. Instructor may also set
one assignment or mini-project that is suitable to respective branch beyond the scope of syllabus.
Operating System recommended :64-bit Open source Linux or its derivative
Programming tools recommended: - Open Source C++ Programming tool like G++/GCC.
Set of suggested assignment list is provided in groups- A, B, and C. Instructor is suggested to
design lab assignments list by selecting/designing 12 suitable assignments- any 5 of group A, 5
from group B, 2 from group C (assignment number 26 is mandatory).
Suggested List of Laboratory Assignments
Group A
1.
Write C++/Java program to draw line using DDA and Bresenhams algorithm. Inherit pixel
class and Use function overloading.
2.
Write C++/Java program to draw circle using Bresenhams algorithm. Inherit pixel class.
3.
4.
5.
6.
Write C++/Java program to draw 2-D object and perform following basic transformations,
a) Scaling
b) Translation
c) Rotation
Use operator overloading.
Write C++/Java program to fill polygon using scan line algorithm. Use mouse interfacing to
draw polygon.
A Mandelbrot Set is a set of complex number z that does not diverge under the
transformation
with
.Where, both x and z represent the complex
numbers. Write C++/Java program to
a). Plot the Mandelbrot set for the threshold |x|= 2.
b) Plot Julia set choosing z 0. Use 254 colors for plotting in both cases.
Write C++/Java program to draw the polygons by using the mouse. Choose colors by clicking
on the designed color pane. Use window port to draw. Use DDA algorithm for line drawing.
Write C++/Java program to draw inscribed and Circumscribed circles in the triangle as shown
as an example below. (Use any Circle drawing and Line drawing algorithms)
7.
Write C++/Java program to draw the following pattern using any Line drawing algorithms.
8.
#52/65
Faculty of Engineering
9.
10.
11.
12.
13.
14.
15.
16.
Write C++/Java program to draw a 4X4 chessboard rotated 45 with the horizontal axis. Use
Bresenham algorithm to draw all the lines. Use seed fill algorithm to fill black squares of the
rotated chessboard.
Group B
Write C++/Java program for line drawing using DDA or Bresenhams algorithm with patterns
such as solid, dotted, dashed, dash dot and thick.
Write C++/Java program to draw a convex polygon and fill it with desired color using Seed
fill algorithm. Use mouse interfacing to draw polygon.
Write C++/Java program to draw a concave polygon and fill it with desired pattern using scan
line algorithm. Use mouse interfacing to draw polygon.
Write C++/Java program to implement Cohen-Sutherland line clipping algorithm for given
window. Draw line using mouse interfacing to draw polygon
Write C++/Java program to draw any object such as flower, waves using any curve generation
techniques
Write C++/Java program to implement Painters algorithm for hidden surface removal
Write C++/Java program to implement reflection of2-D object about X axis, Y axis and about
X=Y axis. Also rotate object about arbitrary point given by user.
17. Write C++/Java program to generate Hilbert curve using concept of fractals.
18. Write C++/Java program to generate snowflake using concept of fractals.
19. Write C++/Java program to generate Bouncing ball animation using Direct3D/Maya/Blender
Write program to implement Cohen Sutherland Hodgman algorithm to clip any polygon.
20.
Provide the vertices of the polygon to be clipped and pattern of clipping interactively.
Write C++/Java program to implement translation, sheer, rotation and scaling transformations
21.
on equilateral triangle and rhombus.
Group C
Write C++/Java program to draw 3-D cube and perform following transformations on it using
OpenGL. a) Scaling b) Translation c) Rotation about one axis
Design and simulate any data structure like stack, queue, and trees using graphics. Simulation
23. should include all operations performed on designed data structure. Implement the same using
OpenGL.
Write C++/Java program to draw implement Cube rotation about vertical axis passing through
24.
its centroid.
22.
25. Write C++/Java program to generate fractal patterns by using Koch curves.
Write C++/Java program to simulate any one of or similar scene Clock with pendulum
National Flag hoisting
26.
Vehicle/boat locomotion
Water drop falling into the water and generated waves after impact
Kaleidoscope views generation (at least 3 colorful patterns)
Mini Project (Optional)- Design and implement game / animation clip / Graphics Editor using
open source graphics library.
Syllabus for Second Year of Computer Engineering
#53/65
Faculty of Engineering
Credit
02
Examination Scheme:
TW: 50 Marks
PR: 50 Marks
#54/65
Faculty of Engineering
3
4
5
6
7
8
A book consists of chapters, chapters consist of sections and sections consist of subsections.
Construct a tree and print the nodes. Find the time and space requirements of your method.
Beginning with an empty binary search tree, Construct binary search tree by inserting the
values in the order given. After constructing a binary tree i.
Insert new node
ii. Find number of nodes in longest path
iii. Minimum data value found in the tree
iv.
Change a tree so that the roles of the left and right pointers are swapped at
every node
v.
Search a value
For given expression eg. a-b*c-d/e+f construct inorder sequence and traverse it using
postorder traversal(non recursive).
Read for the formulas in propositional calculus. Write a function that reads such a formula and
creates its binary tree representation. What is the complexity of your function?
Given binary tree with n nodes, assign this tree to another [operator=] and then erase all nodes
in a binary tree.
Convert given binary tree into threaded binary tree. Analyze time and space complexity of the
algorithm.
Consider threading a binary tree using preorder threads rather than inorder threads. Design an
algorithm for traversal without using stack and analyze its complexity.
A Dictionary stores keywords & its meanings. Provide facility for adding new keywords,
deleting keywords, updating values of any entry. Provide facility to display whole data sorted
in ascending/ Descending order. Also find how many maximum comparisons may require for
finding any keyword. Use Binary Search Tree for implementation.
Group B
#55/65
Faculty of Engineering
10
11
12
13
14
15
16
17
Write a function to get the number of vertices in an undirected graph and its edges. You may
assume that no edge is input twice.
i. Use adjacency list representation of the graph and find runtime of the function
ii. Use adjacency matrix representation of the graph and find runtime of the function
There are flight paths between cities. If there is a flight between city A and city B then there is
an edge between the cities. The cost of the edge can be the time that flight takes to reach city
B from A, or the amount of fuel used for the journey. Represent this as a graph. The node can
be represented by airport name or name of the city. Use adjacency list representation of the
graph or use adjacency matrix representation of the graph. Justify the storage representation
used.
You have a business with several offices; you want to lease phone lines to connect them up
with each other; and the phone company charges different amounts of money to connect
different pairs of cities. You want a set of lines that connects all your offices with a minimum
total cost. Solve the problem by suggesting appropriate data structures.
Tour operator organizes guided bus trips across the Maharashtra. Tourists may have different
preferences. Tour operator offers a choice from many different routes. Every day the bus
moves from starting city S to another city F as chosen by client. On this way, the tourists can
see the sights alongside the route travelled from S to F. Client may have preference to choose
route. There is a restriction on the routes that the tourists may choose from, the bus has to take
a short route from S to F or a route having one distance unit longer than the minimal distance.
Two routes from S to F are considered different if there is at least one road from a city A to a
city B which is part of one route, but not of the other route.
Consider the scheduling problem. n tasks to be scheduled on single processor. Let t1, ..., tn be
durations required to execute on single processor is known. The tasks can be executed in any
order but one task at a time. Design a greedy algorithm for this problem and find a schedule
that minimizes the total time spent by all the tasks in the system. (The time spent by one is the
sum of the waiting time of task and the time spent on its execution.)
Group C
Consider telephone book database of N clients. Make use of a hash table implementation to
quickly look up clients telephone number.
Implement all the functions of a dictionary (ADT) using hashing.
Data: Set of (key, value) pairs, Keys are mapped to values, Keys must be comparable, Keys
must be unique
Standard Operations: Insert(key, value), Find(key), Delete(key)
For given set of elements create skip list. Find the element in the set that is closest to some
given value.
The symbol table is generated by compiler. From this perspective, the symbol table is a set of
name-attribute pairs. In a symbol table for a compiler, the name is an identifier, and the
attributes might include an initial value and a list of lines that use the identifier.
Perform the following operations on symbol table:
(1) Determine if a particular name is in the table
(2) Retrieve the attributes of that name
(3) Modify the attributes of that name
(4) Insert a new name and its attributes
(5) Delete a name and its attributes
Group D
#56/65
Faculty of Engineering
18
19
20
21
22
23
24
25
26
27
28
29
30
31
Given sequence k = k1 <k2 < < kn of n sorted keys, with a search probability pi for each
key ki . Build the Binary search tree that has the least search cost given the access probability
for each key.
A Dictionary stores keywords & its meanings. Provide facility for adding new keywords,
deleting keywords, updating values of any entry. Provide facility to display whole data sorted
in ascending/ Descending order. Also find how many maximum comparisons may require for
finding any keyword. Use Height balance tree and find the complexity for finding a keyword
Group E
Assume we have two input and two output tapes to perform the sorting. The internal memory
can hold and sort m records at a time. Write a program in java for external sorting. Find out
time complexity.
Department maintains a student information. The file contains roll number, name, division
and address. Allow user to add, delete information of student. Display information of
particular employee. If record of student does not exist an appropriate message is displayed.
If it is, then the system displays the student details. Use sequential file to main the data.
Company maintains employee information as employee ID, name, designation and salary.
Allow user to add, delete information of employee. Display information of particular
employee. If employee does not exist an appropriate message is displayed. If it is, then the
system displays the employee details. Use index sequential file to maintain the data.
Group G
Implement the Heap/Shell sort algorithm implemented in Java demonstrating heap/shell data
structure with modularity of programming language.
Any application defining scope of Formal parameter, Global parameter, Local parameter
accessing mechanism and also relevance to private, public and protected access. Write a Java
program which demonstrates the scope rules of the programming mechanism.
Write a Java program which will demonstrate a concept of Interfaces and packages: In this
assignment design and use of customized interfaces and packages for a specific application
are expected.
Write a Java program which will demonstrate a concept of cohesion and coupling of the
various modules in the program.
Write a program on template and exception handling in Java: in this assignment multiple
templates are to be designed as a pattern and these patterns to be used to take decisions.
Write a Java program for the implementation of different data structures using JAVA
collection libraries (Standard toolkit library): at least 5 data structures are used to design a
suitable application.
Design a mini project using JAVA which will use the different data structure with or without
Java collection library and show the use of specific data structure on the efficiency
(performance) of the code.
#57/65
Faculty of Engineering
Teaching Scheme:
PR: 04 Hours/Week
Credit
02
Examination Scheme:
TW: 25 Marks
PR: 50 Marks
#58/65
Faculty of Engineering
In addition to these, instructor may assign one real life application in the form of a mini-project
based on the concepts learned. Instructor may also set one assignment or mini-project that is
suitable to respective branch beyond the scope of syllabus.
Operating System: Latest 64-bit Version and update of Microsoft Windows 7/ Windows 8 Operating
System onwards or 64-bit Open source Linux or its derivative.
Programming Tools: Preferably using Linux equivalent or MASM 64x or equivalent, Microsoft
Visual Studio x64 Intrinsic.
Suggested List of Laboratory Assignments (Any 12)
1.
Write X86/64 ALP to count number of positive and negative numbers from the array
2.
Write X86/64 ALP to perform non-overlapped and overlapped block transfer (with and
without string specific instructions). Block containing data can be defined in the data
segment.
3.
Write X86/64 ALP to convert 4-digit Hex number into its equivalent BCD number and 5-digit
BCD number into its equivalent HEX number. Make your program user friendly to accept the
choice from user for:
(a) HEX to BCD b) BCD to HEX (c) EXIT.
Display proper strings to prompt the user while accepting the input and displaying the result.
(wherever necessary, use 64-bit registers)
4.
Write X86/64 ALP to perform multiplication of two 8-bit hexadecimal numbers. Use
successive addition and add and shift method. (use of 64-bit registers is expected)
5.
Write X86 ALP to find, a) Number of Blank spaces b) Number of lines c) Occurrence of a
particular character. Accept the data from the text file. The text file has to be accessed during
Program_1 execution and write FAR PROCEDURES in Program_2 for the rest of the
processing. Use of PUBLIC and EXTERN directives is mandatory.
6.
Write X86/64 ALP to switch from real mode to protected mode and display the values of
GDTR, LDTR, IDTR, TR and MSW Registers.
7.
Write X86 program to sort the list of integers in ascending/descending order. Read the input
from the text file and write the sorted data back to the same text file using bubble sort
8.
Write X86 menu driven Assembly Language Program (ALP) to implement OS (DOS)
commands TYPE, COPY and DELETE using file operations. User is supposed to provide
command line arguments in all cases.
9.
Write x86 ALP to find the factorial of a given integer number on a command line by using
recursion. Explicit stack manipulation is expected in the code.
10. Write 80387 ALP to find the roots of the quadratic equation. All the possible cases must be
considered in calculating the roots.
11. Write 80387 ALP to plot Sine Wave, Cosine Wave and Sinc function. Access video memory
directly for plotting.
12. Write 80387 ALP to obtain: i) Mean ii) Variance iii) Standard Deviation Also plot the
histogram for the data set. The data elements are available in a text file.
13. Write a Terminate but Stay Resident (TSR) program for a key-logger. The key-presses during
the stipulated time need to be displayed at the center of the screen. OR
Write a TSR to generate the pattern of the frequency tones by reading the Real Time
Clock (RTC). The duration of the each tone is solely decided by the programmer.
14. Write 80386 ALP to implement multitasking. Where each task is supposed to change the
color of the text displayed at the center of the screen
Syllabus for Second Year of Computer Engineering
#59/65
Faculty of Engineering
In addition to credits, it is recommended that there should be audit course in preferably in each
semester from second year to supplement their knowledge and skills. Student will be awarded the
bachelors degree if he/she earns 190 credits and clears all the audit courses specified in the
syllabus. The student will be awarded grade as AP on successful completion of audit course.
The student may opt for one of the audit courses per semester, starting in second year first semester.
Though not mandatory, such a selection of the audit courses helps the learner to explore the subject
of interest in greater detail resulting in achieving the very objective of audit course's inclusion. List
of options offered is provided. Each student has to choose one audit course from the list per
semester. Evaluation of audit course will be done at institute level itself. Method of conduction and
method of assessment for audit courses are suggested.
Criteria:
The student registered for audit course shall be awarded the grade AP(Audit Course Pass) and shall
be included such AP grade in the Semester grade report for that course, provided student has the
minimum attendance as prescribed by the Savitribai Phule Pune University and satisfactory insemester performance and secured a passing grade in that audit course. No grade points are
associated with this 'AP' grade and performance in these courses is not accounted in the calculation
of the performance indices SGPA and CGPA. Evaluation of audit course will be done at institute
level
itself.
(Refhttp://www.unipune.ac.in/Syllabi_PDF/revised2015/engineering/UG_RULE_REGULATIONS_FOR_CREDIT_SYSTEM-2015_18June.pdf)
Guidelines for Conduction and Assessment (Any one or more of following but not limited to)
Surveys
Mini Project
Hands on experience on specific focused
topic
Guidelines for Assessment (Any one or more of following but not limited to)
Written Test
IPR/Publication
Demonstrations/ Practical Test
Report
Presentations
Audit Course 2 Options
Water Management
AC2-II
AC2-III
AC2-IV
AC2-V
#60/65
Faculty of Engineering
Water is a vital resource for all life on the planet. Only three percent of the water resources
on Earth are fresh and two-thirds of the freshwater is locked up in ice caps and glaciers. One fifth of
the remaining one percent is in remote, inaccessible areas. As time advances, water is becoming
scarcer and having access to clean, safe, drinking water is limited among countries. Pure water
supply and disinfected water treatment are prerequisites for the well-being of communities all over
the world. One of the biggest concerns for our water-based resources in the future is the
sustainability of the current and even future water resource allocation. This course will provide
students a unique opportunity to study water management activities like planning, developing,
distributing and optimum use of water resources. This course covers the topics that
management of water treatment
of
drinking water,
industrial water,
sewage
or
wastewater, management of water resources, management of flood protection.
Course Objectives:
To develop understanding of water recourses.
To study global water cycle and factors that affect this cycle.
To analyze the process for water resources and management.
To study the research and development areas necessary for efficient utilization and
management of water recourses.
Course Outcomes:
On completion of the course, learner will be able to
Understanding of the global water cycle and its various processes
Understanding of climate change and their effects on water systems
Understanding of Drinking treatment and quality of groundwater and surface water
Understanding of the Physical, chemical, and biological processes involved in water
treatment and distribution.
Course Contents:
1. Understanding water-Climate change and the global water cycle, Understanding global
hydrology
2. Water resources planning and management-Water law and the search for sustainability: a
comparative analysis, Risk and uncertainty in water resources planning and management
3. Agricultural water use -The role of research and development for agriculture water use
4. Urban water supply and management - The urban water challenge, Water sensitive urban
design
References:
1. R. Quentin Graft, Karen Hussey, Quentin Graft, Karen Hussey, Publisher, "Water Resources
Planning and Management, Cambridge University Press, ISBN: 9780511974304,
9780521762588.
2. P. C. Basil, "Water Management in India, ISBN: 8180690970, 2004.
3. C.A. Brebbia, "Water Resources Management, ISBN: 978-1-84564-960-9
Syllabus for Second Year of Computer Engineering
#61/65
Faculty of Engineering
Intellectual property is the area of law that deals with protecting the rights of those who
create original works. It covers everything from original plays and novels to inventions and
company identification marks. The purpose of intellectual property laws is to encourage new
technologies, artistic expressions and inventions while promoting economic growth.
Innovation and originality have great potential value. Whatever line of activity you are
engaged in, future success depends on them. The last few years have seen intellectual property
rights become an issue of general interest: the smart phone
patent wars, the introduction of
Digital Rights management (DRM) and the rise of generic pharmaceuticals and open-source
software are just some examples that have been in the public eye. Protecting your intellectual rights
appropriately should be a top priority. Yet too many people embark on their chosen professions
without even a basic awareness of intellectual property.
Course Objectives:
To encourage research, scholarship, and a spirit of inquiry
To encourage students at all levels to develop patentable technologies.
To provide environment to the students of the Institute for creation, protection, and
commercialization of intellectual property and to stimulate innovation.
Course Outcomes:
On completion of the course, learner will be able to
Understand the fundamental legal principles related to confidential information, copyright,
patents, designs, trademarks and unfair competition
Identify, apply and assess principles of law relating to each of these areas of intellectual
property
Apply the appropriate ownership rules to intellectual property you have been involved in
creating
Course Contents:
Introduction to Intellectual Property Law The Evolutionary Past - The IPR Tool Kit- Para
-Legal Tasks in Intellectual Property Law
Introduction to Trade mark Trade mark Registration Process Post registration Procedures
Trade mark maintenance - Transfer of Rights Inter partes Proceeding Infringement Dilution Ownership of Trade mark
Introduction to Copyrights Principles of Copyright Principles -The subjects Matter of
Copy right The Rights Afforded by Copyright Law Copy right Ownership, Transfer and
duration Right to prepare Derivative works
Introduction to Trade Secret Maintaining Trade Secret Physical Security Employee
Limitation - Employee confidentiality agreement
References:
1. Debirag E. Bouchoux:
Intellectual Property. Cengage learning ISBN-10:1111648573
2. Ferrera, Bird, Darrow,
Cyber Law. Texts & Cases, South- ISBN:0-324-39972-3
3. Prabhuddha Ganguli:
Intellectual Property Rights TMH, ISBN-10:0070077177
#62/65
Faculty of Engineering
Everybody wants to be happy. One can explore innumerable ideas about what happiness is and how
we can get some. But not many of those ideas are based on science. Thats where this course comes
in. The
The subject
Science of Happiness aims to teach the pioneering science of positive
psychology, which explores the ancestry of a happy and meaningful life. Clinical psychologists
have been dealing with miserable feelings since their discipline was established. In the last 30
years, neuroscientists have made major headway in the understanding of the sources of anger,
depression, and fear.
Today, whole industries profit from this knowledgeproducing pills for every sort of pathological
mood disturbance. But until recently, few neuroscientists focused on the subject of happiness. This
course focuses on discovering how cutting-edge research can be applied to their lives. Students will
learn about the Intra-disciplinary research supporting this view, spanning the fields of psychology,
neuroscience, evolutionary biology, and beyond. The course offers students practical strategies for
tapping into and nurturing their own happiness, including trying several research-backed activities
that foster social and emotional well-being, and exploring how their own happiness changes along
the way.
Course Objectives:
To understand the feeling of happiness
To study the sources of positive feelings
To analyze the anatomy of the happiness system
To study the effect of thoughts and emotions on the happiness system
Course Outcomes:
On completion of the course, learner will be able to
Ability to understand what happiness is and why it matters to you
Ability to learn how to increase your own happiness
Understanding of the power of social connections and the science of empathy
Ability to understand what is mindfulness and its real world applications
Course Contents:
1. Happiness: what is it?
2. The secret of smiling
3. The autonomy of positive feelings
4. Positive feelings as a compass
5. The happiness system
6. Foundations: Emotions, Motivation and nature of Well being
7. Subjective well being
8. Love and well being
9. Optimal well being
10. Religion, Spirituality and well being
References:
1. Happier, Stefan Klein , "The Science of Happiness, How Our Brains Make Us Happy and
what We Can Do to Get, Da Capo Press, ISBN 10: 156924328X, 13: 978-1569243282.
2. C. Compton, Edward Hoffman, "Positive Psychology: The Science of Happiness and
Flourishing, William, Cengage Learning, 2012, ISBN10: 1111834121.
#63/65
Faculty of Engineering
The concepts and practices of Yoga originated in India about several thousand years ago. Its
founders were great Saints and Sages. The great Yogis presented rational interpretation of their
experiences of Yoga and brought about a practical and scientifically sound method within every
ones reach. Yoga today, is no longer restricted to hermits, saints, and sages; it has entered into our
everyday lives and has aroused a worldwide awakening and acceptance in the last few decades. The
science of Yoga and its techniques have now been reoriented to suit modern sociological needs and
lifestyles.
Yoga is one of the six systems of Vedic philosophy. The Yoga advocates certain restraints and
observances, physical discipline, breathe regulations, restraining the sense organs, contemplation,
meditation and Samadhi. The practice of Yoga prevents psychosomatic disorders and improves an
individuals resistance and ability to endure stressful situations.
Course Objectives:
To impart knowledge about the basic technique and practice of yoga, including instruction
in breath control, meditation, and physical postures
To gain an intellectual and theoretical understanding of the principles embodied in the Yoga
Sutras, the Bhagavad-Gita, and other important texts and doctrines
Relaxation and stress reduction ,Personal insight and self understanding, Personal
empowerment, Gaining wisdom and spiritual discernment
Awakening the abilities or powers of the Super conscious mind
Course Outcomes:
On completion of the course, learner will be able to
Students understanding of philosophy and religion as well as daily life issues will be
challenged and enhanced.
Enhances the immune system.
Intellectual and philosophical understanding of the theory of yoga and basic related Hindu
scriptures will be developed.
Powers of concentration, focus, and awareness will be heightened.
Course Contents:
1. Meaning and definition of yoga Scope of Yoga - Aims and Objectives of Yoga
Misconception about yoga.
2. Ayurveda: an introduction to this system of health care derived from the Vedic tradition
Anatomy and Physiology as they relate to Yoga
3. Yoga Philosophy and Psychology
References:
1. B.K.S. Iyengar,
BKS Iyengar Yoga The Path to Holistic Health, DK publisher, ISBN13: 978-1409343479
2. Osho,
The Essence of Yoga, Osho International Foundation, ISBN: 9780918963093
#64/65
Faculty of Engineering
Katakana : Modified kana, double consonant, letters with ya, yu, yo, Long vowels,
Describing time, describing starting & finishing time ( kara ~ made ), Point in time
(denoting the time when any action or the movement occurs)
Means of transport (Vehicles), Places, Countries, Stating Birth date, Indicating movement to
a certain place by a vehicle
References:
1. Minna No Nihongo,
Japanese for Everyone, (Indian Edition), Goyal Publishers &
Distributors Pvt. Ltd.
2. http://www.tcs.com (http://www.tcs.com/news_events/press_releases/Pages/TCS-Inaugurates-Japancentric-Delivery-Center-Pune.aspx)
#65/65