这是用户在 2024-8-15 19:57 为 https://www.nottingham.ac.uk/pgstudy/course/taught/2024/computer-science-or-computer-science-artific... 保存的双语快照页面,由 沉浸式翻译 提供双语支持。了解如何保存?
Triangle

Course overview 课程概述

International student applications for this course will close on 20 November 2023 and re-open on 20 February 2024.
本课程的国际学生申请将于 2023 年 11 月 20 日截止,并于 2024 年 2 月 20 日重新开放。


This course is available to students with or without a first degree in computer science.
本课程适用于有或没有计算机科学第一学位的学生。

Computer Science is playing a key role in many industries all around the world. Developments in artificial intelligence, apps and cyber security are changing how we live, work and socialise. This course will give you the skills and knowledge to prepare you for a range of high-level careers.
计算机科学在全球许多行业中发挥着关键作用。人工智能、应用程序和网络安全的发展正在改变我们的生活、工作和社交方式。本课程将为您提供技能和知识,为您从事一系列高水平的职业做好准备。

Core modules will develop your knowledge in key topics such as programming, databases, and networks. Optional modules give you the flexibility to broaden your knowledge in specialist areas, including machine learning, autonomous robotics, and human-AI interaction. 
核心模块将培养您在编程、数据库和网络等关键主题方面的知识。可选模块使您可以灵活地拓宽专业领域的知识,包括机器学习、自主机器人和人机交互。

You will undertake an individual research project in an area of your choice. All projects are supervised by an expert researcher in the area, and many involve collaborations across the University or with industry partners. Previous projects have included:
你将在你选择的领域进行一个个人研究项目。所有项目都由该领域的专家研究人员监督,其中许多项目涉及整个大学或与行业合作伙伴的合作。以前的项目包括:

  • Benchmarking consumer data and privacy knowledge in connected and autonomous vehicles
    对联网和自动驾驶汽车中的消费者数据和隐私知识进行基准测试
  • How time, peer pressure, cognitive load, and emotional attachment influences affect people’s decisions of moral dilemmas within virtual environments
    时间、同伴压力、认知负荷和情感依恋如何影响人们在虚拟环境中做出道德困境的决定
  • Predicting keystrokes using an audio side-channel attack and machine learning
    使用音频侧信道攻击和机器学习预测击键

If you choose to focus your study and research in the field of AI, you can graduate with a degree titled ‘MSc Computer Science (Artificial Intelligence)’.
如果你选择将学习和研究重点放在人工智能领域,你可以获得名为“计算机科学硕士(人工智能)”的学位。

A two-year full-time version of this course is available.
本课程提供两年制全日制课程

Why choose this course? 为什么选择这门课程?

98%

of our research is classed as ‘world-leading’ (4*) or ‘internationally excellent’ (3*)
的研究被评为“世界领先”(4*)或“国际优秀”(3*)

Research Excellence Framework 2021
2021年卓越研究框架

Joint 1st 并列第1名

in the UK for research environment
在英国的研究环境

Research Excellence Framework 2021
2021年卓越研究框架

Ranked 6th in the UK
在英国排名第6位

For universities targeted by the largest number of top employers in 2019-2020
针对 2019-2020 年顶尖雇主数量最多的大学

High Fliers Report The Graduate Market 2019-2020
High Fliers 报告:2019-2020 年毕业生市场

Conversion option 转换选项

No computer programming experience is needed.
无需计算机编程经验。

Your modules will depend on your background in computer science and maths
你的模块将取决于你在计算机科学和数学方面的背景

98%

of our research is classed as ‘world-leading’ (4*) or ‘internationally excellent’ (3*)
的研究被评为“世界领先”(4*)或“国际优秀”(3*)

Research Excellence Framework 2021
2021年卓越研究框架

Joint 1st 并列第1名

in the UK for research environment
在英国的研究环境

Research Excellence Framework 2021
2021年卓越研究框架

Ranked 6th in the UK
在英国排名第6位

For universities targeted by the largest number of top employers in 2019-2020
针对 2019-2020 年顶尖雇主数量最多的大学

High Fliers Report The Graduate Market 2019-2020
High Fliers 报告:2019-2020 年毕业生市场

Conversion option 转换选项

No computer programming experience is needed.
无需计算机编程经验。

Your modules will depend on your background in computer science and maths
你的模块将取决于你在计算机科学和数学方面的背景

98%

of our research is classed as ‘world-leading’ (4*) or ‘internationally excellent’ (3*)
的研究被评为“世界领先”(4*)或“国际优秀”(3*)

Research Excellence Framework 2021
2021年卓越研究框架

