Module Description


The aim of this module is to cover fundamental mathematics for Computer Scientists. It does not assume A-level mathematics, and the emphasis and delivery will be on understanding the key concepts as they apply to Computer Science.

Additional support is provided by the Talent Development Centre. Participants not having AS or A level mathematics should take a diagnostic test to see whether they would benefit from this extra support.

Learning Outcomes


After completing this module, students will be expected to be able to:

1. Apply propositional logic to simple problems
2. Use counting methods including permutations and combinations
3. Apply the basic notions of sets, and illustrate answers through Venn diagrams
4. Use methods of probability on simple problems
5. Solve problems in linear algebra using vectors and matrices

 
 
Outline Syllabus


Propositional Logic:
Propositions and logical operators. Truth tables. De Morgan's laws. Algebraic rules and inference. Logical identities, Tautologies and Contraditions

Combinatorics:
Fundamental Principle of Counting. Ordered and unordered selections. Selections with and without replacement. Permutations and combinations. Counting methods.

Sets:
Set notation and basic concepts. Definition of sets through propositions. Set intersection, union and complementation. Venn diagrams. Cardinality. Cartesian products. Sample spaces and events.

Probability:
Experiments and outcomes. Sample space, events, relative frequency and probability. Mutual exclusivity and independence. Counting methods. Conditional probability. Mean and variance. The binomial distribution.

Vectors and Matrices:
Basic definitions. Addition and multiplication of matrices, multiplication by scalars. Inversion of 2x2 matrices. Applications. Transformations of the plane. Solving simultaneous equations in two unknowns.

Module Description

This module will provide an introduction to the basic principles and concepts that underpin procedural programming. It will make use of a high level programming language (i.e. Python) supporting control, data and procedural abstraction. Students will also learn to analyse simple programs, incorporate standard control structures, write functions, arrays structures and I/O, as well as debugging simple programmes.
 

Learning Outcomes

After completing this module, students will be expected to be able to:
1. demonstrate an understanding of the basic principles and concepts that underlie the procedural programming model.
2. explain and make use of high-level programming language features that support control, data and procedural abstraction.
3. analyse and explain the behaviour of simple programs that incorporate standard control structures, parameterised functions, arrays, structures and I/O.
4. implement, test and debug simple programs that use the features listed above.
 

Outline Syllabus

  • Underlying principles of procedural programming
  • The imperative programming model; state, sequentiality and destructive assignment.
  • Abstraction: separating internal and external views; control, data and procedural abstraction.
  • A model of memory: variables; static and dynamic memory; the execution stack
  • Programming in a high-level procedural language
  • Identifiers and keywords
  • Expressions and types: well-typed expressions; operator precedence and expression evaluation
  • Statements and control flow: simple, compound and control statements; the assignment statement; selection and repetition
  • Functions: definition, and call; local variables, scope and existence; parameters, formal and actual parameters, parameter passing
  • Lists and dictionaries: declaration and initialisation; accessing elements
  • Input and output: console and file I/O
 

Learning & Teaching Methods

Lecturers & Laboratories
 

Assessment

This course is 50% Exam and 50% Coursework