the beauty and joy of computingbjc.berkeley.edu/slides/bjc-l16-dg-computational-game-theory.pdf ·...

18
The Beauty and Joy of Computing Lecture #16 Computational Game Theory A 19-year project led by Prof Jonathan Schaeffer, he used dozens (sometimes hundreds) of computers and AI to prove it is, in perfect play, a … draw! This means that if two Gods were to play, nobody would ever win! UC Berkeley EECS Sr Lecturer SOE Dan Garcia www.cs.ualberta.ca/~chinook/

Upload: others

Post on 30-Oct-2020

1 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: The Beauty and Joy of Computingbjc.berkeley.edu/slides/BJC-L16-DG-Computational-Game-Theory.pdf · UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

The Beauty and Joy of Computing

Lecture #16 Computational Game Theory

A 19-year project led by Prof Jonathan Schaeffer, he used dozens (sometimes hundreds) of computers and AI to prove it is, in perfect play, a … draw! This means that if two Gods were to play, nobody would ever win!

UC Berkeley EECS Sr Lecturer SOE

Dan Garcia

www.cs.ualberta.ca/~chinook/

Page 2: The Beauty and Joy of Computingbjc.berkeley.edu/slides/BJC-L16-DG-Computational-Game-Theory.pdf · UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (2)

Garcia

§  History §  Definitions

ú  Game Theory ú  What Games We Mean ú  Win, Lose, Tie, Draw ú  Weakly / Strongly Solving

§  Gamesman ú  Dan’s Undergraduate

R&D Group ú  Demo!!

§  Future

Computational Game Theory

Page 3: The Beauty and Joy of Computingbjc.berkeley.edu/slides/BJC-L16-DG-Computational-Game-Theory.pdf · UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (3)

Garcia

§  CS research areas: ú  Artificial Intelligence ú  Biosystems & Computational Biology ú  Computer Architecture & Engineering ú  Database Management Systems ú  Graphics ú  Human-Computer Interaction ú  Operating Systems & Networking ú  Programming Systems ú  Scientific Computing ú  Security ú  Theory ú  …

Computer Science … A UCB view

Page 4: The Beauty and Joy of Computingbjc.berkeley.edu/slides/BJC-L16-DG-Computational-Game-Theory.pdf · UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (4)

Garcia

§  A Hoax! §  Built by Wolfgang von

Kempelen ú  to impress the Empress

§  Could play a strong game of Chess ú  Thanks to Master inside

§  Toured Europe ú  Defeated Benjamin Franklin

& Napoleon!

§  Burned in an 1854 fire ú  Chessboard saved…

The Turk (1770)

Page 5: The Beauty and Joy of Computingbjc.berkeley.edu/slides/BJC-L16-DG-Computational-Game-Theory.pdf · UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (5)

Garcia

§  The “Father of Information Theory” ú  Founded the digital computer ú  Defined fundamental limits

on compressing/storing data

§  Wrote “Programming a Computer for Playing Chess” paper in 1950 ú  C. Shannon, Philos. Mag. 41,

256 (1950). ú  All chess programs today

have his theories at their core ú  His estimate of # of Chess

positions called “Shannon #”    Now proved < 2155 ~ 1046.7

Claude Shannon’s Paper (1950)

Page 6: The Beauty and Joy of Computingbjc.berkeley.edu/slides/BJC-L16-DG-Computational-Game-Theory.pdf · UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (6)

Garcia

§  Kasparov World Champ

§  1996 Tournament – Deep Blue ú  First game DB wins a classic! ú  But DB loses 3 and draws 2 to

lose the 6-game match 4-2 ú  In 1997 Deep Blue upgraded,

renamed “Deeper Blue”

§  1997 Tournament – Deeper Blue ú  GK wins game 1 ú  GK resigns game 2

   even though it was draw!

ú  DB & GK draw games 3-5 ú  Game 6 : 1997-05-11 (May 11th)

   Kasparov blunders move 7, loses in 19 moves. Loses tournament 3 ½ - 2 ½

   GK accuses DB of cheating. No rematch.

§  Defining moment in AI history

Deep Blue vs Garry Kasparov (1997)

Page 7: The Beauty and Joy of Computingbjc.berkeley.edu/slides/BJC-L16-DG-Computational-Game-Theory.pdf · UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (7)

Garcia

Economic ú  von Neumann and

Morgenstern’s 1944 Theory of Games and Economic Behavior

ú  Matrix games ú  Prisoner’s dilemma,

auctions ú  Film : A Beautiful Mind

(about John Nash) ú  Incomplete info,

simultaneous moves ú  Goal: Maximize payoff

Computational ú  R. C. Bell’s 1988

Board and Table Games from many Civilizations

ú  Board games ú  Tic-Tac-Toe, Chess,

Connect 4, Othello ú  Film : Searching for

Bobby Fischer ú  Complete info,

alternating moves ú  Goal: Varies

What is “Game Theory”?

Page 8: The Beauty and Joy of Computingbjc.berkeley.edu/slides/BJC-L16-DG-Computational-Game-Theory.pdf · UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (8)

Garcia

§  No chance, such as dice or shuffled cards

§  Both players have complete information ú  No hidden information, as in

Stratego & Magic