Joint 1st 并列第1名

in the UK for research environment
在英国的研究环境

Research Excellence Framework 2021
2021年卓越研究框架

Course content 课程内容

You will study a total of 180 credits, split across 120 credits of compulsory and optional modules plus a 60 credit individual project.
您将学习总共 180 个学分,分为 120 个学分的必修和选修模块以及一个 60 学分的个人项目。

The Artificial Intelligence pathway allows you to graduate with a degree titled 'MSc Computer Science (Artificial Intelligence)'. You will study 40 credits or more of compulsory AI modules and undertake an AI-focused research project.
人工智能途径允许你毕业时获得名为 “计算机科学硕士(人工智能)”的学位。您将学习 40 个学分或更多的必修 AI 模块,并进行以 AI 为重点的研究项目。

Another pathway is offered for students without a computer science degree. This involves compulsory modules that give you the core knowledge required for the remainder of the degree.
另一种途径是为没有计算机科学学位的学生提供的。这涉及必修模块,这些模块为您提供了学位剩余部分所需的核心知识。

Modules 模块

Core 核心

This module will expose you to a variety of research methods, providing you with good quantitative and qualitative skills. Research approaches covered include:

  • laboratory evaluation
  • surveys
  • case studies
  • action research

In addition to project management, the module introduces the research process, from examining how problems are selected, literature reviews, selection of research methods, data collection and analysis, development of theories and conclusions, to the dissemination of the research based on analysis of research papers. The module also offers an overview of ethical considerations when conducting research, and supports in identifying directions for MSc projects.

Students without a degree in computer science must take the following:
没有计算机科学学位的学生必须参加以下课程:

This module will give you a comprehensive overview of the principles of programming, including procedural logic, variables, flow control, input and output and the analysis and design of programs. Instruction will be provided in an object-oriented programming language.

This module is part of the operating systems and networks theme. The module gives an introduction to the role of the operating system and how it manages computer resources such as memory, processes and disks.

Unix is introduced in terms of the Unix file structure, Input and Output and the Command Line Interface that is used to manipulate these. Computer communication is taught with respect to the Client-Server Architecture and applications that use this. Underlying protocols, such as those in the TCP/IP protocol suite, are introduced, as commonly used on the Internet to provide a universal service. This includes IPv4 and IPv6, the need for IPv6 and how the two differ. Types of computer networks are covered in terms of scale, such as LANs and WANs; and in terms of wired and wireless networks. Mechanisms for connecting networks such as routers, switches and bridges are covered.

Other topics include the role of gateways, proxies, Virtual Private Networks and cloud computing. Potential security risks are examined and how to reduce them, including the use of firewalls.

This module considers both the structure of databases, including how to make them fast, efficient and reliable and the appropriate user interfaces which will make them easy to interact with for users. You will start by looking at how to design a database, gaining an understanding of the standard features that management systems provide and how they can best utilise them, then develop an interactive application to access their database.

Database/software design principles will be introduced with an emphasis on the importance of understanding user requirements and specifications. Throughout the lectures and computing sessions, you will learn how to design and implement systems using a standard database management system, web technologies and GUI interfaces through practical programming/system examples.

Students wishing to obtain MSc Computer Science (Artificial Intelligence) must select 40 credits from the list below:
希望获得计算机科学(人工智能)硕士学位的学生必须从下面的列表中选择 40 个学分:

This module introduces the main concepts of autonomous mobile robotics, providing an understanding of the hardware and software principles appropriate for control, spatial localisation and navigation. The module consists of theoretical concepts around robotic sensing and control in the lectures, together with a strong practical element for robot programming in the laboratory sessions
该模块介绍了自主移动机器人的主要概念,提供了对适用于控制、空间定位和导航的硬件和软件原理的理解。该模块包括讲座中有关机器人传感和控制的理论概念,以及实验室课程中机器人编程的强大实践元素

This module will cover four main concepts.
本模块将涵盖四个主要概念。

It will start with an introduction to big data. You’ll find out about the main principles behind distributed/parallel systems with data intensive applications, identifying key challenges such as capture, store, search, analyse and visualise the data. 
它将从大数据的介绍开始。您将了解分布式/并行系统与数据密集型应用程序背后的主要原则,确定关键挑战,例如捕获、存储、搜索、分析和可视化数据。

