CISC101 Reminders Assn 3 due Friday, this week.

Slides:



Advertisements
Similar presentations
1 Printing in Python Every program needs to do some output This is usually to the screen (shell window) Later we’ll see graphics windows and external files.
Advertisements

Fall 2015CISC/CMPE320 - Prof. McLeod1 CISC/CMPE320 Today: –Review declaration, implementation, simple class structure. –Add an exception class and show.
CMSC 104, Section 301, Fall Lecture 18, 11/11/02 Functions, Part 1 of 3 Topics Using Predefined Functions Programmer-Defined Functions Using Input.
Today… Style, Cont. – Naming Things! Methods and Functions Aside - Python Help System Punctuation Winter 2016CISC101 - Prof. McLeod1.
Today… Python Keywords. Iteration (or “Loops”!) Winter 2016CISC101 - Prof. McLeod1.
Today… Strings: –String Methods Demo. Raising Exceptions. os Module Winter 2016CISC101 - Prof. McLeod1.
Winter 2016CISC101 - Prof. McLeod1 CISC101 Reminders Quiz 3 next week. See next slide. Both versions of assignment 3 are posted. Due today.
Today… Modularity, or Writing Functions. Winter 2016CISC101 - Prof. McLeod1.
Quiz 3 Topics Functions – using and writing. Lists: –operators used with lists. –keywords used with lists. –BIF’s used with lists. –list methods. Loops.
Today… Functions, Cont.: –Designing functions. –Functional Decomposition –Importing our own module –A demo: Functional solution to assignment 2. Winter.
Quiz 4 Topics Aid sheet is supplied with quiz. Functions, loops, conditionals, lists – STILL. New topics: –Default and Keyword Arguments. –Sets. –Strings.
Quiz 1 A sample quiz 1 is linked to the grading page on the course web site. Everything up to and including this Friday’s lecture except that conditionals.
Next Week… Quiz 2 next week: –All Python –Up to this Friday’s lecture: Expressions Console I/O Conditionals while Loops Assignment 2 (due Feb. 12) topics:
Today Encapsulation. Build a fully encapsulated Halloween class, going from Halloween1 to Halloween6 (eventually!): –The final version will have overloaded.
Next Week… Quiz 2 next week: –All Python –Up to this Friday’s lecture: Expressions Console I/O Conditionals while Loops Assignment 2 (due Feb. 12) topics:
Introduction to Computing Science and Programming I
Lecture 2 D&D Chapter 2 & Intro to Eclipse IDE Date.
Introduction to Python
Formatting Output.
Variables, Expressions, and IO
Functions CIS 40 – Introduction to Programming in Python
Functions.
CMPE212 – Stuff… Assn 3 due and Quiz 2 in the lab next week.
Winter 2018 CISC101 11/9/2018 CISC101 Reminders
CMPE212 – Stuff… Exercises 4, 5 and 6 are all fair game now.
CISC101 Reminders Quiz 2 this week.
CISC101 Reminders Quiz 1 grading underway Next Quiz, next week.
Winter 2018 CISC101 11/22/2018 CISC101 Reminders
Number and String Operations
CISC101 Reminders Quiz 1 grading underway Assn 1 due Today, 9pm.
CISC101 Reminders Slides have changed from those posted last night…
Winter 2018 CISC101 12/1/2018 CISC101 Reminders
Winter 2018 CISC101 11/27/2018 CISC101 Reminders
CISC101 Reminders Assn 3 due Friday, this week. Quiz 3 next week.
Winter 2018 CISC101 12/1/2018 CISC101 Reminders
Winter 2018 CISC101 12/1/2018 CISC101 Reminders
Winter 2018 CISC101 12/2/2018 CISC101 Reminders
Fall 2018 CISC124 12/3/2018 CISC124 or talk to your grader with questions about assignment grading. Fall 2018 CISC124 - Prof. McLeod Prof. Alan McLeod.
CISC101 Reminders Quiz 2 graded. Assn 2 sample solution is posted.
CISC101 Reminders Assn 3 due tomorrow, 7pm.
CISC101 Reminders Quiz 1 grading underway Next Quiz, next week.
CISC101 Reminders Quiz 2 this week.
Coding Concepts (Basics)
CISC/CMPE320 - Prof. McLeod
Fall 2018 CISC124 2/15/2019 CISC124 TA names and s will be added to the course web site by the end of the week. Labs start next week in JEFF 155:
Winter 2019 CISC101 2/17/2019 CISC101 Reminders
CISC124 Labs start this week in JEFF 155. Fall 2018
Python programming exercise
CISC/CMPE320 - Prof. McLeod
Fall 2018 CISC124 2/24/2019 CISC124 Quiz 1 marking is complete. Quiz average was about 40/60 or 67%. TAs are still grading assn 1. Assn 2 due this Friday,
CMPE212 – Reminders The other four assignments are now posted.
Winter 2019 CISC101 4/8/2019 CISC101 Reminders
CISC101 Reminders All assignments are now posted.
CISC101 Reminders Assignment 2 due today.
Winter 2019 CISC101 4/16/2019 CISC101 Reminders
CISC101 Reminders Assignment 3 due next Friday. Winter 2019
Winter 2019 CISC101 4/14/2019 CISC101 Reminders
CMPE212 – Reminders Course Web Site:
CISC101 Reminders Quiz 1 marking underway.
Winter 2019 CISC101 4/29/2019 CISC101 Reminders
CISC101 Reminders All assignments are now posted.
Winter 2019 CISC101 4/28/2019 CISC101 Reminders
CMPE212 – Reminders Quiz 1 marking done. Assignment 2 due next Friday.
Winter 2019 CMPE212 5/25/2019 CMPE212 – Reminders
Winter 2019 CISC101 5/26/2019 CISC101 Reminders
CISC101 Reminders Assignment 3 due today.
Winter 2019 CISC101 5/30/2019 CISC101 Reminders
CMPE212 – Reminders Assignment 2 due next Friday.
Functions Taken from notes by Dr. Neil Moore & Dr. Debby Keen
Presentation transcript:

