diff --git a/python/paddle/fluid/framework.py b/python/paddle/fluid/framework.py index 6f6d94a23dc194ac99aee171299b5ffd80b4e5f3..45f5f6ea87e406da07e04194f76ecde84db7bd75 100644 --- a/python/paddle/fluid/framework.py +++ b/python/paddle/fluid/framework.py @@ -1735,7 +1735,7 @@ class Program(object): return self.__is_optimized @_is_optimized.setter - def set__is_optimized(self, target): + def _is_optimized(self, target): self.__is_optimized = target @property @@ -1756,7 +1756,7 @@ class Program(object): return self._current_role @op_role.setter - def set_op_role(self, role): + def op_role(self, role): self._current_role = role @property diff --git a/python/paddle/fluid/io.py b/python/paddle/fluid/io.py index 836b28a5611a73e2f74248f7f1deb70b07a9ee6d..3ae7fddaace8555a8d2998d69698e4d2038494eb 100644 --- a/python/paddle/fluid/io.py +++ b/python/paddle/fluid/io.py @@ -931,7 +931,7 @@ def save_inference_model(dirname, if main_program is None: main_program = default_main_program() - if main_program.is_optimized: + if main_program._is_optimized: warnings.warn( "save_inference_model must put before you call memory_optimize. \ the memory_optimize will modify the original program, \ diff --git a/python/paddle/fluid/parallel_executor.py b/python/paddle/fluid/parallel_executor.py index a07ff6ac69ca20c8c68659a67606076ce8cdf027..c55bc46cc9e132c9be0b4fea25c13b789c4e6819 100644 --- a/python/paddle/fluid/parallel_executor.py +++ b/python/paddle/fluid/parallel_executor.py @@ -135,6 +135,7 @@ class ParallelExecutor(object): # step3: init build_strategy if build_strategy is None: build_strategy = BuildStrategy() + build_strategy.enable_inplace = False if main._is_optimized else True build_strategy.num_trainers = num_trainers build_strategy.trainer_id = trainer_id # FIXME(zcd): is_distribution_ is a temporary field, because in pserver mode, diff --git a/python/paddle/fluid/tests/unittests/test_inference_model_io.py b/python/paddle/fluid/tests/unittests/test_inference_model_io.py index 0b1836ce4dc2faf6909258cfad9df75d9cf3435a..d260afcd623610f0fb27a6c62f831e3d38798ae1 100644 --- a/python/paddle/fluid/tests/unittests/test_inference_model_io.py +++ b/python/paddle/fluid/tests/unittests/test_inference_model_io.py @@ -108,9 +108,9 @@ class TestSaveInferenceModel(unittest.TestCase): exe.run(init_program, feed={}, fetch_list=[]) memory_optimize(program, print_log=True) - self.assertRaises(RuntimeError, - save_inference_model(MODEL_DIR, ["x", "y"], - [avg_cost], exe, program)) + self.assertEqual(program._is_optimized, True) + # will print warning message + save_inference_model(MODEL_DIR, ["x", "y"], [avg_cost], exe, program) if __name__ == '__main__': diff --git a/python/paddle/fluid/transpiler/memory_optimization_transpiler.py b/python/paddle/fluid/transpiler/memory_optimization_transpiler.py index 2e4dbfcdc956cbe42573b196c4a885f9038f9e31..fc8dafbe976533fb8b3601a5a937074ed084a66f 100755 --- a/python/paddle/fluid/transpiler/memory_optimization_transpiler.py +++ b/python/paddle/fluid/transpiler/memory_optimization_transpiler.py @@ -540,7 +540,7 @@ def memory_optimize(input_program, if skip_opt_set is not None: skip_opt_set = set(map(to_name_str, skip_opt_set)) cfgs = _get_cfgs(input_program) - input_program.is_optimized = True + input_program._is_optimized = True for cfg in cfgs: cfg.memory_optimize(skip_opt_set=skip_opt_set, level=level) @@ -560,6 +560,6 @@ def release_memory(input_program, skip_opt_set=None): None """ cfgs = _get_cfgs(input_program) - input_program.is_optimized = True + input_program._is_optimized = True for cfg in cfgs: cfg.release_memory(skip_opt_set=skip_opt_set)