§  Two players (Left & Right) usually alternate moves ú  Repeat & skip moves ok ú  Simultaneous moves not ok

§  The game can end in a pattern, capture, by the absence of moves, or …

What “Board Games” do you mean?

Page 9: The Beauty and Joy of Computingbjc.berkeley.edu/slides/BJC-L16-DG-Computational-Game-Theory.pdf · UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (9)

Garcia

§  We strongly solve abstract strategy games and puzzles ú  70 games / puzzles in

our system ú  Allows perfect play

against an opponent ú  Ability to do a post-

game analysis

Page 10: The Beauty and Joy of Computingbjc.berkeley.edu/slides/BJC-L16-DG-Computational-Game-Theory.pdf · UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (10)

Garcia

What’s in a Strong Solution

§  For every position ú  Assuming alternating play ú  Value …

(for player whose turn it is) Winning (∃ losing child) Losing (All children winning) Tieing (!∃ losing child, but ∃

tieing child) Drawing (can’t force a win or

be forced to lose)

ú  Remoteness    How long before game ends?

W

W W W

..."

L

L

W W W

..."

W

T

W W W

..."

T

D

W W W

D

W

..."

Page 11: The Beauty and Joy of Computingbjc.berkeley.edu/slides/BJC-L16-DG-Computational-Game-Theory.pdf · UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (11)

Garcia

What did you mean “strongly solve”?

Page 12: The Beauty and Joy of Computingbjc.berkeley.edu/slides/BJC-L16-DG-Computational-Game-Theory.pdf · UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (12)

Garcia

Weakly Solving A Game (Checkers)

Endgame databases

(solved)

Master: main line of

play to consider

Workers: positions to search

Log of Search Space Size

Page 13: The Beauty and Joy of Computingbjc.berkeley.edu/slides/BJC-L16-DG-Computational-Game-Theory.pdf · UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (13)

Garcia

Strong Solving Example: 1,2,…,10 §  Rules (on your turn):

ú  Running total = 0

§  Rules (on your turn): ú  Add 1 or 2 to running total

§  Goal ú  Be the FIRST to get to 10

§  Example ú  Ana: “2 to make it 2” ú  Bob: “1 to make it 3” ú  Ana: “2 to make it 5” ú  Bob: “2 to make it 7” à photo ú  Ana: “1 to make it 8” ú  Bob: “2 to make it 10” I WIN!

Page 14: The Beauty and Joy of Computingbjc.berkeley.edu/slides/BJC-L16-DG-Computational-Game-Theory.pdf · UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

Garcia

Example: Tic-Tac-Toe

§  Rules (on your turn): ú  Place your X or O in an

empty slot on 3x3 board

§  Goal ú  If your make 3-in-a-row

first in any row / column / diag, win

ú  Else if board is full with no 3-in-row, tie

§  Misére is tricky ú  3-in-row LOSES ú  Pair up and play now,

then swap who goes 1st

Page 15: The Beauty and Joy of Computingbjc.berkeley.edu/slides/BJC-L16-DG-Computational-Game-Theory.pdf · UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (15)

Garcia

Tic-Tac-Toe Answer Visualized! §  Recursive Values Visualization Image §  Misére Tic-tac-toe

ú  Outer rim is position ú  Inner levels moves ú  Legend

Lose Tie Win

Page 16: The Beauty and Joy of Computingbjc.berkeley.edu/slides/BJC-L16-DG-Computational-Game-Theory.pdf · UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (16)

Garcia

GamesCrafters (revisited) §  Undergraduate Computational

Game Theory Research Group

§  300 students since 2001 ú  We now average 20/semester! ú  They work in teams of 2+

§  Most return, take more senior roles (sub-group team leads) ú  Maximization (bottom-up solve) ú  Oh, DeepaBlue (parallelization) ú  GUI (graphical interface work) ú  Retro (GUI refactoring) ú  Architecture (core) ú  New/ice Games (add / refactor) ú  Documentation (games & code)

Page 17: The Beauty and Joy of Computingbjc.berkeley.edu/slides/BJC-L16-DG-Computational-Game-Theory.pdf · UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (17)

Garcia

Connect 4 Solved, Online! §  We’ve just finished a

solve of Connect 4!! §  It took 30 Machines x

8 Cores x 1 weeks §  Win for the first player

(go in the middle!) ú  3,5 = tie ú  1,2,6,7 = lose

§  Come play online!

Page 18: The Beauty and Joy of Computingbjc.berkeley.edu/slides/BJC-L16-DG-Computational-Game-Theory.pdf · UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (14)

UC Berkeley “The Beauty and Joy of Computing” : Computational Game Theory (18)

Garcia

§  Board games are exponential ú  So has been the progress of the

speed / capacity of computers! ú  Therefore, every few years, we only

get to solve one more “ply”

§  One by one, we’re going to solve them and/or beat humans ú  We’ll never solve some

   E.g., hardest game : Go

§  Strongly solving (GamesCrafters) ú  We visit EVERY position, and

know value of EVERY position ú  E.g., Connect 4

§  Weakly solving (Univ Alberta) ú  We prove game’s value by only

visiting SOME positions, so we only know value of SOME positions

ú  E.g., Checkers

Future