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


Python actions.FUNCTIONS屬性代碼示例

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


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

示例1: main

# 需要導入模塊: from pysc2.lib import actions [as 別名]
# 或者: from pysc2.lib.actions import FUNCTIONS [as 別名]
def main(unused_argv):
  """Print the valid actions."""
  feats = features.Features(
      # Actually irrelevant whether it's feature or rgb size.
      features.AgentInterfaceFormat(
          feature_dimensions=features.Dimensions(
              screen=FLAGS.screen_size,
              minimap=FLAGS.minimap_size)))
  action_spec = feats.action_spec()
  flattened = 0
  count = 0
  for func in action_spec.functions:
    if FLAGS.hide_specific and actions.FUNCTIONS[func.id].general_id != 0:
      continue
    count += 1
    act_flat = 1
    for arg in func.args:
      for size in arg.sizes:
        act_flat *= size
    flattened += act_flat
    print(func.str(True))
  print("Total base actions:", count)
  print("Total possible actions (flattened):", flattened) 
開發者ID:deepmind,項目名稱:pysc2,代碼行數:25,代碼來源:valid_actions.py

示例2: raw_unit_command

# 需要導入模塊: from pysc2.lib import actions [as 別名]
# 或者: from pysc2.lib.actions import FUNCTIONS [as 別名]
def raw_unit_command(self, ability_id, unit_tags, pos=None, target=None):
    """Send a raw unit command."""
    if isinstance(ability_id, str):
      ability_id = actions.FUNCTIONS[ability_id].ability_id
    action = sc_pb.Action()
    cmd = action.action_raw.unit_command
    cmd.ability_id = ability_id
    if isinstance(unit_tags, (list, tuple)):
      cmd.unit_tags.extend(unit_tags)
    else:
      cmd.unit_tags.append(unit_tags)
    if pos:
      cmd.target_world_space_pos.x = pos[0]
      cmd.target_world_space_pos.y = pos[1]
    elif target:
      cmd.target_unit_tag = target
    response = self._controller.act(action)
    for result in response.result:
      assert result == sc_error.Success 
開發者ID:deepmind,項目名稱:pysc2,代碼行數:21,代碼來源:check_apm.py

示例3: raw_unit_command

# 需要導入模塊: from pysc2.lib import actions [as 別名]
# 或者: from pysc2.lib.actions import FUNCTIONS [as 別名]
def raw_unit_command(self, player, ability_id, unit_tags, pos=None,
                       target=None):
    """Issue a raw unit command."""
    if isinstance(ability_id, str):
      ability_id = actions.FUNCTIONS[ability_id].ability_id
    action = sc_pb.Action()
    cmd = action.action_raw.unit_command
    cmd.ability_id = ability_id
    if isinstance(unit_tags, (list, tuple)):
      cmd.unit_tags.extend(unit_tags)
    else:
      cmd.unit_tags.append(unit_tags)
    if pos:
      cmd.target_world_space_pos.x = pos[0]
      cmd.target_world_space_pos.y = pos[1]
    elif target:
      cmd.target_unit_tag = target
    response = self._controllers[player].act(action)
    for result in response.result:
      self.assertEqual(result, sc_error.Success) 
開發者ID:deepmind,項目名稱:pysc2,代碼行數:22,代碼來源:utils.py

示例4: _init_valid_functions

# 需要導入模塊: from pysc2.lib import actions [as 別名]
# 或者: from pysc2.lib.actions import FUNCTIONS [as 別名]
def _init_valid_functions(action_dimensions):
  """Initialize ValidFunctions and set up the callbacks."""
  sizes = {
      "screen": tuple(int(i) for i in action_dimensions.screen),
      "screen2": tuple(int(i) for i in action_dimensions.screen),
      "minimap": tuple(int(i) for i in action_dimensions.minimap),
  }

  types = actions.Arguments(*[
      actions.ArgumentType.spec(t.id, t.name, sizes.get(t.name, t.sizes))
      for t in actions.TYPES])

  functions = actions.Functions([
      actions.Function.spec(f.id, f.name, tuple(types[t.id] for t in f.args))
      for f in actions.FUNCTIONS])

  return actions.ValidActions(types, functions) 