CISC101 Reminders Assn 3 due Friday, this week. Winter 2018 CISC101 11/13/2018 CISC101 Reminders Assn 3 due Friday, this week. Quiz 3 next week. Topics on next slide. Winter 2018 CISC101 - Prof. McLeod Prof. Alan McLeod

Quiz 3 Topics Functions – using and writing. Lists: Loops – still! operators used with lists. keywords used with lists. BIF’s used with lists. list methods. Loops – still! Conditionals – still! File I/O, catching Exceptions. Exercises 1 to 6. Sets not on quiz. Winter 2017 CISC101 - Prof. McLeod

Today Building Functions, Cont.: Another module example. Why are functions better? Functional Decomposition. Go over function syntax in more detail. Winter 2018 CISC101 - Prof. McLeod

Aside - Two Ways to Use import To tell the interpreter that we wish to use module functions, you need to import the module as in: import math But, if you don’t want to have to say math.sqrt() (ie. you don’t want to have to name the module all the time), you can use a different kind of import statement: from math import * Or, to just import the sqrt() function for example: from math import sqrt Winter 2018 CISC101 - Prof. McLeod

Module Functions, Cont. If you have used from math import *, for example, then you can invoke any of the math functions directly: print(sqrt(2)) Instead of: print(math.sqrt(2)) Winter 2018 CISC101 - Prof. McLeod

Example – The myInput Module Put our robust input function in a code module and import it into other programs, just like we have been doing with the turtle and math modules. Create myInput.py, which contains only the getInt() and getFloat() functions and does not need to have a main() function. In another program use “import myInput”. Note the creation of a byte code version (*.pyc) of the new module… See myInput.py and FunctionalMortgageCalculatorV2.py. Winter 2018 CISC101 - Prof. McLeod

Designing a Function A function should only do one thing. If you describe the function and need to use the word “and”, then it is probably doing more than one thing. Try to keep the parameter list short – 3 or fewer parameters, if possible. Or take advantage of default arguments (more on this later). The function should be short: in the range of 1 to 15 lines ideally. Be prepared to re-structure a working program to get a better design. Winter 2018 CISC101 - Prof. McLeod

Designing a Function, Cont. Choose good, descriptive function and parameter names, so it is obvious what the function is doing. If you only need to add a bit more code to make your function more universally applicable – do it! Try to always check all your parameter values for legality. What would happen if the arguments supplied to our myInput functions are not of the expected type? Winter 2018 CISC101 - Prof. McLeod

