KEMBAR78
Python en Toc PDF | PDF | Trigonometric Functions | Sine
0% found this document useful (0 votes)
264 views27 pages

Python en Toc PDF

This textbook provides an introduction to computer programming in Python. It covers topics like using Python as a calculator, functions, plotting, variables, logic, and loops. The textbook was provided by Dr. Pavel Solin for users of the NCLab and acknowledges several people who provided suggestions. It contains 14 chapters organized in the table of contents.

Uploaded by

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

Python en Toc PDF

This textbook provides an introduction to computer programming in Python. It covers topics like using Python as a calculator, functions, plotting, variables, logic, and loops. The textbook was provided by Dr. Pavel Solin for users of the NCLab and acknowledges several people who provided suggestions. It contains 14 chapters organized in the table of contents.

Uploaded by

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

Revision September 12, 2013

About this Textbook


This textbook is provided as a courtesy to NCLab users. Python is a modern high-level
dynamic programming language that is used in many areas of business, engineering,
and science today. After taking this course, you will have solid theoretical knowledge
and vast practical experience with computer programming in Python.
Acknowledgments
The author Dr. Pavel Solin would like to thank the following people for their valuable
suggestions and help:

Martin Novak, Czech Technical University, Prague, Czech Republic.


Joel Landsteiner, Cray Inc, USA.
William Mitchell, NIST, USA.
Venkata Rama Rao Mallela, Hyderabad, India.
Steven Lamb, Philadelphia, USA.
Norman Dunbar, Leeds, West Yorkshire, England.
Samuel Marks, Sydney, Australia.

Graphics Design: TR-Design http://tr-design.cz

Table of Contents
I

Textbook

1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
1.1 Objectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
1.2 Compiled and interpreted programming languages . . . . . . . . . . . . . . . . . . . . .
1.3 Basic facts about Python . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
1.4 Python programming in NCLab . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
1.5 Downloading Python programs from NCLabs database . . . . . . . . . . . . . . . .
1.6 Launching the Python module . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
1.7 Code, output, and descriptive cells . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2 Using Python as a Calculator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.1 Objectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.2 Addition and subtraction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.3 Multiplication . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.4 Division . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.5 Modulo . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.6 Powers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.7 Priority of operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.8 Using empty characters makes your code more readable . . . . . . . . . . . . . . . .
2.9 Using mathematical functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.10 Fractions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.11 Random numbers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.12 Complex numbers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3 Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.1 Objectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.2 Defining new functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.3 Passing arbitrary arguments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.4 Returning multiple values . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.5 Using default arguments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4 Colors and Plotting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.1 Objectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.2 RGB colors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.3 Plotting polylines and polygons . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.4 Plotting functions of one variable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.5 Labels, colors, and styles . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.6 Scaling axes and showing grid . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

5
5
5
5
6
6
6
7
8
8
8
9
9
11
11
12
13
13
14
15
16
17
17
18
19
19
20
23
23
24
25
27
28
30

4.7 Adjusting plot limits . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .


4.8 Plotting multiple functions at once . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.9 Plotting parametric 2D curves . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.10 Plotting parametric 3D curves . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.11 Plotting functions of two variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.12 Plotting functions of two variables with WebGL . . . . . . . . . . . . . . . . . . . . . . .
4.13 Plotting pie charts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.14 Plotting bar charts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5.1 Objectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5.2 Creating variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5.3 Initializing multiple variables at once . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5.4 Changing values of variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5.5 Local and global variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5.6 How to get in trouble . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5.7 Variable shadowing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5.8 Overriding constants . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
Logic and Probability . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.1 Objectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.2 True and False . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.3 Boolean variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.4 Boolean operations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.5 Monte Carlo methods . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
Conditional Loop . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
7.1 Objectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
7.2 Counting and conditional loops . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
7.3 Conditions and the elif statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
7.4 The while loop . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
7.5 The break statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
7.6 The continue statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
7.7 Abusing the while loop . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
7.8 Next trip into scientific computing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
Strings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
8.1 Objectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
8.2 Using quotes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
8.3 Multiline strings and backslashes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
8.4 Concatenation and repetition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
8.5 Referring to letters by their indices . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
8.6 Parsing strings with the for loop . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