We’ll also look at SQL Databases verses NoSQL Databases. You will learn:
我们还将了解 SQL 数据库与 NoSQL 数据库。您将学习:

  • the growing amounts of data
    不断增长的数据量
  • the relational database management systems (RDBMS)
    关系数据库管理系统 (RDBMS)
  • an overview of Structured Query Languages (SQL)
    结构化查询语言 (SQL) 概述
  • an introduction to NoSQL databases
    NoSQL 数据库简介
  • the difference between a relational DBMS and a NoSQL database
    关系型 DBMS 和 NoSQL 数据库的区别
  • how to identify the need to employ a NoSQL database
    如何确定是否需要使用 NoSQL 数据库

Another concept is big data frameworks and how to deal with big data. This includes the MapReduce programming model, as well as an overview of recent technologies (Hadoop ecosystem, and Apache Spark). Then, you will learn how to interact with the latest APIs of Apache Spark (RDDs, DataFrames and Datasets) to create distributed programs capable of dealing with big datasets (using Python and/or Scala).  
另一个概念是大数据框架以及如何处理大数据。这包括MapReduce编程模型,以及最新技术(Hadoop生态系统和Apache Spark)的概述。然后,您将学习如何与Apache Spark的最新API(RDD,DataFrames和Datasets)进行交互,以创建能够处理大型数据集(使用Python和/或Scala)的分布式程序。

Finally, we will cover the data mining and machine learning part of the course. This will include data preprocessing approaches, distributed machine learning algorithms and data stream algorithms. To do so, you will use the machine learning library of Apache Spark to understand how some machine learning algorithms can be deployed at a scale. 
最后,我们将介绍课程的数据挖掘和机器学习部分。这将包括数据预处理方法、分布式机器学习算法和数据流算法。为此,您将使用 Apache Spark 的机器学习库来了解如何大规模部署某些机器学习算法。

You will examine current techniques for the extraction of useful information about a physical situation from individual and sets of images. You will learn a range of methods and applications, with particular emphasis being placed on the detection and identification of objects, image segmentation, pose estimation, recovery of three-dimensional shape and analysis of motion. These problems will be approached with both traditional and modern computer vision approaches, including deep learning.

This module explores the range of data analysis problems that can be modelled computationally and a range of techniques that are suitable to analyse and solve those problems.

Topics covered include:

  • basic statistics
  • types of data
  • data visualisation techniques
  • data modelling
  • data pre-processing methods including data imputation
  • forecasting methods
  • clustering and classification methods

In this module, you will be given a basic introduction to the analysis and design of intelligent agents, software systems which perceive their environment and act in that environment in pursuit of their goals. You will cover topics including task environments, reactive, deliberative and hybrid architectures for individual agents, and architectures and coordination mechanisms for multi-agent systems.

This module focuses on handling uncertainty such as vagueness using fuzzy sets and similar approaches. It provides a thorough understanding of key topics such as:

  • the nature of uncertainty captured by fuzzy sets and associated links to human reasoning
  • inference using fuzzy sets
  • similarity of fuzzy sets
  • design and modelling of information via fuzzy sets
  • type-1 fuzzy sets
  • type-2 fuzzy sets
  • fuzzy logic systems
  • fuzzy set based applications

This module is an introduction to the design of human-AI interaction to ensure the AI-driven systems we build are beneficial and useful to people.

The module will cover practical design topics including methods and techniques such as natural language processing and human-robot interaction. The module will also consider societal and theoretical concerns of human-AI interaction, including the ethics of AI, responsible innovation, trust, accountability and explainable AI.

The practical component of the module will involve building AI-driven systems that drive conversational experiences, such as a text-based ‘chatbots’ and speech-controlled services/ ‘skills’, involving automatic speech recognition and natural language processing.

This module examines how knowledge can be represented symbolically and how it can be manipulated in an automated way by reasoning programs.

Some of the topics you’ll cover include:

  • first order logic
  • resolution
  • description logic
  • default reasoning
  • rule-based systems
  • belief networks

The module provides an entry point to computational optimization techniques, particularly for modelling and solving linear and discrete optimization problems like diet optimization, network flows, task assignment, scheduling, bin-packing, travelling salesmen, facility location, vehicle routing and related problems.

Optimization sits at the interface of computer science and mathematics. Optimization is considered one of the key techniques within the broad spectrum of artificial intelligence methods. Optimization focuses on making decisions instead of predicting or identifying patterns. Optimization is also one of the most important areas within operations research (OR), which is a discipline that uses modelling techniques, analytics and computational methods to solve complex problems in industry and business.

In this module, you will learn to interpret and develop algebraic models for a variety of real-world linear and discrete optimization problems to then use powerful optimization software (linear, integer and mixed-integer solvers) to produce a solution. The module covers topics such as linear programming, integer programming, combinatorial optimization, modelling and optimization software, multi-objective optimization, simplex method, and branch and bound method among others. Optimization technology is ubiquitous in today's world, for applications in logistics, finance, manufacturing, workforce planning, product selection, healthcare, and any other area where the limited resources must be used efficiently. Optimization enables prescriptive analytics, in order to support and automate decision-making"

