Course Assessment Report College of Engineering, The University of Iowa

advertisement
Course Assessment Report
College of Engineering, The University of Iowa
(Revised 20 May 2010)
Course # and Name: 059:006 Engineering Problem Solving II
Semester and Instructor: Spring 2010, Thomas Casavant, Justin Garvin, Gary Christensen
Coordinator: Terry Braun, BME Department
Student Head Count: ???
Teaching Assistants Head Count and FTE: 5 (1.25 FTE)
Catalog Description: Engineering problem solving using computers; introduction to digital
computations, problem formulation using a procedural high-level language; structured, top-down
program design methodology; debugging and testing; introduction to use of software libraries;
examples from numerical analysis and contemporary applications in engineering. Corerequisite:
22M:031.
I. Course Goals and Program Outcomes
Indicate the Program Outcomes associated with each Course Learning Goal along with the extent
(moderate or substantial) of these associations
Course Learning Goal
1. Students will have a thorough understanding of the for, while and do-while
looping structures using the C programming language.
2. Students will have a thorough understanding of logical operators (AND, OR) and
selection statements using the C programming language.
3. Students will understand how to design, implement and test an algorithm to solve
an engineering problem using the C programming language.
4. Students will understand how to use functions to divide an algorithm into
component pieces using the C programming language.
5. Students will be able to demonstrate goals 1-5 using MATLAB.
Program Outcome
a(●), e(●), k(●)
a(●), e(●), k(●)
a(●), e(●), k(●)
a(●), e(●), k(●)
a(●), e(●), k(●)
Notes: ○ denotes moderate contribution to the outcome ● denotes substantial contribution to the outcome
II. Program Outcomes (provided for reference).
New graduates from the College of Engineering Undergraduate Programs will have:
(a) an ability to apply knowledge of mathematics, science, and engineering
(b) an ability to design and conduct experiments, as well as to analyze and interpret data
(c) an ability to design a system, component, or process to meet desired needs within realistic constraints such as economic,
environmental, social, political, ethical, health and safety, manufacturability, and sustainability
(d) an ability to function on multi-disciplinary teams
(e) an ability to identify, formulate, and solve engineering problems
(f) an understanding of professional and ethical responsibility
(g) an ability to communicate effectively
(h) the broad education necessary to understand the impact of engineering solutions in a global, economic, environmental, and
societal context
(i) a recognition of the need for, and an ability to engage in life-long learning
(j) a knowledge of contemporary issues
(k) an ability to use the techniques, skills, and modern engineering tools necessary for engineering practice.
III. Assessment
Part A. Log of Recent Improvements, Recommendations and Comments. Append a brief, dated,
summary of improvements and recommendations made during the current offering along with
motivations and significant comments. If the course is meeting its objectives and no comments are
needed, say this. Six year and older entries may be deleted.
SUMMARY OF PRIOR REMEDIATION ACTIONS: (and their estimated effect)
In 2006, the staff felt that the discussions sections should be held in classrooms with computers. In 2007, the
discussion sections were rearranged so that every discussion section occurred in a computer lab.
In 2007 the staff addressed students’ complaints that the homework was taking too much time by carefully
reviewing each homework assignment to ensure that the problem were not too difficult or time consuming. In
addition, practice exams were provided online so that the students could drill themselves on the relevant
concepts to ensure that they were properly prepared for the exam. This year students did not complain about the
amount of time consumed in solving homework problems.
In 2007 we also discussed developing an online tool so that students could assess their basic skills before
attempting the homework problem. We developed such a tool, then abandoned it because pilot testing suggested
that it did not significantly improve the student experience, primarily because the tool was too complex.
In 2007 we discussed moving all discussion sections to a classroom in which each student will have their own
laptop. This was achieved and the discussion sections went quite well and the students enjoyed the programming
experience.
In 2007 we changed the syllabus to eliminate the concentration on pointers and structures in order to increase
the course’s emphasis on design and the study of MATLAB. Student comments and the experience of the
professors suggests that this approach leaves holes in the exposition. We plan to modify the course substantially
next year and continue to avoid pointers, in the hope that the revisions may satisfactorily cover the holes in the
exposition.
In 2008 we substantially changed the structure of the course by eliminating lectures, dividing the course into six
sections and holding these sections in the laptop classroom in 2, 1:15-length sections each week. In addition,
the course learning goals recommended in the previous Course Assessment Report were adopted.
In 2008, we recommended that the course goals be changed to the following.
Students will have a thorough understanding of logical operators (AND, OR) and selection statements
using the C programming language.
Students will understand how to design, implement and test an algorithm to solve an engineering
problem using the C programming language.
Students will understand how to use functions to divide an algorithm into component pieces using the C
programming language.
Students will be able to demonstrate goals 1-5 using MATLAB.
The following recommendations are made (Spring 2010):
1. There is urgent need of a C development environment that student can use outside of class staring from
the beginning of the semester. Eclipse would be a nice choice if a C compiler were available for
Windows.
2. The current recommendation for lecture structure is: 20 minutes of lecture followed by 50 minutes of
in-class programming. However, especially earlier in the semester (first 2-5 lectures), instructors may
find that they need to spend more time lecturing to bring students up to speed. This is only a suggestion,
as other lecture styles may work too, such as demonstrating functionality of C, have the students try it,
then repeat.
3. A clear, and concise document on a cheating policy should be written (and tailored by each year's
instructors).
4. Keep the reading quizzes and in-class programming problems. Discard the "programming quiz."
5. The current class used 5 take-home programming assignments. Based on this, it is recommended that at
least 7 assignments are needed (5 C, and 2 Matlab).
6. Material needs to be developed and added (at least 1 lecture) dedicated to the topic of systematic
strategies for debugging (divide and conquer, profiling, debuggers, etc.)
7. Managing all of the quizzes and assignments on the Icon website can be problematic. The original
instance simply numbered quizzes (Quiz 1, Quiz 2, … etc.). This has the problem of making it difficult
to know what day each quiz occurred without inspecting timestamps (which is possible, but requires
actually looking at the quiz). It has been proposed to list quizzes by date (Quiz 1 – 01/25/2010, … etc.).
However, this has the flaw that if a quiz is delayed, then all subsequent list dates have to change.
Currently there is not a good solution.
8. Matlab – the book is fine. Recommend only covering chapters 1-6. Chapters 2 and 5 probably need
two lectures each to cover the material. It is suggested that developing a mechanism to have the
students type in the examples before class would be beneficial.
9. Reading quizzes – the spacing of days and topics needs to be adjusted. For example, covering 50 pages
from Tuesday to Thursday is not optimal. Conversely, covering 2 pages from Thursday to Tuesday is
bad pacing as well.
10. "Clickers" may increase student engagement and participation. (Maybe SWD could develop a software
clicker as part of a project, so students could use the laptop as a clicker, as opposed to introducing more
complexity to the course through another device.)
RECOMMENDED CHANGES TO COURSE LEARNING GOALS:
Teach a systematic strategy for debugging program.
Part B. Quantitative Assessment Results. Enter in the table below an assessment of the percentage
of passing students achieving mastery (B+ to A+ level achievement), competency (C- to B level
achievement) or exposure (D- to D+ level achievement) for each course learning goal.
To make room for the rightmost “new” entry, delete the leftmost “old” entry.
SP
2010
Course Learning Goal And
Assessment Basis
1. Students will have a thorough
understanding of the for, while and do-while
looping structures using the C programming
language.
2. Students will have a thorough
understanding of logical operators (AND, OR)
and selection statements using the C
programming language.
3. Students will understand how to design,
implement and test an algorithm to solve an
engineering problem using the C
programming language.
4. Students will understand how to use
functions to divide an algorithm into
component pieces using the C programming
language.
5. Students will be able to demonstrate goals
1-5 using MATLAB.
Assessment:
-- in-class programming assignments
M/C/E
-- homework assignments
M/C/E
-- reading quizzes
M/C/E
-- exams
M/C/E
Part C. Please attach a current syllabus.
SP
2011
59:006 Engineering Problem Solving II, Spring 2009
Course Policies and Procedures
Instructors:
Your instructors are Geb Thomas (8:05-9:20, 9:30-10:45), Xiaodong Wu (10:55-12:10, 1:052:20), and Terry Braun (2:30-3:45, 3:55-5:10).
Geb Thomas: Geb-Thomas@uiowa.edu
Xiaodong Wu: xiaodong-wu@uiowa.edu
Terry Braun: tabraun@eng.uiowa.edu
5318 SC
Office hours: TBD
Course Description:
An introduction to programming using the C programming language and MATLAB. Students
learn how to plan, execute, diagnose failures, and iterate through a logical design. The C
language programming introduces low-level concepts of data types, logic flow, and compiling
programs, while the MATLAB portion emphasizes interactive manipulation of complex data to
solve engineering problems.
Learning Objectives:
1. Students will have a thorough understanding of the for, while and do-while looping
structures using the C programming language.
2. Students will have a thorough understanding of logical operators (AND, OR) and selection
statements using the C programming language.
3. Students will understand how to design, implement and test an algorithm to solve an
engineering problem using the C programming language.
4. Students will understand how to use functions to divide an algorithm into component pieces
using the C programming language.
5. Students will be able to demonstrate goals 1-5 using MATLAB.
Background:
This course is being redesigned.
The new design will have six sections with two meetings per week. Rather than having hourlong lectures, the course will meet in a computer lab. Each day students will prepare by 1)
completing a reading assignment and 2) completing on-line quiz.
The class will begin with a discussion led by the professor, followed by an in-class
programming exercise. At the end of the class, students will complete another on-line quiz to
demonstrate that they mastered the material in the daily assignment. During the summer, the
schedule is compressed so the class meets four times a week rather than twice a week.
Textbooks:
This course will use two textbooks: C How to Program, by Deitle and Deitle, 5th Edition,
Prentice Hall Publishers, ISBN: 978-0132404167; and an Introduction to Matlab 7 by Etter
ISBN: 0-13-1474792-8. Both are available in the University Book Store in the Student Union.
Getting Help:
The in-class assignments are designed to create opportunities to ask the professor and TA's
your programming questions. The at home assignments are designed to be completed by
yourself. If you need extra help, please visit the TA or professor during office hours or send an
email.
Computer Accounts:
You will need an account on the college's Computer Support Systems (CSS) infrastructure. If
you do not already have an account, see http://www.icaen.uiowa.edu for instructions.
Assignments:
You will normally have 1 reading assignment, one on-line reading quiz, and one on-line inclass
quiz for each class meeting. Approximately every 2 weeks (this may very depending on
difficulty) you will also have one homework assignment. Homework assignments are to be
worked on individually, unless explicitly stated otherwise. While you may discuss possible
solution approaches with other students, the work you turn in for grading must be your own.
Specifically, you must type every character of every program yourself.
Unless otherwise stated, all homework should be turned in to ICON by the time specified on
ICON.
If you complete your in class assignment early, you are encouraged to help other students.
Don't expect to hurry through your work and leave class early.
Honors:
You can receive honors for this course if you complete 6 "challenge" problems, in addition to assigned
bi-weekly homework problems. The form is on ISIS and students will find the form under Student
Records -> Reports and Documentation -> Honors Designation for Course Work
You need to print this form out and follow the instructions -- including having it signed by the
instructor at the beginning of class, and after you complete the "challenge" problems.
Exams:
There will be two (2) exams and a final exam. These will be scheduled outside of class.
Makeup Exams:
For those having verified conflicts with the exam schedule, makeup exams will be arranged on
an individual basis. In order to arrange a makeup, you must contact your instructor or TA by
email at least one week prior to the scheduled test date. Serious illness, of course, is an
exception to this policy. All cases of sudden illness must be verified with a Doctor's note
through the Dean's office to arrange an "after the fact" makeup exam. Approval of verified
conflicts will be at the discretion of the instructor.
Retrieval of Graded Materials:
All exams will be individually returned in your class. Please allow a minimum of one week for
grading of exams and homework assignments.
Final Course Grading:
The breakdown of the parts that contribute to the final grade are as follows:
Homework (outside of class)
Reading quizzes
In-class programming submissions
Programming quizzes
15%
10%
10%
10%
Midterm 1
15%
Midterm 2
15%
Final
25%
Incompletes:
A grade of "I" will be given only for cases in which there are documented circumstances
beyond the student's control; it is not a substitute for "F".
Academic Honesty (Cheating):
You should already know the College of Engineering policy on cheating. It applies to this class.
Also note that if two assignments are similar enough to represent the same piece of work, both
assignments will receive a grade of zero. We will not distinguish between the original and the
copy.
DO NOT COPY someone else's homework and turn it in with your name on it. If we determine
that you have collaborated with anyone else (past or present), you will receive a zero for the
homework and possibly more serious penalties. Because this has been a problem in the past, we
have been specifically requested to be strict about this policy and actively identify unethical
students.
Remote Access:
A client is available for download from http://www.nomachine.com
This client, called "NXClient" (Windows, Mac, or Linux) allows you to access the
development environment that is used on the laptops in 2229 SC. For server,
use: desktop.engineering.uiowa.edu
Persons With Disabilities:
We would like to hear from anyone who has a disability which may require some modification
of seating, testing or other class requirements so that appropriate arrangements may be made.
Please see the professor or teaching assistant after class or during office hours.
Privacy:
Grades and other class data will be posted on ICON. Your grade information will be only
available to you, although statistical information about all the students' grades will be available
to all students. If the grades are not yet posted on ICON, you can assume that they are not yet
available.
Class Participation:
Please feel free to ask questions when you don't understand something that is presented in the
lecture or in the Discussion Section. Further, more material will be covered in lecture than is
simply "in the book." You are responsible for all reading and all material presented in lecture.
Reading Assignments:
Take them seriously and always attempt to complete reading before class each day.
Recommendations for Success
Do master material. Try to work out examples from the book, even if we didn't get to cover
them in class.
Do the reading diligently.
Do outline notes and reading. Review the text, your homeworks, and lecture notes to prepare
for exams.
Don't get behind!
Don't simply cram for exams -- keep up all the way along.
Don't just study problems. The concepts in this course can be tested through asking you to
solve original problems on exams. Be prepared to think.
Do take advantage of office hours to get extra help. Communicate with your instructor or
discussion section leader if you are getting into trouble. Don't wait until the last minute to do
this.
Do keep backup copies of your computer files.
Don't wait until the last minute to submit your assignment electronically.
Finally, a note of warning.
This is a demanding, difficult course -- if you work hard. If you do not work hard, or get
behind, it is not hard -- it is impossible. Do not get behind. Start work on assignments as soon
as they are given. Do not underestimate the demanding nature of this course. Expect the system
to crash the night before your program is due. Aim to have a homework assignment done the
day before it is due. This practice will be important when you get a job. After you graduate,
your boss will not be impressed by claims that you lost your files because the system went
down. He or she will simply expect you to deal with it, or better yet, to have planned ahead to
overcome unforeseen problems.
Download