1 / 32

Finite State Machines (FSMs) and RAMs and inner workings of CPUs

Finite State Machines (FSMs) and RAMs and inner workings of CPUs . 3/27/2008 COS 116 Instructor: Sanjeev Arora. Recap. Combinational logic circuits: no cycles, hence no “memory” Sequential circuits: cycles allowed; can have memory as well as “undefined”/ambiguous behavior

ratana
Download Presentation

Finite State Machines (FSMs) and RAMs and inner workings of CPUs

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Finite State Machines (FSMs) and RAMs and inner workings of CPUs 3/27/2008 COS 116 Instructor: Sanjeev Arora

  2. Recap • Combinational logic circuits: no cycles, hence no “memory” • Sequential circuits: cycles allowed; can have memory as well as “undefined”/ambiguous behavior • Clocked sequential circuits: Contain D flip flops whose“Write” input is controlled by a clock signal

  3. Forbidden to turn off bothSet and Resetsimultaneously(value is“ambiguous”) R-S Flip-Flop(corrected slide) S M R

  4. D M W Recap: D Flip Flop Basic Memory Block – stores 1 bit. If we “toggle” the write input (setting it 1 then setting it 0) then M acquires the value of D.

  5. D M W “Timing Diagram” 5V D 0V Time 5V W 0V Time 5V M 0V Time

  6. FSMs (of Moore Type) Detected Person “Automatic Door” • Finite number of states • Machine can produce outputs, these depend upon current state only • Machine can accept one or more bits of input; reading these causes transitions among states. No Person Detected Closed Open Detected Person No Person Detected

  7. Discussion Time What are some examples of FSMs in the Hayes article? How can we implement a FSM using logic gates etc.? • If number of states = 2k then represent “state” by k boolean variables. • Identify number of input variables • Write truth table expressing how “next state” is determined from “current state” and current valuesof the input. • Express as clocked synchronous circuit.

  8. Example: 4-state machine; 1 bit of input; No output State variables: P, Q Input variable: D Next value of P = (P+Q). D Next value of Q = P What is its state diagram?

  9. Flip flops(memoryelements) Circuit to compute next state Circuit tocomputeoutputs CLK Implementation: General Schematic Inputs K Flip flops allow FSM to have 2K states

  10. Implementing door FSM as synchronous circuit INPUT 0 = No Person Detected 1 = Person Detected STATE 0 = Door Closed 1 = Open

  11. D M W Implementation of door FSM (contd) 0 = No Person Detected 1 = Person Detected INPUT STATE 0 = Door Closed 1 = Open CLOCK

  12. Other examples of FSMs • Sisyphus • Brook’s Genghis (51 FSMs) (see p. 46 in our text) • Human Soul a la Aquinas (see Handout)

  13. Aside: Portion of Genghis AFSM Network[Parker’94] unique; “central control” IR sensors prowl for/bak pitch duplicated twice control actuators feeler receive input from sensors beta force beta balance I S alpha collide walk up leg trigger I D leg down beta pos alpha advance S alpha balance S alpha pos steer

  14. Next…. Random Access Memory (RAM) Memory where each location has an address

  15. Recall from last lecture: “Register” with 4 bits of memory How can youset up an addressingsystem for large banks of memory?

  16. RAM RAM RAM Data Data K Address Bits K Address Bits Read 2K bits;bank offlipflops Write

  17. If 4 locations, “address” has 2 bits Address Clock To RAM’s“Clock” input

  18. RAM: Implementing “Write” RAM Decoder (Demux) Data The decoder selects which cell in the RAM gets its “Write” input toggled Clock (simple combinationalcircuit; see logic handout) K-bit address(in binary)

  19. Ram: implementing “Read” RAM Multiplexer Data The multiplexer is connected to all cells in the RAM; selects the appropriate cell based upon the k-bit address (simple combinationalcircuit; see logic handout) K-bit address(in binary)

  20. Next, the secret revealed... How computers execute programs. CPU = Central Processing Unit

  21. Scribbler Control Panel Program Machine Executable Code F5 “Download to Robot” (Compilation) Similar to: Point 1: Programs are “translated” into “machine language”; this iswhat’s get executed. • T-P programs representedin binary • .exe files in the Wintel world

  22. Greatly simplified view of modern CPUs. Program (in binary)stored in memory Memory Registers Arithmetic and Logic Unit(ALU) Control FSM Lots of Custom Hardware Instruction Pointer RAM

  23. Examples of Machine Language Instructions Stored in binary (recall Davis’s binary encoding of T-P programs)

  24. Different CPUs have different machine languages • Intel Pentium • Power PC • Palmpilot, etc. “Backwards Compatibility” – Pentium 4’s machine language extends Pentium 2’s machine languageMachine languages now allow complicated calculations (eg for multimedia, graphics) in a single instruction

  25. Example: Intel press release SANTA CLARA, Calif., June 28, 2004 - Intel Corporation today announced availability of a new Intel® Xeon™ processor-based platform and a host of new products and technologies for its Intel Xeon processor family that significantly boost performance, memory and graphics capabilities for workstation platforms. Workstations will benefit from rich set of new technologies that address the increasingly data-hungry systems and software applications that crave performance for a range of functions such as financial and scientific data modeling to digital filmmaking and design automation.

  26. Main Insight Computer = FSM controlling a larger (or infinite) memory.

  27. Decode Fetch Execute Meet the little green man… The Fetch – Decode – Execute FSM

  28. Fetch – Decode – Execute FSM ADD Instruction IP IP + 1 “Fetch” JUMP Instruction Go to nextinstruction Execute Decode

  29. CPU as a conductor of a symphony Sound Card Network Card CPU “BUS” e.g., PCI CD-ROM Video Card Bus: “Everybody hears everybody else”

  30. T =1 L = 1 L = 0 T= 0 How an FSM does “reasoning” “If left infrared sensor detects a person, turn left”

  31. Speculation: Brain as FSM? • Network (“graph”) of 100 billion neurons; each connected to a few thousand others • Neuron = tiny Computational Element; “switching time” 0.01 s • Neuron generates a voltage spike depending upon how many neighbors are spiking.

  32. Discussion:How would you implement a Turing-Post program with a digital circuit? 1.PRINT 0 2. GO RIGHT 3. GO TO STEP 1 if 1 SCANNED 4. GO TO STEP 1 if 0 SCANNED 5. STOP Assume “PRINT” and “SCAN” as basic operations

More Related