Designing a Function, Cont. Try to get your function to return something rather than print something. Often main() will have to worry about all the console output. By convention, main() should always be the starting point of your program. Winter 2018 CISC101 - Prof. McLeod

Program Construction You can start from a functional decomposition of the problem. Write function headers and add parameters. Put the return value in a comment for now. Choose function names that describe what the function does. Make sure each function does one thing only. You may find a need for additional functions as you fill in the code for each function. Don’t be afraid to further decompose a function if it is getting too big or doing too many things. Winter 2018 CISC101 - Prof. McLeod

Testing and Debugging How can you test a one function program? In this case you need to wait until the entire program is complete before you can start testing! Or, you can choose to test one function at a time by: Putting a pass command in other empty (for the moment) functions. Add temporary code to main() to invoke your test function with test values and then display its return value. You know a failure is from the function under test! Small functions are much easier to debug!! Winter 2018 CISC101 - Prof. McLeod

You Decide! Multi-function PROs: CONs: Easier to design. CISC101 You Decide! Multi-function PROs: Easier to design. Easier to construct. Easier to read. Requires fewer comments. Easier to test and fix. Easier to re-use. CONs: Longer program overall. Slower? (not much…) Winter 2018 CISC101 - Prof. McLeod Prof. Alan McLeod

Functional Decomposition A common-sense idea: break a large problem down into smaller pieces! Keep breaking down the pieces until they are small enough to solve. Each piece will represent a function if the problem is a programming problem. Winter 2018 CISC101 - Prof. McLeod

Example – Washing Machine Control Top-most level: Connect wasther to 110V AC, hot/cold water supply and drain. Place clothes and soap in washer. Washer removes dirt from clothes. Remove clothes containing a minimal amount of water and dirt. We are interested in step 3. Winter 2018 CISC101 - Prof. McLeod

Example, Cont. – Second Level Step 3 on the previous slide decomposed: Agitate clothes in soapy water. Remove soapy water. Rinse with water. Remove as much water as possible from clothes. Winter 2018 CISC101 - Prof. McLeod

Example, Cont. – Third Level Step 1 (only) from the previous slide: Lock washer door. Fill machine with water of specified temperature. Activate agitator motor to specified rate. Agitate for specified time period. Winter 2018 CISC101 - Prof. McLeod

Example, Cont. – Fourth Level Step 2 (only) from the previous slide: Query front panel settings for water temperature. Depending on settings, open cold valve only, hot valve only or both. If water is not flowing activate alarm. Close water input valves when level sensor indicates desired water level has been obtained. Winter 2018 CISC101 - Prof. McLeod

Example, Cont. – Fourth Level, Pseudocode desiredTemp = getTempSetting(frontpanel) if desiredTemp == hot openValve(hot) else if desiredTemp == cold openValve(cold) else if not waterFlowing() sendAlarm(waterError) while not waterFull(desiredLevel) if waterFull(desiredLevel) closeValves() Winter 2018 CISC101 - Prof. McLeod

Example, Cont. And so on… Continue the process until you have sufficient detail to write pseudocode. Put together a list of functions. List: The name of the function. The return type, if any. The required parameters. What the function does. What the function does if input is illegal. Winter 2018 CISC101 - Prof. McLeod

Invoking Functions - Review Name the function and then use round brackets. The brackets can be empty or have one or more arguments inside. For example: print() Displays a linefeed on the console. print("Hello") Displays the string Hello on the console. print("Hello", "Alan") Displays Hello and then Alan, separated by a space on the console. Winter 2018 CISC101 - Prof. McLeod

Invoking Functions, Cont. Arguments are separated by commas. Arguments can be: Literal values. Variables. Expressions. In the case of a variable or an expression, it is first evaluated to come up with the resulting value before it is fed into the function. Winter 2018 CISC101 - Prof. McLeod

Aside - Keyword Arguments The previous print() examples used positional arguments. We have also done things like: print("Hello", "Alan", sep="\n") The two strings will be on different lines this time. The sep="\n" thing is called a keyword argument. We will learn more about keyword arguments and default arguments later! Winter 2018 CISC101 - Prof. McLeod

