Adversarial Search (Game)

Total Page:16

File Type:pdf, Size:1020Kb

Adversarial Search (Game) Adversarial Search CE417: Introduction to Artificial Intelligence Sharif University of Technology Spring 2019 Soleymani “Artificial Intelligence: A Modern Approach”, 3rd Edition, Chapter 5 Most slides have been adopted from Klein and Abdeel, CS188, UC Berkeley. Outline } Game as a search problem } Minimax algorithm } �-� Pruning: ignoring a portion of the search tree } Time limit problem } Cut off & Evaluation function 2 Games as search problems } Games } Adversarial search problems (goals are in conflict) } Competitive multi-agent environments } Games in AI are a specialized kind of games (in the game theory) 3 Adversarial Games 4 Types of Games } Many different kinds of games! } Axes: } Deterministic or stochastic? } One, two, or more players? } Zero sum? } Perfect information (can you see the state)? } Want algorithms for calculating a strategy (policy) which recommends a move from each state 5 Zero-Sum Games } Zero-Sum Games } General Games } Agents have opposite utilities } Agents have independent utilities (values on outcomes) (values on outcomes) } Lets us think of a single value that one } Cooperation, indifference, competition, maximizes and the other minimizes and more are all possible } Adversarial, pure competition } More later on non-zero-sum games 6 Primary assumptions } We start with these games: } Two -player } Tu r n taking } agents act alternately } Zero-sum } agents’ goals are in conflict: sum of utility values at the end of the game is zero or constant } Perfect information } fully observable Examples: Tic-tac-toe, chess, checkers 7 Deterministic Games } Many possible formalizations, one is: } States: S (start at s0) } Players: P={1...N} (usually take turns) } Actions:A (may depend on player / state) } Transition Function: SxA ® S } Terminal Te s t : S ® {t,f} } Terminal Utilities: SxP ® R } Solution for a player is a policy: S ® A 8 Single-Agent Trees 8 2 0 … 2 6 … 4 6 9 Value of a State Value of a state: The Non-Terminal best achievable outcome States: (utility) from that state 8 2 0 … 2 6 … 4 6 Terminal States: 10 Adversarial Search 11 Adversarial Game Trees -20 -8 … -18 -5 … -10 +4 -20 +8 12 Minimax Values States Under AGent’s Control: States Under Opponent’s Control: -8 -5 -10 +8 Terminal States: 13 Tic-Tac-Toe Game Tree 14 Game tree (tic-tac-toe) } Two players: �$ and �% (�$ is now searching to find a good move) } Zero-sum games: �$ gets �(�), �% gets � − �(�) for terminal node � �$: � �$ �%: � 1-ply = half move �% �$ �% Utilities from the point of view of �$ 15 Optimal play } Opponent is assumed optimal } Minimax function is used to find the utility of each state. } MAX/MIN wants to maximize/minimize the terminal payoff MAX gets �(�) for terminal node � 16 Adversarial Search (Minimax) } Minimax search: } A state-space search tree } Players alternate turns 5 max } Compute each node’s minimax value: the best achievable utility against a 2 5 min rational (optimal) adversary 8 2 5 6 Terminal values: part of the game 17 Minimax �������(�, ���) �� ��������_����(�) ������� � = 5���D∈FGHIJKL M �������(������(�, �)) ������ � = ��� ���D∈FGHIJKL M �������(������ �, � ) ������ � = ��� Utility of being in state s } �������(�) shows the best achievable outcome of being in state � (assumption: optimal opponent) 3 3 2 2 18 Minimax (Cont.) } Optimal strategy: move to the state with highest minimax value } Best achievable payoff against best play } Maximizes the worst-case outcome for MAX } It works for zero-sum games 19 Minimax Properties max min 10 10 9 100 Optimal against a perfect player. Otherwise? 20 Minimax Implementation def max-value(state): def min-value(state): initialize v = -∞ initialize v = +∞ for each successor of state: for each successor of state: v = max(v, min-value(successor)) v = min(v, max-value(successor)) return v return v 21 Minimax Implementation (Dispatch) def value(state): if the state is a terminal state: return the state’s utility if the next agent is MAX: return max-value(state) if the next agent is MIN: return min-value(state) def max-value(state): def min-value(state): initialize v = -∞ initialize v = +∞ for each successor of state: for each successor of state: v = max(v, value(successor)) v = min(v, value(successor)) return v return v 22 Minimax algorithm Depth first search function �������_��������(�����) returns �� ������ return max ���_�����(������(�����, �)) D∈FGHIJKL(MVDVW) function ���_�����(�����) returns � ������� ����� if ��������_����(�����) then return �������(�����) � ← −∞ for each � in �������(�����) do � ← ���(�, ���_�����(�������(�����, �))) return � function ���_�����(�����) returns � ������� ����� if ��������_����(�����) then return �������(�����) � ← ∞ for each � in �������(�����) do � ← ���(�, ���_�����(�������(�����, �))) return � 23 Properties of minimax } Complete?Yes (when tree is finite) } Optimal?Yes (against an optimal opponent) } Time complexity: �(��) } Space complexity: �(��) (depth-first exploration) } For chess, � ≈ 35, � > 50 for reasonable games } Finding exact solution is completely infeasible 24 Game Tree Pruning 25 Pruning } Correct minimax decision without looking at every node in the game tree } α-β pruning } Branch & bound algorithm } Prunes away branches that cannot influence the final decision 26 α-β pruning example 27 α-β pruning example 28 α-β pruning example 29 α-β pruning example 30 α-β pruning example 31 α-β pruning } Assuming depth-first generation of tree } We prune node � when player has a better choice � at (parent or) any ancestor of � } Tw o types of pruning (cuts): } pruning of max nodes (α-cuts) } pruning of min nodes (β-cuts) 32 Alpha-Beta Pruning } General configuration (MIN version) } We’re computing the MIN-VALUE at some node n MAX } We’re looping over n’s children } Who cares about n’s value? MAX MIN a } Let a be the best value that MAX can get at any choice point along the current path from the root } If n becomes worse than a, MAX will avoid it, so we MAX can stop considering n’s other children (it’s already bad enough that it won’t be played) MIN n } MAX version is symmetric 33 α-β pruning (an other example) 3 3 ≤2 2 ≥5 1 5 34 Why is it called α-β? } α: Value of the best (highest) choice found so far at any choice point along the path for MAX } �: Value of the best (lowest) choice found so far at any choice point along the path for MIN } Updating α and � during the search process } For a MAX node once the value of this node is known to be more than the current � (v ≥ �), its remaining branches are pruned. } For a MIN node once the value of this node is known to be less than the current � (v ≤ �), its remaining branches are pruned. 35 Alpha-Beta Implementation α: MAX’s best option on path to root β: MIN’s best option on path to root def max-value(state, α, β): def min-value(state , α, β): initialize v = -∞ initialize v = +∞ for each successor of state: for each successor of state: v = max(v, value(successor, α, β)) v = min(v, value(successor, α, β)) if v ≥ β return v if v ≤ α return v α = max(α, v) β = min(β, v) return v return v 36 function �����_����_������(�����) returns �� ������ � ← ���_�����(�����, −∞, +∞) return the ������ in �������(�����) with value � function ���_�����(�����, �, �) returns � ������� ����� if ��������_����(�����) then return �������(�����) � ← −∞ for each � in �������(�����) do � ← ���(�, ���_�����(�������(�����, �), �, �)) if � ≥ � then return � � ← ���(�, �) return � function ���_�����(�����, �, �) returns � ������� ����� if ��������_����(�����) then return �������(�����) � ← +∞ for each � in �������(�����) do � ← ���(�, ���_�����(�������(�����, �), �, �)) if � ≤ � then return � � ← ���(�, �) return � 37 α-β progress 38 Order of moves } Good move ordering improves effectiveness of pruning ? l } Best order: time complexity is �(� ⁄m) 39 Computational time limit (example) } 100 secs is allowed for each move (game rule) } 104 nodes/sec (processor speed) } We can explore just 106 nodes for each move } bm = 106, b=35 ⟹ m=4 } (4-ply look-ahead is a hopeless chess player!) } a-b reaches about depth 8 – decent chess program } It is still hopeless 40 Resource Limits 41 Resource Limits } Problem: In realistic games, cannot search to leaves! 4 max -2 4 min } Solution: Depth-limited search -1 -2 4 9 } Instead, search only to a limited depth in the tree } Replace terminal utilities with an evaluation function for non-terminal positions } Guarantee of optimal play is gone } More plies makes a BIG difference } Use iterative deepening for an anytime ? ? ? ? algorithm 42 Computational time limit: Solution } We must make a decision even when finding the optimal move is infeasible. } Cut off the search and apply a heuristic evaluation function } cutoff test: turns non-terminal nodes into terminal leaves } Cut off test instead of terminal test (e.g., depth limit) } evaluation function: estimated desirability of a state } Heuristic function evaluation instead of utility function } This approach does not guarantee optimality. 43 Depth Matters } Evaluation functions are always imperfect } The deeper in the tree the evaluation function is buried, the less the quality of the evaluation function matters } An important example of the tradeoff between complexity of features and complexity of computation 44 Heuristic minimax �pIKIpFq M,r = ����(�, ���) �� ������_����(�, �) 5���D∈FGHIJKL M �_�������(������ �, � , � + 1) ������ � = MAx ���D∈FGHIJKL M �_�������(������ �, � , � + 1) ������ � = MIN 45 Evaluation Functions 46 Evaluation functions } For terminal states, it should order them in the same way as the true utility
Recommended publications
  • Best-First Minimax Search Richard E
    Artificial Intelligence ELSEVIER Artificial Intelligence 84 ( 1996) 299-337 Best-first minimax search Richard E. Korf *, David Maxwell Chickering Computer Science Department, University of California, Los Angeles, CA 90024, USA Received September 1994; revised May 1995 Abstract We describe a very simple selective search algorithm for two-player games, called best-first minimax. It always expands next the node at the end of the expected line of play, which determines the minimax value of the root. It uses the same information as alpha-beta minimax, and takes roughly the same time per node generation. We present an implementation of the algorithm that reduces its space complexity from exponential to linear in the search depth, but at significant time cost. Our actual implementation saves the subtree generated for one move that is still relevant after the player and opponent move, pruning subtrees below moves not chosen by either player. We also show how to efficiently generate a class of incremental random game trees. On uniform random game trees, best-first minimax outperforms alpha-beta, when both algorithms are given the same amount of computation. On random trees with random branching factors, best-first outperforms alpha-beta for shallow depths, but eventually loses at greater depths. We obtain similar results in the game of Othello. Finally, we present a hybrid best-first extension algorithm that combines alpha-beta with best-first minimax, and performs significantly better than alpha-beta in both domains, even at greater depths. In Othello, it beats alpha-beta in two out of three games. 1. Introduction and overview The best chess machines, such as Deep-Blue [lo], are competitive with the best humans, but generate billions of positions per move.
    [Show full text]
  • Exploding Offers with Experimental Consumer Goods∗
    Exploding Offers with Experimental Consumer Goods∗ Alexander L. Brown Ajalavat Viriyavipart Department of Economics Department of Economics Texas A&M University Texas A&M University Xiaoyuan Wang Department of Economics Texas A&M University August 29, 2014 Abstract Recent theoretical research indicates that search deterrence strategies are generally opti- mal for sellers in consumer goods markets. Yet search deterrence is not always employed in such markets. To understand this incongruity, we develop an experimental market where profit-maximizing strategy dictates sellers should exercise one form of search deterrence, ex- ploding offers. We find that buyers over-reject exploding offers relative to optimal. Sellers underutilize exploding offers relative to optimal play, even conditional on buyer over-rejection. This tendency dissipates when sellers make offers to computerized buyers, suggesting their persistent behavior with human buyers may be due to a preference rather than a miscalculation. Keywords: exploding offer, search deterrence, experimental economics, quantal response equi- librium JEL: C91 D21 L10 M31 ∗We thank the Texas A&M Humanities and Social Science Enhancement of Research Capacity Program for providing generous financial support for our research. We have benefited from comments by Gary Charness, Catherine Eckel, Silvana Krasteva and seminar participants of the 2013 North American Economic Science Association and Southern Economic Association Meetings. Daniel Stephenson and J. Forrest Williams provided invaluable help in conducting the experimental sessions. 1 Introduction One of the first applications of microeconomic theory is to the consumer goods market: basic supply and demand models can often explain transactions in centralized markets quite well. When markets are decentralized, often additional modeling is required to explain the interactions of consumers and producers.
    [Show full text]
  • Adversarial Search (Game Playing)
    Artificial Intelligence Adversarial Search (Game Playing) Chapter 5 Adapted from materials by Tim Finin, Marie desJardins, and Charles R. Dyer Outline • Game playing – State of the art and resources – Framework • Game trees – Minimax – Alpha-beta pruning – Adding randomness State of the art • How good are computer game players? – Chess: • Deep Blue beat Gary Kasparov in 1997 • Garry Kasparav vs. Deep Junior (Feb 2003): tie! • Kasparov vs. X3D Fritz (November 2003): tie! – Checkers: Chinook (an AI program with a very large endgame database) is the world champion. Checkers has been solved exactly – it’s a draw! – Go: Computer players are decent, at best – Bridge: “Expert” computer players exist (but no world champions yet!) • Good place to learn more: http://www.cs.ualberta.ca/~games/ Chinook • Chinook is the World Man-Machine Checkers Champion, developed by researchers at the University of Alberta. • It earned this title by competing in human tournaments, winning the right to play for the (human) world championship, and eventually defeating the best players in the world. • Visit http://www.cs.ualberta.ca/~chinook/ to play a version of Chinook over the Internet. • The developers have fully analyzed the game of checkers and have the complete game tree for it. – Perfect play on both sides results in a tie. • “One Jump Ahead: Challenging Human Supremacy in Checkers” Jonathan Schaeffer, University of Alberta (496 pages, Springer. $34.95, 1998). Ratings of human and computer chess champions Typical case • 2-person game • Players alternate moves • Zero-sum: one player’s loss is the other’s gain • Perfect information: both players have access to complete information about the state of the game.
    [Show full text]
  • Learning Near-Optimal Search in a Minimal Explore/Exploit Task
    Explore/exploit tradeoff strategies with accumulating resources 1 Explore/exploit tradeoff strategies in a resource accumulation search task [revised/resubmitted to Cognitive Science] Ke Sang1, Peter M. Todd1, Robert L. Goldstone1, and Thomas T. Hills2 1 Cognitive Science Program and Department of Psychological and Brain Sciences, Indiana University Bloomington 2 Department of Psychology, University of Warwick REVISION 7/5/2018 Contact information: Peter M. Todd Indiana University, Cognitive Science Program 1101 E. 10th Street, Bloomington, IN 47405 USA phone: +1 812 855-3914 email: [email protected] Explore/exploit tradeoff strategies with accumulating resources 2 Abstract How, and how well, do people switch between exploration and exploitation to search for and accumulate resources? We study the decision processes underlying such exploration/exploitation tradeoffs by using a novel card selection task. With experience, participants learn to switch appropriately between exploration and exploitation and approach optimal performance. We model participants’ behavior on this task with random, threshold, and sampling strategies, and find that a linear decreasing threshold rule best fits participants’ results. Further evidence that participants use decreasing threshold-based strategies comes from reaction time differences between exploration and exploitation; however, participants themselves report non-decreasing thresholds. Decreasing threshold strategies that “front-load” exploration and switch quickly to exploitation are particularly effective
    [Show full text]
  • CS 561: Artificial Intelligence
    CS 561: Artificial Intelligence Instructor: Sofus A. Macskassy, [email protected] TAs: Nadeesha Ranashinghe ([email protected]) William Yeoh ([email protected]) Harris Chiu ([email protected]) Lectures: MW 5:00-6:20pm, OHE 122 / DEN Office hours: By appointment Class page: http://www-rcf.usc.edu/~macskass/CS561-Spring2010/ This class will use http://www.uscden.net/ and class webpage - Up to date information - Lecture notes - Relevant dates, links, etc. Course material: [AIMA] Artificial Intelligence: A Modern Approach, by Stuart Russell and Peter Norvig. (2nd ed) This time: Outline (Adversarial Search – AIMA Ch. 6] Game playing Perfect play ◦ The minimax algorithm ◦ alpha-beta pruning Resource limitations Elements of chance Imperfect information CS561 - Lecture 7 - Macskassy - Spring 2010 2 What kind of games? Abstraction: To describe a game we must capture every relevant aspect of the game. Such as: ◦ Chess ◦ Tic-tac-toe ◦ … Accessible environments: Such games are characterized by perfect information Search: game-playing then consists of a search through possible game positions Unpredictable opponent: introduces uncertainty thus game-playing must deal with contingency problems CS561 - Lecture 7 - Macskassy - Spring 2010 3 Searching for the next move Complexity: many games have a huge search space ◦ Chess: b = 35, m=100 nodes = 35 100 if each node takes about 1 ns to explore then each move will take about 10 50 millennia to calculate. Resource (e.g., time, memory) limit: optimal solution not feasible/possible, thus must approximate 1. Pruning: makes the search more efficient by discarding portions of the search tree that cannot improve quality result. 2. Evaluation functions: heuristics to evaluate utility of a state without exhaustive search.
    [Show full text]
  • Optimal Symmetric Rendezvous Search on Three Locations
    Optimal Symmetric Rendezvous Search on Three Locations Richard Weber Centre for Mathematical Sciences, Wilberforce Road, Cambridge CB2 0WB email: [email protected] www.statslab.cam.ac.uk/~rrw1 In the symmetric rendezvous search game played on n locations two players are initially placed at two distinct locations. The game is played in discrete steps, at each of which each player can either stay where he is or move to a different location. The players share no common labelling of the locations. We wish to find a strategy such that, if both players follow it independently, then the expected number of steps until they are in the same location is minimized. Informal versions of the rendezvous problem have received considerable attention in the popular press. The problem was proposed by Steve Alpern in 1976 and it has proved notoriously difficult to analyse. In this paper we prove a 20 year old conjecture that the following strategy is optimal for the game on three locations: in each block of two steps, stay where you, or search the other two locations in random order, doing these with probabilities 1=3 and 2=3 respectively. This is now the first nontrivial symmetric rendezvous search game to be fully solved. Key words: rendezvous search; search games; semidefinite programming MSC2000 Subject Classification: Primary: 90B40; Secondary: 49N75, 90C22, 91A12, 93A14 OR/MS subject classification: Primary: Games/group decisions, cooperative; Secondary: Analysis of algorithms; Programming, quadratic 1. Symmetric rendezvous search on three locations In the symmetric rendezvous search game played on n locations two players are initially placed at two distinct locations.
    [Show full text]
  • Game Playing (Adversarial Search) CS 580 (001) - Spring 2018
    Lecture 5: Game Playing (Adversarial Search) CS 580 (001) - Spring 2018 Amarda Shehu Department of Computer Science George Mason University, Fairfax, VA, USA February 21, 2018 Amarda Shehu (580) 1 1 Outline of Today's Class 2 Games vs Search Problems 3 Perfect Play Minimax Decision Alpha-Beta Pruning 4 Resource Limits and Approximate Evaluation Expectiminimax 5 Games of Imperfect Information 6 Game Playing Summary Amarda Shehu (580) Outline of Today's Class 2 Game Playing { Adversarial Search Search in a multi-agent, competitive environment ! Adversarial Search/Game Playing Mathematical game theory treats any multi-agent environment as a game, with possibly co-operative behaviors (study of economies) Most games studied in AI: deterministic, turn-taking, two-player, zero-sum games of perfect information Amarda Shehu (580) Games vs Search Problems 3 Game Playing - Adversarial Search Most games studied in AI: deterministic, turn-taking, two-player, zero-sum games of perfect information zero-sum: utilities of the two players sum to 0 (no win-win) deterministic: precise rules with known outcomes perfect information: fully observable Amarda Shehu (580) Games vs Search Problems 4 Game Playing - Adversarial Search Most games studied in AI: deterministic, turn-taking, two-player, zero-sum games of perfect information zero-sum: utilities of the two players sum to 0 (no win-win) deterministic: precise rules with known outcomes perfect information: fully observable Search algorithms designed for such games make use of interesting general techniques (meta-heuristics) such as evaluation functions, search pruning, and more. However, games are to AI what grand prix racing is to automobile design.
    [Show full text]
  • A Model of Add-On Pricing
    NBER WORKING PAPER SERIES A MODEL OF ADD-ON PRICING Glenn Ellison Working Paper 9721 http://www.nber.org/papers/w9721 NATIONAL BUREAU OF ECONOMIC RESEARCH 1050 Massachusetts Avenue Cambridge, MA 02138 May 2003 I would like to thank the National Science Foundation for financial support. This paper grew out of joint work with Sara Fisher Ellison. Joshua Fischman provided excellent research assistance. Jonathan Levin and Steve Tadelis provided helpful feedback. The views expressed herein are those of the authors and not necessarily those of the National Bureau of Economic Research. ©2003 by Glenn Ellison. All rights reserved. Short sections of text not to exceed two paragraphs, may be quoted without explicit permission provided that full credit including © notice, is given to the source. A Model of Add-on Pricing Glenn Ellison NBER Working Paper No. 9721 May 2003 JEL No. L13, M30 ABSTRACT This paper examines a competitive model of add-on pricing, the practice of advertising low prices for one good in hopes of selling additional products (or a higher quality product) to consumers at a high price at the point of sale. The main conclusion is that add-on pricing softens price competition between firms and results in higher equilibrium profits. Glenn Ellison Department of Economics MIT 50 Memorial Drive, E52-274b Cambridge, MA 02142 and NBER [email protected] 1 Introduction In many businesses it is customary to advertise a base price for a product or service and to try to induce customers to buy additional “add-ons” at high prices at the point of sale.
    [Show full text]
  • International Conference Game Theory and Management
    The Tenth International Conference Game Theory and Management 07-09 July, 2016 Saint Petersburg, Russia Organized by Saint Petersburg State University and The International Society of Dynamic Games (Russian Chapter) The Conference is being held at Saint Petersburg State University Volkhovsky per., 3, St. Petersburg, Russia Program Committee Leon Petrosyan (Russia) - chair; Nikolay Zenkevich (Russia) - co-chair; Eitan Altman (France); Jesus Mario Bilbao (Spain); Irinel Dragan (USA); Gao Hongwei (China); Andrey Garnaev (Russia); Margarita Gladkova (Russia); Sergiu Hart (Israel); Steffen Jørgensen (Denmark); Ehud Kalai (USA); Andrea Di Liddo (Italy); Vladimir Mazalov (Russia); Shigeo Muto (Japan); Yaroslavna Pankratova (Russia); Artem Sedakov (Russia); Richard Staelin (USA); Krzysztof J. Szajowski (Poland); Anna Tur (Russia); Anna Veselova (Russia); Myrna Wooders (UK); David W.K. Yeung (HongKong); Georges Zaccour (Canada); Paul Zipkin (USA); Andrey Zyatchin (Russia) Program Graduate School of Management, St. Petersburg State University Volkhovsky per., 3, St. Petersburg, Russia Thursday, July 07 08:45 – 09:30 REGISTRATION 3rd floor 08:45 – 09:30 COFFEE Room 307 09:30 – 09:50 WELCOME ADDRESS Room 309 09.50 – 10:55 PLENARY TALK (1) Room 309 11.00 – 12:00 PLENARY TALK (2) Room 309 12:10 – 14:00 LUNCH University Center 13:30 – 14:00 COFFEE Room 307 14:00 – 16:30 PARALLEL SESSIONS (T1) Room 209, 410 16:30 – 16:50 COFFEE BREAK Room 307 16:50 – 19:00 PARALLEL SESSIONS (T2) Room 209, 410 19:00 – 22:00 WELCOME PARTY Room 309 Friday, July 08 09:30
    [Show full text]
  • Bayesian Search Under Dynamic Disaster Scenarios
    UNIVERSIDAD DEL NORTE Department of Industrial Engineering Barranquilla, Colombia BAYESIAN SEARCH UNDER DYNAMIC DISASTER SCENARIOS BUSQUEDA´ BAYESIANA BAJO ESCENARIOS DE DESASTRE DINAMICOS´ by Jos´eDaniel Betancourt Reyes A thesis submitted in partial fulfillment of the requirements for the Degree of Master of Science in Industrial Engineering Advisor: Gina Galindo, Ph.D. Juries: Dr. Rajan Batta State University of New York Dr. Yezid Donoso Universidad de Los Andes MSc. Santiago Nieto Universidad del Norte Barranquilla, January of 2017 Dedicated to God Who gave me the opportunity to live this wonderful experience and the strength to not give up. He is simply the greatest of my life. My lovely family Whose support and encouragement were exceptional aids to me through this path. My grandparents Vicente and Gloria, my mom and her husband Julia and Luis, my uncles Juan and Jorge, my aunt Zaida and her amazing children Sara and Josue, are all extraordinary people that I will always carry in my heart. My girlfriend Juliette With whom I have been so fortunate of sharing this stage of my life. Her company along this journey has filled my life with thousands of fantastic experiences which I treasure in my heart. ii Acknowledgments First of all, I want to thank God for giving me all the required resources to complete this thesis. I will always recognize that all I achieve is primarily thanks to Him. I feel so happy of been directed by Gina Galindo for the development of this research. Her advices, corrections and instructions were crucial for the satisfactory completion of this thesis.
    [Show full text]
  • Combinatorial Games: Selected Bibliography with a Succinct Gourmet Introduction
    Combinatorial Games: Selected Bibliography With A Succinct Gourmet Introduction Aviezri S. Fraenkel Department of Applied Mathematics and Computer Science Weizmann Institute of Science Rehovot 76100, Israel [email protected] http://www.wisdom.weizmann.ac.il/∼fraenkel 1 What are Combinatorial Games? Roughly speaking, the family of combinatorial games consists of two-player games with perfect information (no hidden information as in some card games), no chance moves (no dice) and outcome restricted to (lose, win), (tie, tie) and (draw, draw) for the two players who move alternately. Tie is an end position such as in tic-tac-toe, where no player wins, whereas draw is a dynamic tie: any position from which a player has a nonlosing move, but cannot force a win. Both the easy game of Nim and the seemingly difficult chess are examples of combinatorial games. And so is go. The shorter terminology game, games is used below to designate combinatorial games. 2 Why are Games Intriguing and Tempting? Amusing oneself with games may sound like a frivolous occupation. But the fact is that the bulk of interesting and natural mathematical problems that are hardest in complexity classes beyond NP ,suchasPspace, Exptime and Expspace, are two-player games; occasionally even one-player games (puzzles) or even zero-player games (Conway’s “Life”). Some of the reasons for the high complexity of two-player games are outlined in the next section. Before that we note that in addition to a natural appeal of the subject, there are applications or connections to various areas, including complexity, logic, graph and matroid theory, networks, error-correcting codes, surreal numbers, on-line algorithms and biology.
    [Show full text]
  • Who's Got Game (Theory)?
    Who’s Got Game (Theory)? By Erik Jackson Blankinship B.A. English Literature University of Maryland College Park, MD, 1997 M.Ed. Harvard University, School of Education Cambridge, MA, 1998 S.M. Media Arts and Sciences Massachusetts Institute of Technology Cambridge, MA, 2000 Submitted to the Program in Media Arts and Sciences, School of Architecture and Planning, in partial fulfillment of the requirements for the degree of DOCTOR OF PHILOSOPHY at the MASSACHUSETTS INSTITUTE OF TECHNOLOGY September 2005 © Massachusetts Institute of Technology, 2005 All Rights Reserved Author _________________________________________________________________ Erik Jackson Blankinship Program in Media Arts and Sciences September 2005 Certified by _____________________________________________________________ Walter Bender Executive Director & Senior Research Scientist MIT Media Laboratory Accepted by _____________________________________________________________ Dr. Andrew B. Lippman Chair, Departmental Committee on Graduate Students Program in Media Arts and Sciences Who’s Got Game (Theory)? By Erik Jackson Blankinship Submitted to the Program in Media Arts and Sciences, School of Architecture and Planning, in partial fulfillment of the requirements for the degree of Doctor of Philosophy in Media Arts and Sciences. September 2005 Abstract: Many players enjoy the challenge of outwitting computer opponents in strategy games. Devising strategies to defeat a computer opponent may enhance certain cognitive skills (e.g., analysis, evaluation, planning). This thesis takes a constructionist approach to gaming, hypothesizing that players may learn more about strategic planning by building their own computer opponents and then playing them to understand how their strategic theories play out in real experiments. I have developed a graphic toolkit for designing strategy games and computer opponents. The goal is to help students learn the underlying mathematical and computer science theories used to win these games.
    [Show full text]