Providing an introduction to machine learning, pattern recognition, and data mining techniques, this module will enable you to consider both systems which are able to develop their own rules from trial-and-error experience to solve problems as well as systems that find patterns in data without any supervision. 

You’ll cover a range of topics including:

  • machine learning foundations
  • pattern recognition foundations
  • artificial neural networks
  • deep learning
  • applications of machine learning
  • data mining techniques
  • evaluating hypotheses

You’ll spend around six hours each week in lectures and computer classes for this module.

This module offers insight into the applications of selected methods of decision support. The foundations for applying these methods are derived from:

  • operations research simulation
  • social simulation
  • data science
  • automated scheduling
  • decision analysis

Throughout the module, you will become more competent in choosing and implementing the appropriate method for the particular problem at hand. You will engage in a mixture of lectures, workshops, and computer classes.

Research projects 研究项目

All students must complete a research project. If you wish to graduate with the title of MSc Computer Science (Artificial Intelligence), you must choose the AI project.
所有学生必须完成一个研究项目。如果你想以计算机科学(人工智能)硕士的头衔毕业,你必须选择人工智能项目。

You will conduct a piece of empirical and/or theoretical research in an appropriate strand of the degree, under the supervision of a member of academic staff. Where appropriate, your project may also be conducted in conjunction with an external organisation and may involve a substantial software implementation. 

You will conduct a piece of empirical and/or theoretical research in artificial intelligence, under the supervision of a member of academic staff. Where appropriate, your project may also be conducted in conjunction with an external organisation and may involve a substantial software implementation. 
你将在一名学术人员的监督下,进行人工智能的实证和/或理论研究。在适当的情况下,您的项目也可能与外部组织一起进行,并可能涉及大量的软件实施。

Optional modules 可选模块

You'll study the theory used in the design and analysis of advanced algorithms and data structures. Topics covered include string algorithms (such as for string matching, longest common subsequence), graph algorithms (such as for minimum cuts and maximum flows, and Google's pagerank algorithm), advanced data structures (such as Fibonacci heaps and Bloom filters), and randomised search heuristics (evolutionary algorithms). You'll learn all the necessary probability theory will be introduced, including random variables and concentration inequalities.

The theory is practiced in weekly labs where we learn how to implement the algorithms and data structures as functional and imperative programs (using the languages Haskell and C), and apply these to solve large instances of real-world problems. 

This module will provide you with an advanced knowledge of computer communications networks, using examples from all-IP core telecommunications networks to illustrate aspects of transmission coding, error control, media access, internet protocols, routing, presentation coding, services and security.

The module will describe Software Defined Networks (SDNs) and provide examples of using them to enable very large scale complex network control. It will also provide advanced knowledge of various routing and query protocols in:

  • Ad Hoc Networks
  • Mobile Ad Hoc Networks (MANETs)
  • Vehicular Ad Hoc Networks (VANETs)
  • Disconnection/Disruption/Delay Tolerant Networks (DTNs)
  • impact of new networking developments, such as security risks, ethics, interception and data protection will be reflected and discussed systematically

This module introduces the main concepts of autonomous mobile robotics, providing an understanding of the hardware and software principles appropriate for control, spatial localisation and navigation. The module consists of theoretical concepts around robotic sensing and control in the lectures, together with a strong practical element for robot programming in the laboratory sessions

You’ll examine the principles of 3D computer graphics, focusing on modelling the 3D world on the computer, projecting onto 2D display and rendering 2D display to give it realism.

Through weekly lectures and laboratory sessions, you’ll explore various methods and requirements in 3D computer graphics, balancing efficiency and realism.

Information Visualisation is the process of extracting knowledge from complex data, and presenting it to a user in a manner that this appropriate to their needs. This module provides a foundational understanding of some important issues in information visualisation design. You will learn about the differences between scientific and creative approaches to constructing visualisations, and consider some important challenges such as the representation of ambiguous or time-based data. You will also learn about psychological theories that help explain how humans process information, and consider their relevance to the design of effective visualisations.

If you want to learn how to design and implement your own interactive information visualisation, you should also take the linked module G53IVP (Information Visualisation Project). Together, these two modules form an integrated 20 credit programme of study.

In this module you will gain practical experience of how to design and evaluate a distinctive interactive visualisation which presents information gathered from a complex and interesting data source.

