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


Python _jsonnet.evaluate_snippet方法代碼示例

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


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

示例1: render_jsonnet

# 需要導入模塊: import _jsonnet [as 別名]
# 或者: from _jsonnet import evaluate_snippet [as 別名]
def render_jsonnet(self, manifeststr, tla_codes=None):
        # @TODO(ant31): workaround until jsonnet compile on windows
        import _jsonnet
        try:
            json_str = _jsonnet.evaluate_snippet(  # pylint: disable=no-member
                "snippet", manifeststr, import_callback=self.import_callback,
                native_callbacks=filters.jsonnet_callbacks(), tla_codes=tla_codes)

        except RuntimeError as e:
            print("tla_codes: %s" % (str(tla_codes)))
            print("\n".join([
                "%s %s" % (i, line) for i, line in enumerate([
                    l for l in manifeststr.split("\n") if re.match(r"^ *#", l) is None])]))
            raise e
        return json.loads(json_str) 
開發者ID:app-registry,項目名稱:appr,代碼行數:17,代碼來源:render_jsonnet.py

示例2: jsonnet_loads

# 需要導入模塊: import _jsonnet [as 別名]
# 或者: from _jsonnet import evaluate_snippet [as 別名]
def jsonnet_loads(jsonnet_str, ext_vars=None):
    """
    Parses jsonnet string into json
    :param jsonnet_str: Jsonnet function
    :param ext_vars: External vars that can be passed as {'SOME_PARAM': 'AI2'} and used in the jsonnet as {name: std.extVar("SOME_PARAM")}
    :return:
    """
    json_parse = json.loads(_jsonnet.evaluate_snippet("snippet", jsonnet_str, ext_vars=ext_vars))

    return json_parse 
開發者ID:allenai,項目名稱:OpenBookQA,代碼行數:12,代碼來源:jsonnet.py

示例3: evaluate_snippet

# 需要導入模塊: import _jsonnet [as 別名]
# 或者: from _jsonnet import evaluate_snippet [as 別名]
def evaluate_snippet(_filename: str, expr: str, **_kwargs) -> str:
        logger.warning(
            "error loading _jsonnet (this is expected on Windows), treating snippet as plain json"
        )
        return expr 
開發者ID:allenai,項目名稱:allennlp,代碼行數:7,代碼來源:params.py

示例4: parse_overrides

# 需要導入模塊: import _jsonnet [as 別名]
# 或者: from _jsonnet import evaluate_snippet [as 別名]
def parse_overrides(serialized_overrides: str) -> Dict[str, Any]:
    if serialized_overrides:
        ext_vars = _environment_variables()

        return unflatten(json.loads(evaluate_snippet("", serialized_overrides, ext_vars=ext_vars)))
    else:
        return {} 
開發者ID:allenai,項目名稱:allennlp,代碼行數:9,代碼來源:params.py

示例5: test_regex_matches_are_initialized_correctly

# 需要導入模塊: import _jsonnet [as 別名]
# 或者: from _jsonnet import evaluate_snippet [as 別名]
def test_regex_matches_are_initialized_correctly(self):
        class Net(torch.nn.Module):
            def __init__(self):
                super().__init__()
                self.linear_1_with_funky_name = torch.nn.Linear(5, 10)
                self.linear_2 = torch.nn.Linear(10, 5)
                self.conv = torch.nn.Conv1d(5, 5, 5)

            def forward(self, inputs):
                pass

        # Make sure we handle regexes properly
        json_params = """{"initializer": {"regexes": [
        ["conv", {"type": "constant", "val": 5}],
        ["funky_na.*bi", {"type": "constant", "val": 7}]
        ]}}
        """
        params = Params(json.loads(_jsonnet.evaluate_snippet("", json_params)))
        initializers = InitializerApplicator.from_params(params=params["initializer"])
        model = Net()
        initializers(model)

        for parameter in model.conv.parameters():
            assert torch.equal(parameter.data, torch.ones(parameter.size()) * 5)

        parameter = model.linear_1_with_funky_name.bias
        assert torch.equal(parameter.data, torch.ones(parameter.size()) * 7) 
開發者ID:allenai,項目名稱:allennlp,代碼行數:29,代碼來源:initializers_test.py

示例6: test_regex_match_prevention_prevents_and_overrides

