CODE 86736 ACADEMIC YEAR 2023/2024 CREDITS 5 cfu anno 1 ROBOTICS ENGINEERING 10635 (LM-32) - GENOVA SCIENTIFIC DISCIPLINARY SECTOR ING-INF/05 LANGUAGE English TEACHING LOCATION GENOVA SEMESTER 1° Semester TEACHING MATERIALS AULAWEB OVERVIEW Robots are programmed machines based on multi-task, distributed and concurrent programming. The ARP course expands the so called system programming level. The student will learn how to use the operating system's services to design such concurrent sitributed applications. In addition, robotic programs must be reliable and portable through differenet kernels, different versions and different architectures/electronics. In general, programming in Robotics encompasses different topics: 1) writing and debugging a soft/hard real time programme, 2) the operating system structure, and its relevant features, 3) concurrent / distributed programming, 4) designing complex, distributed, modular software applications. ARP covers mostly the mid topics of the list above. ARP, RTOS and SOFAR cooperate in addressing all topics. State-of-the-art languages are used, in particular C, C++ and Rust, together with ISO/IEC 9945 POSIX framework AIMS AND CONTENT LEARNING OUTCOMES The goal of the course is to give the students the fundamentals of POSIX programming, concurrent programming, and inter-process communication (i.e., interrupts, signals, pipes, threads, semaphores, shared memory, sockets, publish/subscribe methods). The objective involves both theoretical knowledge and practical work (coding for multiprocess / distributed systems). State-of-the-art programming languages are used in coding, in particular C and rust. AIMS AND LEARNING OUTCOMES Following Bloom's taxonomy, the student will achieve the following results (levels 2 to 4): Describe the behaviour of the different communication / synchronization primitives between tasks and processes (events, shared memory, messages) both in a single and in networked machines. Apply state-of-practice concurrent / distribute programming schemes to solve reference problems in robotics, using the mostly used languages (C/C++ and Rust) Compare different communication / synchronization primitives in solving common robotic problems, and Motivate the selection of the most suitable for a specific process. Design and test concurrent / distributed programmes to solve standard, complex, relevant cases in robotics. PREREQUISITES Programming in C Language (advanced concepts) Basic structure of an Operating System's kernel Basic networking concepts TEACHING METHODS This is a sample scheme based on the flipped classroom model.. The actual scheme will be adapted to schedule, calendar and course organisation SYLLABUS/CONTENT The course is composed by 12 modules, one per week. Course intro Op sys architecture 1 Op sys architecture 2 SysCalls1: processes SysCalls2: threads SysCalls3: mutual exclusion, synchronization SysCalls4: pipes SysCalls5: non determinism SysCalls6: events SysCalls7: sockets Publish/Subscribe: D-BUS Real cases analysis Each module includes an assignment whose solution is discussed in a successive module. The reference framework is the POSIX standard. Languages are C/C++ and Rust. RECOMMENDED READING/BIBLIOGRAPHY The whole study material (reference textbooks, slides, examples) is available in the AulaWeb portal. TEACHERS AND EXAM BOARD RENATO UGO RAFFAELE ZACCARIA Ricevimento: Students having troubles in learning the course concepts can get in touch with the teacher: during classes or immediately after contacting the teacher through internet, any time, at the following addresses: renato.zaccaria@unige.it (email) renato.zaccaria (skype name) using instant messages through Skype The teacher's office is located in Genova, Viale Causa 13, floor 0. Exam Board RENATO UGO RAFFAELE ZACCARIA (President) ANTONIO SGORBISSA FULVIO MASTROGIOVANNI (President Substitute) LESSONS LESSONS START https://corsi.unige.it/10635/p/studenti-orario Class schedule The timetable for this course is available here: Portale EasyAcademy EXAMS EXAM DESCRIPTION The final exam is only one othe component of the assessment process. The exam mark will contribute approximatively with 22% - 33% of the full assessment. The exam consists in an on line test on the AulaWeb portal, with questions related to the learning outcomes. The test is done in presence in the classroom. ASSESSMENT METHODS The course implements a continuous assessment process. All the assignments proposed to students every week may contribute to it. Intermediate and final, more complex, assignments will be also proposed. Assignments are evaluated if delivered in a regular basis, respecting specific deadlines. The final mark will take into account both the exam and the continuous evaluation of assessments, giving specific values to the different components. All the assignment deadlines will be closed before the last exam session of the semester s(approximatively end of February for semester 1 and mid September for semester 2). Exam schedule Data appello Orario Luogo Degree type Note 16/01/2024 09:00 GENOVA Scritto ROOM E4, BUILDING E, AT 9:00 AM 13/02/2024 09:00 GENOVA Scritto E1 (to be confimed) 19/06/2024 09:00 GENOVA Scritto The exam will be in Villa Bonino, Viale Causa 13, ground floor, at 9:00. Carry your PC. Only 3 students are enrolled. 22/07/2024 09:00 GENOVA Scritto No exam on July 22. 11/09/2024 09:00 GENOVA Scritto FURTHER INFORMATION Special assessments will be defined for those students who decide to pass the exam in the second semester.