
| Degree | Type | Year | Semester | 
|---|---|---|---|
| 2502441 Computer Engineering | OB | 3 | 1 | 
| 2502441 Computer Engineering | OT | 4 | 1 | 
It is very, very advisable to have studied and passed the subjects of Fundamentals of Computer Science, Fundamentals of Computers, Computer Structure, Methodology of Computer Programming and Architecture
The fundamental objective of the subject is that students acquire the capabilities of analysis, use and evaluation of advanced computer architectures, for the development of applications and computer services.
The basic concepts that will be described in the theoretical sessions are: the multi-core processor, the shared memory multi-processor system, the computer accelerators, performance evaluation, and the programming languages and models of these parallel systems. The most specific objectives are the following:
1. Understand the keys to obtain good performance from multi-core and multi-processor computers, and from computer accelerators (GPUs)
2. Identify the opportunities for parallelization in an algorithm or application, at different levels (instructions, iterations of a loop, calls to functions ...), and express it formally
3. Design the data structures of an application and the algorithms that access these data to favor the good performance of the memory hierarchy
4. Analyze, design and implement parallel algorithms with abstract computation patterns (reduction, transformation ...) under programming paradigms based on shared variables and synchronization; and with current parallel languages, such as OpenMP and OpenACC.
5. Verify the functionality and evaluate the performance of parallel applications, identifying bottlenecks with respect to performance
6. From performance analysis, select the right computer to an application and / or perform code optimizations that further improve its performance
1. Instruction-Level Parallelism
2. Data-Level Parallelism
3. Parallel computer architecture
4. Parallel Algorithms
5. Performance evaluation of Parallel Applications 
 
Theory classes: the knowledge of the subject will be explained. The basic concepts will be described and illustrated with practical examples. The most important learning problems will be highlighted and will show how to complete and deepen the contents. Practical cases will be discussed and the teacher will detect the most common comprehension and reasoning problems and solve them for all students.
Classes of Problems in Laboratory: cooperative activities of resolution of problems and of simple practical cases will be made, that will serve as support to the theory. After a previous individual work, the students will make a group sharing and solve their doubts. The teacher will detect the most common comprehension and reasoning problems and solve them in groups or for all the students. The student's analysis and synthesis capacity, critical reasoning and problem-solving ability are promoted. During the session, students should inform the teacher about their progress and the problems that may be encountered, and they will deliver a final document with the results and reflections on their activities.
Practical case of Performance Engineering: throughout the course, students must design, plan, perform, present and defend orally a practical work, indicating the objectives, development, results obtained with understandable graphics, the most notable incidents and, finally, the most relevant conclusions. Students are expected to have a proactive and dynamic attitude, the autonomous search for knowledge that is necessary, and ambition with the objectives of the work.
Transversal Competences:
| Title | Hours | ECTS | Learning Outcomes | 
|---|---|---|---|
| Type: Directed | |||
| Classroom Tutorials | 6 | 0.24 | 1, 8, 4, 12 | 
| Problems on LAB | 24 | 0.96 | 1, 2, 7, 9, 8, 4, 6, 5, 10, 11 | 
| Theory | 24 | 0.96 | 1, 2, 8, 4, 5, 12 | 
| Type: Supervised | |||
| Preparation and Presentation of Practical Work | 5 | 0.2 | 3 | 
| Preparation of the work to be done in the laboratory | 15 | 0.6 | 7, 9, 6, 10 | 
| Type: Autonomous | |||
| Autonomous study | 24 | 0.96 | 1, 8, 4, 5, 12 | 
| Prepare LAB sessions | 30 | 1.2 | 1, 2, 6 | 
| Problem solving | 20 | 0.8 | 2, 9, 8, 5, 11 | 
The dates for continuous evaluation and submission of works will be published on the Moodle platform of the UAB (Virtual Campus) and may be subject to programming changes for reasons of adaptation to possible incidents. Always be informed on the Moodle platform about these changes, as it is understood that it is the usual platform for exchanging information between teacher and students.
Evaluation Activities 
 Activity A: solving practical problems in the laboratory; it is done as a group; it represents 20% of the final grade; it is necessary to obtain a minimum score of 4 points out of 10; and it cannot be recovered.