# 需要導入模塊: import _jsonnet [as 別名]
# 或者: from _jsonnet import evaluate_snippet [as 別名]
def test_regex_match_prevention_prevents_and_overrides(self):
        class Net(torch.nn.Module):
            def __init__(self):
                super().__init__()
                self.linear_1 = torch.nn.Linear(5, 10)
                self.linear_2 = torch.nn.Linear(10, 5)
                # typical actual usage: modules loaded from allenlp.model.load(..)
                self.linear_3_transfer = torch.nn.Linear(5, 10)
                self.linear_4_transfer = torch.nn.Linear(10, 5)
                self.pretrained_conv = torch.nn.Conv1d(5, 5, 5)

            def forward(self, inputs):
                pass

        json_params = """{"initializer": {
        "regexes": [
            [".*linear.*", {"type": "constant", "val": 10}],
            [".*conv.*", {"type": "constant", "val": 10}]
            ],
        "prevent_regexes": [".*_transfer.*", ".*pretrained.*"]
        }}
        """
        params = Params(json.loads(_jsonnet.evaluate_snippet("", json_params)))
        initializers = InitializerApplicator.from_params(params=params["initializer"])
        model = Net()
        initializers(model)

        for module in [model.linear_1, model.linear_2]:
            for parameter in module.parameters():
                assert torch.equal(parameter.data, torch.ones(parameter.size()) * 10)

        transfered_modules = [
            model.linear_3_transfer,
            model.linear_4_transfer,
            model.pretrained_conv,
        ]

        for module in transfered_modules:
            for parameter in module.parameters():
                assert not torch.equal(parameter.data, torch.ones(parameter.size()) * 10) 
開發者ID:allenai,項目名稱:allennlp,代碼行數:42,代碼來源:initializers_test.py

示例7: evaluate_snippet

# 需要導入模塊: import _jsonnet [as 別名]
# 或者: from _jsonnet import evaluate_snippet [as 別名]
def evaluate_snippet(self, *args, **kwargs):
    kwargs['import_callback'] = self._import_callback
    kwargs['native_callbacks'] = self._native_callbacks
    return json.loads(_jsonnet.evaluate_snippet(*args, **kwargs)) 
開發者ID:google,項目名稱:kasane,代碼行數:6,代碼來源:jsonnet.py

示例8: test_regex_matches_are_initialized_correctly

# 需要導入模塊: import _jsonnet [as 別名]
# 或者: from _jsonnet import evaluate_snippet [as 別名]
def test_regex_matches_are_initialized_correctly(self):
        class Net(torch.nn.Module):
            def __init__(self):
                super(Net, self).__init__()
                self.linear_1_with_funky_name = torch.nn.Linear(5, 10)
                self.linear_2 = torch.nn.Linear(10, 5)
                self.conv = torch.nn.Conv1d(5, 5, 5)

            def forward(self, inputs):  # pylint: disable=arguments-differ
                pass

        # Make sure we handle regexes properly
        json_params = u"""{"initializer": [
        ["conv", {"type": "constant", "val": 5}],
        ["funky_na.*bi", {"type": "constant", "val": 7}]
        ]}
        """
        params = Params(json.loads(_jsonnet.evaluate_snippet(u"", json_params)))
        initializers = InitializerApplicator.from_params(params[u'initializer'])
        model = Net()
        initializers(model)

        for parameter in model.conv.parameters():
            assert torch.equal(parameter.data, torch.ones(parameter.size()) * 5)

        parameter = model.linear_1_with_funky_name.bias
        assert torch.equal(parameter.data, torch.ones(parameter.size()) * 7) 
開發者ID:plasticityai,項目名稱:magnitude,代碼行數:29,代碼來源:initializers_test.py

示例9: test_regex_match_prevention_prevents_and_overrides

# 需要導入模塊: import _jsonnet [as 別名]
# 或者: from _jsonnet import evaluate_snippet [as 別名]
def test_regex_match_prevention_prevents_and_overrides(self):

        class Net(torch.nn.Module):
            def __init__(self):
                super(Net, self).__init__()
                self.linear_1 = torch.nn.Linear(5, 10)
                self.linear_2 = torch.nn.Linear(10, 5)
                # typical actual usage: modules loaded from allenlp.model.load(..)
                self.linear_3_transfer = torch.nn.Linear(5, 10)
                self.linear_4_transfer = torch.nn.Linear(10, 5)
                self.pretrained_conv = torch.nn.Conv1d(5, 5, 5)
            def forward(self, inputs):  # pylint: disable=arguments-differ
                pass

        json_params = u"""{"initializer": [
        [".*linear.*", {"type": "constant", "val": 10}],
        [".*conv.*", {"type": "constant", "val": 10}],
        [".*_transfer.*", "prevent"],
        [".*pretrained.*",{"type": "prevent"}]
        ]}
        """
        params = Params(json.loads(_jsonnet.evaluate_snippet(u"", json_params)))
        initializers = InitializerApplicator.from_params(params[u'initializer'])
        model = Net()
        initializers(model)

        for module in [model.linear_1, model.linear_2]:
            for parameter in module.parameters():
                assert torch.equal(parameter.data, torch.ones(parameter.size())*10)

        transfered_modules = [model.linear_3_transfer,
                              model.linear_4_transfer,
                              model.pretrained_conv]

        for module in transfered_modules:
            for parameter in module.parameters():
                assert not torch.equal(parameter.data, torch.ones(parameter.size())*10) 