You will gain experience in web-based technologies that enable the implementation of multi-layered and interactive information visualisations, supported through lab work that introduces specific features of these technologies.

This module will require some challenging programming work and assumes some basic knowledge of HTML, CSS and Javascript. Introductory tutorials will be provided to those without this prior knowledge.

This module examines how knowledge can be represented symbolically and how it can be manipulated in an automated way by reasoning programs.

Some of the topics you will cover include:

  • first order logic
  • resolution
  • description logic
  • default reasoning
  • rule-based systems
  • belief networks

The module provides an entry point to computational optimization techniques, particularly for modelling and solving linear and discrete optimization problems like diet optimization, network flows, task assignment, scheduling, bin-packing, travelling salesmen, facility location, vehicle routing and related problems.

Optimization sits at the interface of computer science and mathematics. Optimization is considered one of the key techniques within the broad spectrum of artificial intelligence methods. Optimization focuses on making decisions instead of predicting or identifying patterns. Optimization is also one of the most important areas within operations research (OR), which is a discipline that uses modelling techniques, analytics and computational methods to solve complex problems in industry and business.

In this module, you will learn to interpret and develop algebraic models for a variety of real-world linear and discrete optimization problems to then use powerful optimization software (linear, integer and mixed-integer solvers) to produce a solution. The module covers topics such as linear programming, integer programming, combinatorial optimization, modelling and optimization software, multi-objective optimization, simplex method, and branch and bound method among others. Optimization technology is ubiquitous in today's world, for applications in logistics, finance, manufacturing, workforce planning, product selection, healthcare, and any other area where the limited resources must be used efficiently. Optimization enables prescriptive analytics, in order to support and automate decision-making"

Providing you with an introduction to machine learning, pattern recognition, and data mining techniques, this module will enable you to consider both systems which are able to develop their own rules from trial-and-error experience to solve problems, as well as systems that find patterns in data without any supervision. In the latter case, data mining techniques will make the generation of new knowledge possible, including very big data sets. This is now fashionably termed 'big data' science.

You'll cover a range of topics including:

  • machine learning foundations
  • pattern recognition foundations
  • artificial neural networks
  • deep learning
  • applications of machine learning
  • data mining techniques and evaluating hypotheses

This module looks at the practice of malware analysis, looking at how to analyse malicious software to understand how it works, how to identify it, and how to defeat or eliminate it.  

You will look at how to set up a safe environment in which to analyse malware, as well as exploring both static and dynamic malware analysis. Although malware takes many forms, the focus of this module will primarily be on executable binaries. This will cover object file formats and the use of tools such as debuggers, virtual machines, and disassemblers to explore them. Obfuscation and packing schemes will be discussed, along with various issues related to Windows internals.

The module is practical with encouragement to safely practice the skills you're taught.

This module focuses on the possibilities and challenges of interaction beyond the desktop. Exploring the 'mixed reality continuum' - a spectrum of emerging computing applications that runs from virtual reality (in which a user is immersed into a computer-generated virtual world) at one extreme, to ubiquitous computing (in which digital materials appear embedded into the everyday physical world - often referred to as the 'Internet of Things') at the other. In the middle of this continuum lie augmented reality and locative media in which the digital appears to be overlaid upon the physical world in different ways.

You will gain knowledge and hands-on experience of design and development with key technologies along this continuum, including working with both ubiquitous computing based sensor systems and locative media. You will learn about the Human-Computer Interaction challenges that need to be considered when creating mixed reality applications along with strategies for addressing them, so as to create compelling and reliable user experiences.

This module focuses on some of the fundamental mathematical concepts that underlie modern programming and programming languages emphasizing the role of types. We will use a dependently typed programming language/interactive proof system (eg Agda) to implement some concepts on a computer.

Example topics include

  • basic lambda calculus
  • operational semantics
  • domain theory
  • types, propositions as types and formal verification.

You will engage in a mix of lectures and working in the lab with an interactive proof system.

This project involves a self-guided study of a selected advanced algorithm or data structure. The outcome of the project is an analysis and implementation of the algorithm or data structure, as well as an empirical evaluation, preferably on a real-world data set of significant size.

This module offers insight into the applications of selected methods of decision support. The foundations for applying these methods are derived from:

  • operations research simulation
  • social simulation
  • data science
  • automated scheduling
  • decision analysis

Throughout the module, you will become more competent in choosing and implementing the appropriate method for the particular problem at hand. You will engage in a mixture of lectures, workshops, and computer classes.

This module is an introduction to the design of human-AI interaction to ensure the AI-driven systems we build are beneficial and useful to people.