Activity B: delivery of a report of activity A; it is done individually; assumes 15% of the final grade; it is not necessary to obtain a minimum grade; and it cannot be recovered.
Activity C: proposal and resolution of a practical case of Performance Engineering; it is done as a group; it represents 30% of the final grade; it is necessary to obtain a minimum score of 5 points out of 10; and it can be recovered.
Activity D: oral defense of activity C; it is done individually; assumes 5% of the final grade; it is not necessary to obtain a minimum grade; and it can be recovered.
Activity E: delivery of a report of activity C; it is done as a group; assumes 5% of the final grade; it is not necessary to obtain a minimum grade; and it cannot be recovered.
Activity F: attendance and active participation in class; it is done individually; assumes 5% of the final grade; it is not necessary to obtain a minimum grade; and it cannot be recovered.
Activity G: written examination of theory and problems; it is done individually and without notes; assumes 20% of the final grade; it is necessary to obtain a minimum score of 5 points out of 10; and it can be recovered.
Apart from the assessment activities described above, other voluntary activities may be proposed throughout the course that may contribute to the final grade for the course.
Program of Evaluation Activities
 Activities A, B, C and F are carried out throughout the course. Activities D and E are carried out at the end of the course. Activity G is performed on the dates specified by the coordination.
Recovery Process 
 The student can present himself to the recovery whenever he has submitted to the activities B, D and G. According to the coordination of the Degree and the direction of the School of Engineering, only the activities C, D and G can be recovered, they represent 55% of the final grade.
Review procedure 
 All evaluation activities can be reviewed in a place, date and time that will be published beforehand. Claims may be made on the activity grade, which will be evaluated by the faculty responsible for the subject. If the student does not show up for this revision, this activity will not be reviewed later.
Qualifications
 An honor grade (MH) will be awarded to students who reach a final grade equal to or greater than 9.00, up to a total of 5% of the students enrolled, prioritizing the part of the grade that corresponds to individual assessments (activities B, D, F and G).
 If the student does not reach the minimum grade in any of the evaluation activities, the final numerical grade will be the minimum between 4.5 points and the weighted sum of the grades of all the activities.
 A student will be considered non-assessable (NA) if he / she has not submitted to any of activities B, D and G.
Irregularities by students, copy and plagiarism
 Without prejudice to other disciplinary measures deemed appropriate, will be scored with a zero the irregularities committed by a student that may lead to a variation of the rating of an act of evaluation. Therefore, copying, plagiarism, cheating, letting copy, etc. in any of the evaluation activities will involve suspending it with a zero. The evaluation activities qualified in this way and by this procedure will not be recoverable. If it is necessary to pass any of these assessment activities to pass the subject, then this subject will be suspended directly, with no opportunity to recover it in the same course. In the case of not passing the subject due to the fact that the student has committed irregularities in an evaluation act, the numerical note of the record will be the lower value between 3.0 and the weighted average of the marks (and therefore the approved by compensation will not be possible).
Evaluation of repeating students
 There is no special treatment for repeating students.
| Title | Weighting | Hours | ECTS | Learning Outcomes | 
|---|---|---|---|---|
| Assistance and active participation in class | 5% | 0 | 0 | 3, 10 | 
| Delivery of a performance engineering case report | 5% | 0 | 0 | 3 | 
| Delivery of a report on the resolution of practical problems in the laboratory | 15% | 0 | 0 | 3 | 
| Individual written examination of theory and problems | 20% | 1.9 | 0.08 | 1, 2, 9, 3, 5, 11, 12 | 
| Oral defense of Performance Engineering work | 5% | 0.1 | 0 | 3 | 
| Proposal and resolution of a practical case of Performance Engineering | 30% | 0 | 0 | 1, 2, 7, 9, 8, 4, 6, 5, 10, 11, 12 | 
| Resolution of practical problems in the laboratory | 20% | 0 | 0 | 2, 7, 9, 8, 4, 6, 5, 10, 11, 12 | 
Computer Architecture: A Quantitative Approach.  6th Edition
John Hennessy, David Patterson, Morgan Kaufmann (Elsevier) 2018 (Cap. 4 i 5)
Structured Parallel Programming: Patterns for efficient computation
M. McCool, J. Reinders, A. Robison, Elsevier, 2012
Parallel Programming for Multicore and Cluster Systems
T. Rauber, G. Rünger, Springer (Elsevier), 2010
Programming Massively Parallel Processors: A Hands-on Approach
D. Kirk, & W.M. Hwu, Morgan Kaufmann (Elsevier), 2010