ort-customops/test/test_segment_extraction.py

39 строки
1.3 KiB
Python

import unittest
import numpy as np
from onnxruntime_extensions import PyOrtFunction, SegmentExtraction
def _run_segment_extraction(input, expect_position, expect_value):
t2stc = PyOrtFunction.from_customop(SegmentExtraction)
position, value = t2stc(input)
np.testing.assert_array_equal(position, expect_position)
np.testing.assert_array_equal(value, expect_value)
class TestSegmentExtraction(unittest.TestCase):
def test_text_to_case1(self):
inputs = np.array([[0, 0, 1, 1, 2, 2, 2, 3, 3, 3, 3]], dtype=np.int64)
position = [[2, 4], [4, 7], [7, 11]]
value = [1, 2, 3]
_run_segment_extraction(inputs, position, value)
inputs = np.array([[1, 1, 0, 0, 2, 2, 2, 3, 3, 3, 0, 5]], dtype=np.int64)
position = [[0, 2], [4, 7], [7, 10], [11, 12]]
value = [1, 2, 3, 5]
_run_segment_extraction(inputs, position, value)
inputs = np.array([[1, 2, 4, 5]], dtype=np.int64)
position = [[0, 1], [1, 2], [2, 3], [3, 4]]
value = [1, 2, 4, 5]
_run_segment_extraction(inputs, position, value)
inputs = np.array([[0, 0, 1, 1, 1, 0, 0, 0, 0, 3, 3, 3, 0]], dtype=np.int64)
position = [[2, 5], [9, 12]]
value = [1, 3]
_run_segment_extraction(inputs, position, value)
if __name__ == "__main__":
unittest.main()