當前位置: 首頁>>代碼示例>>Python>>正文


Python sgf_wrapper.replay_sgf方法代碼示例

本文整理匯總了Python中sgf_wrapper.replay_sgf方法的典型用法代碼示例。如果您正苦於以下問題:Python sgf_wrapper.replay_sgf方法的具體用法?Python sgf_wrapper.replay_sgf怎麽用?Python sgf_wrapper.replay_sgf使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在sgf_wrapper的用法示例。


在下文中一共展示了sgf_wrapper.replay_sgf方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: analyze_symmetries

# 需要導入模塊: import sgf_wrapper [as 別名]
# 或者: from sgf_wrapper import replay_sgf [as 別名]
def analyze_symmetries(sgf_file, load_file):
    with open(sgf_file) as f:
        sgf_contents = f.read()
    iterator = sgf_wrapper.replay_sgf(sgf_contents)
    net = dual_net.DualNetwork(load_file)
    for i, pwc in enumerate(iterator):
        if i < 200:
            continue
        feats = features.extract_features(pwc.position)
        variants = [symmetries.apply_symmetry_feat(s, feats) for s in symmetries.SYMMETRIES]
        values = net.sess.run(
            net.inference_output['value_output'],
            feed_dict={net.inference_input['pos_tensor']: variants})
        mean = np.mean(values)
        stdev = np.std(values)
        all_vals = sorted(zip(values, symmetries.SYMMETRIES))

        print("{:3d} {:.3f} +/- {:.3f} min {:.3f} {} max {:.3f} {}".format(
            i, mean, stdev, *all_vals[0], *all_vals[-1])) 
開發者ID:mlperf,項目名稱:training_results_v0.5,代碼行數:21,代碼來源:inspect_game.py

示例2: test_make_sgf

# 需要導入模塊: import sgf_wrapper [as 別名]
# 或者: from sgf_wrapper import replay_sgf [as 別名]
def test_make_sgf(self):
    all_pwcs = list(replay_sgf(utils_test.BOARD_SIZE, NO_HANDICAP_SGF))
    second_last_position, last_move, _ = all_pwcs[-1]
    last_position = second_last_position.play_move(last_move)

    back_to_sgf = make_sgf(
        utils_test.BOARD_SIZE,
        last_position.recent,
        last_position.score(),
        komi=last_position.komi,
    )
    reconstructed_positions = list(replay_sgf(
        utils_test.BOARD_SIZE, back_to_sgf))
    second_last_position2, last_move2, _ = reconstructed_positions[-1]
    last_position2 = second_last_position2.play_move(last_move2)

    self.assertEqualPositions(last_position, last_position2) 
開發者ID:itsamitgoel,項目名稱:Gun-Detector,代碼行數:19,代碼來源:sgf_wrapper_test.py

示例3: cmd_loadsgf

# 需要導入模塊: import sgf_wrapper [as 別名]
# 或者: from sgf_wrapper import replay_sgf [as 別名]
def cmd_loadsgf(self, filename: str, movenum=0):
        try:
            with open(filename, 'r') as f:
                contents = f.read()
        except:
            raise ValueError("Unreadable file: " + filename)

        # Clear the board before replaying sgf
        # TODO: should this use the sgfs komi?
        self._player.initialize_game(go.Position())

        # This is kinda bad, because replay_sgf is already calling
        # 'play move' on its internal position objects, but we really
        # want to advance the engine along with us rather than try to
        # push in some finished Position object.
        for idx, p in enumerate(sgf_wrapper.replay_sgf(contents)):
            dbg("playing #", idx, p.next_move)
            self._player.play_move(p.next_move)
            if movenum and idx == movenum:
                break 
開發者ID:mlperf,項目名稱:training,代碼行數:22,代碼來源:gtp_cmd_handlers.py

示例4: initialize_game

# 需要導入模塊: import sgf_wrapper [as 別名]
# 或者: from sgf_wrapper import replay_sgf [as 別名]
def initialize_game(sgf_file, load_file, move=1):
    with open(sgf_file) as f:
        sgf_contents = f.read()
    iterator = sgf_wrapper.replay_sgf(sgf_contents)
    for i in range(move):
        position_w_context = next(iterator)
    player = strategies.MCTSPlayerMixin(dual_net.DualNetwork(load_file))
    player.initialize_game(position_w_context.position)
    return player 
