Checking date: 16/04/2024


Course: 2024/2025

Massive computing
(16499)
Bachelor in Data Science and Engineering (Plan: 392 - Estudio: 350)


Coordinating teacher: MOLINA BULLA, HAROLD YESID

Department assigned to the subject: Signal and Communications Theory Department

Type: Compulsory
ECTS Credits: 6.0 ECTS

Course:
Semester:




Requirements (Subjects that are assumed to be known)
Labs will be made using Python programming languages.
Objectives
The main objective of this course is to train analysts in data science, either for research or the labour market, using the latest techniques applied in machine learning. We will learn how to get the most out of the computational resources that we can have at our disposal, from our own computer, resources in the cloud for programming with GPUs and programming for Big Data; knowledge in high demand in various environments. The basic concepts of parallel programming will be explained: 1- using the resources of common computers, 2-hybrid programming: using the resources of a normal computer and specific hardware such as graphics processing units (GPUs). 3- distributed and cloud programming, for big cases, such as Big Data.
Skills and learning outcomes
Description of contents: programme
Parallel Programming: * Multiprocessor/Multicore Programming. * Parallel Programming with Shared Memory (and the dangers for data) * Parallel Programming with Shared Memory with traffic lights and locking Hybrid Programming * Use of GPUs and how they differ from ordinary computer processors. * How GPUs are programmed: when and how they can be used. * Use of advanced GPU programming techniques, GPU resource management. * How to use GPUs in Machine Learning. Distributed Programming * What is distributed computing and how can we take advantage of it? * Use of distributed programming platforms for BigData and Machine Learning. * Use cases of Apache Spark for machine learning.
Learning activities and methodology
AF1: THEORETICAL-PRACTICAL CLASSES. They will present the knowledge that should be acquired. They will receive the class notes and will have basic texts of reference to facilitate the follow-up of the classes and the development of the subsequent work. Exercises, practical problems on the part of the student will be solved and workshops and evaluation test will be held to acquire the necessary skills. AF2: Updated to allegation AF3: INDIVIDUAL OR GROUP WORK OF THE STUDENT. MD1: THEORETICAL LESSONS. Exhibitions in class with both support of computer and audiovisual media, in which the main concepts of the subject are developed and the materials and bibliography are provided to complement the students' learning. MD2: ASSIGNMENTS. Resolution of practical use cases, problems, etc. raised by the teacher, individually or in groups. MD3: TUTORIALS. Individualized assistance (individual tutorials) or group (collective tutorials) to students by the teacher.
Assessment System
  • % end-of-term-examination 40
  • % of continuous assessment (assigments, laboratory, practicals...) 60

Calendar of Continuous assessment


Extraordinary call: regulations
Basic Bibliography
  • Benjamin Bengfort ; Jenny Kim. Interactive Spark using PySpark. O'Reilly Media. 2016
  • Holden Karau ; Rachel Warren. High Performance Spark. O'Reilly Media. 2017
  • Holden Karau, Andy Konwinski, Patrick Wendell & Matei Zaharia. Programming in Scala. Artima.
  • Mike Frampton. Mastering Apache Spark. Packt Publishing. 2015

The course syllabus may change due academic events or other reasons.