学習環境
- Surface
- Windows 10 Pro (OS)
- Nebo(Windows アプリ)
- iPad
- MyScript Nebo - MyScript(iPad アプリ(iOS))
- 参考書籍
新装版 数学読本3 (松坂 和夫(著)、岩波書店)の第11章(立体的な広がりの中の図形 - 空間図形)、11.3(直線・平面・球の方程式)、平面の方程式の問31の解答を求めてみる。
2平面の法線ベクトルはそれぞれ
よって 2平面のなす角の余弦は
よって鋭角の余弦は
コード
#!/usr/bin/env python3
from unittest import TestCase, main
from sympy import Matrix, sqrt, solveset, cos, pprint, pi, Interval
from sympy.plotting import plot3d
from sympy.abc import x, y, t
print('31.')
class TestCosine(TestCase):
def test(self):
a = Matrix([2, -1, 1])
b = Matrix([1, 2, -4])
self.assertEqual(a.dot(b) / (a.norm() * b.norm()),
-2 * sqrt(14) / 21)
pprint([(theta, float(theta))
for theta in solveset(cos(t) - 2 * sqrt(14) / 21,
domain=Interval(0, pi))])
p = plot3d(3 - (2 * x - y),
(x + 2 * y) / 4,
xlim=(-30, 30),
ylim=(-30, 30),
show=False)
p.show()
p.save('sample31.png')
if __name__ == "__main__":
main()
入出力結果(Zsh、PowerShell、Terminal、Jupyter(IPython))
% ./sample31.py -v
31.
⎡⎛ ⎛√110⎞ ⎞⎤
⎢⎜atan⎜────⎟, 1.2064396014231937⎟⎥
⎣⎝ ⎝ 4 ⎠ ⎠⎦
test (__main__.TestCosine) ... ok
----------------------------------------------------------------------
Ran 1 test in 0.003s
OK
%
0 コメント:
コメントを投稿