Skip to content

Commit

Permalink
Fix DryRun unittest failed from test_standalon_executor.py (PaddlePad…
Browse files Browse the repository at this point in the history
…dle#35433)

* fix commit

* Open unittest

* fix unittest on Windows

* fix constructor
  • Loading branch information
Aurelius84 authored Sep 7, 2021
1 parent 1445103 commit 071e815
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 14 deletions.
3 changes: 2 additions & 1 deletion paddle/fluid/platform/device_event_cpu.h
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,8 @@ namespace platform {

struct CPUDeviceEventWrapper {
explicit CPUDeviceEventWrapper(const platform::Place& place,
unsigned int flag = 0) {
unsigned int flag = 0)
: status_(EventStatus::INITIALIZED) {
PADDLE_ENFORCE_EQ(
platform::is_cpu_place(place), true,
platform::errors::PreconditionNotMet(
Expand Down
Original file line number Diff line number Diff line change
@@ -1,8 +1,6 @@
file(GLOB TEST_INTERP_CASES RELATIVE "${CMAKE_CURRENT_SOURCE_DIR}" "test_*.py")
string(REPLACE ".py" "" TEST_INTERP_CASES "${TEST_INTERP_CASES}")

list(REMOVE_ITEM TEST_INTERP_CASES test_standalone_executor)

foreach(target ${TEST_INTERP_CASES})
py_test_modules(${target} MODULES ${target})
endforeach()
Original file line number Diff line number Diff line change
Expand Up @@ -25,22 +25,28 @@

class LinearTestCase(unittest.TestCase):
def setUp(self):
self.place = paddle.CUDAPlace(0) if core.is_compiled_with_cuda(
place = paddle.CUDAPlace(0) if core.is_compiled_with_cuda(
) else paddle.CPUPlace()
self.place = core.Place()
self.place.set_place(place)

def test_interp_base(self):
def build_program(self):
a = paddle.static.data(name="a", shape=[2, 2], dtype='float32')
b = paddle.ones([2, 2]) * 2
t = paddle.static.nn.fc(a, 2)
c = t + b

main_program = paddle.fluid.default_main_program()
startup_program = paddle.fluid.default_startup_program()
p = core.Place()
p.set_place(self.place)
standaloneexecutor = StandaloneExecutor(p, startup_program.desc,
main_program.desc, core.Scope())

return startup_program, main_program, c

return standaloneexecutor, c

def test_interp_base(self):
startup_program, main_program, c = self.build_program()
standaloneexecutor = StandaloneExecutor(
self.place, startup_program.desc, main_program.desc, core.Scope())
out = standaloneexecutor.run({
"a": np.ones(
[2, 2], dtype="float32") * 2
Expand All @@ -55,24 +61,35 @@ def test_interp_base(self):
out = standaloneexecutor.run({
"a": np.ones(
[2, 2], dtype="float32") * i
}, [a.name, c.name])
}, ['a', c.name])

def test_dry_run(self):
startup_program, main_program, c = self.build_program()
standaloneexecutor = StandaloneExecutor(
self.place, startup_program.desc, main_program.desc, core.Scope())
# test for cost_info
cost_info = standaloneexecutor.dry_run({
"a": np.ones(
[2, 2], dtype="float32") * i
[2, 2], dtype="float32")
})
self.check_cost_info(cost_info)

def check_cost_info(self, cost_info):
IS_WINDOWS = sys.platform.startswith('win')

if core.is_compiled_with_cuda():
# self.assertEqual(cost_info.host_memory_bytes(), 16)
self.assertGreater(cost_info.device_memory_bytes(), 0)
# input `a` is on CPU, 16 bytes
self.assertEqual(cost_info.host_memory_bytes(), 16)
# # w,bias,b, out, memory block is at least 256 bytes on Linux
gt = 16 * 4 if IS_WINDOWS else 256 * 4
self.assertGreater(cost_info.device_memory_bytes(), gt)
self.assertGreaterEqual(cost_info.device_total_memory_bytes(),
cost_info.device_memory_bytes())
else:
self.assertGreater(cost_info.host_memory_bytes(), 0)
# x(16 bytes), w(16 bytes), bias(8 bytes), b(16 bytes), out(16 bytes)
self.assertGreaterEqual(cost_info.host_memory_bytes(), 72)
self.assertEqual(cost_info.device_memory_bytes(), 0)
self.assertGreaterEqual(cost_info.device_total_memory_bytes(), 0)


class MultiStreamModelTestCase(unittest.TestCase):
Expand Down

0 comments on commit 071e815

Please sign in to comment.