Wednesday, June 5, 2019

Tic Tac Toe Game Computer Science Essay

Tic Tac toenail Game Com dumbfounder Science Es opineMost of the query nowadays is focused towards problems t lid deal with complexity or atomic number 18 influenced by some kind of random events. Interesting ab step to the fore these problems is that if they are deterministic, then a solution is expected to exist, at least a theoretical one. These problems are often inspired by backs, such(prenominal) as mathematical haltings (ex. Tic-Tac-Toe, Chess). On the separate hand the point of randomness involved in these problems increases the difficulty of prediction on the contingent solution, or in some situations outcome. This is thy, thither are plastered methods of operations devised, that in put to work give some supplementary information to a decision maker. In most of the skids, the prob tycoon distribution of an even which in any casek mail randomly, it is possible to be affected by prior events.These risques are often compete by at least 2 histrions (or m any(pre nominal)), out of which the one is called an opponent. The decisions at separately step are made by the last prod of the opponent. The operations inquiry in these halts is called wager theory.The vital Tic-Tac-Toe risque consists of 2 imposters, X and O, who take turns marking the spaces in a 3-3 grid (Crun-inley, 1993 Gardner, 1998).The plot of land commonly begins with the X doer, and the player who impart manage to place third respective marks (in any direction, i.e. in a horizontal, vertical, or diagonal row) follows the gimpy. This basic recitation of the enlivened is rather simple, what allows the grainy to be used as a useful tool in combinatorial lame theory, as well as a branch of artificial intelligence that deals with the searching of bet steers (Beck, 2008). Using game theory t here(predicate) are few approaches that can be undertakenThe games solution is resulted by dominance when the game has only 1 keen-sighted outline for each playerMinimax st rategies decide a stable solution useful if the opponent makes the wrong playMinimax strategies do not decide a stable solution using a probability distributionEven though, game theory researches are made on the possible playing strategies, they faculty not be employed in real life when playing a game, becauseThere might be too many strategies to enumerate (this procedure is simply too large to be estimated).Players are not always rational.There might be more than two players.Real-life games are not zero-sum games.This get off deals with developing a Tic-Tac-Toe to be used on a diligent twist. The following chapter discusses the Aims and Objectives of the game. Chapter 3 talks about a background research on this game, starting with a review on animate Tic-Tac-Toe games, which in turn leads to discussion about the existing models of this game and the proposed model of this work.Finally, Chapter 3 concludes with a technology research c at a timentrated towards deep brown 2 Pl atform, micro Edition (J2ME). Chapters 4 and 5 describe the system requirement analysis and intention on this work, and chapters 6, 7, and 8 include explanation on the implementation, testing and evaluation. And finally, chapter 9 concludes this work.2. Aim and ObjectivesThe aim of this project is to develop a Tic-Tac-Toe game for rambling device. The game is supposed to consist of two part, one a single player game (a player against a system), and the separate a multi-player game (two players on their mobile devices, playing against each other). In order to accomplish these, the following objectives were defined.Single player gameThe player should play Tic-Tac-Toe game on his mobile device.The player should ware option to edit his name.The player ordain start the game of choosing his symbol as X or O.If player 1 selected X then O has to be automatically allotted to the mobile device as a second player, and vice versa.The player has an option to remove the small game grid out of 4 small tick-tack-toe games.If player X marked horizontally or vertically or diagonally of his symbol X in a row, then player X won that small match.Finally, which player won the maximum small games will be declared as winner of the tic-tac-toe game.Multi-player gameUsing Bluetooth as communication channel the two players should play Tic-Tac-Toe game from dissimilar mobiles.Players should get options to edit his name.Once twain players connected together, then scratch player will start the game of choosing his symbol as X or O.If player 1 selected X then O has to be automatically allotted to player 2.Then primary(prenominal) game grid has to display in both mobiles.Player2 have option to demand the small game grid out of 4 small tic-tac-toe games.After grid selection both players will play tic-tac-toe game in that small grid.If player X marked horizontally or vertically or diagonally of his symbol X in a row, then player X won that small match.That small grid is marked with X and Player1 awarded 1 point, screen should zoom out and have to display self-coloured main game grid and now player who won the introductory game will have the choice to choose on which grid have to be select to play remaining game.This process will be repeated until the whole Four (4) small games grids marked with X, or O, or T.Finally which player won the maximum small games will be declared as winner of the tic-tac-toe game. then game shutdowns.3. Background ResearchIn this section the Tic-Tac-Toe game will be discussed in details. At the outset, the basic rules of the game are going to be covered. Then, thither will be a review on existing Tic-Tac-Toe games, which in turn will lead to discussion about the existing models of this game and the proposed model of this work. Finally, this section is going to be concluded with a technology research concentrated towards chocolate 2 Platform, Micro Edition (J2ME).3.1 sanctioned Rules of Tic-Tac-Toe gameThe basic Tic-Tac-Toe game consists of two players, X and O, who take turns marking the spaces in a 3-3 grid (Crowley, 1993 Gardner, 1998). The game usually starts with the X player, and the player who will manage to place trinity respective marks wins the game. The marks can be placed in any direction, i.e. in a horizontal, vertical, or diagonal row. This basic version of the game is rather simple and very often leads to draw. This simplicity allows the game to be used as a useful tool in combinatorial game theory, as well as a branch of artificial intelligence that deals with the searching of game trees (Beck, 2008).The Roman Empire is known to have established the beginnings of the earliest known variant of tic-tac-toe. It originated around the inaugural century BC (Crowley, 1993). At that time, the game was called Terni Lapilli. kind of of having any offspring of pieces, each player only had three. The game was played by moving them around to empty spaces to keep playing. However, according to C laudia Zaslavskys book, the game Tic Tac Toe is originating from ancient Egypt (Zaslavsky, 1982).Chess and Tic-Tac-Toe are one of the most famous games to which the moves are not left to chances, rather than pure mathematics and logical reasoning. In these games, a player wins by achieving a kind human body offshoot, like for instance checkmate in chess, and 3-in-a-row in a basic Tic-Tac-Toe game in 33 wag (Gardner, 1998). Thus, the question which can be posed at this point is How a player can come across a attractive configuration first? Even though on that point isnt a general theorem to answer this question, there might be a well-known strategy take argument that can give a partial answer about when a player can achieve a winning configuration first (Beck, 2008).In order to find a winning strategy, in theory all the paths could be explored. However, in practice this is not easy because the total number of strategies can be calculated a double exponential function of the size of the board. For example, a 3-dimensional 5-5-5 version of Tic-Tac-Toe, has about 3125 positions. This is because each one of the 53 cells has 3 optionsMarked by the first player,Marked by the second player, orUnmarked.Thus the backtracking on a graph of 3125 vertices takes at least 3125 steps. This is the main reason that this 3-dimensional 5-5-5 version of Tic-Tac-Toe remains unsolved up to date. Moreover, only two explicit winning strategies are known from in the whole class ofn-n- -n = nd Tic-Tac-Toe games. This is the 33 version and it is characterized with an easy winning strategy, and the 43 version that in turn has an extremely complicated winning strategy.In order to play a perfect tic-tac-toe game, i.e. a win or a draw, the player can play given they move consistent with the uppermost possible moves. This is presented in the following table (Crowley, 1993)WinIf the player has two in a row, play the third to get three in a row.BlockIf the opponent has two in a row, p lay the third to block them.ForkCreate an opportunity where you can win in two ways.Block opponents forkOption 1 Create two in a row to force the opponent into defending, as bulky as it doesnt result in them creating a fork or winning. For example, if X has a coigne, O has the bear on, and X has the opposite nook as well, O mustiness not play a corner in order to win. (Playing a corner in this scenario bring into beings a fork for X to win.)Option 2 If there is a configuration where the opponent can fork, block that fork.CenterPlay the center.Opposite cornerIf the opponent is in the corner, play the opposite corner.Empty cornerPlay in a corner square.Empty sidePlay in a middle square on any of the 4 sides.Initially, the player that starts first gets the X and has 3 probable positions to mark in his turn. Even though it seems that there are 9 possible positions, as there are 9 squares in the grid, by rotating the board, this is not the case. It can be observed thatEvery corner mark is tactically equal to every other corner mark, andEvery edge mark is tactically equal to every other edge mark.There are therefore only three possible first marks corner, edge, or center. The first player could win (or make a draw) from any of these starting marks. It can be withal observed that playing a corner would give the opponent the smallest choice of squares. This is a priggish strategy as could be played to negate losing (Zaslavsky, 1982) .The second player can be identified as O and this player must respond to Xs opening mark. However, this should be done in such a way as to avoid Player X to win. It can be stated that Player O must always respond with (Zaslavsky, 1982)To a corner opening with a center mark,To a center opening with a corner mark andTo an edge opening either with a center mark, a corner mark undermentioned to the X, or an edge mark opposite the X.Any different play would allow X to compel a win. After every next turn of player X, the player O shou ld follow the above list. This way the player O can achieve a draw (or a win if the player X makes a weak play).3.2 Existing Tic-Tac-Toe gamesAs many other games like three mens morris, nine mens morris, pente, gomoku, Qubic, Connect Four, Quarto and Gobblet, Tic-Tac-Toe also has the same goal, i.e. a player wins if he is the first one to get n-in-a-row. Basically, if a generalization is to be appendd, it can be concluded that all the different formations of Tic-Tac-Toe can be represented as nd-games, which are accordingly played on a d-dimensional boards with edge n (Zaslavsky, 1982). As it was discussed in the previous section as well, the original Tic-Tac-Toe game is actually a 32-game.There are many waverings, discussed as follows (Patashnik, 1980 Gardner, 1998 Beck, 2008).A slightly different version of a Tic-Tac-Toe game is the 33-game, played on a 3x3x3 board (Patashnik, 1980).It can be noted that this game gives good opportunities to the player that plays first, so he coul d achieve an easy win by playing at the center with his first move. Similarly, playing on a 4x4x4 board also gives the first remunerator better chances for wining.More complex version of a Tic-Tac-Toe game is playing it on a board with higher(prenominal) dimensional space. 4 dimensional, i.e. 3-3-3-3 board is one of the most commonly played Tic-Tac-Toe (Patashnik, 1980).In this version there are 2 possible aims. One of them is to position elements through all of the board, therefrom the player that has more rows of 3 totally than the other one is the winner of the game. And the other strategy is to include 4 players, in which case the winner is the payer that will get a row of 3 first.Another version is the misre tic-tac-toe game. It is played according to its conventional rules, such as in this innovation 33 game would be a draw, whereas the winner is the player that will get n in a row (Berlekamp, 1982).Quite a new game is the Tic Tac Tactic variation of tic-tac-toe (Berlekamp , 1982). This game is played on a 3 dimensional curved board, and the here each player tries to roll a ball at least half the way, as it would then drop on a grid that has 9 positions (33 grid). This way the players should make a row of 3 in order to gain a ball. The winner is the player that will have won the first 5 balls. In order to roll their balls precisely, they could use a device that helps into changing a balls trajectory.Yet another version is the nine board tic-tac-toe. In this game, there are in affection 9 boards, arranged as 33 grids, and the first payer can start on any of them by his choice (Gardner, 1998). The following moves are supposed to be places on the board chosen by the first player. Once this board gets full and there is no more space left, the next move can be again on any of the boards left, by the choice of the player. The winner is the one that will achieve 3 in a row. However, having 9 boards gives the game yet another spirit than the usual tic-tac-toe game, as the players can have an opening, middle and end of their game.Similar to the nine board tic-tac-toe game is the super tic-tac-toe game (Beck, 2008).The difference in this variation is that this game does not end once a player makes 3 in a row in one of the 9 boards. As an alternative, the position of that board is marked on a new 33 grid, and the winner is the one that will make 3 in row there.Tic-Tac-Chess is an interesting combination of games, as it involved playing a chess game, as well as a tic-tac-toe game at the same time (Beck, 2008). In this variation, once a player captures a piece from the challenger on the chess game, makes a move on the tic-tac-toe game (even if the challenger has not placed anything on the tic-tac-toe game yet). And of course, the winner is the player that will make 3 in a row on the tic-tac-toe game first.A game that in essence is an isomorphic to a tic-tac-toe game, even though it seems as a completely different game, is described as follow s (Beck, 2008). Basically, there are 2 players that should say a number between 1 and 9, without repeating the previously said numbers. The winner is the player that will first make a sum of 15. This game is isomorphic to a tic-tac-toe, because if those numbers are to be placed on a 33 magic grid, then it will be exactly as playing a tic-tac-toe game, because a straight line is formed only if the sum of the numbers is 15. This information is mostly useful in programme variations of a tic-tac-toe game.Another different variation again employs numbers from 1 to 9 (Gardner, 1998). These are to be placed on a 33 grid, but must be held with an order of priority defined by the players. Then the players play a tic-tac-toe game, filling the grid by the precedence defined beforehand.Check Lines is a very old variation of tic-tac-toe game, invented in the 1970s by Tri-ang Toys Games. In this game the board is actually any geometrical pattern that consists of 12 lines.There are 11 holes in t otal, distributed in a way that each line has 3 holes. At this point, each player is given 5 coins, and each player on their turn should place a coin on the board. The winner is the one that will have first completed 2 lines. Because the players have only 5 coins, this means that they have to complete intersecting lines. If none of the players have won after placing their 5 coins, then they will continue playing by replacing the position of the coins, on the remaining spaces, with the rule that it must be done only on an adjacent hole.Very similar game to the tic-tac-toe game is the Toss Across game. Here, the players are given bags with beans and they are throwing them on a big board for marking the squares.Star Tic Tac Toe is another popular variation of tic-tac-toe. This game is played with checkers like movable pieces. It has a 33 board, thus a player has 3 pieces accordingly.The participants keep on replacing pieces into the spaces which are left empty in the board, until one t he players wins this actually adds some more dynamism in the game. Moreover, the players have supplementary star shaped pieces, which can be swapped.Similar category of games as the previous bullet, are the Mojo, Mojo Too and Mojo tic-tac-toe games. In these variation the payers also pieces and pawn(s) onto empty positions until there is a winner.Moreover, there are many plants based on the tic-tac-toe game, as wellHollywood Squares is a show with 9 celebrities, which fill the cells of the tic-tac-toe grid.Tic-Tac-Dough is a show on which the players put symbols up on the board. This is achieved by answering queries in a variety of categories.In Beat the Teacher competitors respond to questions to win a turn, again on a tic-tac-toe grid.On The Price Is Right, there is a pricing game called Secret X, in which players must estimate prices to win Xes, in order to place them on a blank board. They must position the Xes as to provide speculation of the location on the secret X. This is in turn hidden in the middle line of the board, forming a tic-tac-toe line across.The fictional game Dni game of Gemedet, has an aim to place 6 balls in a row to a 9x9x9 grid (Gardner, 1998).The fictional game Squid-Tac-Toad, has an aim to place 4 or 5 balls in a row to a 44 or 55 grid, accordingly (Gardner, 1998).A more simplistic variation of this game is having the rules as of the Y formations to count as a win. This is rather simple, because all the scenarios basically forming some kind of a Y configuration.Quantum tic tac toe is yet another variation in which the participants are positioning a quantum superposition of numbers on a tic tac toe board (Gardner, 1998).A bigger grid (for example 1010) tic-tac-toe games also exist. In a 1010 grid the winner should place 5 in a row. The more the grids there are on a board, the larger complexity of the game is.Another similar game named Go-moku, originating from Vietnam, also has the strategy for a player to get 5 in a row in order to win the game (Gardner, 1998). The players put Xs and Os, but in order to try blocking each other, in this variation they should also try to create changes for wining. Another difference is that the board has no limit, thus the game is played until there is a winner.Three Mens Morris and Nine Mens Morris are also variations, in which there is a limiting on the number of pieces in order for a move to be allowed (Gardner, 1998).Finally, the last variation of the tic-tac-toe game, employs the delivery eat, an, laf, it, line, if, lot, on and foe. In this game, the winner is the one that will select 3 words that start with the same letter. If the game was places on a tic-tac-toe grid, it would mean 3 words in order to form a line (three in a row line).3.3 Proposed modelThere are quite a few algorithmic rules hat can be used for creating the Tic-Tac-Toes game strategy. The most popular ones are the semantic algorithms and the lexical algorithms. For this project, a lexical algorithm was utilized. The model of the tic-tac-toe game described in this work contains 2 different game strategies. Basically, the one strategy is the Single Player game where a player plays against a system. The other strategy involves Multiple Player environment, and it is being played by a player versus another player.In order to analyze this game, a decision tree might be used. Moreover, for the analyzing part it should be expunged that both the players in the Multiple Player environment, and the single player in the Single Player game, are in essence experienced. This means that the result of a game can be foreseen after the first move from each participant (again assuming that there are no mistakes). Let us represent with 1 if the player that has the X wins and with -1 if the player that has the O wins. The following figure represents the decision tree after the first move from each participant. As it was already discussed in section 3.1 Basic Rules of Tic-Tac-Toe game, the tic-tac-toe game is symmetric and therefore it is sufficient to strike only the squares 1, 2 and 3 for the first player (see the figure below). The rest of the moves are symmetric and will be presented. So, following this reasoning, the first player has the positions 1, 2 and 3 available, and the second player has the remaining two positions.The figure above presents an expansion, so called an long form. It demonstrates that even in the simplest scenario the decision tree can be quite large. For example, if the first two moves were to be presented, this would be impossible to be demonstrated on a single page.Similarly to this discussion, the strategic form of the game can be presented by a different model, i.e. as a matrix. In order to demonstrate this approach, it should be assumed that the players choose one strategy and they strictly follow it when their turn comes. Of course, each strategy should represent all the paths of action and in every possible situation.At the beginning, let us as sume that there is a strategy that the first player uses for their first move, and another strategy for the first move of the second player. This logic would create some rules like the following (Zaslavsky, 1982)For the first player select one of the nine squares on the game board.For the second player Select one of the nine squares on the game board. If the first player already uses the selected square, then put an O in square 3, 5, 7, or 9 if an X is in square 1 (center) put an O in cell 1 if an X is in cell j.These rules are examples of complete strategies, and these can be selected by the payers before the beginning of the game, and thus followed with their first moves. The strategic form of a tic-tac-toe game is presented on the figure below. It should be noted that the entries in the table below are in essence the values of the game. They hold values for every possible selection of strategies.Each tic-tac-toe game that can be actually presented in an extensive form would have an equivalent strategic form similar to the one shown in the table presented above. Moreover, this table is also equivalent to the matrix established previously. The effect matrix in cooperation with the descriptions of the strategies comprises the model for the two-person tic-tac-toe game.3.4 Comparison of Proposed model with Existing ModelsThe semantic algorithm is yet another approach towards the tic-tac-toe game. The semantic algorithm is in essence a learning algorithm, and it might be structured in the following way. It might have as initial information the ability to recognizing the 3 states of a game lost, won or a draw. The algorithm in this case would play the X, and it will play against another algorithm, i.e. the O. As presently as a game is finishes, the information if the game was won or lost is stored. Moreover, the moves are presented with the smaller letters x and o accordingly. A possible structure of stored information could be the following line x5 o3 x9 o4 x1 won. The first move is always randomly selected. So, given that the algorithm played 7 (x7), and the opponent played 6 (o6), the algorithm will search for previous games that are most similar to x7 o6. If such a case is found, then the following rules applyIf the game found was a win, than the algorithm will try to reproduce the move. If the position is not available, it will play randomly.If the game found was a loss, the algorithm will try to correct the move, by not placing an element in the same position as in the lost game.This is repeated until there is a winner. Moreover, if a game end with a draw, it is not saved in the database.Comparing this algorithm with a lexical algorithm such as our proposed model, it might be noted that the semantic algorithm usually plays very badly at the begging. But, after a certain number of games, the learning curve of the algorithm becomes better. On the other hand, our proposed model behaves well during all the stages of the game.3.5 Technolo gy Research (j2me)Being quite different from other programming languages, Java does both compiling and interlingual rendition when it comes to process code.As it can be seen from the photo above, the source code (i.e. the .java files) is initially translated by the compiler. This gives an output of an intermediate language, called Java bytecode (i.e. the .class files). The bytecode is then ready to be executed (or in other words, interpreted) within a particular virtual mainframe, known as the JVM (Java Virtual Machine) (Hayun, 2009 Knudsen, 2008). This is in essence a simulated processor that executes all the bytecode commands. The Java Virtual Machine is the basic components that give to Java the feature to compatibility. This is simply because it represents a reliable layer between bytecode and the concrete gondola instructions, translated at runtime.Over the years, the Java language has undergone many changes and development. J2SE (Java 2 Standard Edition) had its first editi on targeting GUIs, applets, and other basic and rather simple operations. Recently, the language was extend with the Java suite known as J2EE (Java 2 Enterprise Edition). This edition is based for server side development, and includes tools for database access, messaging, content rendering, inter-process communications, and transaction control (Hayun, 2009 Li, 2005). J2ME (Java 2 Micro Edition) came into existence as to cover the needs for applications targeting mobile devices. As it can be seen from this short overview, there are versions of Java to suit different environments from the initiative development tools intend for use in servers, to the micro systems. An important thing to note at this point is that the separation between platforms is not just absolute (Knudsen, 2008). Many times these are not a simple line than can be drawn. In order to demonstrate this, it might be explained that Java 2 Micro Edition development sometimes requires the use of Java 2 Enterprise Editi on and Java 2 Micro Edition. This is the case with multiplayer games for instance, so and Java 2 Micro Edition is used for the client side, but Java 2 Enterprise Edition is used for the server side of the application/game. Moreover, different Java editions target different hardware configurations. Similarly, there are 3 virtual cable cars to be used for the different environments (Li, 2005). For example, Hotspot VM is a negligence virtual machine suitable for a executing the full-scale edition of JavaHotspot. JavaHotspot is a newer type of virtual machine competent of vigorously optimizing a big(p) deal of executed code (called as hotspots) during the runtime (Li, 2005). Other versions of virtual machine are the Compact Virtual Machine (CVM) and Kilobyte Virtual Machine (KVM). These are in essence smaller virtual machine implementations. They are targeted to run within the restrictions of the limited resources found on the micro devices (these will be discussed ulterior in this section, as well).The requirement of having another version (like the Java 2 Micro Edition) for the mobile devices came because these devices do not have sufficient recourses to run Java 2 Standard Edition, since J2SE was clearly way excessively large to fit on even the bigger micro devices. However, the question was imposed initially was which features should be left out from the J2SE, so to be minimized in a smaller edition. Also, having great diversity of different devices, it would not have been a nice decision to restrict all the J2ME applications to the lowest compatible hardware configuration (Li, 2005 Kochnev, 2003). Moreover, this solution would not have been practical as well, because it would incorrectly neglect the capabilities of the higher end devices. The final solution is comprehended through a mixture of J2ME configurations and profiles (Krikke, 2005). It represented a revised Java architecture, which actually offers for the leaving out of parts of the platform, at the same time as addition to device and category precise components. Along these lines, the configuration would identify the abilities of a Java platform intended for use on a sequence of analogous hardware. Possible components that can be removed are the following (Kochnev, 2003 Lefevre, 2005)Java language mechanismsmallest amount hardware necessities, such as the memory, screen size, and processor power for the family of devicesintegrated Java librariesBy utilizing this approach, there are actually 2 preset configurations for mobile devices one for somewhat restricted devices such as PDAs and Set-Top-Boxes (for instance the digital TV receivers), and another one for devices such as pagers and mobile phones.These two configurations are (Kochnev, 2003 Krikke, 2005 Lefevre, 2005)CDC (Connected Device Configuration)CLDC (Connected, Limited Device Configuration)All of these configurations are to be reviewed as follows. On the other hand, a good example of java profiles is the UI (User Interface) for mobile phones. For example, the J2ME configuration CLDC that wraps this type of device, keeps out the typical Java UI libraries (AWT and Swing). The devices do not have the ability of presenting anything derived from these libraries in any case. This is due to the fact that their screens are just too small. Thus, there is no point to slaughtering valued space on them. The solution was to generate an innovative User Interface, fitting to the exact necessities of the poor mobiles LCD display. The eventful LCD UI is built-in in the CLDC profile. This targets MIDs (Mobile Information Devices), for this reason the name is MIDP.The CDC is built for bigger devices such as digital TV set-top-boxes and PDAs. These are devices characteristically with many space of memory. The CDC is the bigger brother of the J2ME configurations. It encloses a single profile (the Foundation profile) as well as a high performance virtual machine (known as the Compact Virtual Machine CVM). This Java language implementation, as well as the API, practically has all the influence of J2SE.Unluckily, the CDC is not accessible on the platform for the most micro-game players (the mobile phones).The CLDC is especially targeted to micro devices, like mobile phones. It fundamentally defines a standard, which in turn is used by all the device manufact

No comments:

Post a Comment

Note: Only a member of this blog may post a comment.