CMPSC 40: Foundations of Computer Science
This course introduces you to the discrete mathematics needed to successfully complete your computer science degree. Learning to produce & write mathematical proofs is a central course theme.
Catalog Description
Propositional & predicate logic, set theory, functions & relations, counting, mathematical induction & recursion.
Prerequisites
Computer Science 16 with a grade of C or better & Mathematics 4A with a grade of C or better.
Why have a lower division course on mathematical foundations?
To prepare computer science students for the mathematical knowledge & maturity required by some upper division courses, such as the courses on algorithms & the course on automata & formal languages.
It also can be argued that any educated person in an information economy should have a basic grasp of logic & sets.
Course Goals
To learn & be able to apply basic knowledge of:
- logic
- sets
- relations
- recursion & induction
- counting.
The principal application of this knowledge is the ability to comprehend and develop proofs for mathematical statements and to communicate proofs in a clear, precise written form.
As an instructor, I also encourage you to become a more self-directed learner. I believe that the future belongs to those who enjoy learning things for themselves. I consequently hope that you explore some additional topics that are of personal interest. Self-directed learning, like any skill, takes practice. Persevere. Being self-directed does not mean that you cannot talk to people. It means that you take personal responsibility for organizing & executing—in a word, directing—your own learning plan. I would love to discuss any plans you may have or wish to formulate for self-directed learning.
Topics
The slides linked to below are not a substitute for attending lecture. They merely organize the discussion that takes place in class.
- Logic
- Basic Structures: Sets & Functions
- Algorithms
- Number Theory & Cryptography
- Induction & Recursion
- Counting
- Discrete Probability - covered in PSTAT 120A
- Advanced Counting Techniques
- Relations
Written Communication
Students present their solutions to problems in writing on both homework & examinations. Precision & clarity are the coin of this communication realm.
Problem Analysis
This course's essence: Develop mathematical problem-solving skills that you can apply in a variety of intellectual pursuits.
Workload
This is a 4-credit course at UCSB. You are expected to finish this course in 10 weeks, working intelligently for an average of 10 hours/week.
Please email Peter Cappello comments about what you would like to see in future lectures, so that he can better accommodate your wishes.
Office Hours
Pete Cappello | cappello@cs.ucsb.edu | Harold Frank Hall, 2157 |
|