31
32
34
35
36
39
41
43
46
46
47
48
49
50
51
52
53
53
53
53
55
55
57
60
60
61
61
63
64
65
66
67
69
69
69
69
71
72
72

8.7 Slicing strings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .


9 Tuples, Lists, and Dictionaries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
9.1 Objectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
9.2 Tuples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
9.3 Lists . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
9.4 Dictionaries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
10 More on Counting Loop . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
10.1 Objectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
10.2 The range() function revisited . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
10.3 The for loop combined with the range() function . . . . . . . . . . . . . . . . . . . .
10.4 The for loop combined with a list or tuple . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
10.5 The for loop combined with a dictionary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
11 Exceptions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
11.1 Objectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
11.2 Exceptions handling . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
11.3 The assert() function . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
11.4 The raise statement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
11.5 Other types of exceptions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
12 Object-Oriented Programming . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
12.1 Objectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
12.2 From procedural to object-oriented programming . . . . . . . . . . . . . . . . . . . . . .
12.3 Example: Moving to a different city . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
12.4 Classes, objects, and methods . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
12.5 An example from geometry . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
12.6 Defining and using class circle . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
12.7 Text string as a class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
13 Class Inheritance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
13.1 Objectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
13.2 Creating base class geometry . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
13.3 Deriving polygon from geometry . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
13.4 Deriving circle from geometry . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
13.5 Deriving triangle and quad from polygon . . . . . . . . . . . . . . . . . . . . . . . . . .
13.6 Deriving rectangle from quad . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
13.7 Deriving square from rectangle . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
13.8 Diagram of class structure . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
13.9 Creating sample instances . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
14 Python Libraries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
14.1 Objectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
14.2 Python Standard Library . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

74
75
75
75
76
80
82
82
82
83
83
84
85
85
86
86
87
88
89
89
90
90
91
91
92
94
100
100
100
101
102
103
104
104
105
105
108
108
108

14.3 Pylab and Matplotlib . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .


14.4 Scipy, Numpy and Sympy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
15 Other Recommended Topics in Python . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
16 What Next? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

II

108
109
109
109

Programming Exercises

1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
1.1 Python is fun . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
1.2 Big word . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
1.3 Military exercise . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2 Using Python as a Calculator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.1 Grocery shopping . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.2 Oil change . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.3 Age average . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.4 Saving for a bike . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.5 Growing town . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.6 Coffee maker . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.7 Gardening . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.8 Setting tiles . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.9 Submerged soccer ball . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.10 Fastest runner . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.11 Triangle area . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.12 Math functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.13 Random numbers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.14 Greatest common divisor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2.15 Fractions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3 Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.1 Circle . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.2 Square . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.3 Rectangle . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.4 Sales prediction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.5 Sales tax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.6 Restaurant bill . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.7 Gas consumption conversion I (EU to US) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.8 Gas consumption conversion II (US to EU) . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.9 Distance per tank of gas . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.10 Circuit board price . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.11 Gross pay . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

113
113
113
113
113
114
114
114
114
114
114
115
115
115
115
115
116
116
116
116
116
116
117
117
117
117
117
117
118
118
118
118

3.12 Stock gain . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .


3.13 Temperature conversion I (Fahrenheit to Celsius) . . . . . . . . . . . . . . . . . . . . . . .
3.14 Temperature conversion II (Celsius to Fahrenheit) . . . . . . . . . . . . . . . . . . . . . .
3.15 Time in seconds . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.16 Time in hours . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.17 Time last time . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.18 Distance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.19 Angle conversion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.20 Length conversion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.21 Area conversion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.22 Digital storage conversion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3.23 Savings account . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4 Colors and plotting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.1 Polygon . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.2 Custom plotting function . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.3 Planar curve . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.4 Random triangle . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.5 Wireframe plot . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.6 Solid surface plot . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.7 Contour plot . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.8 WebGL plot . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.9 Pie chart plot . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5 Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5.1 Arithmetic sequence . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5.2 Geometric sequence . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5.3 Graph length . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5.4 3D curve length . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5.5 Triangle area . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5.6 Roof area . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6 Logic and probability . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.1 Even or odd . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.2 Mysterious parabola . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.3 Point in circle . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.4 Slot machine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.5 Dice game . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.6 Cheat dice . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.7 Monte Carlo pie . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.8 Maximum of a function . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.9 Monte Carlo area . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

118
119
119
119
119
119
119
120
120
120
120
120
120
120
121
121
121
122
122
122
122
123
123
123
123
124
124
124
124
125
125
126
126
126
126
126
127
127
128

6.10 Trapezoids . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
7 Conditional Loop . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
7.1 Water jar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
7.2 Throwing stones . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
7.3 Missing numbers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
7.4 Trapezoids revisited . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
7.5 Infinite sum . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
8 Strings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
8.1 Spelling . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
8.2 Inserting spaces . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
8.3 Counting chars . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
8.4 Counting words . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
8.5 Search and replace . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
9 Tuples, Lists, and Dictionaries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
9.1 List reverse . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
9.2 String to list . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
10 More on Counting Loop . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
10.1 Analyze string . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
10.2 Multiplication table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
10.3 Approximating . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
10.4 Prime numbers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
10.5 List maximizer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
10.6 Fibonacci . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
10.7 Adding fractions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
11 Exceptions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
11.1 Sure plot . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
11.2 Syntax check . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
12 Object-Oriented Programming . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
12.1 Bank account . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
12.2 Word magic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
12.3 Number magic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
12.4 Vector magic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
13 Class Inheritance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
13.1 Number master . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
13.2 Vector master . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

III

128
129
129
129
130
130
130
130
131
131
131
131
131
131
131
131
132
132
132
132
132
132
133
133
133
133
134
134
134
134
135
135
136
136
136

Review Questions

1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 139

2 Using Python as a Calculator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .


3 Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4 Colors and plotting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5 Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6 Logic and Probability . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
7 Conditional Loop . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
8 Strings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
9 Tuples, Lists, and Dictionaries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
10 More on Counting Loop . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
11 Exceptions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
12 Object-Oriented Programming . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
13 Class Inheritance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

142
146
148
154
157
160
163
165
171
172
173
175

