CS 101 – Sept. 18 Adder circuit example (handout) How computers think –Concept of “state” –Turing machine model –Finite state machine model a.k.a. “Finite automaton”
State Fundamental concept for any computation –Machine keeps track of where it is, what it needs –a.k.a. Status, mode –state may be stored in some memory cell Many examples –Logging in –Using a dialog box, or other user-interface –Fax machine, photocopier, telephone –Car transmission
Examples In a Tic-Tac-Toe game, the “state” of the game would include: –Whose turn it is –Is the game over? Who won, or was it a tie? State is determined by looking at the board. Backgammon (roll dice, move pieces…) –Depending on your situation in the game, some moves are illegal. Another way to think about states is to consider all possible board configurations!
Turing machine Alan Turing, 1936 Any general purpose machine must: –Work automatically –Be aware of what state it’s in –Have sufficient memory –Be able to do I/O, and be able to read the input many times if necessary Powerful model, but tedious to work with
Adder example 4 possible states, depending on the inputs –For example, (S = 0 and C = 0) would be one outcome. Programming the details make working with real TMs a headache. x y z S C
Finite Automata singular: finite automaton Simple model for machine behavior. Purpose is to accept or reject some input –Examples: logging in, using a wizard, game At any given time, machine is in some “state” –Start state –Final (or accept, “happy”) states –Dead states Transitions between states
Example Vending machine for 25¢ item
Binary example We want a “word” starting with “101…” need 101 need 01 need 1 ,1
Binary Example (2) We want a word with at least two 0’s. need two need one ,1 What if we wanted exactly two 0’s?
What does this FA do? A B