開發者ID:deepmind,項目名稱:pysc2,代碼行數:19,代碼來源:features.py

示例5: step

# 需要導入模塊: from pysc2.lib import actions [as 別名]
# 或者: from pysc2.lib.actions import FUNCTIONS [as 別名]
def step(self, obs):
    super(DefeatRoaches, self).step(obs)
    if FUNCTIONS.Attack_screen.id in obs.observation.available_actions:
      player_relative = obs.observation.feature_screen.player_relative
      roaches = _xy_locs(player_relative == _PLAYER_ENEMY)
      if not roaches:
        return FUNCTIONS.no_op()

      # Find the roach with max y coord.
      target = roaches[numpy.argmax(numpy.array(roaches)[:, 1])]
      return FUNCTIONS.Attack_screen("now", target)

    if FUNCTIONS.select_army.id in obs.observation.available_actions:
      return FUNCTIONS.select_army("select")

    return FUNCTIONS.no_op() 
開發者ID:deepmind,項目名稱:pysc2,代碼行數:18,代碼來源:scripted_agent.py

示例6: fl_action

# 需要導入模塊: from pysc2.lib import actions [as 別名]
# 或者: from pysc2.lib.actions import FUNCTIONS [as 別名]
def fl_action(self, obs, act, *args):
    return self._controller.act(self._features.transform_action(
        obs.observation, actions.FUNCTIONS[act](*args), skip_available=True)) 
開發者ID:deepmind,項目名稱:pysc2,代碼行數:5,代碼來源:check_apm.py

示例7: test_general_actions

# 需要導入模塊: from pysc2.lib import actions [as 別名]
# 或者: from pysc2.lib.actions import FUNCTIONS [as 別名]
def test_general_actions(self):
    run_config = run_configs.get()
    with run_config.start(want_rgb=False) as controller:
      map_inst = maps.get("Simple64")
      create = sc_pb.RequestCreateGame(
          realtime=False, disable_fog=False,
          local_map=sc_pb.LocalMap(map_path=map_inst.path,
                                   map_data=map_inst.data(run_config)))
      create.player_setup.add(type=sc_pb.Participant)
      create.player_setup.add(
          type=sc_pb.Computer, race=sc_common.Random, difficulty=sc_pb.VeryEasy)
      join = sc_pb.RequestJoinGame(race=sc_common.Random,
                                   options=sc_pb.InterfaceOptions(raw=True))
      controller.create_game(create)
      controller.join_game(join)

      abilities = controller.data().abilities

      errors = []

      for f in actions.FUNCTIONS:
        if abilities[f.ability_id].remaps_to_ability_id != f.general_id:
          errors.append("FUNCTIONS %s/%s has abilitiy %s, general %s, expected "
                        "general %s" % (
                            f.id, f.name, f.ability_id, f.general_id,
                            abilities[f.ability_id].remaps_to_ability_id))

      for f in actions.RAW_FUNCTIONS:
        if abilities[f.ability_id].remaps_to_ability_id != f.general_id:
          errors.append(
              "RAW_FUNCTIONS %s/%s has abilitiy %s, general %s, expected "
              "general %s" % (
                  f.id, f.name, f.ability_id, f.general_id,
                  abilities[f.ability_id].remaps_to_ability_id))

      print("\n".join(errors))
      self.assertFalse(errors) 
開發者ID:deepmind,項目名稱:pysc2,代碼行數:39,代碼來源:general_actions_test.py

示例8: select

# 需要導入模塊: from pysc2.lib import actions [as 別名]
# 或者: from pysc2.lib.actions import FUNCTIONS [as 別名]
def select(func, unit_type):
  return lambda o: actions.FUNCTIONS.select_point('select', func(unit_type, o)) 
開發者ID:deepmind,項目名稱:pysc2,代碼行數:4,代碼來源:replay_obs_test.py

示例9: assertAvail

