開発環境
- macOS Sierra - Apple (OS)
- Emacs (Text Editor)
- Python 3.6 (プログラミング言語)
行列プログラマー(Philip N. Klein (著)、 松田 晃一 (翻訳)、 弓林 司 (翻訳)、 脇本 佑紀 (翻訳)、 中田 洋 (翻訳)、 齋藤 大吾 (翻訳)、オライリージャパン)の3章(ベクトル空間)、3.2(線形包)、3.2.4(線形結合の線形結合)のクイズ 3.2.12 を取り組んでみる。
クイズ 3.2.12
コード(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 1
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 Test(unittest.TestCase):
def setUp(self):
self.v1 = list2vec([2, 0, 1])
self.v2 = list2vec([1, 0, 2])
self.v3 = list2vec([2, 2, 2])
def tearDown(self):
pass
def test_1(self):
v = list2vec([3, 0, 0])
a1 = 2
a2 = -1
a3 = 0
self.assertEqual(v, a1 * self.v1 +
a2 * self.v2 + a3 * self.v3)
def test_2(self):
v = list2vec([0, 2, 0])
a1 = -2 / 3
a2 = -2 / 3
a3 = 1
self.assertEqual(v, a1 * self.v1 +
a2 * self.v2 + a3 * self.v3)
def test_3(self):
v = list2vec([0, 0, 1])
a1 = -1 / 3
a2 = 2 / 3
a3 = 0
self.assertEqual(v, a1 * self.v1 +
a2 * self.v2 + a3 * self.v3)
if __name__ == '__main__':
unittest.main()
入出力結果(Terminal, IPython)
$ ./sample3.py -v test_1 (__main__.Test) ... ok test_2 (__main__.Test) ... ok test_3 (__main__.Test) ... ok ---------------------------------------------------------------------- Ran 3 tests in 0.001s OK $
0 コメント:
コメントを投稿