The module will cover practical design topics including methods and techniques such as natural language processing and human-robot interaction. The module will also consider societal and theoretical concerns of human-AI interaction, including the ethics of AI, responsible innovation, trust, accountability and explainable AI.

The practical component of the module will involve building AI-driven systems that drive conversational experiences, such as a text-based ‘chatbots’ and speech-controlled services/ ‘skills’, involving automatic speech recognition and natural language processing.

You’ll be given a basic introduction to the analysis and design of intelligent agents, software systems which perceive their environment and act in that environment in pursuit of their goals.

You’ll cover topics including:

  • task environments
  • reactive, deliberative and hybrid architectures for individual agents
  • architectures and coordination mechanisms for multi-agent systems

You will spend around four hours each week in lectures and tutorials for this module.

As part of the assessment of this module you will produce a research paper-style report, and deliver a conference-style presentation.

This module covers the history, development and state-of-the-art in computer games and technological entertainment.

You will gain an appreciation of the range of gaming applications available and be able to chart their emergence as a prevalent form of entertainment. You will study the fundamental principles of theoretical game design and how these can be applied to a variety of modern computer games.

In addition, you will study the development of games as complex software systems. Specific software design issues to be considered will include the software architecture of games, and the technical issues associated with networked and multiplayer games.

Finally, you will use appropriate software environments to individually develop a number of games to explore relevant theoretical design and practical implementation concepts.

This module will enable you to appreciate the range of data analysis problems that can be modelled computationally and a range of techniques that are suitable to analyse and solve those problems.

Topics covered include:

  • basic statistics
  • types of data
  • data visualisation techniques
  • data modelling
  • data pre-processing methods including data imputation
  • forecasting methods
  • clustering and classification methods (decision trees, naīve bayes classifiers, k-nearest neighbours)
  • data simulation
  • model interpretation techniques to aid decision support.

You will engage in a mixture of lectures and computer classes where appropriate software (eg R, Weka) will be used.

This module focuses on handling uncertainty such as vagueness using fuzzy sets and similar approaches. It provides a thorough understanding of key topics such as:

  • the nature of uncertainty captured by fuzzy sets and associated links to human reasoning
  • inference using fuzzy sets
  • similarity of fuzzy sets
  • design and modelling of information via fuzzy sets
  • type-1 fuzzy sets
  • type-2 fuzzy sets
  • fuzzy logic systems
  • fuzzy set based applications

This module will cover four main concepts.

It will start with an introduction to big data. You’ll find out about the main principles behind distributed/parallel systems with data intensive applications, identifying key challenges such as capture, store, search, analyse and visualise the data. 

We’ll also look at SQL Databases verses NoSQL Databases. You will learn:

  • the growing amounts of data
  • the relational database management systems (RDBMS)
  • an overview of Structured Query Languages (SQL)
  • an introduction to NoSQL databases
  • the difference between a relational DBMS and a NoSQL database
  • how to identify the need to employ a NoSQL database

Another concept is big data frameworks and how to deal with big data. This includes the MapReduce programming model, as well as an overview of recent technologies (Hadoop ecosystem, and Apache Spark). Then, you will learn how to interact with the latest APIs of Apache Spark (RDDs, DataFrames and Datasets) to create distributed programs capable of dealing with big datasets (using Python and/or Scala).  

Finally, we will cover the data mining and machine learning part of the course. This will include data preprocessing approaches, distributed machine learning algorithms and data stream algorithms. To do so, you will use the machine learning library of Apache Spark to understand how some machine learning algorithms can be deployed at a scale. 

You will examine current techniques for the extraction of useful information about a physical situation from individual and sets of images. You will learn a range of methods and applications, with particular emphasis being placed on the detection and identification of objects, image segmentation, pose estimation, recovery of three-dimensional shape and analysis of motion. These problems will be approached with both traditional and modern computer vision approaches, including deep learning.

Cyber security is an essential consideration for the protection of IT-based devices, systems, networks and data, providing safeguard and reassurance to the organisations and individuals that now rely (and increasingly depend) upon them. We provide coverage of both technical and human perspectives, considering the fundamental threats and safeguards that concern both personal and workplace contexts. You will emerge with the knowledge and skills necessary to enable informed cyber security decisions spanning the technical, human and organisational dimensions of the topic.

You will gain knowledge and practical experience across a range of key cyber security topics, including foundational concepts and principles, authentication and access control, operating system security, cryptographic mechanisms and applications, security management, risk assessment, cyber-attacks and threat intelligence, network and Internet security, intrusion detection and incident response, and human aspects. You will learn about the challenges that need to be considered when designing and implementing secure systems, along with associated approaches to ensure that security is addressed in an effective and holistic manner.

