開発環境
- macOS Sierra - Apple (OS)
- Emacs (Text Editor)
- Python 3.6 (プログラミング言語)
行列プログラマー(Philip N. Klein (著)、 松田 晃一 (翻訳)、 弓林 司 (翻訳)、 脇本 佑紀 (翻訳)、 中田 洋 (翻訳)、 齋藤 大吾 (翻訳)、オライリージャパン)の4章(行列)、4.10(線形関数)、4.10.8(対角行列)、クイズ4.10.21を取り組んでみる。
クイズ4.10.21
コード(Emacs)
#!/usr/bin/env python3 # -*- coding: utf-8 -*- # from vec import Vec import unittest class Mat: def __init__(self, labels, function): self.D = labels self.f = function def __str__(self): return 'Mat({0}, {1})'.format(self.D, self.f) def mat2rowdict(A): return {i: Vec(A.D[1], {j: A.f[(i, j)] for j in A.D[1]}) for i in A.D[0]} def mat2coldict(A): return {j: Vec(A.D[0], {i: A.f[(i, j)] for i in A.D[0]}) for j in A.D[1]} def mat2vec(M): return Vec({(i, j) for i in M.D[0] for j in M.D[1]}, M.f) def transpose(M): return Mat((M.D[1], M.D[0]), {(j, i): v for (i, j), v in M.f.items()}) def diag(D, entries): return Mat((D, D), {(d, d): entries[d] for d in D}) if __name__ == '__main__': for D, entries in [({'a'}, {'a': 1}), ({'a', 'b'}, {'a': 1, 'b': 2})]: M = diag(D, entries) print(M)
入出力結果(Terminal, IPython)
$ ./sample10.py Mat(({'a'}, {'a'}), {('a', 'a'): 1}) Mat(({'b', 'a'}, {'b', 'a'}), {('b', 'b'): 2, ('a', 'a'): 1}) $
0 コメント:
コメントを投稿