Foreword
This course provides a gentle yet efficient introduction to Python a modern highlevel dynamic programming language that is widely used in business, science, and
engineering applications. If this is your first time learning a programming language,
then we recommend that you spend a few days with Karel the Robot before diving into
Python. Karel the Robot is available in NCLab (http://nclab.com) and it will teach you
what you will need most algorithmic thinking.
Algorithmic thinking is ability to translate your ideas into procedures, or sequences
of steps, that are compatible with the way a machine operates. It is the most essential skill in computer programming. Algorithmic thinking is not bound to any specific
programming language, and therefore it is a very good idea to acquire it using a very
simple language such as Karel the Robot. Once you have algorithmic thinking, your efficiency in learning any new programming language will improve dramatically. Moreover, Karels syntax is very similar to Python, so the transition from Karel to Python is
effortless.
In Python you will learn more applied concepts including mathematical operations
and functions, 2D and 3D plotting, local and global variables, strings, tuples, lists, dictionaries, exceptions, object-oriented programming, and more. A strong companion of
Python are its libraries. Besides the Standard Library that contains many built-in functions not present in lower-level languages such as Java, C, C++ or Fortran, Python also
has powerful scientific libraries including Scipy, Numpy, Matplotlib, Pylab, Sympy and
others. With these, you will be able to solve entry-level scientific and engineering problems. These libraries are used throughout the course.

Part I
Textbook

1
1.1

1.2

Introduction
Objectives
Learn the difference between compiled and interpreted programming languages.
Learn basic facts about Python and its powerful companion libraries.
Understand how Python programming works in the cloud setting.
Write and run your first Python program.
Compiled and interpreted programming languages

Compilation is a process where human-readable source code (text) is translated by means


of a compiler and a linker into a binary (executable) file which then can be run on the concrete computer. The same source code, compiled on different hardware architectures,
yields different binaries.
Interpreted (scripting) programming languages are more recent than the compiled
ones. A program that is written using an interpreted language is "read" (parsed) at
runtime it is not compiled and there are no binaries. Programs written using compiled languages are usually more efficient than programs written using the interpreted
ones because the former take better advantage of the underlying hardware. On the
other hand, interpreted languages are usually more universal and easier to use. Compiled programming languages include Pascal, C, C++, Fortran, Java and many others.
Examples of interpreted languages are Python, Lua, Perl and Ruby.
1.3

Basic facts about Python

Python is a powerful modern programming language that is used in many areas of


business, engineering, and science. Its interpreted character along with a very intuitive
syntax make Python an ideal language for beginners.
Python was conceived in the late 1980s and its implementation was started in December 1989 by Guido van Rossum in the Netherlands. Rossum also gave it a name
originated in his favorite television series Monty Pythons Flying Circus. Python 2.0 was
released in October 2000 and Python 3.0 in December 2008. Python was awarded the
TIOBE Programming Language of the Year award twice (2007, 2010), which is given to the
language with the greatest growth in popularity over the course of a year.
Python is a multi-paradigm programming language. Rather than forcing programmers to adopt a particular style of programming, it permits several styles: structured
(procedural) programming and object-oriented programming are fully supported, and there
are a number of language features which support functional programming.
In this course you will learn the most important aspects of the language and you
will be able to use the programming language to solve a large variety of problems.
5

Depending on your objectives, this course may be all you will ever need. We hope
that you will like Python and want to learn more and there is much more to learn
out there. References to materials covering more advanced topics and object-oriented
programming are given in Section 15.
1.4

Python programming in NCLab

In NCLabs Python module, Python code is typed into one or more code cells. The code
is then sent as a text string to a remote server where it is interpreted, and the results are
sent back to your web browser. It does not matter if you are using a desktop computer,
laptop, netbook, tablet, or any other hardware platform. Your hardware is not used for
computing, only in a limited way for graphics rendering.
1.5

Downloading Python programs from NCLabs database

NCLabs public database can be accessed from the File managers File menu or from
the File menu of the Python module. In the Search box that appears, enter the keywords
that best match what you are looking for. For example, typing "textbook python" will
find exercises that belong to the Python textbook. Any project that you find you can
download into your account, modify, and use in any way you wish.
1.6

Launching the Python module

The Python module can be launched via the Programming icon on Desktop or via File
managers File menu. Initially, the module will contain a demo program Python program that can be run instantly by pressing the green arrow button. The demo program
is not necessarily the simplest possible Python program. Its purpose is to illustrate the
usage of the Python module and yield interesting graphics. The output of the present
demo program is the so-called Dragon fractal, as shown in Fig. 1.
After you do not need the demo program anymore, you can turn it off in Settings.
Next time you launch the Python module, it will not contain any code.

Fig. 1: Launching a new Python project.

1.7

Code, output, and descriptive cells

There are three types of cells in the Python worksheet:


code cells for entering computer code,
output cells to display results,
descriptive cells for textual and graphical descriptions.
Code cells as well as descriptive cells can be added via buttons located under any code
or descriptive cell. Each cell can be removed by clicking on the red remove button
below the cell. All output cells can be removed at once via Remove all output option in
the Edit menu. Pressing the green arrow button in the upper menu will run all code
cells in the project. Clicking on the green arrow under a code cell will run only the
contents of that particular code cell.
7

Using Python as a Calculator

2.1

Objectives

Learn how to use Python for elementary as well as advanced math operations.
Learn how to work with mathematical functions, fractions, random numbers and
complex numbers.
Python can be used as an advanced scientific calculator no need to own a TI-89 ($150
value). As a matter of fact, NCLab is much more powerful a TI-89 hardly could compete with thousands of processors under NCLabs hood. In this textbook we will learn
how to use this computing power. Let us begin with the simplest math operations. The
rest of this section is fairly slow, so feel free to skip to Section 3 should it be too boring
you can always return to it later.
2.2

Addition and subtraction

Launch a new Python project and in the code cell type:


3 + 6
Then click on the green arrow under the cell. The output should be displayed quickly:
9
Of course you can add real numbers too:
3.2 + 6.31
Output:
9.51
Two numbers can be subtracted using the minus sign:
7.5 - 2.1
Output:
5.4
8

2.3

Multiplication

Multiplication is done using the asterisk * symbol as in


3 * 12
Output:
36
Indeed, real numbers can be multiplied as well:
3.7 * 12.17
Output:
45.029

2.4

Division

The forward slash / symbol is used for division:


30 / 5
Output:
6
However, we need to be careful. Look at this:
33 / 5
Output:
6
This doesnt look correct! Why did Python return 6 and not 6.6? The answer is that
since the numbers 33 and 5 are both integers, the / operator performs integer divi9

sion, or floored division, and returns an integer. This is because like C, C++, and Fortran,
Python is strongly-typed. This means that python will avoid implicitly changing between types of data. In order to perform floating-point division, the type of division
that is more common in the sciences, at least one of the numbers must be represented
as a real number.
Adding a decimal point after the number will accomplish this. Now, the result is a
real number:
33. / 5
yields
6.6
An alternative way of turning an integer into a real number, which also works for
variables, is using the function float(). Then the above division could be done as
follows:
float(33) / 5
Output:
6.6
Once we understand the behavior, we can use it to our advantage. For example, we
can calculate how many times a dozen fits into a thousand:
1000 / 12
Output:
83
By calculating 1000 - 83 * 12 we obtain 4 which is the remainder of the integer
division. In fact the remainder can be calculated in a simpler way using the modulo
operator that will be introduced in the next paragraph.

10

In summary:
Keep in mind that division is a tricky operation. Failure to convert at least one
operand to a real number can be a source of mistakes that are very hard to find.
2.5

Modulo

The last of the common arithmetic operations is modulo (remainder after integer division). In Python modulo is represented via the percent symbol %:
6 % 4
Output:
2
Modulo can be applied to real numbers as well:
12.5 % 2.0
Output:
0.5

2.6

Powers

For exponents, such as in 24 , Python has a double-star symbol **:


2**4
Output:
16
Both the base and the exponent can be real numbers:
3.2**2.5
11

Output:
18.31786887167828
But we have to be careful with negative numbers:
(-3.2)**2.5
Output:
Traceback (most recent call last):
File "<nclab>", line 1, in <module>
ValueError: negative number cannot be raised to a fractional
power

2.7

Priority of operators

Python respects the priority of operators that is standard in mathematics:

Round brackets (...)have the highest priority,


then exponentiation **,
then multiplication *, division / and modulo %,
the lowest priority have addition + and subtraction -,
operations with the same priority are evaluated from left to right for example the
result of 20 / 10 * 2 is 4.

Note that no other brackets such as { } and [ ] are admissible in mathematical expressions. The reason is that they have a different function in the programming language. To illustrate the priority of operations, we evaluate the following expression:
3**4 / 27 * 5 + 3 * 5
Output:
30
If we are not sure, it never hurts to use round brackets:

12

(3**4) / 27 * 5 + 3 * 5
Output:
30

2.8

Using empty characters makes your code more readable

Your code will be much more readable if you use empty characters on either side of
arithmetic symbols, as well as after commas. Hence, you should never write things like
sin(x+y)+f(x,y,z)*5-2.4.
Instead, the same can be written in a much more reader-friendly form as
sin(x + y) + f(x, y, z) * 5 - 2.4.

2.9

Using mathematical functions

In order to calculate square roots, exponentials, sines, cosines, tangents, and many
other math functions, the best way is to import Numpy. Numpy is a powerful Python
library for numerical computations. To import it, just include the following line in your
code:
from numpy import *
Here the symbol * stands for "everything". If you wanted to import just one or two
functions, you could do that as well by just giving their names, separated by commas.
After Numpy is imported, we can calculate, for example, e2 :
exp(2)
Output:
7.3890560989306504
13

Elementary functions (and constants) that one can import from Numpy are listed below. We also show their arguments for clarity, but the functions are imported without
them. For example, the absolute value function is imported via from numpy import
abs.
pi
abs(x)
arccos(x)
arccosh(x)
arcsin(x)
arcsinh(x)
arctan(x)
arctanh(x)
arctan2(x1 , x2 )
cos(x)
cosh(x)
exp(x)
log(x)
pow(a, b)
sin(x)
sinh(x)
sqrt(x)
tan(x)
tanh(x)

absolute value of x
inverse cosine of x
inverse hyperbolic cosine of x
inverse sine of x
inverse hyperbolic sine of x
inverse tangent of x
inverse hyperbolic tangent of x
arc tangent of x1 /x2 choosing the quadrant correctly
cosine of x
hyperbolic tangent of x
ex
natural logarithm of x
ab (same as "a**b")
sine of x
hyperbolic sine of x
square root of x
tangent of x
hyperbolic tangent of x

In summary:
Python provides many readily available mathematical functions via the Numpy
library. To use them, import them via the command from numpy import *
2.10

Fractions

Python makes operation with fractions easy via the Fraction function that is imported from the fractions library:
from fractions import Fraction
A fraction such as 4/7 can be defined simply as Fraction(4, 7). Fractions can be
used with the same operations as numbers, and the result of such an operation is a
14

Fraction. For example


Fraction(2, 6) + Fraction(2, 3)
yields
Fraction(1, 1)
Another example:
Fraction(2, 6) / Fraction(2, 3)
results into
Fraction(1, 2)
The fractions library also provides the useful function gcd() that calculates the
Greatest Common Divisor (GCD) of two integers. It is imported via
from fractions import gcd
For illustration let us calculate the GCD of 867 and 629:
gcd(867, 629)
The output is
17

2.11

Random numbers

Python provides a random number generator via the random() function that can be
imported from the random library:
from random import random
15

This function returns a random real number between 0 and 1. For example,
random()
yields
0.871979925682207
Sometimes we need to generate random integers rather than real numbers. This is easy.
For illustration, a random integer n between 1 and 3 can be generated via the code
a = random()
n = int(3*a + 1)
Here the function int() will erase the decimal part of the real number, converting it
to an integer.
2.12

Complex numbers

Complex numbers are always represented as two floating point numbers, the real and
imaginary part. Appending j or J to a real number makes it imaginary:
1j * 1J
Output:
(-1+0j)
This is one way to define complex numbers:
1 + 3j
Output:
(1+3j)
Another way is to use the command complex:

16

complex(1, 3)
Output:
(1+3j)
All arithmetic operations that are used for real numbers can be used for complex numbers as well, for example:
(1 + 2j) / (1 + 1j)
Output:
(1.5+0.5j)
To extract the real and imaginary parts of a complex number z, use z.real and
z.imag. Use abs() to get the absolute value:
a = 3 + 4j
a.real
a.imag
abs(a)
Output:
3
4
5

3
3.1

Functions
Objectives

Review what we know about functions from Karel the Robot.


Learn that in Python, functions can accept input arguments.
Learn to use default arguments and return multiple values.

17

You might also like