diff options
| author | J08nY | 2018-11-20 00:36:46 +0100 |
|---|---|---|
| committer | J08nY | 2019-03-14 18:03:54 +0100 |
| commit | e0a6e7c452cd55365096bc3e4b8f36f5f9660ae7 (patch) | |
| tree | bf1c80e015cdfd47d864665946f44a072f7b38db /test/test_process.py | |
| download | pyecsca-e0a6e7c452cd55365096bc3e4b8f36f5f9660ae7.tar.gz pyecsca-e0a6e7c452cd55365096bc3e4b8f36f5f9660ae7.tar.zst pyecsca-e0a6e7c452cd55365096bc3e4b8f36f5f9660ae7.zip | |
Diffstat (limited to 'test/test_process.py')
| -rw-r--r-- | test/test_process.py | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/test/test_process.py b/test/test_process.py new file mode 100644 index 0000000..130d51f --- /dev/null +++ b/test/test_process.py @@ -0,0 +1,47 @@ +from unittest import TestCase + +import numpy as np +from pyecsca import Trace, absolute, invert, threshold, rolling_mean, offset, recenter + + +class ProcessTests(TestCase): + + def setUp(self): + self._trace = Trace(None, None, np.array([30, -60, 145, 247], dtype=np.dtype("i2"))) + + def test_absolute(self): + result = absolute(self._trace) + self.assertIsNotNone(result) + self.assertIsInstance(result, Trace) + self.assertEqual(result.samples[1], 60) + + def test_invert(self): + result = invert(self._trace) + self.assertIsNotNone(result) + self.assertIsInstance(result, Trace) + np.testing.assert_equal(result.samples, [-30, 60, -145, -247]) + + def test_threshold(self): + result = threshold(self._trace, 128) + self.assertIsNotNone(result) + self.assertIsInstance(result, Trace) + self.assertEqual(result.samples[0], 0) + self.assertEqual(result.samples[2], 1) + + def test_rolling_mean(self): + result = rolling_mean(self._trace, 2) + self.assertIsNotNone(result) + self.assertIsInstance(result, Trace) + self.assertEqual(len(result.samples), 3) + self.assertEqual(result.samples[0], -15) + self.assertEqual(result.samples[1], 42) + self.assertEqual(result.samples[2], 196) + + def test_offset(self): + result = offset(self._trace, 5) + self.assertIsNotNone(result) + self.assertIsInstance(result, Trace) + np.testing.assert_equal(result.samples, np.array([35, -55, 150, 252], dtype=np.dtype("i2"))) + + def test_recenter(self): + self.assertIsNotNone(recenter(self._trace)) |