# 需要導入模塊: from pysc2.lib import actions [as 別名]
# 或者: from pysc2.lib.actions import FUNCTIONS [as 別名]
def assertAvail(self, expected):
    actual = self.features.available_actions(self.obs)
    actual_names = {actions.FUNCTIONS[i].name for i in actual}
    self.assertEqual(actual_names, set(expected) | self.always_expected) 
開發者ID:deepmind,項目名稱:pysc2,代碼行數:6,代碼來源:features_test.py

示例10: testValidFunctionsAreConsistent

# 需要導入模塊: from pysc2.lib import actions [as 別名]
# 或者: from pysc2.lib.actions import FUNCTIONS [as 別名]
def testValidFunctionsAreConsistent(self):
    feats = features.Features(features.AgentInterfaceFormat(
        feature_dimensions=RECTANGULAR_DIMENSIONS))

    valid_funcs = feats.action_spec()
    for func_def in valid_funcs.functions:
      func = actions.FUNCTIONS[func_def.id]
      self.assertEqual(func_def.id, func.id)
      self.assertEqual(func_def.name, func.name)
      self.assertEqual(len(func_def.args), len(func.args))  # pylint: disable=g-generic-assert 
開發者ID:deepmind,項目名稱:pysc2,代碼行數:12,代碼來源:features_test.py

示例11: testSpecificActionsAreReversible

# 需要導入模塊: from pysc2.lib import actions [as 別名]
# 或者: from pysc2.lib.actions import FUNCTIONS [as 別名]
def testSpecificActionsAreReversible(self):
    """Test that the `transform_action` and `reverse_action` are inverses."""
    feats = features.Features(features.AgentInterfaceFormat(
        feature_dimensions=RECTANGULAR_DIMENSIONS,
        hide_specific_actions=False))
    action_spec = feats.action_spec()

    for func_def in action_spec.functions:
      for _ in range(10):
        func_call = self.gen_random_function_call(action_spec, func_def.id)

        sc2_action = feats.transform_action(
            None, func_call, skip_available=True)
        func_call2 = feats.reverse_action(sc2_action)
        sc2_action2 = feats.transform_action(
            None, func_call2, skip_available=True)
        if func_def.id == actions.FUNCTIONS.select_rect.id:
          # Need to check this one manually since the same rect can be
          # defined in multiple ways.
          def rect(a):
            return point.Rect(point.Point(*a[1]).floor(),
                              point.Point(*a[2]).floor())

          self.assertEqual(func_call.function, func_call2.function)
          self.assertEqual(len(func_call.arguments), len(func_call2.arguments))  # pylint: disable=g-generic-assert
          self.assertEqual(func_call.arguments[0], func_call2.arguments[0])
          self.assertEqual(rect(func_call.arguments),
                           rect(func_call2.arguments))
        else:
          self.assertEqual(func_call, func_call2, msg=sc2_action)
        self.assertEqual(sc2_action, sc2_action2) 
開發者ID:deepmind,項目名稱:pysc2,代碼行數:33,代碼來源:features_test.py

示例12: testCanPickleFunctionCall

# 需要導入模塊: from pysc2.lib import actions [as 別名]
# 或者: from pysc2.lib.actions import FUNCTIONS [as 別名]
def testCanPickleFunctionCall(self):
    func = actions.FUNCTIONS.select_point("select", [1, 2])
    self.assertEqual(func, pickle.loads(pickle.dumps(func))) 
開發者ID:deepmind,項目名稱:pysc2,代碼行數:5,代碼來源:features_test.py

示例13: step

