2017年3月10日金曜日

開発環境

行列プログラマー(Philip N. Klein (著)、 松田 晃一 (翻訳)、 弓林 司 (翻訳)、 脇本 佑紀 (翻訳)、 中田 洋 (翻訳)、 齋藤 大吾 (翻訳)、オライリージャパン)の1章(ベクトル)、2.6(ベクトルの和とスカラーとの積の組み合わせ)、2.6.3(はじめての凸結合)、課題2.6.9を取り組んでみる。

課題2.6.9

コード(Emacs)

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

from plotting import plot


def addn(v, w):
    return [a + w[i] for i, a in enumerate(v)]


def muln(v, w):
    return [a * w[i] for i, a in enumerate(v)]


def scalar_vector_mult(alpha, v):
    return [alpha * x for x in v]


def segment(pt1, pt2):
    n = 100
    return [
        addn(scalar_vector_mult(alpha / n, pt1),
             scalar_vector_mult((n - alpha) / n, pt2))
        for alpha in range(n)
    ]

import unittest


class Test(unittest.TestCase):

    def setUp(self):
        pass

    def tearDown(self):
        pass

    def test_count(self):
        seg = segment([1, 2, 3], [4, 5, 6])
        self.assertEqual(len(seg), 100)

if __name__ == '__main__':
    plot(segment([3.5, 3], [0.5, 1]), 10)
    input()
    unittest.main()

入出力結果(Terminal, IPython)

$ ./sample6_9.py -v
q
test_count (__main__.Test) ... ok

----------------------------------------------------------------------
Ran 1 test in 0.000s

OK
$

0 コメント:

コメントを投稿