Computing with numbers - comp

Download Report

Transcript Computing with numbers - comp

3. COMPUTING WITH
NUMBERS
Rocky K. C. Chang
September 10, 2015
(Adapted from John Zelle’s slides)
Objectives
• To understand the concept of data types.
• To be familiar with the basic numeric data types in Python.
• To understand the fundamental principles of how numbers
are represented on a computer.
• To be able to use the Python math library.
• To be able to read and write programs that process
numerical data.
Real number system
• Recall from your math class, real numbers consist of
rational numbers and irrational numbers.
Source: http://catalog.flatworldknowledge.com/bookhub/reader/128?e=fwk-redden-ch01_s01#
Numeric data types
• Computers “simulate” the real number system.
• Two numeric data types:
• Integer (int), e.g., 10, 0, -9999
• Floating-point number (float), e.g., 1.1, 0., -3333.33
• Inside the computer, integers and floating point are
represented quite differently.
• int and float are two different data types.
• A floating-point number can be represented by an
exponent component, e.g., -3.33333x103 (type 3.33333e3 in Python)
EXERCISE 3.1
o Enter a very large integer in your IDLE and
see whether the returned value is the same
as the entered value.
o Repeat above with a very large floatingpoint number.
Limits of range and precision
• The size of an integer in Python is only limited by the
memory that stores it.
• Floating-point values are presented by a double-precision
format (IEEE 754).
• A range of 10-308 to 10308 with 16 to 17 digits of precision
• Arithmetic overflow/underflow
Source: http://en.wikipedia.org/wiki/Double-precision_floating-point_format
EXERCISE 3.2
o Enter 3 * (1/3). Does the result match your
expectation?
o Enter 1/3 + 1/3 + 1/3 + 1/3 + 1/3 + 1/3. Does
the result match your expectation?
Rounding
• The displayed value has been rounded.
• Several related functions:
• round(x, n) built-in function
• math.ceil(x) math function
• math.floor(x) math function
EXERCISE 3.3
o Try round(0.45,1), round(1.45,1),
round(2.45,1), …, round(9.45,1). Do
you observe any patterns?
o Try math.ceil(5.45) and
math.floor(5.45).
o Try int(5.45) and float(5).
Data types
• Each literal or variable is associated with a data type (int
and float for now).
• A type(x) function returns the data type of x which
could be a literal or variable.
• Explicit type conversion
• Built-in functions int(x) and float(x).
EXERCISE 3.4
o Try out the type() function for both numeric
and string literals and variables.
o Assign 10 to x and find out the type of x, and
assign 10.0 to x and find out its type.
Python built-in numeric operations
EXERCISE 3.5
What are the data types of the following
arithmetic expressions: 2.0/3.0, 2/3, 2.0/3,
2+3, 2.0+3.0, 2+3.0, 2.0*3.0, 2*3, 2.0*3?
Data type of a numeric expression
• Same as numeric literals, an arithmetic expression has a
data type, because it returns a value.
• The case of division
Using the Math Library
• Refer to https://docs.python.org/3.2/library/math.html.
• Number-theoretic and representation functions
• Power and logarithmic functions
• Trigonometric functions
• Angular conversion
• Hyperbolic functions
• Special functions
• Constants: math.pi, math.e
EXERCISE 3.6
Below is a well-known way to compute the
value of e:
Implement it using Python. Ask user for a
maximum n and print out the value of each
round. A sample output is on the next page.
Enter a positive integer for approximating e: 10
The value of e is 2.718281828459045.
Round The approximated e
1
1.0
2
2.0
3
2.5
4
2.6666666666666665
5
2.708333333333333
6
2.7166666666666663
7
2.7180555555555554
8
2.7182539682539684
9
2.71827876984127
10
2.7182815255731922
END