# 需要導入模塊: from pysc2.lib import actions [as 別名]
# 或者: from pysc2.lib.actions import FUNCTIONS [as 別名]
def step(self, action):
        """Apply actions, step the world forward, and return observations"""        
        if FLAGS.verbose:
            print('{} AVAILABLE ACTIONS.'.format(len(self.observation_cur.available_actions)))
            # Uncomment to print individual available actions.
            # for a in observation_cur.available_actions:
            #     print(actions.FUNCTIONS[a])

        chosen_func_id = np.random.choice(self.observation_cur.available_actions)

        if FLAGS.verbose:
            chosen_action = actions.FUNCTIONS[chosen_func_id]  
            print('Chosen action: ', chosen_func_id, '~~', chosen_action)
        
        # Uncomment to print "template" args of chosen action:
        # allargs = self.action_spec.functions[chosen_func_id].args
        # for arg in allargs:
        #     print(arg); print('arg sizes ', arg.sizes)
        
        chosen_args = [[np.random.randint(0, size) for size in arg.sizes] for arg in self.action_spec.functions[chosen_func_id].args]

        if FLAGS.verbose:
            print('Chosen args: ', chosen_args)

        action = actions.FunctionCall(chosen_func_id, chosen_args)
        obs = super(Environment, self).step([action])
        self.observation_cur = obs[0].observation
        r = obs[0].reward
        done = obs[0].step_type == pysc2environment.StepType.LAST
        self.episode_reward += r
        time.sleep(FLAGS.pause)
        return obs, r, done, {} 
開發者ID:SoyGema,項目名稱:Startcraft_pysc2_minigames,代碼行數:34,代碼來源:DQN_Agent_LSTM.py

示例14: step

# 需要導入模塊: from pysc2.lib import actions [as 別名]
# 或者: from pysc2.lib.actions import FUNCTIONS [as 別名]
def step(self, obs):
    super(SentryForceField, self).step(obs)
    if _FORCE_FIELD in obs.observation["available_actions"]:
      player_relative = obs.observation.feature_screen.player_relative
      hydralisk_y, hydralisk_x = (player_relative == _PLAYER_HOSTILE).nonzero()
      if not hydralisk_y.any():
        return FUNCTIONS.no_op()
      index = numpy.argmax(hydralisk_y)
      target = [hydralisk_x[index], hydralisk_y[index]]
      return FUNCTIONS.Effect_ForceField_screen("now", target)
    elif _SELECT_ARMY in obs.observation["available_actions"]:
      return FUNCTIONS.select_army("select")
    else:
      return FUNCTIONS.no_op() 
開發者ID:SoyGema,項目名稱:Startcraft_pysc2_minigames,代碼行數:16,代碼來源:scripted_agent.py

示例15: __init__

# 需要導入模塊: from pysc2.lib import actions [as 別名]
# 或者: from pysc2.lib.actions import FUNCTIONS [as 別名]
def __init__(
        self,
        map_name='MoveToBeacon',
        render=False,
        reset_done=True,
        max_ep_len=None,
        spatial_dim=16,
        step_mul=8,
        obs_features=None,
        action_ids=ACTIONS_MINIGAMES
    ):
        super().__init__(map_name, render, reset_done, max_ep_len)

        self.step_mul = step_mul
        self.spatial_dim = spatial_dim
        self._env = None

        # sensible action set for all minigames
        if not action_ids or action_ids in [ACTIONS_MINIGAMES, ACTIONS_MINIGAMES_ALL]:
            action_ids = [0, 1, 2, 3, 4, 6, 7, 12, 13, 42, 44, 50, 91, 183, 234, 309, 331, 332, 333, 334, 451, 452, 490]

        # some additional actions for minigames (not necessary to solve)
        if action_ids == ACTIONS_MINIGAMES_ALL:
            action_ids += [11, 71, 72, 73, 74, 79, 140, 168, 239, 261, 264, 269, 274, 318, 335, 336, 453, 477]

        # full action space, including outdated / unusable to current race / usable only in certain cases
        if action_ids == ACTIONS_ALL:
            action_ids = [f.id for f in actions.FUNCTIONS]

        # by default use majority of obs features, except for some that are unnecessary for minigames
        # e.g. race-specific like creep and shields or redundant like player_id
        if not obs_features:
            obs_features = {
                'screen': ['player_relative', 'selected', 'visibility_map', 'unit_hit_points_ratio', 'unit_density'],
                'minimap': ['player_relative', 'selected', 'visibility_map', 'camera'],
                # available actions should always be present and in first position
                'non-spatial': ['available_actions', 'player']}

        self.act_wrapper = ActionWrapper(spatial_dim, action_ids)
        self.obs_wrapper = ObservationWrapper(obs_features, action_ids) 
開發者ID:inoryy,項目名稱:reaver,代碼行數:42,代碼來源:sc2.py


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