Python 4 HPC
Python 4 HPC
Amey Karkare
Dept. of CSE
IIT Kanpur
1
Welcome Python Programming
Acknowledgements
MS Office clip art, various websites and
images
The images/contents are used for
teaching purpose and for fun. The
copyright remains with the original
creator. If you suspect a copyright
violation, bring it to my notice and I will
remove that image/content.
2
Welcome Python Programming
About me
http://www.cse.iitk.ac.in/~karkare
3
9/18/22 Programming
The Programming Cycle for Python
4
9/18/22 Programming
Run
with some input
Write/Edit
OK?
NO
YES
YES
NO More
Inputs?
5
9/18/22 Programming
User Program
Filename, preferred extension is py
6
9/18/22 Programming
IN[1]: Python Shell Prompt
IN[2]:
User Commands
IN[3]: (Statements)
IN[4]: ( )
Outputs
8
9/18/22 Programming
input
• Take as argument a string to print as a prompt
• Returns the user typed value as a string
– details of how to process user string later
IN[1]:
IN[2]: ( )
IN[3]:
9/18/22 Programming 9
Elements of Python
• A Python program is a sequence of definitions
and commands (statements)
• Commands manipulate objects
• Each object is associated with a Type
• Type:
– A set of values
– A set of operations on these values
• Expressions: An operation (combination of
objects and operators)
10
9/18/22 Programming
Types in Python
• int
– Bounded integers, e.g. 732 or -5
• float
– Real numbers, e.g. 3.14 or 2.0
• long
– Long integers with unlimited precision
• str
– Strings, e.g. ‘hello’ or ‘C’
11
9/18/22 Programming
Types in Python
• Scalar
– Indivisible objects that do not have internal
structure
– int (signed integers), float (floating point), bool
(Boolean), NoneType
• NoneType is a special type with a single value
• The value is called None
• Non-Scalar
– Objects having internal structure
– str (strings)
12
9/18/22 Programming
Example of Types
13
9/18/22 Programming
Type Conversion (Type Cast)
14
9/18/22 Programming
Type Conversion Examples
Note that float to int conversion
is truncation, not rounding off
15
9/18/22 Programming
Type Conversion and Input
16
9/18/22 Programming
Operators
• Arithmetic + - * // / % **
17
9/18/22 Programming
Variables
• A name associated with an m
object 64
• Assignment used for binding Acads
m = 64; c
3.1416
c = ‘Acads’;
f = 3.1416; f
19
9/18/22 Programming
Multiple Assignments
• Python allows multiple assignments
x, y = 10, 20 Binds x to 10 and y to 20
21
09/18/2022 Programming
Binary Operations
Op Meaning Example Remarks
+ Addition 9+2 is 11
9.1+2.0 is 11.1
- Subtraction 9-2 is 7
9.1-2.0 is 7.1
* Multiplication 9*2 is 18
9.1*2.0 is 18.2
/ Division 9/2 is 4.25 In Python3
9.1/2.0 is 4.55 Real div.
// Integer Division 9//2 is 4
% Remainder 9%2 is 1
22
09/18/2022 Programming
The // operator
• Also referred to as “integer division”
• Result is a whole integer (floor of real
division)
– But the type need not be int
– the integral part of the real division
– rounded towards minus infinity
• Examples
9//4 is 2 (-1)//2 is -1 (-1)//(-2) is 0
1//2 is 0 1//(-2) is -1 9//4.5 is 2.0
23
09/18/2022 Programming
The % operator
• The remainder operator % returns the
remainder of the result of dividing its
first operand by its second.
9%4 is 1 (-1)%2 is 1 (-1)//(-2) is 0
9%4.5 is 0.0 1%(-2) is 1 1%0.6 is 0.4
Ideally: x == (x//y)*y + x %y
24
09/18/2022 Programming
Conditional Statements
• In daily routine
– If it is very hot, I will skip
exercise.
– If there is a quiz tomorrow, I will
first study and then sleep.
Otherwise I will sleep now.
– If I have to buy coffee, I will
go left. Else I will go
straight. 25
9/18/22 Programming
if-else statement
• Compare two integers and print the min.
26
9/18/22 Programming
Indentation
• Indentation is important in Python
– grouping of statement (block of statements)
– no explicit brackets, e.g. { }, to group statements
x,y = 6,10 Run
x the program
y
if x < y: 6 10
print (x)
else:
print (y) ed Output
print (‘is i pp
sk the min’) 6 27
9/18/22 Programming
if statement (no else!)
• General form of the if statement
e
if boolean-expr : tru
fals
e
S1
S1
S2
• Execution of if statement S2
– First the expression is evaluated.
– If it evaluates to a true value, then S1 is
executed and then control moves to the S2.
– If expression evaluates to false, then control
moves to the S2 directly.
28
9/18/22 Programming
if-else statement
• General form of the if-else statement
if boolean-expr : tru
e
fa
S1
ls
e
else: S1 S2
S2
S3 S3
• Execution of if-else statement
– First the expression is evaluated.
– If it evaluates to a true value, then S1 is executed and
then control moves to S3.
– If expression evaluates to false, then S2 is executed
and then control moves to S3.
– S1/S2 can be blocks of statements! 29
9/18/22 Programming
Nested if, if-else
if a <= b:
if a <= c:
…
else:
…
else:
if b <= c) :
…
else:
… 30
9/18/22 Programming
Elif
• A special kind of nesting is the chain of if-
else-if-else-… statements
• Can be written elegantly using if-elif-..-else
if cond1: if cond1:
s1 s1
else: elif cond2:
if cond2: s2
s2 elif cond3:
else: s3
if cond3: elif …
s3 else
else: last-block-of-stmt
…
31
9/18/22 Programming
Summary of if, if-else
• if-else, nested if's, elif.
• Multiple ways to solve a problem
–issues of readability,
maintainability
–and efficiency
32
9/18/22 Programming
Class Quiz
• What is the value of expression:
(5<2) and (3/0 > 1)
d) True
33
9/18/22 Programming
Short-circuit Evaluation
• Do not evaluate the second operand of binary
short-circuit logical operator if the result can be
deduced from the first operand
– Also applies to nested logical operators
37
9/18/22 Programming
Caution about Using Floats
• The value stored internally for the decimal
number 0.1 is the binary fraction
0.00011001100110011001100110011001100110011001100110011010
39
9/18/22 Programming
Programming using Python
Loops
40
9/18/22 Python Programming
Printing Multiplication Table
5 X 1 = 5
5 X 2 = 10
5 X 3 = 15
5 X 4 = 20
5 X 5 = 25
5 X 6 = 30
5 X 7 = 35
5 X 8 = 40
5 X 9 = 45
5 X 10 = 50
41
9/18/22 Python Programming
Program…
n = int(input('Enter a Too
number:
much '))
print (n, 'X', 1, '=', n*1)
repetition!
print (n, 'X', 2, '=', n*2)
Can I avoid
print (n, 'X', 3, '=', n*3)it?
print (n, 'X', 4, '=', n*4)
print (n, 'X', 5, '=', n*5)
print (n, 'X', 6, '=', n*6)
….
42
9/18/22 Python Programming
Printing Multiplication Table
Loop Exit
i <=10
TRUE FALSE
Loop 43
9/18/22 Python Programming
Printing Multiplication Table
Input n
i=1
TRUE
i <=10
FALSE n = int(input('n=? '))
i=1
Print n x i = ni Stop
i = i+1
44
9/18/22 Python Programming
While Statement
while (expression):
S1 FALSE
expression
S2
TRUE
S1 S2
1. Evaluate expression
2. If TRUE then
a) execute statement1
b) goto step 1.
3. If FALSE then execute statement2.
45
9/18/22 Python Programming
For Loop
• Print the sum of the reciprocals of the
first 100 natural numbers.
47
9/18/22 Python Programming
range
• range(s, e, d)
– generates the list:
[s, s+d, s+2*d, …, s+k*d]
where s+k*d < e <= s+(k+1)*d
• range(s, e) is equivalent to range(s, e, 1)
• range(e) is equivalent to range(0, e)
Exercise: What if d is negative? Use python
interpreter to find out. 48
9/18/22 Python Programming
Quiz
• What will be the output of the following
program
f(unctions)
51
9/18/22 Programming, Functions
Parts of a function
Input
52
9/18/22 Output
Programming, Functions
def max (a, b):
‘’’return maximum among a and b’’’
keyword if (a > b):
return a 2 arguments
else: a and b
Function Name return b (formal args)
In[3] : help(max)
Help on function max in module __main__:
max(a, b)
return maximum among a and b
54
9/18/22 Programming, Functions
Keyword Arguments
Note use of [0]
def printName(first, last, initials) : to get the first
if initials: character of a
string. More on
print (first[0] + '. ' + last[0] + '.') this later.
else:
print (first, last)
Call Output
printName('Acads', 'Institute', False) Acads Institute
printName('Acads', 'Institute', True) A. I.
printName(last='Institute', initials=False, first='Acads') Acads Institute
printName('Acads', initials=True, last='Institute') A. I.
55
9/18/22 Programming, Functions
Keyword Arguments
• Parameter passing where formal is bound to
actual using formal's name
• Can mix keyword and non-keyword arguments
– All non-keyword arguments precede keyword
arguments in the call
– Non-keyword arguments are matched by position
(order is important)
– Order of keyword arguments is not important
56
9/18/22 Programming, Functions
Default Values
def printName(first, last, initials=False) :
if initials:
print (first[0] + '. ' + last[0] + '.')
Note the use
else: of “default”
value
print (first, last)
Call Output
printName('Acads', 'Institute') Acads Institute
printName(first='Acads', last='Institute', initials=True) A. I.
printName(last='Institute', first='Acads') Acads Institute
printName('Acads', last='Institute') Acads Institute
57
9/18/22 Programming, Functions
Default Values
• Allows user to call a function with fewer
arguments
• Useful when some argument has a fixed value
for most of the calls
• All arguments with default values must be at
the end of argument list
– non-default argument can not follow default
argument
58
9/18/22 Programming, Functions
Globals
• Globals allow functions to communicate with
each other indirectly
– Without parameter passing/return value
• Convenient when two seemingly “far-apart”
functions want to share data
– No direct caller/callee relation
• If a function has to update a global, it must re-
declare the global variable with global keyword.
59
9/18/22 Programming, Functions
Globals
PI = 3.14 >>> print(area (100))
def perimeter(r): 31400.0
return 2 * PI * r >>> print(perimeter(10))
def area(r): 62.800000000000004
return PI * r * r >>> update_pi()
def update_pi(): >>> print(area(100))
global PI 31415.999999999996
PI = 3.14159 >>> print(perimeter(10))
62.832
defines PI to be of float type with value
3.14. PI can be used across functions. Any
change to PI in update_pi will be visible to 60
all due to the use of global.
9/18/22 Programming, Functions
Programming with Python
S T R I NGS
T UP L E S
L I S T S
61
9/18/22 Programming
Strings
• Strings in Python have type str
• They represent sequence of characters
– Python does not have a type corresponding to
character.
• Strings are enclosed in single quotes(') or double
quotes(“)
– Both are equivalent
• Backslash (\) is used to escape quotes and
special characters
62
9/18/22 Programming
Strings
63
9/18/22 Programming
Length of a String
• len function gives the length of a string
\n is a single character:
the special character
representing newline 64
9/18/22 Programming
Concatenate and Repeat
• In Python, + and * operations have special
meaning when operating on strings
• + is used for concatenation of (two) strings
• * is used to repeat a string, an int number of
time
• Function/Operator Overloading
65
9/18/22 Programming
Concatenate and Repeat
66
9/18/22 Programming
Indexing
• Strings can be indexed
• First character has index 0
67
9/18/22 Programming
Indexing
• Negative indices start counting from the right
• Negatives indices start from -1
• -1 means last, -2 second last, ...
68
9/18/22 Programming
Indexing
• Using an index that is too large or too small
results in “index out of range” error
69
9/18/22 Programming
Slicing
• To obtain a substring
• s[start:end] means substring of s starting at
index start and ending at index end-1
• s[0:len(s)] is same as s
• Both start and end are optional
– If start is omitted, it defaults to 0
– If end is omitted, it defaults to the length of string
• s[:] is same as s[0:len(s)], that is same as s
70
9/18/22 Programming
Slicing
71
9/18/22 Programming
More Slicing
73
9/18/22 Programming
Tuples
• A tuple consists of a number of values
separated by commas
74
9/18/22 Programming
Nested Tuples
• Tuples can be nested
75
9/18/22 Programming
Length of a Tuple
• len function gives the length of a tuple
76
9/18/22 Programming
More Operations on Tuples
• Tuples can be concatenated, repeated,
indexed and sliced
77
9/18/22 Programming
Unpacking Sequences
• Strings and Tuples are examples of sequences
– Indexing, slicing, concatenation, repetition
operations applicable on sequences
• Sequence Unpacking operation can be applied
to sequences to get the components
– Multiple assignment statement
– LHS and RHS must have equal length
78
9/18/22 Programming
Unpacking Sequences
( )
79
9/18/22 Programming
Lists
• Ordered sequence of values
• Written as a sequence of comma-separated
values between square brackets
• Values can be of different types
– usually the items all have the same type
80
9/18/22 Programming
Lists
• List is also a sequence type
– Sequence operations are applicable
81
9/18/22 Programming
Lists
• List is also a sequence type
– Sequence operations are applicable
Repetition
( )
82
9/18/22 Programming
More Operations on Lists
• L.append(x) • L.pop()
• L.extend(seq) • L.index(x)
• L.insert(i, x) • L.count(x)
• L.remove(x) • L.sort()
• L.pop(i) • L.reverse()
x is any value, seq is a sequence value (list, string, tuple, …),
i is an integer value
83
9/18/22 Programming
Mutable and Immutable Types
• Tuples and List types look very similar
• However, there is one major difference: Lists
are mutable
– Contents of a list can be modified
• Tuples and Strings are immutable
– Contents can not be modified
84
9/18/22 Programming
Summary of Sequences
Operation Meaning
seq[i] i-th element of the sequence
len(seq) Length of the sequence
seq1 + seq2 Concatenate the two sequences
num*seq
seq*num Repeat seq num times
86
9/18/22 Programming
Programming with Python
87
9/18/22 Esc101, Strings
Sets
• An unordered collection with no duplicate
elements
• Supports
– membership testing
– eliminating duplicate entries
– Set operations: union, intersection, difference, and
symmetric difference.
88
9/18/22 Programming
Sets
{ }
89
9/18/22 Programming
Set Operations
{ }
{ }
{ }
{ }
{ }
90
9/18/22 Programming
Dictionaries
• Unordered set of key:value pairs,
• Keys have to be unique and immutable
• Key:value pairs enclosed inside curly braces
{...}
• Empty dictionary is created by writing {}
• Dictionaries are mutable
– add new key:value pairs,
– change the pairing
– delete a key (and associated value)
91
9/18/22 Programming
Operations on Dictionaries
Operation Meaning
len(d) Number of key:value pairs in d
d.keys() List containing the keys in d
d.values() List containing the values in d
k in d True if key k is in d
d[k] Value associated with key k in d
d.get(k, v) If k is present in d, then d[k] else v
d[k] = v Map the value v to key k in d
(replace d[k] if present)
del d[k] Remove key k (and associated value) from d
for k in d Iterate over the keys in d
92
9/18/22 Programming
Operations on Dictionaries
93
9/18/22 Programming
Operations on Dictionaries
94
9/18/22 Programming
Operations on Dictionaries
95
9/18/22 Programming
Dictionary Construction
• The dict constructor: builds dictionaries
directly from sequences of key-value pairs
96
9/18/22 Esc101, Strings
Programming with Python
File I/O
97
9/18/22 Programming
File I/O
• Files are persistent storage
• Allow data to be stored beyond program
lifetime
• The basic operations on files are
– open, close, read, write
• Python treat files as sequence of lines
– sequence operations work for the data read from
files
98
9/18/22 Programming
File I/O: open and close
open(filename, mode)
• While opening a file, you need to supply
– The name of the file, including the path
– The mode in which you want to open a file
– Common modes are r (read), w (write), a (append)
• Mode is optional, defaults to r
• open(..) returns a file object
• close() on the file object closes the file
– finishes any buffered operations
99
9/18/22 Programming
File I/O: Example
• Do some writing
• How to do it?
• see the next few slides
100
9/18/22 Programming
File I/O: read, write and append
• Reading from an open file returns the
contents of the file
– as sequence of lines in the program
• Writing to a file
– IMPORTANT: If opened with mode 'w', clears the
existing contents of the file
– Use append mode ('a') to preserve the contents
– Writing happens at the end
101
9/18/22 Programming
File I/O: Examples
102
9/18/22 Programming
File I/O: Examples
( )
( )
103
9/18/22 Programming
File I/O: Examples
( )
104
9/18/22 Programming
File I/O: Examples
Note the use of for ... in
for sequence
( )
]
105
9/18/22 Programming
File I/O: Examples
( )
( )
( )
106
9/18/22 Programming
Programming using Python
107
Welcome Python Programming
Modules
• As program gets longer, need to organize them for
easier access and easier maintenance.
• Reuse same functions across programs without
copying its definition into each program.
• Python allows putting definitions in a file
– use them in a script or in an interactive instance of the
interpreter
• Such a file is called a module
– definitions from a module can be imported into other
modules or into the main module
108
9/18/22 Programming
Modules
• A module is a file containing Python
definitions and statements.
• The file name is the module name with the
suffix .py appended.
• Within a module, the module’s name is
available in the global variable __name__.
109
9/18/22 Programming
Modules Example
fib.py - C:\
110
9/18/22 Programming
Modules Example
112
9/18/22 Programming
Importing ALL Functions
• To import all functions from a module, in the current
symbol table
116
9/18/22 Programming
A sound Package
https://docs.python.org/3/tutorial/modules.html
117
9/18/22 Programming
A sound Package
https://docs.python.org/3/tutorial/modules.html
118
9/18/22xs Programming
__init.py__
• The __init__.py files are required to make
Python treat directories containing the file as
packages.
• This prevents directories with a common name, such
as string, unintentionally hiding valid modules
that occur later on the module search path.
• __init__.py can just be an empty file
• It can also execute initialization code for the package
119
9/18/22 Programming
Importing Modules from Packages
https://docs.python.org/3/tutorial/
modules.html 120
9/18/22 Programming
Importing Modules from Packages
import sound.effects.echo
sound.effects.echo.echofilter(
input, output,
delay=0.7, atten=4
)
121
9/18/22 Programming
Importing Modules from Packages
from sound.effects import echo
• This also loads the submodule echo
• Makes it available without package prefix
• It can be used as:
echo.echofilter(
input, output,
delay=0.7, atten=4
)
122
9/18/22 Programming
Importing Modules from Packages
from sound.effects.echo import echofilter
echofilter(input, output,
delay=0.7, atten=4)
123
9/18/22 Programming
Popular Packages
• pandas, numpy, scipy, matplotlib, …
• Provide a lot of useful functions
124
9/18/22 Programming