## Test of Pearl 000 — Binary logic and computer architecture Pearls of Computer Science (202001022) Bachelor module 1.1, Technical Computer Science, EWI September 11, 2020, 13:45–14:45 Module coordinator: Doina Bucur Instructor: Pieter-Tjerk de Boer - You may use 1 A4 document with your own notes for this exam and a simple calculator. - Scientific or graphical calculators, laptops, mobile phones, books etc. are not allowed. Put those in your bag now! - Questions marked with MC must be answered on the separate multiple-choice form, at the number indicated in the circle. - Other questions have a box in which you can write the answer on this paper; this paper must be handed in. - Total number of points: 100. Total number of pages: 6. | Vo | 111 | r | na | m | Δ. | |-------|-----|---|-----|---|----| | - 1 - | u | | ııа | | ┖. | | Your student number: | | | |----------------------|--|--| | | | | | | | | ## 1. Binary numbers 4 pt (a) What is the decimal number +4 expressed as a 5-bit 2-complement binary number? A. 00011B. 00100 (Feel free to use the open space besides MC questions for scratch) MC**01** C. 00101 D. 01000 E. 10100 F. 10011 G. 11000 (b) Considering the 1-complement and 2-complement number representation scheme(s), which has/have the property that the left-most bit indicates the sign? (ignore the number 0, as it has no sign) MC02 4 pt 4 pt - A. Neither of them. - B. Only the 1-complement scheme. - C. Only the 2-complement scheme. - D. Both of them. (c) Convert decimal 2592 to hexadecimal. A. A20 B. A02 (MC03) C. 0A2D. 2A0 E. 02A F. 20A G. none of the above - (d) Convert the 2-complement hexadecimal number F0 to decimal: 4 pt (i.e., first convert to 2-complement 8-bit binary and then to decimal) - A. -240 - B. -16 MC**04** C. -15 D. 0 - E. 15 F. 16 - G. 240 - (e) Suppose we shift a 4-bit unsigned binary number X one position to the left; we fill the gap at the 4 pt right by a 0, and the left-most bit is dropped so the result again fits in 4 bits. Which statement is true? - A. This calculates 2X, for any X - B. This calculates 2X correctly if and only if $X \geq 0$ - C. This calculates 2X correctly if and only if X > 0 - D. This calculates 2X correctly if and only if X>1 - E. This calculates 2X correctly if and only if X < 7 - F. This calculates 2X correctly if and only if X < 8 - G. This calculates 2X correctly if and only if X < 15 - (f) What does "positional" notation mean? 4 pt - A. Each digit indicates its own position. - **MC06** - B. The position of a digit indicates its weight. - C. Each digit has a position that does not change. - D. A digit changes when moved to a different position. - E. The sign is determined by the digit in the first position. ## 2. Boolean logic (a) Give the truth table of a "conditional inverter": its output is the same as input X if input Y is 0, and it is the inverse of input X if input Y is 1. Note that you have to answer 4 multiple choice questions here: for 0 choose A, for 1 choose B. | X | Υ | output | |---|---|--------| | 0 | 0 | (MC07) | | 0 | 1 | MC08 | | 1 | 0 | MC09 | | 1 | 1 | MC10 | | | | | 4 pt form which relationship is used, using the following options: - 12 pt (b) Consider the following derivation in Boolean algebra. For each step, indicate on the multiple-choice - A commutative property - B identity property - C complement property - D distributive property - E DeMorgan's theorem - F this step is not correct (Note: check each step for equality only to the previous line. So if one step is incorrect (option F), the next step by itself can still be correct, even though of course it's no longer equal to what we started with.) $$\overline{\overline{X} + \overline{Y}} + \overline{Y}X + \overline{\overline{Y}} + \overline{Z}$$ $$\boxed{MC11} = XY + \overline{Y}X + \overline{\overline{Y}} + \overline{Z}$$ $$\boxed{MC12} = XY + \overline{Y}X + \overline{Y}Z$$ $$\boxed{MC13} = XY + X\overline{Y} + \overline{Y}Z$$ $$\boxed{MC14} = X(Y + \overline{Y}) + \overline{Y}Z$$ $$\boxed{MC15} = X \cdot 1 + \overline{Y}Z$$ $$\boxed{MC16} = X + \overline{Y}Z$$ 6 pt (c) Sketch a diagram implementing the following formula with only NAND gates: $\overline{(\overline{A} + \overline{B}) \cdot C} \cdot A$ - 4 pt - (d) Suppose you take two 2-input AND gates, and feed their outputs into a third 2-input NAND gate. Does this as a whole work as a 4-input NAND gate? - A. Yes, it does. - B. No, a 4-input NAND gate is not well-defined. - (MC17) - C. No, for that we should replace the third NAND gate by an AND gate. - D. No, for that we should replace the first two AND gates by NAND gates. - E. No, for that we should do both of the above-mentioned changes. - F. No, for that we should replace the third NAND gate by a NOR gate. - G. No, for that we should replace the first two AND gates by NOR gates. | 3. | Problem 3 | | Clock | | |----|-----------|---------------|----------------|----------------------| | | | Data in | , | Data in ALU Data out | | | V | Mrite address | Read address 2 | nstruction | The ALU of the processor above has two instructions: 0 = `ADD' and 1 = `MUL'. The register bank (RB) contains four 8-bit registers. Give for this processor the program for computing R1 $\times$ R2 $\times$ R2 + R1 and storing the result into R1. (You may not need all timeslots.) | | read address 1 / write address | read address 2 | instruction | | |------------|--------------------------------|----------------|-------------|--| | Timeslot 0 | | | | | | Timeslot 1 | | | | | | Timeslot 2 | | | | | | Timeslot 3 | | | | | | Timeslot 4 | | | | | | | | 1 | 1 | | Continued on next page... if so, to where (e.g., "branch to LDI R19, \$01"). | 4. Problem 4 | LDI | R17, \$0 | 02 | |-------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|-----| | Consider the AVR program at the right. | LDI | R18, \$0 | 07 | | ("BRNE" means "BRanch if Not Equal", "SUB" means "Subtract".) | LDI | R19, \$0 | 01 | | Assume that each instruction takes 1 clock cycle, except jumping to a differ- | LDI | R20, \$0 | 04 | | ent address, which takes 2 clock cycles. | SUB | R18, R | .17 | | | SUB | R20, R | .17 | | (a) Write in the below table the status of the registers after each instruction, one instruction per line. If a register doesn't change from one line | BRNE | -3 | | | to the next, you may leave it blank. If the instruction is a BRNE, use | SUB | R18, R | .19 | | the "branch" column to write down whether a jump is performed, and | BRNE | -2 | | | R17 | R18 | R19 | R20 | branch | |-----|-----|-----|-----|--------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 18 pt | 5. Prob | olem 5 | |----------------------------------------------------------|-------------------------------------------------------------------------------------| | | the mathematical function that is computed by the code below? | | Write as | a function of X and Y, e.g. $f(X, Y) = X + Y$ , and explain. | | _ | | | | that X and Y are larger than 0; the result is available in R19. | | LDI | R17, \$X | | LDI<br>LDI | R17, \$X<br>R18, \$Y | | LDI<br>LDI<br>LDI | R17, \$X<br>R18, \$Y<br>R19, \$00 | | LDI<br>LDI<br>LDI<br>LDI | R17, \$X<br>R18, \$Y<br>R19, \$00<br>R21, \$01 | | LDI<br>LDI<br>LDI<br>LDI<br>label1: | R17, \$X<br>R18, \$Y<br>R19, \$00<br>R21, \$01 | | LDI<br>LDI<br>LDI<br>LDI<br>label1:<br>SUB | R17, \$X<br>R18, \$Y<br>R19, \$00<br>R21, \$01 | | LDI<br>LDI<br>LDI<br>LDI<br>label1:<br>SUB<br>ADD | R17, \$X<br>R18, \$Y<br>R19, \$00<br>R21, \$01<br>R17, \$01<br>R19, R17 | | LDI<br>LDI<br>LDI<br>LDI<br>label1:<br>SUB<br>ADD<br>SUB | R17, \$X<br>R18, \$Y<br>R19, \$00<br>R21, \$01<br>R17, \$01<br>R19, R17<br>R18, R21 | | LDI<br>LDI<br>LDI<br>LDI<br>label1:<br>SUB<br>ADD<br>SUB | R17, \$X<br>R18, \$Y<br>R19, \$00<br>R21, \$01<br>R17, \$01<br>R19, R17 | | LDI<br>LDI<br>LDI<br>LDI<br>label1:<br>SUB<br>ADD<br>SUB | R17, \$X<br>R18, \$Y<br>R19, \$00<br>R21, \$01<br>R17, \$01<br>R19, R17<br>R18, R21 | | LDI<br>LDI<br>LDI<br>LDI<br>label1:<br>SUB<br>ADD<br>SUB | R17, \$X<br>R18, \$Y<br>R19, \$00<br>R21, \$01<br>R17, \$01<br>R19, R17<br>R18, R21 | | LDI<br>LDI<br>LDI<br>LDI<br>label1:<br>SUB<br>ADD<br>SUB | R17, \$X<br>R18, \$Y<br>R19, \$00<br>R21, \$01<br>R17, \$01<br>R19, R17<br>R18, R21 | | LDI<br>LDI<br>LDI<br>LDI<br>label1:<br>SUB<br>ADD<br>SUB | R17, \$X<br>R18, \$Y<br>R19, \$00<br>R21, \$01<br>R17, \$01<br>R19, R17<br>R18, R21 | | LDI<br>LDI<br>LDI<br>LDI<br>label1:<br>SUB<br>ADD<br>SUB | R17, \$X<br>R18, \$Y<br>R19, \$00<br>R21, \$01<br>R17, \$01<br>R19, R17<br>R18, R21 | | LDI<br>LDI<br>LDI<br>LDI<br>label1:<br>SUB<br>ADD<br>SUB | R17, \$X<br>R18, \$Y<br>R19, \$00<br>R21, \$01<br>R17, \$01<br>R19, R17<br>R18, R21 | | LDI<br>LDI<br>LDI<br>LDI<br>label1:<br>SUB<br>ADD<br>SUB | R17, \$X<br>R18, \$Y<br>R19, \$00<br>R21, \$01<br>R17, \$01<br>R19, R17<br>R18, R21 | | LDI<br>LDI<br>LDI<br>LDI<br>label1:<br>SUB<br>ADD<br>SUB | R17, \$X<br>R18, \$Y<br>R19, \$00<br>R21, \$01<br>R17, \$01<br>R19, R17<br>R18, R21 | End of this exam. — Scratch space below this line