開發者ID:plasticityai,項目名稱:magnitude,代碼行數:39,代碼來源:initializers_test.py

示例10: evaluate_snippet

# 需要導入模塊: import _jsonnet [as 別名]
# 或者: from _jsonnet import evaluate_snippet [as 別名]
def evaluate_snippet(_filename     , expr     , **_kwargs)       :
        logger.warning("_jsonnet not loaded, treating snippet as json")
        return expr 
開發者ID:plasticityai,項目名稱:magnitude,代碼行數:5,代碼來源:params.py

示例11: parse_overrides

# 需要導入模塊: import _jsonnet [as 別名]
# 或者: from _jsonnet import evaluate_snippet [as 別名]
def parse_overrides(serialized_overrides     )                  :
    if serialized_overrides:
        ext_vars = dict(os.environ)
        return unflatten(json.loads(evaluate_snippet(u"", serialized_overrides, ext_vars=ext_vars)))
    else:
        return {} 
開發者ID:plasticityai,項目名稱:magnitude,代碼行數:8,代碼來源:params.py

示例12: evaluate_snippet

# 需要導入模塊: import _jsonnet [as 別名]
# 或者: from _jsonnet import evaluate_snippet [as 別名]
def evaluate_snippet(_filename: str, expr: str, **_kwargs) -> str:
        logger.warning(f"_jsonnet not loaded, treating snippet as json")
        return expr 
開發者ID:uwdata,項目名稱:errudite,代碼行數:5,代碼來源:params.py

示例13: render_jsonnet

# 需要導入模塊: import _jsonnet [as 別名]
# 或者: from _jsonnet import evaluate_snippet [as 別名]
def render_jsonnet(self, manifeststr, tla_codes=None):
        try:
            json_str = _jsonnet.evaluate_snippet(
                "snippet", manifeststr, import_callback=self.import_callback,
                native_callbacks=filters.jsonnet_callbacks(), tla_codes=tla_codes)

        except RuntimeError as e:
            print("tla_codes: %s" % (str(tla_codes)))
            print("\n".join([
                "%s %s" % (i, line) for i, line in enumerate(
                    [l for l in manifeststr.split("\n") if re.match(r"^ *#", l) is None])
            ]))
            raise e
        return json.loads(json_str) 
開發者ID:coreos,項目名稱:kpm,代碼行數:16,代碼來源:render_jsonnet.py

示例14: get_run_func

# 需要導入模塊: import _jsonnet [as 別名]
# 或者: from _jsonnet import evaluate_snippet [as 別名]
def get_run_func(
        self,
        args: argparse.Namespace,
    ):
        if args is None:
            raise ValueError("No run arguments found for AllenNLP runner.")

        with open(args.base_config, "r") as parameter_f:
            parameter_file_snippet = parameter_f.read()

        def train_func(config, reporter):
            logger.debug(f"CUDA_VISIBLE_DEVICES: {os.environ['CUDA_VISIBLE_DEVICES']}")
            
            for package_name in getattr(args, "include_package", ()):
                import_module_and_submodules(package_name)

            search_space = HyperparameterSearch(**config)
            sample = search_space.sample()
            for k, v in sample.items():
                config[k] = str(v)
            
            params_dict = json.loads(
                _jsonnet.evaluate_snippet(
                    "config", parameter_file_snippet, tla_codes={}, ext_vars=config
                )
            )
            if args.num_gpus == 0:
                logger.warning(f"No GPU specified, using CPU.")
                params_dict["trainer"]["cuda_device"] = -1

            if args.cpus_per_trial > 0:
                torch.set_num_threads(args.cpus_per_trial)

            params = Params(params_dict)

            logger.debug(f"AllenNLP Configuration: {params.as_dict()}")

            train_model(params=params, serialization_dir="trial")

            reporter(done=True)
            
        return train_func 
開發者ID:allenai,項目名稱:allentune,代碼行數:44,代碼來源:allennlp_runner.py


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