mirror of
https://github.com/saymrwulf/pytorch.git
synced 2026-05-15 21:00:47 +00:00
Summary: There is a module called `2to3` which you can target for future specifically to remove these, the directory of `caffe2` has the most redundant imports: ```2to3 -f future -w caffe2``` Pull Request resolved: https://github.com/pytorch/pytorch/pull/45033 Reviewed By: seemethere Differential Revision: D23808648 Pulled By: bugra fbshipit-source-id: 38971900f0fe43ab44a9168e57f2307580d36a38
84 lines
3.3 KiB
Python
84 lines
3.3 KiB
Python
|
|
|
|
|
|
|
|
|
|
from caffe2.python import core, workspace
|
|
from caffe2.python.test_util import TestCase
|
|
import tempfile
|
|
|
|
|
|
class TestCounterOps(TestCase):
|
|
|
|
def test_counter_ops(self):
|
|
workspace.RunOperatorOnce(core.CreateOperator(
|
|
'CreateCounter', [], ['c'], init_count=1))
|
|
|
|
workspace.RunOperatorOnce(core.CreateOperator(
|
|
'CountDown', ['c'], ['t1'])) # 1 -> 0
|
|
assert not workspace.FetchBlob('t1')
|
|
|
|
workspace.RunOperatorOnce(core.CreateOperator(
|
|
'CountDown', ['c'], ['t2'])) # 0 -> -1
|
|
assert workspace.FetchBlob('t2')
|
|
|
|
workspace.RunOperatorOnce(core.CreateOperator(
|
|
'CountUp', ['c'], ['t21'])) # -1 -> 0
|
|
assert workspace.FetchBlob('t21') == -1
|
|
workspace.RunOperatorOnce(core.CreateOperator(
|
|
'RetrieveCount', ['c'], ['t22']))
|
|
assert workspace.FetchBlob('t22') == 0
|
|
|
|
workspace.RunOperatorOnce(core.CreateOperator(
|
|
'ResetCounter', ['c'], [], init_count=1)) # -> 1
|
|
workspace.RunOperatorOnce(core.CreateOperator(
|
|
'CountDown', ['c'], ['t3'])) # 1 -> 0
|
|
assert not workspace.FetchBlob('t3')
|
|
|
|
workspace.RunOperatorOnce(core.CreateOperator(
|
|
'ResetCounter', ['c'], ['t31'], init_count=5)) # 0 -> 5
|
|
assert workspace.FetchBlob('t31') == 0
|
|
workspace.RunOperatorOnce(core.CreateOperator(
|
|
'ResetCounter', ['c'], ['t32'])) # 5 -> 0
|
|
assert workspace.FetchBlob('t32') == 5
|
|
|
|
workspace.RunOperatorOnce(core.CreateOperator(
|
|
'ConstantFill', [], ['t4'], value=False, shape=[],
|
|
dtype=core.DataType.BOOL))
|
|
assert workspace.FetchBlob('t4') == workspace.FetchBlob('t1')
|
|
|
|
workspace.RunOperatorOnce(core.CreateOperator(
|
|
'ConstantFill', [], ['t5'], value=True, shape=[],
|
|
dtype=core.DataType.BOOL))
|
|
assert workspace.FetchBlob('t5') == workspace.FetchBlob('t2')
|
|
|
|
assert workspace.RunOperatorOnce(core.CreateOperator(
|
|
'And', ['t1', 't2'], ['t6']))
|
|
assert not workspace.FetchBlob('t6') # True && False
|
|
|
|
assert workspace.RunOperatorOnce(core.CreateOperator(
|
|
'And', ['t2', 't5'], ['t7']))
|
|
assert workspace.FetchBlob('t7') # True && True
|
|
|
|
workspace.RunOperatorOnce(core.CreateOperator(
|
|
'CreateCounter', [], ['serialized_c'], init_count=22))
|
|
with tempfile.NamedTemporaryFile() as tmp:
|
|
workspace.RunOperatorOnce(core.CreateOperator(
|
|
'Save', ['serialized_c'], [], absolute_path=1,
|
|
db_type='minidb', db=tmp.name))
|
|
for i in range(10):
|
|
workspace.RunOperatorOnce(core.CreateOperator(
|
|
'CountDown', ['serialized_c'], ['t8']))
|
|
workspace.RunOperatorOnce(core.CreateOperator(
|
|
'RetrieveCount', ['serialized_c'], ['t8']))
|
|
assert workspace.FetchBlob('t8') == 12
|
|
workspace.RunOperatorOnce(core.CreateOperator(
|
|
'Load', [], ['serialized_c'], absolute_path=1,
|
|
db_type='minidb', db=tmp.name))
|
|
workspace.RunOperatorOnce(core.CreateOperator(
|
|
'RetrieveCount', ['serialized_c'], ['t8']))
|
|
assert workspace.FetchBlob('t8') == 22
|
|
|
|
if __name__ == "__main__":
|
|
import unittest
|
|
unittest.main()
|