開發者ID:mlperf,項目名稱:training_results_v0.5,代碼行數:11,代碼來源:inspect_game.py

示例5: parse_sgf

# 需要導入模塊: import sgf_wrapper [as 別名]
# 或者: from sgf_wrapper import replay_sgf [as 別名]
def parse_sgf(sgf_path):
  with open(sgf_path) as f:
    sgf_contents = f.read()

  collection = sgf.parse(sgf_contents)
  game = collection.children[0]
  props = game.root.properties
  assert int(sgf_prop(props.get('GM', ['1']))) == 1, "Not a Go SGF!"

  result = utils.parse_game_result(sgf_prop(props.get('RE')))

  positions, moves = zip(*[(p.position, p.next_move) for p in sgf_wrapper.replay_sgf(sgf_contents)])
  return positions, moves, result, props 
開發者ID:mlperf,項目名稱:training_results_v0.5,代碼行數:15,代碼來源:training_curve.py

示例6: predict_move

# 需要導入模塊: import sgf_wrapper [as 別名]
# 或者: from sgf_wrapper import replay_sgf [as 別名]
def predict_move(filename, network, tries_per_move=1, readouts=1000):
  replay = []

  if filename not in REPLAY_CACHE:
    with open(filename) as f:
        text = f.read()
        for position_w_context in sgf_wrapper.replay_sgf(text):
          replay.append(position_w_context)
    REPLAY_CACHE[filename] = replay
  replay = REPLAY_CACHE[filename]


  black_net = network

  player = MCTSPlayer(
        black_net, verbosity=0, two_player_mode=True, num_parallel=4)

  tried = 0
  correct = 0
  move_ratings = []
  for position_w_context in replay:
      if position_w_context.next_move is None:
          continue

      num_correct = 0
      for i in range(tries_per_move):
        move, correct_move, is_correct = predict_position(position_w_context, player, readouts=readouts)
        if is_correct:
          num_correct += 1
      move_ratings.append(num_correct * 1.0 / tries_per_move)
      print('RATING: ', sum(move_ratings) / len(move_ratings))
  return move_ratings 
開發者ID:mlperf,項目名稱:training_results_v0.5,代碼行數:34,代碼來源:predict_games.py

示例7: cmd_loadsgf

# 需要導入模塊: import sgf_wrapper [as 別名]
# 或者: from sgf_wrapper import replay_sgf [as 別名]
def cmd_loadsgf(self, arguments):
        args = arguments.split()
        if len(args) == 2:
            file_, movenum = args
            movenum = int(movenum)
            print("movenum =", movenum, file=sys.stderr)
        else:
            file_ = args[0]
            movenum = None

        try:
            with open(file_, 'r') as f:
                contents = f.read()
        except:
            raise ValueError("Unreadable file: " + file_)

        try:
            # This is kinda bad, because replay_sgf is already calling
            # 'play move' on its internal position objects, but we really
            # want to advance the engine along with us rather than try to
            # push in some finished Position object.
            for idx, p in enumerate(sgf_wrapper.replay_sgf(contents)):
                print("playing #", idx, p.next_move, file=sys.stderr)
                self._game.play_move(p.next_move)
                if movenum and idx == movenum:
                    break
        except:
            raise

# Should this class blatantly reach into the game_obj and frob its tree?  Sure!
# What are private members?  Python lets you do *anything!* 
開發者ID:mlperf,項目名稱:training_results_v0.5,代碼行數:33,代碼來源:gtp_extensions.py

示例8: test_make_sgf

