2017年5月11日木曜日

開発環境

行列プログラマー(Philip N. Klein (著)、 松田 晃一 (翻訳)、 弓林 司 (翻訳)、 脇本 佑紀 (翻訳)、 中田 洋 (翻訳)、 齋藤 大吾 (翻訳)、オライリージャパン)の3章(ベクトル空間)、3.2(線形包)、3.2.5(標準生成子)のクイズ 3.2.13 を取り組んでみる。

クイズ 3.2.13

コード(Emacs)

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

import unittest
from vec import Vec


def standard(D, one):
    return [Vec(D, {k: one}) for k in D]


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_0(self):
        vs = standard({}, 1)
        self.assertEqual(vs, [])

    def test_1(self):
        vs = standard({'a'}, 1)
        self.assertEqual(vs, [Vec({'a'}, {'a': 1})])

    def test_5(self):
        D = {'a', 'b', 'c', 'd', 'e'}
        vs = set(standard(D, 1))
        self.assertEqual(vs, set([Vec(D, {'a': 1}),
                                  Vec(D, {'b': 1}),
                                  Vec(D, {'c': 1}),
                                  Vec(D, {'d': 1}),
                                  Vec(D, {'e': 1})]))


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

入出力結果(Terminal, IPython)

$ ./sample4.py -v
test_0 (__main__.Test) ... ok
test_1 (__main__.Test) ... ok
test_5 (__main__.Test) ... ok

----------------------------------------------------------------------
Ran 3 tests in 0.001s

OK
$

0 コメント:

コメントを投稿