diff options
| author | J08nY | 2018-12-11 21:24:35 +0100 |
|---|---|---|
| committer | J08nY | 2019-03-21 11:00:14 +0100 |
| commit | 0c740f412626f33f08d6bb9857f0c5619b9ea79c (patch) | |
| tree | c2313faaf8bc878d3d72acf2fd7c830b9512a529 /test/sca/test_combine.py | |
| parent | cbeca585d5787e8cab35fb5207339e7b22eab382 (diff) | |
| download | pyecsca-0c740f412626f33f08d6bb9857f0c5619b9ea79c.tar.gz pyecsca-0c740f412626f33f08d6bb9857f0c5619b9ea79c.tar.zst pyecsca-0c740f412626f33f08d6bb9857f0c5619b9ea79c.zip | |
Diffstat (limited to 'test/sca/test_combine.py')
| -rw-r--r-- | test/sca/test_combine.py | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/test/sca/test_combine.py b/test/sca/test_combine.py new file mode 100644 index 0000000..113eb69 --- /dev/null +++ b/test/sca/test_combine.py @@ -0,0 +1,35 @@ +from unittest import TestCase + +import numpy as np +from pyecsca.sca import Trace, CombinedTrace, average, conditional_average, standard_deviation + + +class CombineTests(TestCase): + + def setUp(self): + self.a = Trace(None, b"\xff", np.array([20, 80], dtype=np.dtype("i1"))) + self.b = Trace(None, b"\xff", np.array([30, 42], dtype=np.dtype("i1"))) + self.c = Trace(None, b"\x00", np.array([78, 56], dtype=np.dtype("i1"))) + + def test_average(self): + self.assertIsNone(average()) + result = average(self.a, self.b) + self.assertIsNotNone(result) + self.assertIsInstance(result, CombinedTrace) + self.assertEqual(len(result.samples), 2) + self.assertEqual(result.samples[0], 25) + self.assertEqual(result.samples[1], 61) + + def test_conditional_average(self): + result = conditional_average(self.a, self.b, self.c, + condition=lambda trace: trace.data[0] == 0xff) + self.assertIsInstance(result, CombinedTrace) + self.assertEqual(len(result.samples), 2) + self.assertEqual(result.samples[0], 25) + self.assertEqual(result.samples[1], 61) + + def test_standard_deviation(self): + self.assertIsNone(standard_deviation()) + result = standard_deviation(self.a, self.b) + self.assertIsInstance(result, CombinedTrace) + self.assertEqual(len(result.samples), 2) |