The above is a sample of the typical modules we offer but is not intended to be construed and/or relied upon as a definitive list of the modules that will be available in any given year. Modules (including methods of assessment) may change or be updated, or modules may be cancelled, over the duration of the course due to a number of reasons such as curriculum developments or staffing changes. Please refer to the module catalogue for information on available modules. This content was last updated on Wednesday 15 May 2024.
以上是我们提供的典型模块的样本,但不打算被解释和/或依赖为任何给定年份将提供的模块的最终列表。由于课程发展或人员配备变动等多种原因,在课程期间,模块(包括评估方法)可能会更改或更新,或者模块可能会被取消。有关可用模块的信息,请参阅模块目录。此内容最后更新于 2024 年 5 月 15 日星期三。


Due to timetabling availability, there may be restrictions on some module combinations.
由于时间表的可用性,某些模块组合可能会受到限制。

Learning and assessment 学习和评估

How you will learn 你将如何学习

  • Lectures 讲座
  • Tutorials 教程
  • Seminars 研讨会
  • Computer labs 计算机实验室
  • Practical classes 实践课
  • Project work 项目工作
  • Supervision 监督

You will study a total of 180 credits, split across 120 credits of compulsory and optional modules plus a 60-credit individual project.
你将学习总共180个学分,分为120个学分的必修和选修模块,以及一个60学分的个人项目。

You will work in lecture theatres, seminar rooms and labs to develop a theoretical and practical understanding of this subject.
你将在演讲厅、研讨室和实验室工作,以发展对这一主题的理论和实践理解。

Teaching is typically delivered by professors, associate and assistant professors. Some practical laboratory sessions and research projects may be supported by postgraduate research students or postdoctoral research fellows.
教学通常由教授、副教授和助理教授授课。一些实际的实验室课程和研究项目可能会得到研究生或博士后研究员的支持。

How you will be assessed
您将如何接受评估

  • Coursework 课程作业
  • Written exam 笔试
  • Project work 项目工作

Modules are assessed using a variety of individual assessment types which are weighted to calculate your final mark for each module. In many modules, assessments are mixed with 75/25 or 25/75 coursework/exam.
模块使用各种单独的评估类型进行评估,这些评估类型经过加权以计算每个模块的最终分数。在许多模块中,评估与 75/25 或 25/75 课程作业/考试混合在一起。

The final degree classification will be the average of all credits, e.g. an average of 120 taught credits and 60 credits on your project. To pass a module, you’ll need a mark of at least 50%. 
最终的学位分类将是所有学分的平均值,例如,平均 120 个教学学分和 60 个项目学分。要通过一个模块,您需要至少 50% 的标记。

Contact time and study hours
接触时间和学习时间

The class size depends on the module. In 2021/2022, class and lecture sizes ranged from 25 to 285 students.
班级大小取决于模块。在 2021/2022 学年,班级和讲座人数从 25 到 285 名学生不等。

All students meet their tutors in the Induction week. Students are then encouraged to make individual arrangements to discuss any issues during the study. Some staff offer weekly drop-in time for students.
所有学生在入职周与他们的导师会面。然后鼓励学生做出个人安排,在学习期间讨论任何问题。一些工作人员为学生提供每周的上课时间。

As a guide, one credit is equal to approximately 10 hours of work.
作为指导,一个学分相当于大约 10 小时的工作。

Entry requirements 入学要求

All candidates are considered on an individual basis and we accept a broad range of qualifications. The entrance requirements below apply to 2024 entry.
所有候选人都会被单独考虑,我们接受广泛的资格。以下入学要求适用于 2024 年入学。

Undergraduate degree 本科学位2:1 (or international equivalent) with an affinity for programming evidenced through prior study of programming or practical experience detailed in the application. Prior study of programming modules is desirable, but not essential.
2:1(或国际同等学历),对编程有亲和力,通过先前的编程学习或应用程序中详细说明的实践经验来证明。事先学习编程模块是可取的,但不是必需的。

Applying 应用

International applications
国际申请

This course will close to international applications on the 20 November 2023, and will reopen on 20 February 2024. Applications must be submitted before this time and the international student application fee must be received by the university within 24 hours.
本课程将于 2023 年 11 月 20 日关闭国际申请,并将于 2024 年 2 月 20 日重新开放。申请必须在此时间之前提交,大学必须在 24 小时内收到国际学生申请费。

The course will remain open to Home applicants throughout this period.
在此期间,该课程将继续对家庭申请者开放。

Alternative courses 替代课程