# 需要導入模塊: import sgf_wrapper [as 別名]
# 或者: from sgf_wrapper import replay_sgf [as 別名]
def test_make_sgf(self):
        all_pwcs = list(replay_sgf(NO_HANDICAP_SGF))
        second_last_position, last_move, _ = all_pwcs[-1]
        last_position = second_last_position.play_move(last_move)

        back_to_sgf = make_sgf(
            last_position.recent,
            last_position.score(),
            komi=last_position.komi,
        )
        reconstructed_positions = list(replay_sgf(back_to_sgf))
        second_last_position2, last_move2, _ = reconstructed_positions[-1]
        last_position2 = second_last_position2.play_move(last_move2)

        self.assertEqualPositions(last_position, last_position2) 
開發者ID:mlperf,項目名稱:training_results_v0.5,代碼行數:17,代碼來源:test_sgf_wrapper.py

示例9: test_sgf_props

# 需要導入模塊: import sgf_wrapper [as 別名]
# 或者: from sgf_wrapper import replay_sgf [as 別名]
def test_sgf_props(self):
        sgf_replayer = replay_sgf(CHINESE_HANDICAP_SGF)
        initial = next(sgf_replayer)
        self.assertEqual(initial.result, go.BLACK)
        self.assertEqual(initial.position.komi, 5.5) 
開發者ID:mlperf,項目名稱:training_results_v0.5,代碼行數:7,代碼來源:test_sgf_wrapper.py

示例10: test_replay_position

# 需要導入模塊: import sgf_wrapper [as 別名]
# 或者: from sgf_wrapper import replay_sgf [as 別名]
def test_replay_position(self):
        sgf_positions = list(sgf_wrapper.replay_sgf(NO_HANDICAP_SGF))
        initial = sgf_positions[0]
        self.assertEqual(initial.result, go.WHITE)

        final = sgf_positions[-1].position.play_move(
            sgf_positions[-1].next_move)

        # sanity check to ensure we're working with the right position
        final_board = test_utils.load_board('''
            .OXX.....
            O.OX.X...
            .OOX.....
            OOOOXXXXX
            XOXXOXOOO
            XOOXOO.O.
            XOXXXOOXO
            XXX.XOXXO
            X..XOO.O.
        ''')
        expected_final_position = go.Position(
            final_board,
            n=62,
            komi=6.5,
            caps=(3, 2),
            ko=None,
            recent=tuple(),
            to_play=go.BLACK
        )
        self.assertEqualPositions(expected_final_position, final)
        self.assertEqual(final.n, len(final.recent))

        replayed_positions = list(go.replay_position(final, 1))
        for sgf_pos, replay_pos in zip(sgf_positions, replayed_positions):
            self.assertEqualPositions(sgf_pos.position, replay_pos.position) 
開發者ID:mlperf,項目名稱:training_results_v0.5,代碼行數:37,代碼來源:test_go.py

示例11: test_make_sgf

# 需要導入模塊: import sgf_wrapper [as 別名]
# 或者: from sgf_wrapper import replay_sgf [as 別名]
def test_make_sgf(self):
        all_positions = list(replay_sgf(NO_HANDICAP_SGF))
        last_position, _, metadata = all_positions[-1]
        back_to_sgf = make_sgf(
            last_position.recent,
            last_position.score(),
            boardsize=metadata.board_size,
            komi=last_position.komi,
        )
        reconstructed_positions = list(replay_sgf(back_to_sgf))
        last_position2, _, _ = reconstructed_positions[-1]

        self.assertEqualPositions(last_position, last_position2) 
開發者ID:llSourcell,項目名稱:alphago_demo,代碼行數:15,代碼來源:test_sgf_wrapper.py

示例12: test_sgf_props

# 需要導入模塊: import sgf_wrapper [as 別名]
# 或者: from sgf_wrapper import replay_sgf [as 別名]
def test_sgf_props(self):
        sgf_replayer = replay_sgf(CHINESE_HANDICAP_SGF)
        initial = next(sgf_replayer)
        self.assertEqual(initial.metadata.result, 'B+39.50')
        self.assertEqual(initial.metadata.board_size, 9)
        self.assertEqual(initial.position.komi, 5.5) 
開發者ID:llSourcell,項目名稱:alphago_demo,代碼行數:8,代碼來源:test_sgf_wrapper.py

示例13: test_replay_position

