Big Idea 2 'Binary Numbers'
taking a look at binary abstractions and logic gates
- Binary Abstraction and Logic Gates
- Hacks
Binary Abstraction and Logic Gates
Concepts and Visualization Ideas
Multiply and Divide by 2 (Shift)
Shifting bits is a common computer operation Look for shift on w3schools
UI Concept/Design
 n Right Shifts (divides by 2^n); n Left Shifts (mutliplies by 2^n)
Add buttons for  “«”   and  “ »”
n Right Shifts (divides by 2^n); n Left Shifts (mutliplies by 2^n)
Add buttons for  “«”   and  “ »”
Logic of Shift

Elaboration of Shift
 Arithmetic Shift
Arithmetic Shift
In an arithmetic shift, the bits that are shifted out of either end are discarded. In a left arithmetic shift, zeros are shifted in on the right; in a right arithmetic shift, the sign bit (the MSB in two’s complement) is shifted in on the left, thus preserving the sign of the operand. This example uses an 8-bit register, interpreted as two’s complement: In the first case, the leftmost digit was shifted past the end of the register, and a new 0 was shifted into the rightmost position. In the second case, the rightmost 1 was shifted out (perhaps into the carry flag), and a new 1 was copied into the leftmost position, preserving the sign of the number.
Unicode vs ASCII
Unicode can be UTF-8, 16 or 32, ASCII is preserved in Unicode.
 Sample of Unicode characters.
Sample of Unicode characters.
UI Concept/Design
 Original ASCII
Original ASCII
The ASCII label in picture should be change based off of the type of evaluation you are doing. Bits displayed, label, and evaluation would be specific to evaluation type:
- ASCII - 7 bits
- UTF-8
- UTF-16
- UTF-32
Color Codes
Color code is a 24 bit abstraction.
 255 * 255 * 255 combinations of R, G, B
255 * 255 * 255 combinations of R, G, B
UI Design
 by Anthony Vo
3 rows representing R, G, B 
Resulting color displayed in block
by Anthony Vo
3 rows representing R, G, B 
Resulting color displayed in block
Logic Gates
Logic Gates can be simulated with 2 bits
Look for bitwise operators on w3schools
UI Concept
 Logic Gates
Establish check boxes for A / B on and off
Show result of Boolean Expression using Gate visual
Logic Gates
Establish check boxes for A / B on and off
Show result of Boolean Expression using Gate visual
UI Design
 by Kylie Scharf
AB checkboxes with Submit button
Table with Symbol, Description, and Result
by Kylie Scharf
AB checkboxes with Submit button
Table with Symbol, Description, and Result
Logic of Logic Gates
A logic gate can have two inputs (a,b) and by how changing these inputs it impacts the output(c).
There are four possible inputs:
- 0 0
- 0 1
- 1 0
- 1 1
Understanding the output enables us to understand a logical expressions. All outputs are routed in Logic Gates (similar to how a language is routed in Latin).
- AND is true for 1 1; NAND is true opposite of AND 0 0, 0 1, 1 0
- OR is true for 1 1, 0 1, 1 0, NOR is true opposite of OR 0 0
- XOR is true for 0 1, 1 0
Practical Application

Unsigned Addition
Here we are requesting 3 rows of bits to simulate Math. This could be done with 4, 8, or 16 bits.
Initial UI Implementation
 Action buttons for +1 and -1
Additional actions for Turn On and Turn Off
Action buttons for +1 and -1
Additional actions for Turn On and Turn Off
Unsigned Addition

Signed Addition
Integers in most languages are int8, int16, int32, or int64. They typically reserve left most bit for sign.
Common concept for Integer Math
 Positive number
Positive number
Basic concept, but not typically used
 Negative number
Negative number
Inverting numbers, twos complement
 Two’s complement allows adding for signed and unsigned numbers
Two’s complement allows adding for signed and unsigned numbers
Basic concept is to invert/negate bits to produce negative. This allows numbers to be added together for expected results. » and »> have been adapted to handle signed and zero filled shifting.
Technical helpers
Algorithm in Jinja2 to limit Bits per row
 8 images per row by Kylie Scharf
Modulo 8 algorithm add <tr> for every eight bits (code).
8 images per row by Kylie Scharf
Modulo 8 algorithm add <tr> for every eight bits (code).
Binary Addition overview
CHAPTER 8 - Binary Addition and Two’s Complement Overview find by Val Wilson