You may be interested in the following courses which are open for international applications:
您可能对以下对国际申请开放的课程感兴趣:

Our step-by-step guide covers everything you need to know about applying.
我们的分步指南涵盖了您需要了解的有关申请的所有信息。

How to apply 如何申请

Fees 费用

Qualification 资格 MSc 理学硕士
Home / UK 首页 / 英国 £12,500
International 国际 £28,600

Additional information for international students
为国际学生提供的其他信息

If you are a student from the EU, EEA or Switzerland, you may be asked to complete a fee status questionnaire and your answers will be assessed using guidance issued by the UK Council for International Student Affairs (UKCISA) .
如果您是来自欧盟、欧洲经济区或瑞士的学生,您可能会被要求填写一份费用状态问卷,您的答案将使用英国国际学生事务委员会 (UKCISA) 发布的指南进行评估。

These fees are for full-time study. If you are studying part-time, you will be charged a proportion of this fee each year (subject to inflation).
这些费用是全日制学习的费用。如果您是非全日制学习,您每年将被收取此费用的一部分(视通货膨胀而定)。

Additional costs 额外费用

All students will need at least one device to approve security access requests via Multi-Factor Authentication (MFA). We also recommend students have a suitable laptop to work both on and off-campus. For more information, please check the equipment advice.
所有学生都需要至少一台设备才能通过多重身份验证 (MFA) 批准安全访问请求。我们还建议学生有一台合适的笔记本电脑,以便在校内和校外工作。欲了解更多信息,请查看设备建议

We do not anticipate any extra significant costs. You should be able to access most of the books you’ll need through our libraries, though you may wish to purchase your own copies which you would need to factor into your budget.
我们预计不会产生任何额外的重大成本。您应该能够通过我们的图书馆访问所需的大部分书籍,尽管您可能希望购买自己的副本,这需要将其计入您的预算。

Funding 资金

There are many ways to fund your postgraduate course, from scholarships to government loans.
有很多方法可以为您的研究生课程提供资金,从奖学金到政府贷款。

We also offer a range of international masters scholarships for high-achieving international scholars who can put their Nottingham degree to great use in their careers.
我们还为成就卓著的国际学者提供一系列国际硕士奖学金,他们可以在职业生涯中充分利用他们的诺丁汉学位。

Check our guide to find out more about funding your postgraduate degree.
查看我们的指南,了解更多关于资助您的研究生学位的信息。

Postgraduate funding 研究生资助

Careers 职业

We offer individual careers support for all postgraduate students.
我们为所有研究生提供个人职业支持。

Expert staff can help you research career options and job vacancies, build your CV or résumé, develop your interview skills and meet employers.
专家团队可以帮助您研究职业选择和职位空缺,建立您的简历或简历,发展您的面试技巧并会见雇主。

Each year 1,100 employers advertise graduate jobs and internships through our online vacancy service. We host regular careers fairs, including specialist fairs for different sectors.
每年有 1,100 名雇主通过我们的在线职位空缺服务为毕业生招聘和实习广告。我们定期举办招聘会,包括针对不同行业的专业招聘会。

International students who complete an eligible degree programme in the UK on a student visa can apply to stay and work in the UK after their course under the Graduate immigration route. Eligible courses at the University of Nottingham include bachelors, masters and research degrees, and PGCE courses.
持学生签证在英国完成符合条件的学位课程的国际学生可以申请在研究生移民途径完成课程后在英国逗留和工作。诺丁汉大学的合格课程包括学士、硕士和研究学位,以及 PGCE 课程。

Two masters graduates proudly holding their certificates
" I'm an Associate Professor in the School of Computer Science. I teach modules in data science and artificial intelligence, as well as supervising MSc dissertation projects on a wide range of topics. I'm also involved in a research project using AI for finding and correcting bugs in code, and I'm writing a book about study skills for PhD students. "
我是计算机科学学院的副教授。我教授数据科学和人工智能模块,并指导有关广泛主题的硕士论文项目。我还参与了一个使用人工智能来查找和纠正代码中的错误的研究项目,我正在为博士生写一本关于学习技巧的书。
Dr Colin Johnson  科林·约翰逊博士

Related courses 相关课程

This content was last updated on Wednesday 15 May 2024. Every effort has been made to ensure that this information is accurate, but changes are likely to occur given the interval between the date of publishing and course start date. It is therefore very important to check this website for any updates before you apply.
此内容最后更新于 2024 年 5 月 15 日星期三。我们已尽一切努力确保此信息准确无误,但考虑到发布日期和课程开始日期之间的间隔,可能会发生更改。因此,在申请之前检查本网站是否有任何更新非常重要。