statistics/src/main/java/cz/xelfi/quoridor/statistics/OpeningTree.java
author Jaroslav Tulach <jaroslav.tulach@apidesign.org>
Tue, 14 Sep 2010 08:56:13 +0200
changeset 264 d60370059c3c
parent 179 c5fbddc4c590
child 266 15fcdfc4cd4a
permissions -rw-r--r--
Changing headers to GPLv3
jaroslav@178
     1
/*
jaroslav@264
     2
 * Quoridor server and related libraries
jaroslav@264
     3
 * Copyright (C) 2009-2010 Martin Rexa
jaroslav@178
     4
 *
jaroslav@264
     5
 * This program is free software: you can redistribute it and/or modify
jaroslav@264
     6
 * it under the terms of the GNU General Public License as published by
jaroslav@264
     7
 * the Free Software Foundation, either version 3 of the License.
jaroslav@178
     8
 *
jaroslav@264
     9
 * This program is distributed in the hope that it will be useful,
jaroslav@264
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
jaroslav@264
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
jaroslav@264
    12
 * GNU General Public License for more details.
jaroslav@178
    13
 *
jaroslav@264
    14
 * You should have received a copy of the GNU General Public License
jaroslav@264
    15
 * along with this program. Look for COPYING file in the top folder.
jaroslav@264
    16
 * If not, see http://www.gnu.org/licenses/.
jaroslav@178
    17
 */
jaroslav@178
    18
package cz.xelfi.quoridor.statistics;
jaroslav@178
    19
jaroslav@178
    20
import cz.xelfi.quoridor.Board;
jaroslav@178
    21
import cz.xelfi.quoridor.Move;
jaroslav@178
    22
import cz.xelfi.quoridor.webidor.Game;
jaroslav@178
    23
import cz.xelfi.quoridor.webidor.CommentedMove;
jaroslav@178
    24
import cz.xelfi.quoridor.IllegalPositionException;
jaroslav@178
    25
import java.util.Map;
jaroslav@178
    26
import java.util.HashMap;
jaroslav@178
    27
jaroslav@178
    28
/**
jaroslav@178
    29
 *
jaroslav@178
    30
 * @author Martin Rexa
jaroslav@178
    31
 */
jaroslav@178
    32
public class OpeningTree {
jaroslav@178
    33
    Map<String, OpeningTreeNode> nodes = new HashMap<String, OpeningTreeNode>();
jaroslav@178
    34
    OpeningTreeNode root;
jaroslav@178
    35
jaroslav@178
    36
    public OpeningTree(){
jaroslav@178
    37
        root = new OpeningTreeNode("ROOT");
jaroslav@178
    38
        nodes.put("ROOT", root);
jaroslav@178
    39
    }
jaroslav@178
    40
jaroslav@178
    41
    public OpeningTreeNode getRoot(){
jaroslav@178
    42
        return root;
jaroslav@178
    43
    }
jaroslav@178
    44
jaroslav@178
    45
    public OpeningTreeNode getNode(String hashCode){
jaroslav@178
    46
        return nodes.get(hashCode);
jaroslav@178
    47
    }
jaroslav@178
    48
jaroslav@178
    49
    public void processGame(Game game) throws IllegalPositionException{
jaroslav@178
    50
        OpeningTreeNode node = root;
jaroslav@178
    51
        OpeningTreeNode parentNode;
jaroslav@178
    52
        OpeningTreeNode mirrorNode = root;
jaroslav@178
    53
        OpeningTreeNode mirrorParentNode;
jaroslav@178
    54
        Board board = Board.empty();
jaroslav@178
    55
        Board mirrorBoard = Board.empty();
jaroslav@178
    56
        root.addGame(game);
jaroslav@178
    57
        for(CommentedMove move: game.getMoves()){
jaroslav@178
    58
            if(!move.getMove().equals(Move.RESIGN)){
jaroslav@178
    59
                parentNode = node;
jaroslav@178
    60
                mirrorParentNode = mirrorNode;
jaroslav@178
    61
                board = board.apply(move.getMove());
jaroslav@178
    62
                mirrorBoard = mirrorBoard.apply(move.getMove().getMirrorMove());
jaroslav@179
    63
                String hashCode = board.getCode();
jaroslav@179
    64
                String mirrorHashCode = mirrorBoard.getCode();
jaroslav@178
    65
                node = nodes.get(hashCode);
jaroslav@178
    66
                if(node == null){
jaroslav@178
    67
                    node = new OpeningTreeNode(hashCode);
jaroslav@178
    68
                    nodes.put(hashCode, node);
jaroslav@178
    69
                }
jaroslav@178
    70
                node.addGame(game);
jaroslav@178
    71
                mirrorNode = nodes.get(mirrorHashCode);
jaroslav@178
    72
                if(mirrorHashCode.equals(hashCode)){
jaroslav@178
    73
                    if(mirrorNode == null){
jaroslav@178
    74
                        mirrorNode = node;
jaroslav@178
    75
                    }
jaroslav@178
    76
                }else{
jaroslav@178
    77
                    if(mirrorNode == null){
jaroslav@178
    78
                        mirrorNode = new OpeningTreeNode(mirrorHashCode);
jaroslav@178
    79
                        nodes.put(mirrorHashCode, mirrorNode);
jaroslav@178
    80
                    }
jaroslav@178
    81
                    mirrorNode.addGame(game);
jaroslav@178
    82
                }
jaroslav@178
    83
                if(parentNode != null)
jaroslav@178
    84
                    parentNode.addChild(move.getMove(),node);
jaroslav@178
    85
                if(mirrorParentNode != null){
jaroslav@178
    86
                    if(parentNode.equals(mirrorParentNode) && node.equals(mirrorNode))
jaroslav@178
    87
                        ;
jaroslav@178
    88
                    else
jaroslav@178
    89
                        mirrorParentNode.addChild(move.getMove().getMirrorMove(),mirrorNode);
jaroslav@178
    90
                }
jaroslav@178
    91
            }
jaroslav@178
    92
        }
jaroslav@178
    93
        node.addFinishedGame(game);
jaroslav@178
    94
        if(!node.equals(mirrorNode))
jaroslav@178
    95
            mirrorNode.addFinishedGame(game);
jaroslav@178
    96
    }
jaroslav@178
    97
jaroslav@178
    98
}