# 需要導入模塊: import sgf_wrapper [as 別名]
# 或者: from sgf_wrapper import replay_sgf [as 別名]
def test_replay_position(self):
        sgf_positions = list(replay_sgf(NO_HANDICAP_SGF))
        initial = sgf_positions[0]
        self.assertEqual(initial.metadata.result, 'W+1.5')
        self.assertEqual(initial.metadata.board_size, 9)
        self.assertEqual(initial.position.komi, 6.5)

        final = sgf_positions[-1].position

        # sanity check to ensure we're working with the right position
        final_board = load_board('''
            .OXX.....
            O.OX.X...
            .OOX.....
            OOOOXXXXX
            XOXXOXOOO
            XOOXOO.O.
            XOXXXOOXO
            XXX.XOXXO
            X..XOO.O.
        ''')
        expected_final_position = go.Position(
            final_board,
            n=62,
            komi=6.5,
            caps=(3, 2),
            ko=None,
            recent=tuple(),
            to_play=go.BLACK
        )
        self.assertEqualPositions(expected_final_position, final)
        self.assertEqual(final.n, len(final.recent))

        replayed_positions = list(replay_position(final))
        for sgf_pos, replay_pos in zip(sgf_positions, replayed_positions):
            self.assertEqualPositions(sgf_pos.position, replay_pos.position) 
開發者ID:llSourcell,項目名稱:alphago_demo,代碼行數:38,代碼來源:test_sgf_wrapper.py

示例14: test_replay_position

# 需要導入模塊: import sgf_wrapper [as 別名]
# 或者: from sgf_wrapper import replay_sgf [as 別名]
def test_replay_position(self):
    sgf_positions = list(sgf_wrapper.replay_sgf(
        utils_test.BOARD_SIZE, NO_HANDICAP_SGF))
    initial = sgf_positions[0]
    self.assertEqual(initial.result, go.WHITE)

    final = sgf_positions[-1].position.play_move(
        sgf_positions[-1].next_move)

    # sanity check to ensure we're working with the right position
    final_board = utils_test.load_board('''
        .OXX.....
        O.OX.X...
        .OOX.....
        OOOOXXXXX
        XOXXOXOOO
        XOOXOO.O.
        XOXXXOOXO
        XXX.XOXXO
        X..XOO.O.
      ''')
    expected_final_position = go.Position(
        utils_test.BOARD_SIZE,
        final_board,
        n=62,
        komi=6.5,
        caps=(3, 2),
        ko=None,
        recent=tuple(),
        to_play=go.BLACK
    )
    self.assertEqualPositions(expected_final_position, final)
    self.assertEqual(final.n, len(final.recent))

    replayed_positions = list(go.replay_position(
        utils_test.BOARD_SIZE, final, 1))
    for sgf_pos, replay_pos in zip(sgf_positions, replayed_positions):
      self.assertEqualPositions(sgf_pos.position, replay_pos.position) 
開發者ID:itsamitgoel,項目名稱:Gun-Detector,代碼行數:40,代碼來源:go_test.py

示例15: cmd_loadsgf

# 需要導入模塊: import sgf_wrapper [as 別名]
# 或者: from sgf_wrapper import replay_sgf [as 別名]
def cmd_loadsgf(self, arguments):
    args = arguments.split()
    if len(args) == 2:
      file_, movenum = args
      movenum = int(movenum)
      print('movenum =', movenum, file=sys.stderr)
    else:
      file_ = args[0]
      movenum = None

    try:
      with open(file_, 'r') as f:
        contents = f.read()
    except:
      raise ValueError('Unreadable file: ' + file_)

    try:
      # This is kinda bad, because replay_sgf is already calling
      # 'play move' on its internal position objects, but we really
      # want to advance the engine along with us rather than try to
      # push in some finished Position object.
      for idx, p in enumerate(sgf_wrapper.replay_sgf(contents)):
        print('playing #', idx, p.next_move, file=sys.stderr)
        self._game.play_move(p.next_move)
        if movenum and idx == movenum:
          break
    except:
      raise 
開發者ID:itsamitgoel,項目名稱:Gun-Detector,代碼行數:30,代碼來源:gtp_extensions.py


注:本文中的sgf_wrapper.replay_sgf方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。