Function Returns A function may return something. Functions that don’t return anything (like print(), for example) are sometimes called procedures or void functions. Can you think of some functions that return something? input() float() str() len() sorted() … Winter 2018 CISC101 - Prof. McLeod

Function Returns This “thing” that is returned can be any Python type such as a string, a list, an int, a float, etc. It is also possible to return multiple things in Python: a, b, c = someFunction(arg1, arg2) But, is the a, b, c part three “things” or just one thing really? What type is it? Winter 2018 CISC101 - Prof. McLeod

A Function with Parameters Here is a (useless) function that displays the higher of two numbers: def showHighest(num1, num2) : if num1 > num2 : print(num1, "is higher.") else : print(num2, "is higher.") Winter 2018 CISC101 - Prof. McLeod

A Function with Parameters, Cont. So, when you invoke this (completely useless) function from within some other function (main() perhaps…), you need to supply two things for the parameters - you supply two arguments: showHighest(3.4, 6.7) The code in showHighest() runs and the larger number is displayed. Within showHighest(), num1 has the value 3.4 and num2 has the value 6.7 Winter 2018 CISC101 - Prof. McLeod

A Function with Parameters, Cont. To put it another way: The positional arguments 3.4 and 6.7 have been mapped into the parameters num1 and num2. num1 and num2 are variables that have been created in the function’s parameter list and are local to the function. Winter 2018 CISC101 - Prof. McLeod

Functions Returning a Value How can showHighest() be changed to return the highest number instead of printing it out? (It is kind of tacky to have functions print things instead of returning them - let main() do the printing!) def getHighest(num1, num2) : if num1 > num2 : return num1 else : return num2 Winter 2018 CISC101 - Prof. McLeod

Functions Returning a Value, Cont. Or: def getHighest(num1, num2) : if num1 > num2 : return num1 return num2 Winter 2018 CISC101 - Prof. McLeod

Returning Values So, here are a few things you need to know about returning things: You can have as many return statements as you want in a function. If you don’t have a return statement, then your function does not return anything. It is invoked without expecting any value to come out of the function (no assignment required when invoking). Execution of a function stops as soon as you execute the return statement, even if there is code after the return statement. Winter 2018 CISC101 - Prof. McLeod

Jazzing Up the Parameter List When using a function, you might not always need or wish to supply all possible parameters. Or, you might not want to have to worry about the order of the arguments supplied. The use of keyword (when invoking) and default (when defining) arguments allows you to enhance the flexibility of how your function is used. Winter 2018 CISC101 - Prof. McLeod

parameterName=argument CISC101 Keyword Arguments Suppose you have a function with several parameters, but you don’t want to worry about supplying values in the matching order. You can use keyword arguments to supply the arguments in any order with the syntax: parameterName=argument in the parameter list. See KeywordArgumentsDemo.py Winter 2018 CISC101 - Prof. McLeod Prof. Alan McLeod

Keyword Arguments, Cont. All positional arguments must come before keyword arguments. But, the keyword arguments can be in any order. Unless the function has default arguments, you must still supply arguments for each parameter. Style note: No spaces on either side of the equals sign. Winter 2018 CISC101 - Prof. McLeod

Default Arguments You can make a function a great deal more flexible by making it optional for the user to supply all the arguments. You do this by creating default arguments in your function definition statement. Default arguments must come after all positional parameters. The same syntax as for Keyword Arguments, but this time it is used in the def line instead of the invoking line. See DefaultArgumentsDemo.py Winter 2018 CISC101 - Prof. McLeod

Default Arguments, Cont. You must decide which parameters are optional, if any. Then you must make assumptions to come up with values for those optional parameters. Supplying an argument value for a default argument replaces the default value. We will see quite a bit of this stuff when using Tkinter! Reduces the need for multiple function versions. Winter 2018 CISC101 - Prof. McLeod

Example: The print() BIF We know that print() can have any number of positional arguments. It also has sep= and end= default arguments. They have been defaulted as sep=" " and end="\n" In other words the default separator between printed items is a space and a linefeed will be added to the output after the last item has been printed. You can only change these values using the keyword arguments. Winter 2018 CISC101 - Prof. McLeod