Computer Architecture and Technology

Base Knowledge

Basic concepts of programming, algorithms and data structure.

Teaching Methodologies

The following methodologies are used in this course:

1 – Expository method: an explanatory method where theoretical foundations and concept are presented by the lecturer and discussed with the class, followed by demonstrative examples;
2 – Experimental method: an active method where the student develops knowledge through problem-solving and the development of individual laboratory projects or group dynamics.

Each class will consist of two moments:

1 – Introductory presentation: At the beginning of the class, the lecturer exposes and discusses the new contents understudy with the students;
2 – Practical application: After the introductory presentation, students develop worksheets and problem solving, individually and together, for practical application of new concepts, autonomously and under the guidance of the lecturer;

 

Learning Results

Upon completion of UC, students should be able to:

1. Identify the future evolution of computers based on the knowledge of their evolution until today.

2. Express the basic mathematical and logical operations and different ways of representing numerical and non-numerical quantities.

3. Identify the general architecture of computers.

4. Build algorithms and implement programs and or procedures in low-level languages and compare their performance with programs and or procedures implemented in high-level languages.

5. Identify different techniques to increase the processing speed of applications, both in terms of hardware and software.

6. Use microcontrollers to acquire and control analog and digital signals as well as communicate the microcontroller with a computer.

Program

1. Brief history of computers

2. Review of fundamental concepts for computer architecture

a) Bits, Bytes, Words
b) Numbers representation in different bases
c) Operations with numbers in different bases
d) Negative numbers representation
e) Floating points
f) Nonnumeric data representation

3. General architecture of computers

a) General organization of a CPU
b) Different types of BUS
c) Device I / O

4. 80XXX architecture.

a) Architectures CISC / RISC

5. Memory organization

a) Memory hierarchies
b) Real mode / protected mode
c) Virtual memory
d) Cache memory
e) Memory aligned and its influence on performance.

6. Introduction to low-level Programming

a)Instructions
b)Assembly integration in high level languages
c) Sub routines
d) Integration between low level and high level languages
e) Accessing to I / O devices.
i) pooling
ii) interrupts

7. Introduction to microcontrollers

a. Basics for using Arduino
b. Read analog and digital signals
c. Control analog and digital signals
d. Communications between Arduino and Computer
e. Interrupts in Arduino: vantages and limitations

 

Curricular Unit Teachers

Internship(s)

NAO

Bibliography

Delgado , J., & Ribeiro, C. (2014). Arquitetura De Computadores. FCA.

Monk, S. (2019). Programming arduino next steps: Going further with sketches. McGraw-Hill Education.