Upload
anirudh-chauhan
View
25
Download
1
Embed Size (px)
Citation preview
PROGRAMMING PARADIGM
BY,Anirudh Chauhan
Introduction to programming paradigm
Introduction
A way of conceptualizing what it means to perform computation and how tasks to be carried out on the computer should be structured and organized.
A programming paradigm is a fundamental style of computer programming, serving as a way of building the structure and elements of computer programs
Introduction
Some languages are designed to support one particular paradigm Smalltalk supports object-oriented programming Haskell supports functional programming
Other programming languages support multiple paradigms Object Pascal, C++, C#, Visual Basic, Common
Lisp, Scheme, Perl, Python, Ruby, Oz and F#.
Introduction
Programming paradigms differ in: The concepts and abstractions used to represent the elements of a program (such as objects, functions, variables, constraints, etc.)
The steps that compose a computation (assignation, evaluation, data flow, control flow, etc.).
Programming Paradigms
Programming paradigms
There are four main Programming Paradigms.
Imperative : Machine-model based Functional : Equations; Expression
Evaluation
Logical : First-order Logic Deduction
Object-Oriented : Programming with Data
Types
Why study so many programming languages ?
To Improve our ability to Develop Effective algorithms.
To improve Use of Existing Programming Languages. To allow a better choice of Programming Language. To make it Easier to design a new language.
Procedural Programming
Procedural Programming
Often thought as a synonym for imperative programming.
Specifying the steps the program must take to reach the desired state.
Based upon the concept of the procedure call.
Procedural Programming
Procedures, also known as routines, subroutines, methods, or functions that contain a series of computational steps to be carried out.
Any given procedure might be called at any point during a program's execution, including by other procedures or itself.
The syntax of such languages generally has the form
statement 1;statement 2;--------------statement n;
Procedural Programming
Often a better choice than simple sequential or unstructured programming in many situations which involve moderate complexity or require significant ease of maintainability.
The ability to re-use the same code at different places in the program without copying it.
Procedural Programming
An easier way to keep track of program flow than a collection of "GOTO" or "JUMP" statements .
The ability to be strongly modular or structured. Example of procedural programming are C, Pascal, Basic,
FORTRAN etc.
Functional Programming
Functional Programming
Functional programming is a programming paradigm that treats computation as the evaluation of mathematical functions and avoids state changes and mutable data.
Programs written using the functional programming paradigm are much more easily representable using mathematical concepts, and thus it is much more easy to mathematically reason about functional programs than it is to reason about programs written in any other paradigm.
Functional Programming
The syntax of such languages is :functionn { …function2 { function1 (data)} …}
LISP was the first operational functional programming language.
The Haskell programming language was released in the late 1980s in an attempt to gather together many ideas in functional programming research.
Up to this day, functional programming has not been very popular except for a restricted number of application areas, such as artificial intelligence.
Functional Programming
In practice, the difference between a mathematical function and the notion of a "function" used in imperative programming is that imperative functions can have side effects, changing the value of already calculated variables.
Conversely, in functional code, the output value of a function depends only on the arguments that are input to the function, so calling a function f twice with the same value for an argument x will produce the same result f(x) both times.
Examples of Functional Programming are C, LISP, ML .
Imperative Vs Non Imperative
Imperative VS non imperative
Functional/Logic programs specify WHAT is to be computed abstractly, leaving the details of data organization and instruction sequencing to the interpreter.
In contrast, Imperative programs describe the details of HOW the results are to be obtained, in
terms of the underlying machine model. Functional/Logic style clearly separates WHAT aspects of
a program (programmers’ responsibility) from the HOW aspects (implementation decisions).
An Imperative program contains both the specification and the implementation details, inseparably inter-twined.
Imperative VS Non Imperative
Imperative•Program: a sequence of instructions for a von Neumann m/c.•Computation by instruction execution.•Iteration.•Modifiable or updateable variables.
Non imperative
•Program: a collection of function definitions (m/c independent).•Computation by term rewriting.•Recursion.•Assign-only-once variables.
Logical Programming
Logical Programming
Also known as Rule based programming and Declarative programming.
Rule based programming checks for presence for a certain condition and when present execute an appropriate action.
Logical Programming
We can describe rule-based languages as a set of filters to apply to data storage. Enabling conditions determine order of execution. The syntax of such Languages generally is similar to the following.
enabling condition1→action1
enabling condition2→action2
.......................... enabling conditionn→actionn
Some examples of logical programming languages are Prolog, Ant, Oz, SQL etc.
Object Oriented Programming
Object Oriented Programming
Object-oriented programming (OOP) is a programming paradigm that uses "objects" – data structures encapsulating data fields and procedures together with their interactions – to design applications and computer programs.
Associated programming techniques may include features such as data abstraction, encapsulation, modularity, polymorphism, and inheritance.
Object oriented programming
Though it was invented with the creation of the Simula language in 1965, and further developed in Smalltalk in the 1970s, it was not commonly used in mainstream software application development until the early 1990s.
Many modern programming languages now support OOP.
Examples of Object oriented Programming are C++, java, Smalltalk, simula etc.
Thank You for your consideration