2017年4月28日金曜日

開発環境

行列プログラマー(Philip N. Klein (著)、 松田 晃一 (翻訳)、 弓林 司 (翻訳)、 脇本 佑紀 (翻訳)、 中田 洋 (翻訳)、 齋藤 大吾 (翻訳)、オライリージャパン)の2章(ベクトル)、2.14(問題)、GF(2)上のベクトルを他のベクトルの合計として表す、問題 2.14.4、2.14.5 を取り組んでみる。

問題 2.14.4、2.14.5

コード(Emacs)

#!/usr/bin/env python3
# -*- coding: utf-8 -*-

import unittest
from vec import Vec


def list2vec(l):
    return Vec(set(range(len(l))), {i: v for i, v in enumerate(l)})


def gf2mul(u, v):
    def mul(x, y):
        if x == 0 or y == 0:
            return 0
        return 'one'
    return [mul(x, y) for x, y in zip(u, v)]


def gf2add(u, v):
    def add(x, y):
        if x == y:
            return 0
        return 1
    return [add(x, y) for x, y in zip(u, v)]


class Text(unittest.TestCase):

    def setUp(self):
        self.a1 = [1, 1, 0, 0, 0, 0, 0]
        self.b1 = [0, 1, 1, 0, 0, 0, 0]
        self.c1 = [0, 0, 1, 1, 0, 0, 0]
        self.d1 = [0, 0, 0, 1, 1, 0, 0]
        self.e1 = [0, 0, 0, 0, 1, 1, 0]
        self.f1 = [0, 0, 0, 0, 0, 1, 1]
        self.vs1 = [self.a1, self.b1, self.c1, self.d1, self.e1, self.f1]

        self.a2 = [1, 1, 1, 0, 0, 0, 0]
        self.b2 = [0, 1, 1, 1, 0, 0, 0]
        self.c2 = [0, 0, 1, 1, 1, 0, 0]
        self.d2 = [0, 0, 0, 1, 1, 1, 0]
        self.e2 = [0, 0, 0, 0, 1, 1, 1]
        self.f2 = [0, 0, 0, 0, 0, 1, 1]
        self.vs2 = [self.a2, self.b2, self.c2, self.d2, self.e2, self.f2
                    ]
        self.u1 = [0, 0, 1, 0, 0, 1, 0]
        self.u2 = [0, 1, 0, 0, 0, 1, 0]

    def tearDown(self):
        pass

    # 2.14.4
    def test_u01(self):
        # 1. 無い
        for u in self.vs1:
            for v in self.vs1:
                self.assertNotEqual(gf2add(u, v), self.u1)

    def test_u02(self):
        # 1. 無い
        for u in self.vs1:
            for v in self.vs1:
                self.assertNotEqual(gf2add(u, v), self.u2)

    # 2.14.5
    def test_u11(self):
        v = gf2add(self.c2, self.d2)
        self.assertEqual(v, self.u1)

    def test_u12(self):
        # 2. 無い
        for u in self.vs2:
            for v in self.vs2:
                self.assertNotEqual(gf2add(u, v), self.u2)


if __name__ == '__main__':
    unittest.main()

入出力結果(Terminal, IPython)

$ ./sample14_4.py -v
test_u01 (__main__.Text) ... ok
test_u02 (__main__.Text) ... ok
test_u11 (__main__.Text) ... ok
test_u12 (__main__.Text) ... ok

----------------------------------------------------------------------
Ran 4 tests in 0.001s

OK
$

0 コメント:

コメントを投稿