{"id":4484,"date":"2024-12-25T14:30:06","date_gmt":"2024-12-25T05:30:06","guid":{"rendered":"https:\/\/home.hirosaki-u.ac.jp\/relativity\/?page_id=4484"},"modified":"2024-12-25T14:32:02","modified_gmt":"2024-12-25T05:32:02","slug":"scipy-%e3%81%a7%e6%95%b0%e5%80%a4%e8%a7%a3%e6%9e%90","status":"publish","type":"page","link":"https:\/\/home.hirosaki-u.ac.jp\/relativity\/%e3%82%b3%e3%83%b3%e3%83%94%e3%83%a5%e3%83%bc%e3%82%bf%e6%bc%94%e7%bf%92\/python-%e3%81%a7%e6%95%b0%e5%80%a4%e8%a7%a3%e6%9e%90\/scipy-%e3%81%a7%e6%95%b0%e5%80%a4%e8%a7%a3%e6%9e%90\/","title":{"rendered":"SciPy \u3067\u6570\u5024\u89e3\u6790"},"content":{"rendered":"<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p>Python \u3067\u6570\u5024\u89e3\u6790\u3059\u308b\u305f\u3081\u306e\u30e9\u30a4\u30d6\u30e9\u30ea\u3067\u3042\u308b <code>SciPy<\/code> \u306e\u4f7f\u7528\u4f8b\u3092\u793a\u3057\u307e\u3059\u3002\u30b0\u30e9\u30d5\u306f <code>Matplotlib<\/code> \u306e <code>pyplot.plot()<\/code> \u3092\u4f7f\u3063\u3066\u63cf\u304d\u307e\u3059\u3002\u4e09\u89d2\u95a2\u6570\u306a\u3069\u306e\u6570\u5b66\u95a2\u6570\u306b\u3064\u3044\u3066\u306f\uff0cSymPy \u3092\u4f7f\u308f\u305a\uff0c\u5168\u3066 NumPy \u306e\u95a2\u6570\u3092\u4f7f\u3044\u307e\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<p><!--more--><\/p>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<h3 id=\"\u30e9\u30a4\u30d6\u30e9\u30ea\u306e-import-\u3068\u8a2d\u5b9a\">\u30e9\u30a4\u30d6\u30e9\u30ea\u306e import \u3068\u8a2d\u5b9a<\/h3>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[1]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"c1\"># NumPy \u3092\u4f7f\u3044\u307e\u3059<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">numpy<\/span> <span class=\"k\">as<\/span> <span class=\"nn\">np<\/span>\r\n<span class=\"c1\"># Matplotlib \u3067\u30b0\u30e9\u30d5\u3092\u63cf\u304d\u307e\u3059<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">matplotlib.pyplot<\/span> <span class=\"k\">as<\/span> <span class=\"nn\">plt<\/span>\r\n\r\n<span class=\"c1\"># \u30b0\u30e9\u30d5\u306e\u76ee\u76db\u8a2d\u5b9a\u7528<\/span>\r\n<span class=\"kn\">from<\/span> <span class=\"nn\">matplotlib.ticker<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">MultipleLocator<\/span>\r\n\r\n<span class=\"c1\"># \u4ee5\u4e0b\u306f\u30b0\u30e9\u30d5\u3092 SVG \u3067 Notebook \u306b\u30a4\u30f3\u30e9\u30a4\u30f3\u8868\u793a\u3055\u305b\u308b\u8a2d\u5b9a<\/span>\r\n<span class=\"o\">%<\/span><span class=\"k\">config<\/span> InlineBackend.figure_formats = ['svg']\r\n\r\n<span class=\"c1\"># mathtext font \u306e\u8a2d\u5b9a<\/span>\r\n<span class=\"n\">plt<\/span><span class=\"o\">.<\/span><span class=\"n\">rcParams<\/span><span class=\"p\">[<\/span><span class=\"s1\">'mathtext.fontset'<\/span><span class=\"p\">]<\/span> <span class=\"o\">=<\/span> <span class=\"s1\">'cm'<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<h3 id=\"SciPy-\u306b\u3088\u308b\u6570\u5024\u5fae\u5206\">SciPy \u306b\u3088\u308b\u6570\u5024\u5fae\u5206<\/h3>\n<p>SciPy \u306b\u306f\u6570\u5024\u5fae\u5206\u3092\u3057\u3066\u304f\u308c\u308b\u95a2\u6570 <code>scipy.misc.derivative<\/code> \u304c\u3042\u308a\u307e\u3057\u305f\u304c\uff0c\u975e\u63a8\u5968\u3068\u306a\u308a\uff0cSciPy 1.12.0 \u304b\u3089\u306f\u4f7f\u3048\u306a\u304f\u306a\u3063\u305f\u3088\u3046\u3067\u3059\u3002<\/p>\n<p>\u89e3\u6790\u7684\u306a\u5fae\u5206\u306e\u5b9a\u7fa9\u306f\uff08\u524d\u65b9\u5dee\u5206\u306e\u6975\u9650\u3068\u3057\u3066\uff09<\/p>\n<p>$$\\frac{df}{dx} \\equiv \\lim_{h \\rightarrow 0} \\frac{f(x+h) -f(x)}{h}$$<\/p>\n<p>\u3067\u3057\u305f\u3002\u6ed1\u3089\u304b\u306a\u95a2\u6570\u3067\u3042\u308c\u3070\uff0c\uff08\u5f8c\u65b9\u5dee\u5206\u306e\u6975\u9650\u3068\u3057\u3066\uff09<br \/>\n$$\\frac{df}{dx} = \\lim_{h \\rightarrow 0} \\frac{f(x) -f(x-h)}{h}$$<br \/>\n\u3068\u3057\u3066\u3082\u826f\u3044\u3067\u3059\u3002<\/p>\n<p>\u73fe\u5b9f\u4e16\u754c\u3067\u306f $ h\\rightarrow 0$ \u306e\u6975\u9650\u306f\u3068\u308c\u307e\u305b\u3093\u304b\u3089\u5341\u5206\u5c0f\u3055\u3044\u5024\u3068\u3057\u3066 h \u3092\u5b9a\u7fa9\u3057\uff0c\u8fd1\u4f3c\u7684\u306a\u6570\u5024\u5fae\u5206\u3092\uff08\u524d\u65b9\u5dee\u5206\u3068\u5f8c\u65b9\u5dee\u5206\u306e\u5e73\u5747\u3067\u3042\u308b\u4e2d\u5fc3\u5dee\u5206\u3068\u3057\u3066\uff09\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u5b9a\u7fa9\u3057\u307e\u3057\u3087\u3046\u3002<\/p>\n<p>\\begin{eqnarray}<br \/>\n\\frac{df}{dx} &amp;\\simeq&amp; \\frac{1}{2} \\left\\{\\frac{f(x+h) &#8211; f(x)}{h} + \\frac{f(x) &#8211; f(x-h)}{h} \\right\\} \\\\<br \/>\n&amp;=&amp; \\frac{f(x+h) &#8211; f(x-h)}{2h}<br \/>\n\\end{eqnarray}<\/p>\n<p>\u95a2\u6570 $f(x)$ \u304c\u521d\u7b49\u95a2\u6570\uff08\u304a\u3088\u3073\u521d\u7b49\u95a2\u6570\u306e\u5408\u6210\u95a2\u6570\uff09\u3067\u3042\u308b\u5834\u5408\u306f\u89e3\u6790\u7684\u306b\u5fae\u5206\u3067\u304d\u307e\u3059\u304c\uff0c\u305d\u3046\u3067\u306a\u3044\u5834\u5408\uff0c\u4f8b\u3048\u3070 $f(x)$ \u304c\u6570\u5024\u7684\u306b\u3057\u304b\u4e0e\u3048\u3089\u308c\u3066\u3044\u306a\u3044\u3068\u304b\uff0c\u4f55\u304b\u89e3\u6790\u7684\u306b\u5fae\u5206\u3067\u304d\u306a\u3044\u5834\u5408\u306b\u306f\uff0c\u6570\u5024\u5fae\u5206\u306b\u3088\u3063\u3066\u8fd1\u4f3c\u7684\u306a\u5024\u3092\u6c42\u3081\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n<p>\u307e\u305f\uff0c\u89e3\u6790\u7684\u306b\u5fae\u5206\u3067\u304d\u305d\u3046\u3060\u304c\uff0c\u4eba\u529b\u3067\u306f\u3051\u3063\u3053\u3046\u5927\u5909\u305d\u3046\u306a\u5834\u5408\u306b\u3082\uff0c\u6570\u5024\u5fae\u5206\u306b\u3088\u3063\u3066\u8fd1\u4f3c\u7684\u306a\u5024\u3092\u4f7f\u3046\u307b\u3046\u304c\u4fbf\u5229\u306a\u5834\u5408\u304c\u3042\u308b\u304b\u3082\u3057\u308c\u307e\u305b\u3093\u3002<\/p>\n<p>\u4ee5\u4e0b\u306e\u3088\u3046\u306b\uff0c\u95a2\u6570 <code>f(x)<\/code> \u3092\u6570\u5024\u5fae\u5206\u3057\u3066\u304f\u308c\u308b\u95a2\u6570 <code>ndiff()<\/code> \u3092\u5b9a\u7fa9\u3057\u307e\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[2]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"k\">def<\/span> <span class=\"nf\">ndiff<\/span><span class=\"p\">(<\/span><span class=\"n\">f<\/span><span class=\"p\">,<\/span> <span class=\"n\">x<\/span><span class=\"p\">,<\/span> <span class=\"n\">h<\/span><span class=\"o\">=<\/span><span class=\"mf\">1e-5<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"c1\"># h \u3092\u7701\u7565\u3059\u308b\u3068 h=1e-5 \u3068\u3057\u3066\u8a08\u7b97\u3059\u308b<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"p\">(<\/span><span class=\"n\">f<\/span><span class=\"p\">(<\/span><span class=\"n\">x<\/span> <span class=\"o\">+<\/span> <span class=\"n\">h<\/span><span class=\"p\">)<\/span> <span class=\"o\">-<\/span> <span class=\"n\">f<\/span><span class=\"p\">(<\/span><span class=\"n\">x<\/span> <span class=\"o\">-<\/span> <span class=\"n\">h<\/span><span class=\"p\">))<\/span><span class=\"o\">\/<\/span><span class=\"p\">(<\/span><span class=\"mi\">2<\/span><span class=\"o\">*<\/span><span class=\"n\">h<\/span><span class=\"p\">)<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p>\u4f8b\u3068\u3057\u3066\uff0c$f(x) = \\sin x$ \u306e $x = 3$ \u306b\u304a\u3051\u308b\u6570\u5024\u5fae\u5206\u3092\u6c42\u3081\u3066\u307f\u307e\u3059\u3002\uff08\u7b54\u3048\u306f $\\cos 3$ \u3067\u3059\u3002\uff09<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[3]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"c1\"># h \u3092\u7701\u7565\u3057\u305f\u5834\u5408<\/span>\r\n<span class=\"nb\">print<\/span><span class=\"p\">(<\/span><span class=\"s1\">'       ndiff(f, 3) = <\/span><span class=\"si\">%.15f<\/span><span class=\"s1\">'<\/span> <span class=\"o\">%<\/span> <span class=\"n\">ndiff<\/span><span class=\"p\">(<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">sin<\/span><span class=\"p\">,<\/span> <span class=\"mi\">3<\/span><span class=\"p\">))<\/span>\r\n\r\n<span class=\"k\">for<\/span> <span class=\"n\">h<\/span> <span class=\"ow\">in<\/span> <span class=\"p\">[<\/span><span class=\"mf\">1e-4<\/span><span class=\"p\">,<\/span> <span class=\"mf\">1e-5<\/span><span class=\"p\">,<\/span> <span class=\"mf\">1e-6<\/span><span class=\"p\">,<\/span> <span class=\"mf\">1e-7<\/span><span class=\"p\">,<\/span> <span class=\"mf\">1e-8<\/span><span class=\"p\">]:<\/span>\r\n    <span class=\"nb\">print<\/span><span class=\"p\">(<\/span><span class=\"s1\">'h = <\/span><span class=\"si\">%3.1e<\/span><span class=\"s1\">, ndiff = <\/span><span class=\"si\">%.15f<\/span><span class=\"s1\">'<\/span> <span class=\"o\">%<\/span> <span class=\"p\">(<\/span><span class=\"n\">h<\/span><span class=\"p\">,<\/span> <span class=\"n\">ndiff<\/span><span class=\"p\">(<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">sin<\/span><span class=\"p\">,<\/span> <span class=\"mi\">3<\/span><span class=\"p\">,<\/span> <span class=\"n\">h<\/span><span class=\"p\">)))<\/span>\r\n\r\n<span class=\"nb\">print<\/span><span class=\"p\">(<\/span><span class=\"s1\">' '<\/span><span class=\"o\">*<\/span><span class=\"mi\">10<\/span> <span class=\"o\">+<\/span> <span class=\"s1\">'cos(<\/span><span class=\"si\">%3.1f<\/span><span class=\"s1\">) = <\/span><span class=\"si\">%.15f<\/span><span class=\"s1\">'<\/span> <span class=\"o\">%<\/span> <span class=\"p\">(<\/span><span class=\"mi\">3<\/span><span class=\"p\">,<\/span> <span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">cos<\/span><span class=\"p\">(<\/span><span class=\"mi\">3<\/span><span class=\"p\">)))<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_subarea output_stream output_stdout output_text\">\n<pre>       ndiff(f, 3) = -0.989992496590319\r\nh = 1.0e-04, ndiff = -0.989992494952602\r\nh = 1.0e-05, ndiff = -0.989992496590319\r\nh = 1.0e-06, ndiff = -0.989992496730485\r\nh = 1.0e-07, ndiff = -0.989992494926373\r\nh = 1.0e-08, ndiff = -0.989992490763036\r\n          cos(3.0) = -0.989992496600445\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p>\u4ee5\u4e0a\u306e\u7d50\u679c\u304b\u3089\u308f\u304b\u308b\u3088\u3046\u306b\uff0c<code>h<\/code> \u3092\u3084\u307f\u304f\u3082\u306b\u5c0f\u3055\u304f\u3059\u308c\u3070\u3059\u308b\u307b\u3069\uff0c\u6570\u5024\u5fae\u5206\u306e\u7cbe\u5ea6\u304c\u3042\u304c\u308b\uff0c\u3068\u3044\u3046\u308f\u3051\u3067\u306f\u306a\u3044\u3067\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<h4 id=\"\u25cb\u7df4\u7fd2\uff1a\u95a2\u6570\u306e\u6570\u5024\u5fae\u5206\">\u25cb\u7df4\u7fd2\uff1a\u95a2\u6570\u306e\u6570\u5024\u5fae\u5206<\/h4>\n<p>$\\displaystyle f(x) = \\frac{x^3}{e^x -1}$ \u306e\u6975\u5927\u5024\u3092\u6c42\u3081\u308b\u305f\u3081\u306e\u6e96\u5099\u3068\u3057\u3066\uff0c\u307e\u305a\uff0c$f(x)$ \u3068\u305d\u306e\u6570\u5024\u5fae\u5206 <code>ndiff(f, x)<\/code> \u3092 $0 \\leq x \\leq 5$ \u306e\u7bc4\u56f2\u3067\u30b0\u30e9\u30d5\u306b\u3059\u308b\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[4]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"k\">def<\/span> <span class=\"nf\">f<\/span><span class=\"p\">(<\/span><span class=\"n\">x<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"n\">x<\/span><span class=\"o\">**<\/span><span class=\"mi\">3<\/span><span class=\"o\">\/<\/span><span class=\"p\">(<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">exp<\/span><span class=\"p\">(<\/span><span class=\"n\">x<\/span><span class=\"p\">)<\/span> <span class=\"o\">-<\/span> <span class=\"mi\">1<\/span><span class=\"p\">)<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[5]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"c1\"># ax \u3092\u4f7f\u3046\u969b\u306e\u6700\u521d\u306e\u304a\u307e\u3058\u306a\u3044<\/span>\r\n<span class=\"n\">fig<\/span><span class=\"p\">,<\/span> <span class=\"n\">ax<\/span> <span class=\"o\">=<\/span> <span class=\"n\">plt<\/span><span class=\"o\">.<\/span><span class=\"n\">subplots<\/span><span class=\"p\">()<\/span>\r\n\r\n<span class=\"c1\"># x \u306e\u7bc4\u56f2<\/span>\r\n<span class=\"n\">xrange<\/span> <span class=\"o\">=<\/span> <span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">linspace<\/span><span class=\"p\">(<\/span><span class=\"mf\">0.001<\/span><span class=\"p\">,<\/span> <span class=\"mi\">5<\/span><span class=\"p\">,<\/span> <span class=\"mi\">200<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"c1\"># y = f(x) \u306e\u30b0\u30e9\u30d5<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">plot<\/span><span class=\"p\">(<\/span><span class=\"n\">xrange<\/span><span class=\"p\">,<\/span> <span class=\"n\">f<\/span><span class=\"p\">(<\/span><span class=\"n\">xrange<\/span><span class=\"p\">),<\/span> <span class=\"n\">label<\/span> <span class=\"o\">=<\/span> <span class=\"s1\">'$f(x)$'<\/span><span class=\"p\">)<\/span>\r\n<span class=\"c1\"># y = f'(x) \u306e\u30b0\u30e9\u30d5<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">plot<\/span><span class=\"p\">(<\/span><span class=\"n\">xrange<\/span><span class=\"p\">,<\/span> <span class=\"n\">ndiff<\/span><span class=\"p\">(<\/span><span class=\"n\">f<\/span><span class=\"p\">,<\/span> <span class=\"n\">xrange<\/span><span class=\"p\">),<\/span> <span class=\"n\">label<\/span> <span class=\"o\">=<\/span> <span class=\"s1\">'$f^{\\prime}(x)$'<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"c1\"># x \u8ef8\u306e\u30e9\u30d9\u30eb<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_xlabel<\/span><span class=\"p\">(<\/span><span class=\"s1\">'$x$'<\/span><span class=\"p\">)<\/span>\r\n<span class=\"c1\"># \u30b0\u30ea\u30c3\u30c9<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">grid<\/span><span class=\"p\">()<\/span>\r\n<span class=\"c1\"># \u51e1\u4f8b\u306e\u8868\u793a<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">legend<\/span><span class=\"p\">();<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_svg output_subarea \">\n<p><!--?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?--><\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-large wp-image-9972\" src=\"https:\/\/home.hirosaki-u.ac.jp\/relativity\/wp-content\/uploads\/sites\/76\/scipysk01.svg\" alt=\"\" width=\"640\" height=\"427\" \/><\/p>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p>\u4e0a\u306e\u30b0\u30e9\u30d5\u304b\u3089\uff0c\u6570\u5024\u5fae\u5206\u3057\u305f\u5fae\u5206\u4fc2\u6570 $f^{\\prime}(x)$ \u306e\u5024\u304c\u30bc\u30ed\u306b\u306a\u308b $x$ \u306f\uff0c$2 &lt; x &lt; 3$ \u306e\u3042\u305f\u308a\u3067\u3042\u308b\u3053\u3068\uff0c\u305d\u306e\u3042\u305f\u308a\u3067\u78ba\u304b\u306b $f(x)$ \u304c\u6975\u5927\uff08\u6700\u5927\uff09\u3068\u306a\u3063\u3066\u3044\u308b\u3053\u3068\u304c\u898b\u3066\u3068\u308c\u307e\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<h3 id=\"SciPy-\u306b\u3088\u308b\u6570\u5024\u7a4d\u5206\">SciPy \u306b\u3088\u308b\u6570\u5024\u7a4d\u5206<\/h3>\n<h4 id=\"scipy.integrate.quad()\"><code>scipy.integrate.quad()<\/code><\/h4>\n<p>SciPy \u306b\u306f\u6570\u5024\u7a4d\u5206\u3057\u3066\u304f\u308c\u308b\u95a2\u6570 <code>scipy.integrate.quad()<\/code> \u304c\u7528\u610f\u3055\u308c\u3066\u3044\u307e\u3059\u3002\u305d\u308c\u3092\u4f7f\u3063\u3066\u307f\u307e\u3057\u3087\u3046\u3002\u7d50\u679c\u306b\u306f\u7a4d\u5206\u5024\u3068\u63a8\u5b9a\u8aa4\u5dee\u304c\u51fa\u529b\u3055\u308c\u307e\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p>$\\displaystyle \\int_0^{\\pi} \\sin(\\sin x)\\, dx$ \u306e\u8a08\u7b97\u3092\u3057\u307e\u3059\u3002<\/p>\n<p>\u6570\u5024\u8a08\u7b97\u306e\u969b\u306f\uff0c\u4e09\u89d2\u95a2\u6570\u7b49\u306f NumPy \u306e\u95a2\u6570\u3092\u4f7f\u3044\uff0c\u5186\u5468\u7387 $\\pi$ \u3082 NumPy \u306e <code>np.pi<\/code> \u3092\u4f7f\u3044\u307e\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[6]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"kn\">from<\/span> <span class=\"nn\">scipy.integrate<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">quad<\/span>\r\n\r\n<span class=\"c1\"># quad \u3092\u4f7f\u3046\u3068\u304d\u306f\u5909\u6570\u540d x \u6c7a\u3081\u6253\u3061<\/span>\r\n<span class=\"k\">def<\/span> <span class=\"nf\">sinsin<\/span><span class=\"p\">(<\/span><span class=\"n\">x<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">sin<\/span><span class=\"p\">(<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">sin<\/span><span class=\"p\">(<\/span><span class=\"n\">x<\/span><span class=\"p\">))<\/span>\r\n\r\n<span class=\"c1\"># quad \u3067\u6570\u5024\u7a4d\u5206<\/span>\r\n<span class=\"c1\"># quad(f, a, b): \u88ab\u7a4d\u5206\u95a2\u6570 f(x) \u3092 x = a \u304b\u3089 b \u307e\u3067\u6570\u5024\u7a4d\u5206<\/span>\r\n<span class=\"n\">quad<\/span><span class=\"p\">(<\/span><span class=\"n\">sinsin<\/span><span class=\"p\">,<\/span> <span class=\"mi\">0<\/span><span class=\"p\">,<\/span> <span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">pi<\/span><span class=\"p\">)<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt output_prompt\">Out[6]:<\/div>\n<div class=\"output_text output_subarea output_execute_result\">\n<pre>(1.7864874819500525, 2.4687274069628184e-11)<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p><code>scipy.integrate.quad()<\/code> \u306f\u4e0a\u8a18\u306e\u3088\u3046\u306b\uff0c\u6570\u5024\u7a4d\u5206\u306e\u5024\u3068\u7d76\u5bfe\u8aa4\u5dee\u306e\u63a8\u5b9a\u5024\u3092\u30bf\u30d7\u30eb (tuple) \u3067\u8fd4\u3057\u307e\u3059\u3002<\/p>\n<p>\u6570\u5024\u7a4d\u5206\u5024\uff08\u3068\u8aa4\u5dee\uff09\u3092\u500b\u5225\u306b\u53d6\u308a\u51fa\u3059\u306b\u306f\uff0c\u4f8b\u3048\u3070\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[7]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"n\">y<\/span><span class=\"p\">,<\/span> <span class=\"n\">abserr<\/span> <span class=\"o\">=<\/span> <span class=\"n\">quad<\/span><span class=\"p\">(<\/span><span class=\"n\">sinsin<\/span><span class=\"p\">,<\/span> <span class=\"mi\">0<\/span><span class=\"p\">,<\/span> <span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">pi<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"nb\">print<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"\u7a4d\u5206\u5024\u306f\"<\/span><span class=\"p\">,<\/span> <span class=\"n\">y<\/span><span class=\"p\">)<\/span>\r\n<span class=\"nb\">print<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"\u8aa4\u5dee\u306f\"<\/span><span class=\"p\">,<\/span> <span class=\"n\">abserr<\/span><span class=\"p\">)<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_subarea output_stream output_stdout output_text\">\n<pre>\u7a4d\u5206\u5024\u306f 1.7864874819500525\r\n\u8aa4\u5dee\u306f 2.4687274069628184e-11\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<h4 id=\"\u53c2\u8003\uff1a\u30b7\u30f3\u30d7\u30bd\u30f3\u6cd5\u306b\u3088\u308b\u6570\u5024\u7a4d\u5206\">\u53c2\u8003\uff1a\u30b7\u30f3\u30d7\u30bd\u30f3\u6cd5\u306b\u3088\u308b\u6570\u5024\u7a4d\u5206<\/h4>\n<p>\u30b7\u30f3\u30d7\u30bd\u30f3\u6cd5\u3067 $\\displaystyle \\int_a^b f(x)\\, dx$ \u3092\u6c42\u3081\u308b\u3002<\/p>\n<p>\u7a4d\u5206\u533a\u9593 $[a, b]$ \u3092 $N (=2n)$ \u7b49\u5206\uff08\u5076\u6570\u7b49\u5206\uff09\u3057\uff0c<\/p>\n<p>$$h = \\frac{b-a}{N}, \\quad f_i = f(a + i\\,h)$$<\/p>\n<p>\u3068\u3059\u308b\u3002\u30b7\u30f3\u30d7\u30bd\u30f3\u6cd5\u306e\u516c\u5f0f\u306f<\/p>\n<p>\\begin{eqnarray}<br \/>\n\\int_a^b f(x)\\, dx &amp;\\simeq&amp;<br \/>\n\\frac{h}{3}( f_0 + 4 f_1 + f_2) + \\frac{h}{3}( f_2 + 4 f_3 + f_4) + \\\\<br \/>\n&amp;&amp; \\frac{h}{3}( f_4 + 4 f_5 + f_6) + \\frac{h}{3}( f_6 + 4 f_7 + f_8)+ \\cdots\\\\<br \/>\n&amp;&amp;+ \\frac{h}{3}( f_{N-2} + 4 f_{N-1} + f_N)\\\\<br \/>\n&amp;=&amp;\\frac{h}{3}<br \/>\n\\left(f_0 + 2 \\sum_{i=1}^{n-1} f_{2i} + 4 \\sum_{i=1}^{n} f_{2i-1}+ f_{2n}\\right)<br \/>\n\\end{eqnarray}<\/p>\n<p>SciPy \u3067\u306f <code>scipy.integrate.quad()<\/code> \u3092\u4f7f\u3063\u3066\u6570\u5024\u7a4d\u5206\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u308b\u306e\u3067\u308f\u3056\u308f\u3056\u81ea\u4f5c\u306e\u95a2\u6570\u3092\u3064\u304f\u308b\u5fc5\u8981\u306f\u306a\u3044\u306e\u3067\u3059\u304c\uff0c\u6559\u80b2\u7684\u898b\u5730\u304b\u3089\u3042\u3048\u3066\uff0c\u30b7\u30f3\u30d7\u30bd\u30f3\u6cd5\u306e\u516c\u5f0f\u3092\u4f7f\u3063\u3066\u6570\u5024\u7a4d\u5206\u306e\u5024\u3092\u8fd4\u3059\u95a2\u6570 <code>simpson()<\/code> \u3092\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u5b9a\u7fa9\u3057\u3066\u307f\u307e\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[8]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"k\">def<\/span> <span class=\"nf\">simpson<\/span><span class=\"p\">(<\/span><span class=\"n\">f<\/span><span class=\"p\">,<\/span> <span class=\"n\">a<\/span><span class=\"p\">,<\/span> <span class=\"n\">b<\/span><span class=\"p\">,<\/span> <span class=\"n\">Ndiv<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"n\">h<\/span> <span class=\"o\">=<\/span> <span class=\"p\">(<\/span><span class=\"n\">b<\/span> <span class=\"o\">-<\/span> <span class=\"n\">a<\/span><span class=\"p\">)<\/span><span class=\"o\">\/<\/span><span class=\"n\">Ndiv<\/span>\r\n    <span class=\"n\">simp<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">0<\/span>\r\n    <span class=\"k\">for<\/span> <span class=\"n\">i<\/span> <span class=\"ow\">in<\/span> <span class=\"nb\">range<\/span><span class=\"p\">(<\/span><span class=\"mi\">0<\/span><span class=\"p\">,<\/span> <span class=\"n\">Ndiv<\/span><span class=\"p\">,<\/span> <span class=\"mi\">2<\/span><span class=\"p\">):<\/span>\r\n        <span class=\"n\">simp<\/span> <span class=\"o\">+=<\/span> <span class=\"n\">f<\/span><span class=\"p\">(<\/span><span class=\"n\">a<\/span> <span class=\"o\">+<\/span> <span class=\"n\">i<\/span><span class=\"o\">*<\/span><span class=\"n\">h<\/span><span class=\"p\">)<\/span> <span class=\"o\">+<\/span> <span class=\"mi\">4<\/span><span class=\"o\">*<\/span><span class=\"n\">f<\/span><span class=\"p\">(<\/span><span class=\"n\">a<\/span> <span class=\"o\">+<\/span> <span class=\"p\">(<\/span><span class=\"n\">i<\/span><span class=\"o\">+<\/span><span class=\"mi\">1<\/span><span class=\"p\">)<\/span><span class=\"o\">*<\/span><span class=\"n\">h<\/span><span class=\"p\">)<\/span> <span class=\"o\">+<\/span> <span class=\"n\">f<\/span><span class=\"p\">(<\/span><span class=\"n\">a<\/span> <span class=\"o\">+<\/span> <span class=\"p\">(<\/span><span class=\"n\">i<\/span><span class=\"o\">+<\/span><span class=\"mi\">2<\/span><span class=\"p\">)<\/span><span class=\"o\">*<\/span><span class=\"n\">h<\/span><span class=\"p\">)<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"n\">simp<\/span><span class=\"o\">*<\/span><span class=\"n\">h<\/span><span class=\"o\">\/<\/span><span class=\"mi\">3<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p><code>N<\/code> \u306e\u5024\u3092\u5909\u3048\u3066 $\\displaystyle \\int_0^{\\pi} \\sin(\\sin x)\\, dx$ \u3092 <code>simpson()<\/code> \u3067\u6570\u5024\u7a4d\u5206\u3057\u3066\uff0c\u7cbe\u5ea6\u3092\u78ba\u8a8d\u3057\u3066\u307f\u307e\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[9]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"k\">def<\/span> <span class=\"nf\">f<\/span><span class=\"p\">(<\/span><span class=\"n\">x<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">sin<\/span><span class=\"p\">(<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">sin<\/span><span class=\"p\">(<\/span><span class=\"n\">x<\/span><span class=\"p\">))<\/span>\r\n\r\n<span class=\"k\">for<\/span> <span class=\"n\">N<\/span> <span class=\"ow\">in<\/span> <span class=\"p\">[<\/span><span class=\"mi\">10<\/span><span class=\"o\">*<\/span><span class=\"mi\">2<\/span><span class=\"o\">**<\/span><span class=\"n\">i<\/span> <span class=\"k\">for<\/span> <span class=\"n\">i<\/span> <span class=\"ow\">in<\/span> <span class=\"nb\">range<\/span><span class=\"p\">(<\/span><span class=\"mi\">9<\/span><span class=\"p\">)]:<\/span>\r\n    <span class=\"nb\">print<\/span><span class=\"p\">(<\/span><span class=\"s1\">'N = <\/span><span class=\"si\">%4d<\/span><span class=\"s1\">, <\/span><span class=\"si\">%.15f<\/span><span class=\"s1\">'<\/span> <span class=\"o\">%<\/span><span class=\"p\">(<\/span><span class=\"n\">N<\/span><span class=\"p\">,<\/span> <span class=\"n\">simpson<\/span><span class=\"p\">(<\/span><span class=\"n\">f<\/span><span class=\"p\">,<\/span> <span class=\"mi\">0<\/span><span class=\"p\">,<\/span> <span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">pi<\/span><span class=\"p\">,<\/span> <span class=\"n\">N<\/span><span class=\"p\">)))<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_subarea output_stream output_stdout output_text\">\n<pre>N =   10, 1.786721213744079\r\nN =   20, 1.786501256275661\r\nN =   40, 1.786488331266680\r\nN =   80, 1.786487534856180\r\nN =  160, 1.786487485253951\r\nN =  320, 1.786487482156504\r\nN =  640, 1.786487481962955\r\nN = 1280, 1.786487481950862\r\nN = 2560, 1.786487481950104\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p>\u4ee5\u4e0a\u306e\u7d50\u679c\u304b\u3089\uff0c\u3069\u3093\u306a\u3053\u3068\u304c\u308f\u304b\u308b\u304b\u306a\uff1f<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<h3 id=\"SciPy-\u306b\u3088\u308b\u65b9\u7a0b\u5f0f\u306e\u6570\u5024\u89e3\">SciPy \u306b\u3088\u308b\u65b9\u7a0b\u5f0f\u306e\u6570\u5024\u89e3<\/h3>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p>\u4f8b\u3068\u3057\u3066\u30d9\u30c3\u30bb\u30eb\u95a2\u6570 $J_0(x)$ \u306e\u30bc\u30ed\u70b9\u3092\u6c42\u3081\u3066\u307f\u307e\u3059\u3002<code>SciPy<\/code> \u306b\u304a\u3051\u308b\u30d9\u30c3\u30bb\u30eb\u95a2\u6570 $J_0(x)$ \u306f <code>scipy.special.jv(0,x)<\/code> \u3067\u3059\u3002<\/p>\n<p>\u307e\u305a\u306f $J_0(x) = 0$ \u3068\u306a\u308b $x$ \u306e\u3042\u305f\u308a\u3092\u3064\u3051\u308b\u305f\u3081\u306b\u30b0\u30e9\u30d5\u3092\u63cf\u3044\u3066\u307f\u307e\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[10]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"kn\">from<\/span> <span class=\"nn\">scipy.special<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">jv<\/span>\r\n\r\n<span class=\"k\">def<\/span> <span class=\"nf\">J0<\/span><span class=\"p\">(<\/span><span class=\"n\">x<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"n\">jv<\/span><span class=\"p\">(<\/span><span class=\"mi\">0<\/span><span class=\"p\">,<\/span><span class=\"n\">x<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"c1\"># ax \u3092\u4f7f\u3046\u969b\u306e\u6700\u521d\u306e\u304a\u307e\u3058\u306a\u3044<\/span>\r\n<span class=\"n\">fig<\/span><span class=\"p\">,<\/span> <span class=\"n\">ax<\/span> <span class=\"o\">=<\/span> <span class=\"n\">plt<\/span><span class=\"o\">.<\/span><span class=\"n\">subplots<\/span><span class=\"p\">()<\/span>\r\n\r\n<span class=\"n\">xrange<\/span> <span class=\"o\">=<\/span> <span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">linspace<\/span><span class=\"p\">(<\/span><span class=\"mi\">0<\/span><span class=\"p\">,<\/span> <span class=\"mi\">10<\/span><span class=\"p\">,<\/span> <span class=\"mi\">200<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">plot<\/span><span class=\"p\">(<\/span><span class=\"n\">xrange<\/span><span class=\"p\">,<\/span> <span class=\"n\">J0<\/span><span class=\"p\">(<\/span><span class=\"n\">xrange<\/span><span class=\"p\">))<\/span>\r\n\r\n<span class=\"c1\"># x \u8ef8<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">plot<\/span><span class=\"p\">(<\/span><span class=\"n\">xrange<\/span><span class=\"p\">,<\/span> <span class=\"mi\">0<\/span><span class=\"o\">*<\/span><span class=\"n\">xrange<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_xlabel<\/span><span class=\"p\">(<\/span><span class=\"s1\">'x'<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_ylabel<\/span><span class=\"p\">(<\/span><span class=\"s1\">'J0(x)'<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">grid<\/span><span class=\"p\">()<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_xlim<\/span><span class=\"p\">(<\/span><span class=\"mi\">0<\/span><span class=\"p\">,<\/span> <span class=\"mi\">10<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_title<\/span><span class=\"p\">(<\/span><span class=\"s1\">'\u30d9\u30c3\u30bb\u30eb\u95a2\u6570 J0(x)'<\/span><span class=\"p\">);<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_svg output_subarea \">\n<p><!--?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?--><\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-large wp-image-9973\" src=\"https:\/\/home.hirosaki-u.ac.jp\/relativity\/wp-content\/uploads\/sites\/76\/scipysk02.svg\" alt=\"\" width=\"640\" height=\"427\" \/><\/p>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<h4 id=\"scipy.optimize.root_scalar\"><code>scipy.optimize.root_scalar<\/code><\/h4>\n<p>\u65b9\u7a0b\u5f0f\u306e\u6570\u5024\u89e3\u3092\u6c42\u3081\u3066\u304f\u308c\u308b\u95a2\u6570\u306f <code>scipy.optimize.root_scalar<\/code> \u3067\u3059\u3002$2 &lt; x &lt; 3$ \u306e\u3042\u305f\u308a\u3067 $x$ \u8ef8\u3068\u4ea4\u308f\u3063\u3066\u3044\u307e\u3059\u304b\u3089\uff0c\u3053\u306e\u3042\u305f\u308a\u306e\u89e3\u3092\u63a2\u3057\u307e\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[11]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"kn\">from<\/span> <span class=\"nn\">scipy.optimize<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">root_scalar<\/span>\r\n\r\n<span class=\"c1\"># x \u304c 2 ~ 3 \u306e\u9593\u3067 j0(x) = 0 \u306e\u6839\u3092\u63a2\u3059<\/span>\r\n<span class=\"n\">root_scalar<\/span><span class=\"p\">(<\/span><span class=\"n\">J0<\/span><span class=\"p\">,<\/span> <span class=\"n\">bracket<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span><span class=\"mi\">2<\/span><span class=\"p\">,<\/span> <span class=\"mi\">3<\/span><span class=\"p\">])<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt output_prompt\">Out[11]:<\/div>\n<div class=\"output_text output_subarea output_execute_result\">\n<pre>      converged: True\r\n           flag: 'converged'\r\n function_calls: 8\r\n     iterations: 7\r\n           root: 2.404825557695807<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p><code>scipy.optimize.root_scalar()<\/code> \u306f\u7d50\u679c\u3092\u4e0a\u8a18\u306e\u3088\u3046\u306b\u8868\u793a\u3057\u307e\u3059\u3002\u89e3 <code>root<\/code> \u306e\u307f\u3092\u8868\u793a\u3057\u305f\u3044\u5834\u5408\u306f\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u3057\u307e\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[12]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"c1\"># \u6839\u306e\u307f\u3092\u51fa\u529b\u3059\u308b\u306b\u306f...<\/span>\r\n<span class=\"n\">ans<\/span> <span class=\"o\">=<\/span> <span class=\"n\">root_scalar<\/span><span class=\"p\">(<\/span><span class=\"n\">J0<\/span><span class=\"p\">,<\/span> <span class=\"n\">bracket<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span><span class=\"mi\">2<\/span><span class=\"p\">,<\/span> <span class=\"mi\">3<\/span><span class=\"p\">])<\/span>\r\n<span class=\"nb\">print<\/span><span class=\"p\">(<\/span><span class=\"n\">ans<\/span><span class=\"o\">.<\/span><span class=\"n\">root<\/span><span class=\"p\">)<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_subarea output_stream output_stdout output_text\">\n<pre>2.404825557695807\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[13]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"c1\"># \u307b\u3093\u3068\u306b\u6839\u306b\u306a\u3063\u3066\u308b\u304b\u78ba\u8a8d\u3002\u30bc\u30ed\u306b\u8fd1\u3051\u308c\u3070\u3088\u3044\u3002<\/span>\r\n<span class=\"n\">J0<\/span><span class=\"p\">(<\/span><span class=\"n\">ans<\/span><span class=\"o\">.<\/span><span class=\"n\">root<\/span><span class=\"p\">)<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt output_prompt\">Out[13]:<\/div>\n<div class=\"output_text output_subarea output_execute_result\">\n<pre>-1.7918655681235457e-14<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[14]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"c1\"># \u3069\u3046\u3057\u3066\u3082\u3082\u3063\u3068\u7cbe\u5ea6\u304c\u6b32\u3057\u3044\u3068\u3044\u3046\u306e\u3067\u3042\u308c\u3070...<\/span>\r\n<span class=\"c1\"># xtol \u306b\uff0c\u5c0f\u3055\u3044\u5024\u3092\u3044\u308c\u3066\u307f\u308b<\/span>\r\n<span class=\"n\">ans<\/span> <span class=\"o\">=<\/span> <span class=\"n\">root_scalar<\/span><span class=\"p\">(<\/span><span class=\"n\">J0<\/span><span class=\"p\">,<\/span> <span class=\"n\">bracket<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span><span class=\"mi\">2<\/span><span class=\"p\">,<\/span> <span class=\"mi\">3<\/span><span class=\"p\">],<\/span> <span class=\"n\">xtol<\/span><span class=\"o\">=<\/span><span class=\"mf\">1e-15<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ans<\/span><span class=\"o\">.<\/span><span class=\"n\">root<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt output_prompt\">Out[14]:<\/div>\n<div class=\"output_text output_subarea output_execute_result\">\n<pre>2.4048255576957724<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[15]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"c1\"># \u307b\u3093\u3068\u306b\u6839\u306b\u306a\u3063\u3066\u308b\u304b\u78ba\u8a8d\u3002\u30bc\u30ed\u306b\u8fd1\u3051\u308c\u3070\u3088\u3044\u3002<\/span>\r\n<span class=\"n\">J0<\/span><span class=\"p\">(<\/span><span class=\"n\">_<\/span><span class=\"p\">)<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt output_prompt\">Out[15]:<\/div>\n<div class=\"output_text output_subarea output_execute_result\">\n<pre>1.535884772676773e-16<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<h4 id=\"\u25cb\u7df4\u7fd2\uff1a\u95a2\u6570\u306e\u6975\u5927\u5024\">\u25cb\u7df4\u7fd2\uff1a\u95a2\u6570\u306e\u6975\u5927\u5024<\/h4>\n<ol>\n<li>$\\displaystyle f(x) = \\frac{x^3}{e^x -1}$ \u304c\u6975\u5927\u5024\u3092\u3068\u308b\u3068\u304d\u306e $x$ \u306e\u5024\uff0c\u304a\u3088\u3073\u305d\u306e\u3068\u304d\u306e\u6975\u5927\u5024\u3092\u6c42\u3081\u308b\u3002<\/li>\n<li>$\\displaystyle g(x) = \\frac{x^5}{e^x -1}$ \u304c\u6975\u5927\u5024\u3092\u3068\u308b\u3068\u304d\u306e $x$ \u306e\u5024\uff0c\u304a\u3088\u3073\u305d\u306e\u3068\u304d\u306e\u6975\u5927\u5024\u3082\u540c\u69d8\u306b\u3057\u3066\u6c42\u3081\u3066\u307f\u3088\u3002<\/li>\n<\/ol>\n<p>\u307e\u305a $f(x)$ \u306e\u6570\u5024\u5fae\u5206 <code>ndiff(f, x)<\/code> \u3092\u30b0\u30e9\u30d5\u306b\u3057\u3066\u307f\u308b\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[16]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"k\">def<\/span> <span class=\"nf\">f<\/span><span class=\"p\">(<\/span><span class=\"n\">x<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"n\">x<\/span><span class=\"o\">**<\/span><span class=\"mi\">3<\/span><span class=\"o\">\/<\/span><span class=\"p\">(<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">exp<\/span><span class=\"p\">(<\/span><span class=\"n\">x<\/span><span class=\"p\">)<\/span> <span class=\"o\">-<\/span> <span class=\"mi\">1<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"c1\"># ax \u3092\u4f7f\u3046\u969b\u306e\u6700\u521d\u306e\u304a\u307e\u3058\u306a\u3044<\/span>\r\n<span class=\"n\">fig<\/span><span class=\"p\">,<\/span> <span class=\"n\">ax<\/span> <span class=\"o\">=<\/span> <span class=\"n\">plt<\/span><span class=\"o\">.<\/span><span class=\"n\">subplots<\/span><span class=\"p\">()<\/span>\r\n\r\n<span class=\"n\">xrange<\/span> <span class=\"o\">=<\/span> <span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">linspace<\/span><span class=\"p\">(<\/span><span class=\"mi\">0<\/span><span class=\"p\">,<\/span> <span class=\"mi\">5<\/span><span class=\"p\">,<\/span> <span class=\"mi\">200<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">plot<\/span><span class=\"p\">(<\/span><span class=\"n\">xrange<\/span><span class=\"p\">,<\/span> <span class=\"n\">ndiff<\/span><span class=\"p\">(<\/span><span class=\"n\">f<\/span><span class=\"p\">,<\/span> <span class=\"n\">xrange<\/span><span class=\"p\">),<\/span> <span class=\"n\">label<\/span> <span class=\"o\">=<\/span> <span class=\"s1\">'$f^{\\prime}(x)$'<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"c1\"># x \u8ef8<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">plot<\/span><span class=\"p\">(<\/span><span class=\"n\">xrange<\/span><span class=\"p\">,<\/span> <span class=\"mi\">0<\/span><span class=\"o\">*<\/span><span class=\"n\">xrange<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_xlabel<\/span><span class=\"p\">(<\/span><span class=\"s1\">'$x$'<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_ylabel<\/span><span class=\"p\">(<\/span><span class=\"s1\">' '<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">grid<\/span><span class=\"p\">()<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">legend<\/span><span class=\"p\">();<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_svg output_subarea \">\n<p><!--?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?--><\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-large wp-image-9974\" src=\"https:\/\/home.hirosaki-u.ac.jp\/relativity\/wp-content\/uploads\/sites\/76\/scipysk03.svg\" alt=\"\" width=\"640\" height=\"427\" \/><\/p>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p><code>ndiff(f, x)<\/code> \u306f $2 &lt; x &lt;3$ \u306e\u3042\u305f\u308a\u3067\u30bc\u30ed\u306b\u306a\u3063\u3066\u3044\u308b\u306e\u3067\uff0c\u305d\u306e\u3042\u305f\u308a\u3092 <code>root_scalar()<\/code> \u3067\u63a2\u3057\u3066\u307f\u308b\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[17]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"k\">def<\/span> <span class=\"nf\">df<\/span><span class=\"p\">(<\/span><span class=\"n\">x<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"n\">ndiff<\/span><span class=\"p\">(<\/span><span class=\"n\">f<\/span><span class=\"p\">,<\/span> <span class=\"n\">x<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"n\">ans<\/span> <span class=\"o\">=<\/span> <span class=\"n\">root_scalar<\/span><span class=\"p\">(<\/span><span class=\"n\">df<\/span><span class=\"p\">,<\/span> <span class=\"n\">bracket<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span><span class=\"mi\">2<\/span><span class=\"p\">,<\/span> <span class=\"mi\">3<\/span><span class=\"p\">])<\/span>\r\n<span class=\"n\">ans<\/span><span class=\"o\">.<\/span><span class=\"n\">root<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt output_prompt\">Out[17]:<\/div>\n<div class=\"output_text output_subarea output_execute_result\">\n<pre>2.8214393721317643<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[18]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"c1\"># \u305d\u306e\u3068\u304d\u306e f(x) \u306e\u6975\u5927\u5024\u306f...<\/span>\r\n<span class=\"n\">f<\/span><span class=\"p\">(<\/span><span class=\"n\">_<\/span><span class=\"p\">)<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt output_prompt\">Out[18]:<\/div>\n<div class=\"output_text output_subarea output_execute_result\">\n<pre>1.4214354727477367<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<h3 id=\"SciPy-\u306b\u3088\u308b1\u968e\u5e38\u5fae\u5206\u65b9\u7a0b\u5f0f\u306e\u6570\u5024\u89e3\u6cd5\">SciPy \u306b\u3088\u308b1\u968e\u5e38\u5fae\u5206\u65b9\u7a0b\u5f0f\u306e\u6570\u5024\u89e3\u6cd5<\/h3>\n<h4 id=\"scipy.integrate.solve_ivp()\"><code>scipy.integrate.solve_ivp()<\/code><\/h4>\n<p>SciPy \u306b\u306f\u5e38\u5fae\u5206\u65b9\u7a0b\u5f0f\u3092\u6570\u5024\u7684\u306b\u89e3\u3044\u3066\u304f\u308c\u308b\u95a2\u6570 <code>scipy.integrate.solve_ivp()<\/code> \u304c\u7528\u610f\u3055\u308c\u3066\u3044\u307e\u3059\u3002\u305d\u308c\u3092\u4f7f\u3063\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p>\u4f8b\u3068\u3057\u3066\uff0c\u7c21\u5358\u306a\u30ed\u30b8\u30b9\u30c6\u30a3\u30c3\u30af\u65b9\u7a0b\u5f0f<\/p>\n<p>$$ \\frac{dx}{dt} = f(x) = (1-x)\\,x$$<\/p>\n<p>\u3092\uff0c\u521d\u671f\u6761\u4ef6 $t_0 = 0$ \u3067 $x_0 = x(t_0) = 0.1$\uff0c$t = t_0 = 0$ \u304b\u3089 $t_1 = 10$ \u307e\u3067\u89e3\u304d\u307e\u3059\u3002<\/p>\n<p><code>solve_ivp()<\/code> \u3092\u4f7f\u3046\u5834\u5408\u306f\u5909\u6570\u540d\u304c\u6c7a\u3081\u6253\u3061\u3067 <code>t, y<\/code> \u3067\u3059\u3002\u9023\u7acb\u5e38\u5fae\u5206\u65b9\u7a0b\u5f0f\u306e\u5834\u5408\u306f <code>y<\/code> \u304c\u30ea\u30b9\u30c8\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[19]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"kn\">from<\/span> <span class=\"nn\">scipy.integrate<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">solve_ivp<\/span>\r\n\r\n<span class=\"c1\"># scipy.integrate.solve_ivp() \u306f<\/span>\r\n<span class=\"c1\"># dy\/dt = f(t, y) \u306e\u5f62\u3092\u89e3\u304f<\/span>\r\n<span class=\"c1\"># solve_ivp \u3092\u4f7f\u3046\u969b\u306f\u5909\u6570\u540d t, y \u306f\u6c7a\u3081\u6253\u3061<\/span>\r\n<span class=\"c1\"># solve.ivp() \u306b\u6e21\u3059\u95a2\u6570\u306e\u5f15\u6570\u306e\u9806\u756a\u306b\u6ce8\u610f\u3002t \u304c\u5148<\/span>\r\n<span class=\"c1\"># \u9023\u7acb\u3067\u306a\u3044\u3068\u304d\u306f\uff0c1\u6b21\u5143\u30ea\u30b9\u30c8\u3068\u3057\u3066\u8fd4\u3059<\/span>\r\n\r\n<span class=\"k\">def<\/span> <span class=\"nf\">f<\/span><span class=\"p\">(<\/span><span class=\"n\">t<\/span><span class=\"p\">,<\/span> <span class=\"n\">y<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"n\">x<\/span> <span class=\"o\">=<\/span> <span class=\"n\">y<\/span><span class=\"p\">[<\/span><span class=\"mi\">0<\/span><span class=\"p\">]<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"p\">[(<\/span><span class=\"mi\">1<\/span><span class=\"o\">-<\/span><span class=\"n\">x<\/span><span class=\"p\">)<\/span><span class=\"o\">*<\/span><span class=\"n\">x<\/span><span class=\"p\">]<\/span>\r\n\r\n<span class=\"c1\"># t \u306e\u7bc4\u56f2<\/span>\r\n<span class=\"n\">tini<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">0<\/span>\r\n<span class=\"n\">tend<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">10<\/span>\r\n<span class=\"c1\"># \u8a08\u7b97\u3059\u308b\u70b9\u306f t \u306e\u7bc4\u56f2\u3092 N \u7b49\u5206\u3057\u3066 N+1 \u70b9<\/span>\r\n<span class=\"n\">N<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">20<\/span>\r\n<span class=\"n\">t_list<\/span> <span class=\"o\">=<\/span> <span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">linspace<\/span><span class=\"p\">(<\/span><span class=\"n\">tini<\/span><span class=\"p\">,<\/span> <span class=\"n\">tend<\/span><span class=\"p\">,<\/span> <span class=\"n\">N<\/span><span class=\"o\">+<\/span><span class=\"mi\">1<\/span><span class=\"p\">)<\/span>\r\n<span class=\"c1\"># y \u306e\u521d\u671f\u5024<\/span>\r\n<span class=\"n\">y_ini<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span><span class=\"mf\">0.1<\/span><span class=\"p\">]<\/span>\r\n\r\n<span class=\"n\">answer<\/span> <span class=\"o\">=<\/span> <span class=\"n\">solve_ivp<\/span><span class=\"p\">(<\/span><span class=\"n\">f<\/span><span class=\"p\">,<\/span> <span class=\"p\">[<\/span><span class=\"n\">tini<\/span><span class=\"p\">,<\/span> <span class=\"n\">tend<\/span><span class=\"p\">],<\/span> <span class=\"n\">y_ini<\/span><span class=\"p\">,<\/span> <span class=\"n\">t_eval<\/span> <span class=\"o\">=<\/span> <span class=\"n\">t_list<\/span><span class=\"p\">,<\/span> \r\n                   <span class=\"c1\"># \u30c7\u30d5\u30a9\u30eb\u30c8\u306e\u8a31\u5bb9\u8aa4\u5dee\u306f\u5927\u304d\u3081\u306a\u306e\u3067<\/span>\r\n                   <span class=\"c1\"># \u5c0f\u3055\u3044\u5024\u306b\u8a2d\u5b9a<\/span>\r\n                   <span class=\"n\">rtol<\/span> <span class=\"o\">=<\/span> <span class=\"mf\">1.e-12<\/span><span class=\"p\">,<\/span> \r\n                   <span class=\"n\">atol<\/span> <span class=\"o\">=<\/span> <span class=\"mf\">1.e-15<\/span><span class=\"p\">)<\/span>\r\n<span class=\"nb\">print<\/span><span class=\"p\">(<\/span><span class=\"n\">answer<\/span><span class=\"p\">)<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_subarea output_stream output_stdout output_text\">\n<pre>  message: The solver successfully reached the end of the integration interval.\r\n  success: True\r\n   status: 0\r\n        t: [ 0.000e+00  5.000e-01 ...  9.500e+00  1.000e+01]\r\n        y: [[ 1.000e-01  1.548e-01 ...  9.993e-01  9.996e-01]]\r\n      sol: None\r\n t_events: None\r\n y_events: None\r\n     nfev: 1790\r\n     njev: 0\r\n      nlu: 0\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[20]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"c1\"># ax \u3092\u4f7f\u3046\u969b\u306e\u6700\u521d\u306e\u304a\u307e\u3058\u306a\u3044<\/span>\r\n<span class=\"n\">fig<\/span><span class=\"p\">,<\/span> <span class=\"n\">ax<\/span> <span class=\"o\">=<\/span> <span class=\"n\">plt<\/span><span class=\"o\">.<\/span><span class=\"n\">subplots<\/span><span class=\"p\">()<\/span>\r\n\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">scatter<\/span><span class=\"p\">(<\/span><span class=\"n\">answer<\/span><span class=\"o\">.<\/span><span class=\"n\">t<\/span><span class=\"p\">,<\/span> <span class=\"n\">answer<\/span><span class=\"o\">.<\/span><span class=\"n\">y<\/span><span class=\"p\">[<\/span><span class=\"mi\">0<\/span><span class=\"p\">],<\/span> <span class=\"n\">s<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">10<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">grid<\/span><span class=\"p\">()<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_xlabel<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"$t$\"<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_ylabel<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"$x(t)$\"<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_title<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"\u30ed\u30b8\u30b9\u30c6\u30a3\u30c3\u30af\u65b9\u7a0b\u5f0f\u306e\u6570\u5024\u89e3\"<\/span><span class=\"p\">);<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_svg output_subarea \">\n<p><!--?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?--><\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-large wp-image-9975\" src=\"https:\/\/home.hirosaki-u.ac.jp\/relativity\/wp-content\/uploads\/sites\/76\/scipysk04.svg\" alt=\"\" width=\"640\" height=\"427\" \/><\/p>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p>\u53c2\u8003\u307e\u3067\u306b\uff0c\u89e3\u6790\u89e3\u306f<\/p>\n<p>$$x(t) = \\frac{\\exp(t)}{9 + \\exp(t)}$$<\/p>\n<p>\u3067\u3059\u3002\uff08\u89e3\u6790\u89e3\u304c\u308f\u304b\u3063\u3066\u3044\u308b\u3068\u304d\u306b\u306f\uff0c\u308f\u3056\u308f\u3056\u6570\u5024\u8a08\u7b97\u3059\u308b\u5fc5\u8981\u306f\u306a\u3044\u306e\u3067\u3059\u304c\uff0c\u7df4\u7fd2\u3068\u3044\u3046\u3053\u3068\u3067\u3002\uff09<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[21]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"c1\"># \u89e3\u6790\u89e3<\/span>\r\n<span class=\"k\">def<\/span> <span class=\"nf\">xsol<\/span><span class=\"p\">(<\/span><span class=\"n\">t<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">exp<\/span><span class=\"p\">(<\/span><span class=\"n\">t<\/span><span class=\"p\">)<\/span><span class=\"o\">\/<\/span><span class=\"p\">(<\/span><span class=\"mi\">9<\/span><span class=\"o\">+<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">exp<\/span><span class=\"p\">(<\/span><span class=\"n\">t<\/span><span class=\"p\">))<\/span>\r\n\r\n<span class=\"c1\"># ax \u3092\u4f7f\u3046\u969b\u306e\u6700\u521d\u306e\u304a\u307e\u3058\u306a\u3044<\/span>\r\n<span class=\"n\">fig<\/span><span class=\"p\">,<\/span> <span class=\"n\">ax<\/span> <span class=\"o\">=<\/span> <span class=\"n\">plt<\/span><span class=\"o\">.<\/span><span class=\"n\">subplots<\/span><span class=\"p\">()<\/span>\r\n\r\n<span class=\"c1\"># \u89e3\u6790\u89e3<\/span>\r\n<span class=\"n\">ts<\/span> <span class=\"o\">=<\/span> <span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">linspace<\/span><span class=\"p\">(<\/span><span class=\"n\">tini<\/span><span class=\"p\">,<\/span> <span class=\"n\">tend<\/span><span class=\"p\">,<\/span> <span class=\"mi\">200<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">plot<\/span><span class=\"p\">(<\/span><span class=\"n\">ts<\/span><span class=\"p\">,<\/span> <span class=\"n\">xsol<\/span><span class=\"p\">(<\/span><span class=\"n\">ts<\/span><span class=\"p\">),<\/span> <span class=\"n\">c<\/span> <span class=\"o\">=<\/span> <span class=\"s1\">'tab:blue'<\/span><span class=\"p\">,<\/span> <span class=\"n\">label<\/span><span class=\"o\">=<\/span><span class=\"s1\">'\u89e3\u6790\u89e3'<\/span><span class=\"p\">)<\/span>\r\n<span class=\"c1\"># \u6570\u5024\u89e3<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">scatter<\/span><span class=\"p\">(<\/span><span class=\"n\">answer<\/span><span class=\"o\">.<\/span><span class=\"n\">t<\/span><span class=\"p\">,<\/span> <span class=\"n\">answer<\/span><span class=\"o\">.<\/span><span class=\"n\">y<\/span><span class=\"p\">[<\/span><span class=\"mi\">0<\/span><span class=\"p\">],<\/span> <span class=\"n\">zorder<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">2<\/span><span class=\"p\">,<\/span>\r\n           <span class=\"n\">c<\/span> <span class=\"o\">=<\/span> <span class=\"s1\">'tab:orange'<\/span><span class=\"p\">,<\/span> <span class=\"n\">s<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">10<\/span><span class=\"p\">,<\/span> <span class=\"n\">label<\/span> <span class=\"o\">=<\/span> <span class=\"s1\">'\u6570\u5024\u89e3'<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">grid<\/span><span class=\"p\">()<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_xlabel<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"$t$\"<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_ylabel<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"$x(t)$\"<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_title<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"\u30ed\u30b8\u30b9\u30c6\u30a3\u30c3\u30af\u65b9\u7a0b\u5f0f\u306e\u89e3\"<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">legend<\/span><span class=\"p\">();<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_svg output_subarea \">\n<p><!--?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?--><\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-large wp-image-9976\" src=\"https:\/\/home.hirosaki-u.ac.jp\/relativity\/wp-content\/uploads\/sites\/76\/scipysk05.svg\" alt=\"\" width=\"640\" height=\"427\" \/><\/p>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<h3 id=\"SciPy-\u306b\u3088\u308b2\u968e\u5e38\u5fae\u5206\u65b9\u7a0b\u5f0f\u306e\u6570\u5024\u89e3\u6cd5\">SciPy \u306b\u3088\u308b2\u968e\u5e38\u5fae\u5206\u65b9\u7a0b\u5f0f\u306e\u6570\u5024\u89e3\u6cd5<\/h3>\n<h4 id=\"scipy.integrate.solve_ivp()\"><code>scipy.integrate.solve_ivp()<\/code><\/h4>\n<p>SciPy \u306b\u306f\u5e38\u5fae\u5206\u65b9\u7a0b\u5f0f\u3092\u6570\u5024\u7684\u306b\u89e3\u3044\u3066\u304f\u308c\u308b\u95a2\u6570 <code>scipy.integrate.solve_ivp()<\/code> \u304c\u7528\u610f\u3055\u308c\u3066\u3044\u307e\u3059\u3002\u3053\u306e\u51fd\u6570\u306f\uff0c1\u968e\u5e38\u5fae\u5206\u65b9\u7a0b\u5f0f\u3060\u3051\u3067\u306a\u304f\uff0c\u9023\u7acb1\u968e\u5e38\u5fae\u5206\u65b9\u7a0b\u5f0f\u3082\uff0c\u5f93\u3063\u3066\u9ad8\u968e\u306e\u5e38\u5fae\u5206\u65b9\u7a0b\u5f0f\u3082\u89e3\u3044\u3066\u304f\u308c\u308b\u306e\u3067\uff0c\u305d\u308c\u3092\u4f7f\u3063\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p>\u4f8b\u3068\u3057\u3066\uff0c\u7c21\u5358\u306a\u6e1b\u8870\uff0b\u5f37\u5236\u632f\u52d5\u306e\u65b9\u7a0b\u5f0f<\/p>\n<p>$$ \\frac{d^2 x}{dt^2} = -x &#8211; a \\frac{dx}{dt} + b \\cos(t) $$<\/p>\n<p>\u3092\uff0c<\/p>\n<ul>\n<li>$a , b $ \u306b\u3044\u304f\u3064\u304b\u5024\u3092\u5165\u308c\u3066<\/li>\n<li>\u521d\u671f\u6761\u4ef6 $t_0 = 0$ \u3067 $x_0 = x(t_0) = 3, v_0 = v(t_0) = 0$\uff0c<\/li>\n<li>$t = t_0 = 0$ \u304b\u3089 $t_1 = 20$ \u307e\u3067\u3092\u89e3\u304d\u307e\u3059\u3002<\/li>\n<\/ul>\n<p>2\u968e\u5e38\u5fae\u5206\u65b9\u7a0b\u5f0f\u306f\uff0c<\/p>\n<p>\\begin{eqnarray}<br \/>\n\\frac{dx}{dt} &amp;=&amp; F_1(t,x,v) = v \\\\<br \/>\n\\frac{dv}{dt} &amp;=&amp; F_2(t,x,v) = -x &#8211; a v + b \\cos t<br \/>\n\\end{eqnarray}<\/p>\n<p>\u3068\u3057\u3066\u9023\u7acb1\u968e\u5fae\u5206\u65b9\u7a0b\u5f0f\u306e\u5f62\u306b\u3057\u3066\u89e3\u304d\u307e\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[22]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"kn\">from<\/span> <span class=\"nn\">scipy.integrate<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">solve_ivp<\/span>\r\n\r\n<span class=\"c1\"># scipy.integrate.solve_ivp() \u306f<\/span>\r\n<span class=\"c1\"># dy\/dt = F(t, y) \u306e\u5f62\u3092\u89e3\u304f<\/span>\r\n\r\n<span class=\"k\">def<\/span> <span class=\"nf\">F<\/span><span class=\"p\">(<\/span><span class=\"n\">t<\/span><span class=\"p\">,<\/span> <span class=\"n\">y<\/span><span class=\"p\">,<\/span> <span class=\"n\">a<\/span><span class=\"p\">,<\/span> <span class=\"n\">b<\/span><span class=\"p\">):<\/span>\r\n<span class=\"c1\"># solve.ivp() \u306b\u6e21\u3059\u95a2\u6570\u306e\u5f15\u6570\u306e\u9806\u756a\u306b\u6ce8\u610f\u3002t \u304c\u5148<\/span>\r\n    <span class=\"n\">x<\/span> <span class=\"o\">=<\/span> <span class=\"n\">y<\/span><span class=\"p\">[<\/span><span class=\"mi\">0<\/span><span class=\"p\">]<\/span>\r\n    <span class=\"n\">v<\/span> <span class=\"o\">=<\/span> <span class=\"n\">y<\/span><span class=\"p\">[<\/span><span class=\"mi\">1<\/span><span class=\"p\">]<\/span>\r\n    <span class=\"n\">F1<\/span> <span class=\"o\">=<\/span> <span class=\"n\">v<\/span>\r\n    <span class=\"n\">F2<\/span> <span class=\"o\">=<\/span> <span class=\"o\">-<\/span><span class=\"n\">x<\/span> <span class=\"o\">-<\/span> <span class=\"n\">a<\/span><span class=\"o\">*<\/span><span class=\"n\">v<\/span> <span class=\"o\">+<\/span> <span class=\"n\">b<\/span><span class=\"o\">*<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">cos<\/span><span class=\"p\">(<\/span><span class=\"n\">t<\/span><span class=\"p\">)<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"p\">[<\/span><span class=\"n\">F1<\/span><span class=\"p\">,<\/span> <span class=\"n\">F2<\/span><span class=\"p\">]<\/span>\r\n\r\n<span class=\"n\">tini<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">0<\/span>\r\n<span class=\"n\">tend<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">20<\/span>\r\n<span class=\"n\">t_list<\/span> <span class=\"o\">=<\/span> <span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">linspace<\/span><span class=\"p\">(<\/span><span class=\"n\">tini<\/span><span class=\"p\">,<\/span> <span class=\"n\">tend<\/span><span class=\"p\">,<\/span> <span class=\"mi\">200<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">y_ini<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span><span class=\"mi\">3<\/span><span class=\"p\">,<\/span> <span class=\"mi\">0<\/span><span class=\"p\">]<\/span>\r\n\r\n<span class=\"n\">a<\/span> <span class=\"o\">=<\/span> <span class=\"mf\">0.5<\/span><span class=\"p\">;<\/span> <span class=\"n\">b<\/span> <span class=\"o\">=<\/span> <span class=\"mf\">0.2<\/span>\r\n<span class=\"n\">answer1<\/span> <span class=\"o\">=<\/span> <span class=\"n\">solve_ivp<\/span><span class=\"p\">(<\/span><span class=\"n\">F<\/span><span class=\"p\">,<\/span> <span class=\"p\">[<\/span><span class=\"n\">tini<\/span><span class=\"p\">,<\/span> <span class=\"n\">tend<\/span><span class=\"p\">],<\/span> <span class=\"n\">y_ini<\/span><span class=\"p\">,<\/span> <span class=\"n\">t_eval<\/span> <span class=\"o\">=<\/span> <span class=\"n\">t_list<\/span><span class=\"p\">,<\/span> \r\n                    <span class=\"n\">args<\/span><span class=\"o\">=<\/span><span class=\"p\">(<\/span><span class=\"n\">a<\/span><span class=\"p\">,<\/span> <span class=\"n\">b<\/span><span class=\"p\">),<\/span> \r\n                    <span class=\"c1\"># \u30c7\u30d5\u30a9\u30eb\u30c8\u306e\u8a31\u5bb9\u8aa4\u5dee\u306f\u5927\u304d\u3081\u306a\u306e\u3067<\/span>\r\n                    <span class=\"c1\"># \u5c0f\u3055\u3044\u5024\u306b\u8a2d\u5b9a<\/span>\r\n                    <span class=\"n\">rtol<\/span> <span class=\"o\">=<\/span> <span class=\"mf\">1.e-12<\/span><span class=\"p\">,<\/span> \r\n                    <span class=\"n\">atol<\/span> <span class=\"o\">=<\/span> <span class=\"mf\">1.e-15<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"nb\">print<\/span><span class=\"p\">(<\/span><span class=\"n\">answer1<\/span><span class=\"p\">)<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_subarea output_stream output_stdout output_text\">\n<pre>  message: The solver successfully reached the end of the integration interval.\r\n  success: True\r\n   status: 0\r\n        t: [ 0.000e+00  1.005e-01 ...  1.990e+01  2.000e+01]\r\n        y: [[ 3.000e+00  2.986e+00 ...  3.669e-01  3.840e-01]\r\n            [ 0.000e+00 -2.740e-01 ...  1.881e-01  1.509e-01]]\r\n      sol: None\r\n t_events: None\r\n y_events: None\r\n     nfev: 8834\r\n     njev: 0\r\n      nlu: 0\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p>\u6a2a\u8ef8\u306b $t = $ <code>answer1.t<\/code>\uff0c\u7e26\u8ef8\u306b $x(t) = $ <code>answer1.y[0]<\/code> \u3092\u3068\u3063\u3066\u30b0\u30e9\u30d5\u306b\u3057\u3066\u307f\u307e\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[23]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"c1\"># ax \u3092\u4f7f\u3046\u969b\u306e\u6700\u521d\u306e\u304a\u307e\u3058\u306a\u3044<\/span>\r\n<span class=\"n\">fig<\/span><span class=\"p\">,<\/span> <span class=\"n\">ax<\/span> <span class=\"o\">=<\/span> <span class=\"n\">plt<\/span><span class=\"o\">.<\/span><span class=\"n\">subplots<\/span><span class=\"p\">()<\/span>\r\n\r\n<span class=\"c1\"># \u6570\u5024\u89e3 x \u306f .y[0] \u306e\u3088\u3046\u306b\u3057\u3066\u53d6\u308a\u51fa\u3059<\/span>\r\n<span class=\"c1\"># \u6570\u5f0f\u3092 label \u306b\u8a2d\u5b9a\u3059\u308b\u969b\u306f $ \u3067\u56f2\u3093\u3067 LaTeX \u5f0f\u306b<\/span>\r\n<span class=\"c1\"># a, b \u306e\u5024\u3092\u51e1\u4f8b\u306b<\/span>\r\n<span class=\"n\">key<\/span> <span class=\"o\">=<\/span> <span class=\"s1\">'$a=<\/span><span class=\"si\">%3.1f<\/span><span class=\"s1\">, b=<\/span><span class=\"si\">%3.1f<\/span><span class=\"s1\">$'<\/span> <span class=\"o\">%<\/span> <span class=\"p\">(<\/span><span class=\"n\">a<\/span><span class=\"p\">,<\/span> <span class=\"n\">b<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">plot<\/span><span class=\"p\">(<\/span><span class=\"n\">answer1<\/span><span class=\"o\">.<\/span><span class=\"n\">t<\/span><span class=\"p\">,<\/span> <span class=\"n\">answer1<\/span><span class=\"o\">.<\/span><span class=\"n\">y<\/span><span class=\"p\">[<\/span><span class=\"mi\">0<\/span><span class=\"p\">],<\/span> <span class=\"n\">label<\/span><span class=\"o\">=<\/span><span class=\"n\">key<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">grid<\/span><span class=\"p\">()<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_xlabel<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"$t$\"<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_ylabel<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"$x(t)$\"<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">legend<\/span><span class=\"p\">()<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_title<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"\u6e1b\u8870\uff0b\u5f37\u5236\u632f\u52d5\"<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_xlim<\/span><span class=\"p\">(<\/span><span class=\"mi\">0<\/span><span class=\"p\">,<\/span> <span class=\"mi\">20<\/span><span class=\"p\">);<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_svg output_subarea \">\n<p><!--?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?--><\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-large wp-image-9977\" src=\"https:\/\/home.hirosaki-u.ac.jp\/relativity\/wp-content\/uploads\/sites\/76\/scipysk06.svg\" alt=\"\" width=\"640\" height=\"427\" \/><\/p>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<h4 id=\"\u25cb\u7df4\u7fd2\uff1a\u6e1b\u8870\uff0b\u5f37\u5236\u632f\u52d5\">\u25cb\u7df4\u7fd2\uff1a\u6e1b\u8870\uff0b\u5f37\u5236\u632f\u52d5<\/h4>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p>\u6e1b\u8870\uff0b\u5f37\u5236\u632f\u52d5\u306e\u65b9\u7a0b\u5f0f\u3092\u4ee5\u4e0b\u306e\u5834\u5408\u306b\u89e3\u304d\uff0c\u30b0\u30e9\u30d5\u306b\u3059\u308b\u3002<\/p>\n<p>\u307e\u305a $a$ \u306e\u5f71\u97ff\u3092\u8abf\u3079\u308b\u305f\u3081\uff0c<\/p>\n<ol>\n<li>$a = 0, b = 0$<\/li>\n<li>$a = 0.2, b = 0$<\/li>\n<li>$a = 0.5, b = 0$<\/li>\n<li>$a = 0.8, b = 0$<\/li>\n<\/ol>\n<p>\u6b21\u306b\uff0c$b$ \u306e\u5f71\u97ff\u3092\u8abf\u3079\u308b\u305f\u3081\uff0c<\/p>\n<ol>\n<li>$a = 0, b = 0$<\/li>\n<li>$a = 0, b = 0.2$<\/li>\n<li>$a = 0, b = 0.5$<\/li>\n<li>$a = 0, b = 0.8$<\/li>\n<\/ol>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<h4 id=\"\u25cb\u7df4\u7fd2\uff1a\u5358\u632f\u308a\u5b50\">\u25cb\u7df4\u7fd2\uff1a\u5358\u632f\u308a\u5b50<\/h4>\n<p>2\u968e\u5e38\u5fae\u5206\u65b9\u7a0b\u5f0f<\/p>\n<p>$$ \\frac{d^2\\theta}{dt^2} = -4\\pi^2 \\sin\\theta$$<\/p>\n<p>\u3092\u521d\u671f\u6761\u4ef6<\/p>\n<p>$$ \\theta = 45^{\\circ}, \\ \\ \\frac{d\\theta}{dt} = 0 \\quad \\mbox{at}\\ \\ t = 0$$<\/p>\n<p>\u306e\u3082\u3068\u3067 $t=0$ \u304b\u3089 $t = 5$ \u307e\u3067\u6570\u5024\u7684\u306b\u89e3\u3051\u3002<\/p>\n<p>$\\theta \\Rightarrow $ <code>y[0]<\/code>\uff0c$\\dot{\\theta} \\Rightarrow $ <code>y[1]<\/code> \u3068\u3057\u3066<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[24]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"k\">def<\/span> <span class=\"nf\">F<\/span><span class=\"p\">(<\/span><span class=\"n\">t<\/span><span class=\"p\">,<\/span> <span class=\"n\">y<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"c1\"># solve.ivp() \u306b\u6e21\u3059\u95a2\u6570\u306e\u5f15\u6570\u306e\u9806\u756a\u306b\u6ce8\u610f\u3002t \u304c\u5148<\/span>\r\n    <span class=\"n\">theta<\/span> <span class=\"o\">=<\/span> <span class=\"n\">y<\/span><span class=\"p\">[<\/span><span class=\"mi\">0<\/span><span class=\"p\">]<\/span>\r\n    <span class=\"n\">dottheta<\/span> <span class=\"o\">=<\/span> <span class=\"n\">y<\/span><span class=\"p\">[<\/span><span class=\"mi\">1<\/span><span class=\"p\">]<\/span>\r\n    <span class=\"n\">F1<\/span> <span class=\"o\">=<\/span> <span class=\"n\">dottheta<\/span>\r\n    <span class=\"n\">F2<\/span> <span class=\"o\">=<\/span> <span class=\"o\">-<\/span><span class=\"mi\">4<\/span><span class=\"o\">*<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">pi<\/span><span class=\"o\">**<\/span><span class=\"mi\">2<\/span><span class=\"o\">*<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">sin<\/span><span class=\"p\">(<\/span><span class=\"n\">theta<\/span><span class=\"p\">)<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"p\">[<\/span><span class=\"n\">F1<\/span><span class=\"p\">,<\/span> <span class=\"n\">F2<\/span><span class=\"p\">]<\/span>\r\n\r\n<span class=\"n\">tini<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">0<\/span>\r\n<span class=\"n\">tend<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">5<\/span>\r\n<span class=\"n\">t_list<\/span> <span class=\"o\">=<\/span> <span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">linspace<\/span><span class=\"p\">(<\/span><span class=\"n\">tini<\/span><span class=\"p\">,<\/span> <span class=\"n\">tend<\/span><span class=\"p\">,<\/span> <span class=\"mi\">200<\/span><span class=\"p\">)<\/span>\r\n<span class=\"c1\"># \u521d\u671f\u6761\u4ef6\u306f\u30e9\u30b8\u30a2\u30f3\u306b\u306a\u304a\u3057\u3066<\/span>\r\n<span class=\"n\">y_ini<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">radians<\/span><span class=\"p\">(<\/span><span class=\"mi\">45<\/span><span class=\"p\">),<\/span> <span class=\"mi\">0<\/span><span class=\"p\">]<\/span>\r\n\r\n<span class=\"n\">answer2<\/span> <span class=\"o\">=<\/span> <span class=\"n\">solve_ivp<\/span><span class=\"p\">(<\/span><span class=\"n\">F<\/span><span class=\"p\">,<\/span> <span class=\"p\">[<\/span><span class=\"n\">tini<\/span><span class=\"p\">,<\/span> <span class=\"n\">tend<\/span><span class=\"p\">],<\/span> <span class=\"n\">y_ini<\/span><span class=\"p\">,<\/span> <span class=\"n\">t_eval<\/span> <span class=\"o\">=<\/span> <span class=\"n\">t_list<\/span><span class=\"p\">,<\/span> \r\n                    <span class=\"c1\"># \u30c7\u30d5\u30a9\u30eb\u30c8\u306e\u8a31\u5bb9\u8aa4\u5dee\u306f\u5927\u304d\u3081\u306a\u306e\u3067<\/span>\r\n                    <span class=\"c1\"># \u5c0f\u3055\u3044\u5024\u306b\u8a2d\u5b9a<\/span>\r\n                    <span class=\"n\">rtol<\/span> <span class=\"o\">=<\/span> <span class=\"mf\">1.e-12<\/span><span class=\"p\">,<\/span> \r\n                    <span class=\"n\">atol<\/span> <span class=\"o\">=<\/span> <span class=\"mf\">1.e-15<\/span><span class=\"p\">)<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p>\u4e00\u65b9\uff0c$\\theta$ \u304c\u3042\u307e\u308a\u5927\u304d\u304f\u306a\u3044\u3068\u3059\u308c\u3070\uff0c\u30c6\u30a4\u30e9\u30fc\u5c55\u958b\u306e1\u6b21\u306e\u8fd1\u4f3c\u3067 $\\sin\\theta \\simeq \\theta$ \u3067\u3042\u308b\u304b\u3089<\/p>\n<p>$$ \\frac{d^2\\theta}{dt^2} \\simeq -4\\pi^2 \\theta$$<\/p>\n<p>$\\simeq$ \u3092 $=$ \u306b\u5909\u3048\u3066\u65b9\u7a0b\u5f0f\u306b\u3059\u308b\u3068\uff0c\u3053\u308c\u306f\u5358\u632f\u52d5\u306e\u65b9\u7a0b\u5f0f\u3067\u3042\u308b\u304b\u3089\uff0c\u540c\u3058\u521d\u671f\u6761\u4ef6\u3067\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u89e3\u6790\u7684\u306b\u89e3\u3051\u308b\u3002<\/p>\n<p>$$\\theta_s = \\theta_0 \\cos (2 \\pi t) = \\frac{\\pi}{4} \\cos (2 \\pi t)$$<\/p>\n<p>\u307e\u305f\uff0c\u3053\u306e\u3068\u304d<\/p>\n<p>$$\\dot{\\theta}_s = &#8211; \\frac{\\ \\pi^2}{2} \\sin (2 \\pi t)$$<\/p>\n<p>\u3053\u306e\u5358\u632f\u52d5\u306e\u89e3\u3082\u91cd\u306d\u3066\u30b0\u30e9\u30d5\u306b\u3057\u3066\u307f\u3088\u3002\u5468\u671f\u306b\u306f\u3069\u306e\u3088\u3046\u306a\u9055\u3044\u304c\u3042\u308b\u304b\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[25]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"c1\"># ax \u3092\u4f7f\u3046\u969b\u306e\u6700\u521d\u306e\u304a\u307e\u3058\u306a\u3044<\/span>\r\n<span class=\"n\">fig<\/span><span class=\"p\">,<\/span> <span class=\"n\">ax<\/span> <span class=\"o\">=<\/span> <span class=\"n\">plt<\/span><span class=\"o\">.<\/span><span class=\"n\">subplots<\/span><span class=\"p\">()<\/span>\r\n\r\n<span class=\"c1\"># \u6570\u5024\u89e3 x \u306f .y[0] \u306e\u3088\u3046\u306b\u3057\u3066\u53d6\u308a\u51fa\u3059<\/span>\r\n\r\n<span class=\"c1\"># \u7e26\u8ef8\u306e\u5024\u3092\u30e9\u30b8\u30a2\u30f3\u304b\u3089\u5ea6\u306b\u5909\u63db<\/span>\r\n<span class=\"n\">theta<\/span> <span class=\"o\">=<\/span> <span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">degrees<\/span><span class=\"p\">(<\/span><span class=\"mi\">1<\/span><span class=\"p\">)<\/span><span class=\"o\">*<\/span><span class=\"p\">(<\/span><span class=\"n\">answer2<\/span><span class=\"o\">.<\/span><span class=\"n\">y<\/span><span class=\"p\">[<\/span><span class=\"mi\">0<\/span><span class=\"p\">])<\/span>\r\n<span class=\"c1\"># \u6570\u5024\u89e3<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">plot<\/span><span class=\"p\">(<\/span><span class=\"n\">answer2<\/span><span class=\"o\">.<\/span><span class=\"n\">t<\/span><span class=\"p\">,<\/span> <span class=\"n\">theta<\/span><span class=\"p\">,<\/span> <span class=\"n\">label<\/span><span class=\"o\">=<\/span><span class=\"s1\">'\u6570\u5024\u89e3'<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"c1\"># \u540c\u3058\u521d\u671f\u6761\u4ef6\u306e\u5358\u632f\u52d5\u89e3<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">plot<\/span><span class=\"p\">(<\/span><span class=\"n\">t_list<\/span><span class=\"p\">,<\/span> <span class=\"mi\">45<\/span><span class=\"o\">*<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">cos<\/span><span class=\"p\">(<\/span><span class=\"mi\">2<\/span><span class=\"o\">*<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">pi<\/span><span class=\"o\">*<\/span><span class=\"n\">t_list<\/span><span class=\"p\">),<\/span> <span class=\"n\">label<\/span> <span class=\"o\">=<\/span> <span class=\"s1\">'\u5358\u632f\u52d5\u89e3'<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">grid<\/span><span class=\"p\">()<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_xlabel<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"$t$\"<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_ylabel<\/span><span class=\"p\">(<\/span><span class=\"sa\">r<\/span><span class=\"s2\">\"$\\theta$ (\u5ea6)\"<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">legend<\/span><span class=\"p\">();<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_svg output_subarea \">\n<p><!--?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?--><\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-large wp-image-9978\" src=\"https:\/\/home.hirosaki-u.ac.jp\/relativity\/wp-content\/uploads\/sites\/76\/scipysk07.svg\" alt=\"\" width=\"640\" height=\"427\" \/><\/p>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<h4 id=\"\u53c2\u8003\uff1a\u30eb\u30f3\u30b2\u30fb\u30af\u30c3\u30bf\u6cd5\u306b\u3088\u308b2\u968e\u5e38\u5fae\u5206\u65b9\u7a0b\u5f0f\u306e\u6570\u5024\u89e3\u6cd5\">\u53c2\u8003\uff1a\u30eb\u30f3\u30b2\u30fb\u30af\u30c3\u30bf\u6cd5\u306b\u3088\u308b2\u968e\u5e38\u5fae\u5206\u65b9\u7a0b\u5f0f\u306e\u6570\u5024\u89e3\u6cd5<\/h4>\n<p>\u3055\u3066\uff0cSymPy \u3067\u81ea\u4f5c\u306e\u30eb\u30f3\u30b2\u30fb\u30af\u30c3\u30bf\u6cd5 <code>rk2()<\/code> \u3092\u4f7f\u3063\u305f\u6570\u5024\u89e3\u6cd5\u306e\u969b\u306f\uff0c\u304b\u306a\u308a\u6642\u9593\u304c\u304b\u304b\u308a\u307e\u3057\u305f\u3002<\/p>\n<ul>\n<li><a href=\"https:\/\/home.hirosaki-u.ac.jp\/relativity\/%E3%82%B3%E3%83%B3%E3%83%94%E3%83%A5%E3%83%BC%E3%82%BF%E6%BC%94%E7%BF%92\/python-%E3%81%A7%E6%95%B0%E5%80%A4%E8%A7%A3%E6%9E%90\/sympy-%E3%81%A7%EF%BC%88%E3%81%82%E3%81%88%E3%81%A6%EF%BC%89%E6%95%B0%E5%80%A4%E8%A7%A3%E6%9E%90\/#i-5\">SymPy \u3066\u3099\uff08\u3042\u3048\u3066\uff09\u6570\u5024\u89e3\u6790<\/a><\/li>\n<\/ul>\n<p>NumPy \u306e\u95a2\u6570\u3092\u4f7f\u3063\u305f\u5834\u5408\u306f\u3069\u3046\u3067\u3057\u3087\u3046\u304b\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[26]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"k\">def<\/span> <span class=\"nf\">rk2<\/span><span class=\"p\">(<\/span><span class=\"n\">Func<\/span><span class=\"p\">,<\/span> <span class=\"n\">x0<\/span><span class=\"p\">,<\/span> <span class=\"n\">v0<\/span><span class=\"p\">,<\/span> <span class=\"n\">t0<\/span><span class=\"p\">,<\/span> <span class=\"n\">t1<\/span><span class=\"p\">,<\/span> <span class=\"n\">N<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"sd\">\"\"\" d^2 x\/dt^2 = Func(t, x, v) \u3092<\/span>\r\n<span class=\"sd\">        \u521d\u671f\u6761\u4ef6 t = t0 \u3067 x = x0, v = v0 \u3068\u3057\uff0c<\/span>\r\n<span class=\"sd\">        [t0, t1] \u3092 N \u5206\u5272\u3057\u3066<\/span>\r\n<span class=\"sd\">        4\u6b21\u306e\u30eb\u30f3\u30b2\u30fb\u30af\u30c3\u30bf\u6cd5\u3067\u89e3\u304f<\/span>\r\n<span class=\"sd\">    \"\"\"<\/span>\r\n    <span class=\"n\">h<\/span> <span class=\"o\">=<\/span> <span class=\"p\">(<\/span><span class=\"n\">t1<\/span> <span class=\"o\">-<\/span> <span class=\"n\">t0<\/span><span class=\"p\">)<\/span><span class=\"o\">\/<\/span><span class=\"n\">N<\/span>\r\n    <span class=\"n\">T<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span><span class=\"n\">t0<\/span><span class=\"p\">]<\/span>\r\n    <span class=\"n\">X<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span><span class=\"n\">x0<\/span><span class=\"p\">]<\/span>\r\n    <span class=\"n\">V<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span><span class=\"n\">v0<\/span><span class=\"p\">]<\/span>\r\n    <span class=\"n\">t<\/span> <span class=\"o\">=<\/span> <span class=\"n\">t0<\/span>\r\n    <span class=\"n\">x<\/span> <span class=\"o\">=<\/span> <span class=\"n\">x0<\/span>\r\n    <span class=\"n\">v<\/span> <span class=\"o\">=<\/span> <span class=\"n\">v0<\/span>\r\n    <span class=\"k\">for<\/span> <span class=\"n\">i<\/span> <span class=\"ow\">in<\/span> <span class=\"nb\">range<\/span><span class=\"p\">(<\/span><span class=\"n\">N<\/span><span class=\"p\">):<\/span>\r\n        <span class=\"n\">k1<\/span> <span class=\"o\">=<\/span> <span class=\"n\">h<\/span><span class=\"o\">*<\/span><span class=\"n\">v<\/span>\r\n        <span class=\"n\">m1<\/span> <span class=\"o\">=<\/span> <span class=\"n\">h<\/span><span class=\"o\">*<\/span><span class=\"n\">Func<\/span><span class=\"p\">(<\/span><span class=\"n\">t<\/span><span class=\"p\">,<\/span> <span class=\"n\">x<\/span><span class=\"p\">,<\/span> <span class=\"n\">v<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"n\">k2<\/span> <span class=\"o\">=<\/span> <span class=\"n\">h<\/span><span class=\"o\">*<\/span><span class=\"p\">(<\/span><span class=\"n\">v<\/span><span class=\"o\">+<\/span><span class=\"n\">m1<\/span><span class=\"o\">\/<\/span><span class=\"mi\">2<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"n\">m2<\/span> <span class=\"o\">=<\/span> <span class=\"n\">h<\/span><span class=\"o\">*<\/span><span class=\"n\">Func<\/span><span class=\"p\">(<\/span><span class=\"n\">t<\/span><span class=\"o\">+<\/span><span class=\"n\">h<\/span><span class=\"o\">\/<\/span><span class=\"mi\">2<\/span><span class=\"p\">,<\/span> <span class=\"n\">x<\/span><span class=\"o\">+<\/span><span class=\"n\">k1<\/span><span class=\"o\">\/<\/span><span class=\"mi\">2<\/span><span class=\"p\">,<\/span> <span class=\"n\">v<\/span><span class=\"o\">+<\/span><span class=\"n\">m1<\/span><span class=\"o\">\/<\/span><span class=\"mi\">2<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"n\">k3<\/span> <span class=\"o\">=<\/span> <span class=\"n\">h<\/span><span class=\"o\">*<\/span><span class=\"p\">(<\/span><span class=\"n\">v<\/span><span class=\"o\">+<\/span><span class=\"n\">m2<\/span><span class=\"o\">\/<\/span><span class=\"mi\">2<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"n\">m3<\/span> <span class=\"o\">=<\/span> <span class=\"n\">h<\/span><span class=\"o\">*<\/span><span class=\"n\">Func<\/span><span class=\"p\">(<\/span><span class=\"n\">t<\/span><span class=\"o\">+<\/span><span class=\"n\">h<\/span><span class=\"o\">\/<\/span><span class=\"mi\">2<\/span><span class=\"p\">,<\/span> <span class=\"n\">x<\/span><span class=\"o\">+<\/span><span class=\"n\">k2<\/span><span class=\"o\">\/<\/span><span class=\"mi\">2<\/span><span class=\"p\">,<\/span> <span class=\"n\">v<\/span><span class=\"o\">+<\/span><span class=\"n\">m2<\/span><span class=\"o\">\/<\/span><span class=\"mi\">2<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"n\">k4<\/span> <span class=\"o\">=<\/span> <span class=\"n\">h<\/span><span class=\"o\">*<\/span><span class=\"p\">(<\/span><span class=\"n\">v<\/span><span class=\"o\">+<\/span><span class=\"n\">m3<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"n\">m4<\/span> <span class=\"o\">=<\/span> <span class=\"n\">h<\/span><span class=\"o\">*<\/span><span class=\"n\">Func<\/span><span class=\"p\">(<\/span><span class=\"n\">t<\/span><span class=\"o\">+<\/span><span class=\"n\">h<\/span><span class=\"p\">,<\/span> <span class=\"n\">x<\/span><span class=\"o\">+<\/span><span class=\"n\">k3<\/span><span class=\"p\">,<\/span> <span class=\"n\">v<\/span><span class=\"o\">+<\/span><span class=\"n\">m3<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"n\">x<\/span> <span class=\"o\">=<\/span> <span class=\"n\">x<\/span> <span class=\"o\">+<\/span> <span class=\"p\">(<\/span><span class=\"n\">k1<\/span> <span class=\"o\">+<\/span> <span class=\"mi\">2<\/span><span class=\"o\">*<\/span><span class=\"n\">k2<\/span> <span class=\"o\">+<\/span> <span class=\"mi\">2<\/span><span class=\"o\">*<\/span><span class=\"n\">k3<\/span> <span class=\"o\">+<\/span> <span class=\"n\">k4<\/span><span class=\"p\">)<\/span><span class=\"o\">\/<\/span><span class=\"mi\">6<\/span>\r\n        <span class=\"n\">v<\/span> <span class=\"o\">=<\/span> <span class=\"n\">v<\/span> <span class=\"o\">+<\/span> <span class=\"p\">(<\/span><span class=\"n\">m1<\/span> <span class=\"o\">+<\/span> <span class=\"mi\">2<\/span><span class=\"o\">*<\/span><span class=\"n\">m2<\/span> <span class=\"o\">+<\/span> <span class=\"mi\">2<\/span><span class=\"o\">*<\/span><span class=\"n\">m3<\/span> <span class=\"o\">+<\/span> <span class=\"n\">m4<\/span><span class=\"p\">)<\/span><span class=\"o\">\/<\/span><span class=\"mi\">6<\/span>\r\n        <span class=\"n\">t<\/span> <span class=\"o\">=<\/span> <span class=\"n\">t<\/span> <span class=\"o\">+<\/span> <span class=\"n\">h<\/span> \r\n        <span class=\"n\">T<\/span><span class=\"o\">.<\/span><span class=\"n\">append<\/span><span class=\"p\">(<\/span><span class=\"n\">t<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"n\">X<\/span><span class=\"o\">.<\/span><span class=\"n\">append<\/span><span class=\"p\">(<\/span><span class=\"n\">x<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"n\">V<\/span><span class=\"o\">.<\/span><span class=\"n\">append<\/span><span class=\"p\">(<\/span><span class=\"n\">v<\/span><span class=\"p\">)<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"p\">[<\/span><span class=\"n\">T<\/span><span class=\"p\">,<\/span> <span class=\"n\">X<\/span><span class=\"p\">,<\/span> <span class=\"n\">V<\/span><span class=\"p\">]<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[27]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"k\">def<\/span> <span class=\"nf\">F<\/span><span class=\"p\">(<\/span><span class=\"n\">t<\/span><span class=\"p\">,<\/span> <span class=\"n\">x<\/span><span class=\"p\">,<\/span> <span class=\"n\">v<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"c1\"># NumPy \u306e\u95a2\u6570\u30fb\u5b9a\u6570\u3092\u4f7f\u3046<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"o\">-<\/span><span class=\"mi\">4<\/span><span class=\"o\">*<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">pi<\/span><span class=\"o\">**<\/span><span class=\"mi\">2<\/span><span class=\"o\">*<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">sin<\/span><span class=\"p\">(<\/span><span class=\"n\">x<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"n\">x0<\/span> <span class=\"o\">=<\/span> <span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">radians<\/span><span class=\"p\">(<\/span><span class=\"mi\">45<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">v0<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">0<\/span>\r\n<span class=\"n\">t0<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">0<\/span>\r\n<span class=\"n\">t1<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">3<\/span>\r\n\r\n<span class=\"k\">for<\/span> <span class=\"n\">N<\/span> <span class=\"ow\">in<\/span> <span class=\"p\">[<\/span><span class=\"mi\">100<\/span><span class=\"p\">,<\/span> <span class=\"mi\">200<\/span><span class=\"p\">,<\/span> <span class=\"mi\">400<\/span><span class=\"p\">,<\/span> <span class=\"mi\">800<\/span><span class=\"p\">,<\/span> <span class=\"mi\">1600<\/span><span class=\"p\">,<\/span> <span class=\"mi\">3200<\/span><span class=\"p\">]:<\/span>\r\n    <span class=\"n\">T2<\/span><span class=\"p\">,<\/span> <span class=\"n\">X2<\/span><span class=\"p\">,<\/span> <span class=\"n\">V2<\/span> <span class=\"o\">=<\/span> <span class=\"n\">rk2<\/span><span class=\"p\">(<\/span><span class=\"n\">F<\/span><span class=\"p\">,<\/span> <span class=\"n\">x0<\/span><span class=\"p\">,<\/span> <span class=\"n\">v0<\/span><span class=\"p\">,<\/span> <span class=\"n\">t0<\/span><span class=\"p\">,<\/span> <span class=\"n\">t1<\/span><span class=\"p\">,<\/span> <span class=\"n\">N<\/span><span class=\"p\">)<\/span>\r\n    <span class=\"c1\"># X2 \u306e\u6700\u5f8c\u306e\u8981\u7d20 X2[-1] \u3092\u8868\u793a<\/span>\r\n    <span class=\"nb\">print<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"N =<\/span><span class=\"si\">%5d<\/span><span class=\"s2\">, x(t1) =<\/span><span class=\"si\">%15.12f<\/span><span class=\"s2\">\"<\/span> <span class=\"o\">%<\/span> <span class=\"p\">(<\/span><span class=\"n\">N<\/span><span class=\"p\">,<\/span> <span class=\"n\">X2<\/span><span class=\"p\">[<\/span><span class=\"o\">-<\/span><span class=\"mi\">1<\/span><span class=\"p\">]))<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_subarea output_stream output_stdout output_text\">\n<pre>N =  100, x(t1) = 0.591465894161\r\nN =  200, x(t1) = 0.591544091180\r\nN =  400, x(t1) = 0.591548830281\r\nN =  800, x(t1) = 0.591549121191\r\nN = 1600, x(t1) = 0.591549139198\r\nN = 3200, x(t1) = 0.591549140318\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[28]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"o\">%%time<\/span>\r\n\r\n<span class=\"n\">T2<\/span><span class=\"p\">,<\/span> <span class=\"n\">X2<\/span><span class=\"p\">,<\/span> <span class=\"n\">V2<\/span> <span class=\"o\">=<\/span> <span class=\"n\">rk2<\/span><span class=\"p\">(<\/span><span class=\"n\">F<\/span><span class=\"p\">,<\/span> <span class=\"n\">x0<\/span><span class=\"p\">,<\/span> <span class=\"n\">v0<\/span><span class=\"p\">,<\/span> <span class=\"n\">t0<\/span><span class=\"p\">,<\/span> <span class=\"n\">t1<\/span><span class=\"p\">,<\/span> <span class=\"mi\">1600<\/span><span class=\"p\">)<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_subarea output_stream output_stdout output_text\">\n<pre>CPU times: user 12.1 ms, sys: 14 \u00b5s, total: 12.1 ms\r\nWall time: 11.9 ms\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p><code>rk2()<\/code> \u306f\u540c\u3058\u30b3\u30fc\u30c9\u3067\u3059\u306e\u3067\uff0c<code>F(t, x, v)<\/code> \u306b NumPy \u306e\u95a2\u6570\u3092\u4f7f\u3063\u305f\u3060\u3051\u3067\uff0c\u7d04 600 \u500d (!) \u7a0b\u5ea6\u9ad8\u901f\u306b\u306a\u3063\u3066\u3044\u308b\u3053\u3068\u304c\u308f\u304b\u308a\u307e\u3059\u3002<\/p>\n<p>\u3067\u3059\u306e\u3067\uff0c\u89e3\u6790\u7684\u306b\u8a08\u7b97\u3092\u3057\u305f\u3044\u306a\u3089 SymPy \u3067\u3059\u304c\uff0c\u6570\u5024\u8a08\u7b97\u3092\u9ad8\u901f\u306b\u3057\u305f\u3044\u306a\u3089 NumPy\uff0c\u3068\u3044\u3046\u5177\u5408\u306b\u4f7f\u3044\u5206\u3051\u304c\u809d\u5fc3\u3067\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<h4 id=\"\u25cb\u7df4\u7fd2\uff1a\u5358\u632f\u308a\u5b50\u306e\u5468\u671f\">\u25cb\u7df4\u7fd2\uff1a\u5358\u632f\u308a\u5b50\u306e\u5468\u671f<\/h4>\n<p>\u6570\u5024\u8a08\u7b97\u3067\u6c42\u3081\u305f\u5358\u632f\u308a\u5b50\u306e\u5468\u671f\u3092\u8abf\u3079\u308b\u305f\u3081\uff0c$\\dot{\\theta} =$ <code>y[1]<\/code> \u306e\u30b0\u30e9\u30d5\u3092\u63cf\u3044\u3066\u307f\u307e\u3059\u3002\u6bd4\u8f03\u306e\u305f\u3081\u306b\uff0c\u5358\u632f\u52d5\u306e\u5834\u5408\u306e $\\dot{\\theta}_s$ \u3082\u4e00\u7dd2\u306b\u30b0\u30e9\u30d5\u306b\u3057\u307e\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[29]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"c1\"># ax \u3092\u4f7f\u3046\u969b\u306e\u6700\u521d\u306e\u304a\u307e\u3058\u306a\u3044<\/span>\r\n<span class=\"n\">fig<\/span><span class=\"p\">,<\/span> <span class=\"n\">ax<\/span> <span class=\"o\">=<\/span> <span class=\"n\">plt<\/span><span class=\"o\">.<\/span><span class=\"n\">subplots<\/span><span class=\"p\">()<\/span>\r\n\r\n<span class=\"c1\"># \u6570\u5024\u89e3<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">plot<\/span><span class=\"p\">(<\/span><span class=\"n\">answer2<\/span><span class=\"o\">.<\/span><span class=\"n\">t<\/span><span class=\"p\">,<\/span> <span class=\"n\">answer2<\/span><span class=\"o\">.<\/span><span class=\"n\">y<\/span><span class=\"p\">[<\/span><span class=\"mi\">1<\/span><span class=\"p\">],<\/span> <span class=\"n\">label<\/span><span class=\"o\">=<\/span><span class=\"s1\">'\u6570\u5024\u89e3'<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"c1\"># \u540c\u3058\u521d\u671f\u6761\u4ef6\u306e\u5358\u632f\u52d5\u89e3<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">plot<\/span><span class=\"p\">(<\/span><span class=\"n\">t_list<\/span><span class=\"p\">,<\/span> <span class=\"o\">-<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">pi<\/span><span class=\"o\">**<\/span><span class=\"mi\">2<\/span><span class=\"o\">\/<\/span><span class=\"mi\">2<\/span><span class=\"o\">*<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">sin<\/span><span class=\"p\">(<\/span><span class=\"mi\">2<\/span><span class=\"o\">*<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">pi<\/span><span class=\"o\">*<\/span><span class=\"n\">t_list<\/span><span class=\"p\">),<\/span> <span class=\"n\">label<\/span> <span class=\"o\">=<\/span> <span class=\"s1\">'\u5358\u632f\u52d5\u89e3'<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">xaxis<\/span><span class=\"o\">.<\/span><span class=\"n\">set_major_locator<\/span><span class=\"p\">(<\/span><span class=\"n\">MultipleLocator<\/span><span class=\"p\">(<\/span><span class=\"mf\">0.5<\/span><span class=\"p\">))<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_xlim<\/span><span class=\"p\">(<\/span><span class=\"mi\">0<\/span><span class=\"p\">,<\/span> <span class=\"mi\">5<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">grid<\/span><span class=\"p\">()<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_xlabel<\/span><span class=\"p\">(<\/span><span class=\"s2\">\"$t$\"<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">set_ylabel<\/span><span class=\"p\">(<\/span><span class=\"sa\">r<\/span><span class=\"s2\">\"$\\dot{\\theta}$\"<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">ax<\/span><span class=\"o\">.<\/span><span class=\"n\">legend<\/span><span class=\"p\">();<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_svg output_subarea \">\n<p><!--?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?--><\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-large wp-image-9979\" src=\"https:\/\/home.hirosaki-u.ac.jp\/relativity\/wp-content\/uploads\/sites\/76\/scipysk08.svg\" alt=\"\" width=\"640\" height=\"427\" \/><\/p>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p>\u4e0a\u306e\u30b0\u30e9\u30d5\u304b\u3089\uff0c\u5358\u632f\u52d5\u306e\u5834\u5408\u306f $t = 0$ \u3067 $\\dot{\\theta} = 0$ \u304b\u3089\u59cb\u307e\u308a\uff0c$t = 0.5$ \u3067\u6298\u308a\u8fd4\u3057\uff0c$t = 1$ \u3067\u518d\u3073 $\\dot{\\theta} = 0$ \u3068\u306a\u308b\u3053\u3068\u304b\u3089\uff0c\u5468\u671f\u304c $1$ \u3067\u3042\u308b\u3053\u3068\u304c\u308f\u304b\u308a\u307e\u3059\u3002<\/p>\n<p>\u5358\u632f\u308a\u5b50\u306e\u6570\u5024\u89e3\u306e\u5834\u5408\u306f $t = 1$ \u3067\u306f\u306a\u304f\uff0c$1 &lt; t_1 &lt; 1.5$ \u306b\u3042\u308b\u3053\u3068\u304c\u308f\u304b\u308a\u307e\u3059\u3002\u3053\u306e\u5024\u3092\u6570\u5024\u7684\u306b\u6c42\u3081\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<p>\u30d2\u30f3\u30c8\uff1a\u4ee5\u4e0b\u306e\u3088\u3046\u306b\uff0c<code>x<\/code> \u3092\u5165\u308c\u308b\u3068 $t = $ <code>0<\/code> \u304b\u3089 $t = $ <code>x<\/code> \u307e\u3067\u6570\u5024\u7684\u306b\u5fae\u5206\u65b9\u7a0b\u5f0f\u3092\u89e3\u304d\uff0c\u6700\u5f8c\u306e\u5024 $\\dot{\\theta}(x)$ \u3092\u8fd4\u3059\u95a2\u6570\u3092 <code>dottheta(x)<\/code> \u3068\u3057\u3066\u5b9a\u7fa9\u3057\u3066\u307f\u307e\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[30]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"k\">def<\/span> <span class=\"nf\">F<\/span><span class=\"p\">(<\/span><span class=\"n\">t<\/span><span class=\"p\">,<\/span> <span class=\"n\">y<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"n\">theta<\/span> <span class=\"o\">=<\/span> <span class=\"n\">y<\/span><span class=\"p\">[<\/span><span class=\"mi\">0<\/span><span class=\"p\">]<\/span>\r\n    <span class=\"n\">dottheta<\/span> <span class=\"o\">=<\/span> <span class=\"n\">y<\/span><span class=\"p\">[<\/span><span class=\"mi\">1<\/span><span class=\"p\">]<\/span>\r\n    <span class=\"n\">F1<\/span> <span class=\"o\">=<\/span> <span class=\"n\">dottheta<\/span>\r\n    <span class=\"n\">F2<\/span> <span class=\"o\">=<\/span> <span class=\"o\">-<\/span><span class=\"mi\">4<\/span><span class=\"o\">*<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">pi<\/span><span class=\"o\">**<\/span><span class=\"mi\">2<\/span><span class=\"o\">*<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">sin<\/span><span class=\"p\">(<\/span><span class=\"n\">theta<\/span><span class=\"p\">)<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"p\">[<\/span><span class=\"n\">F1<\/span><span class=\"p\">,<\/span> <span class=\"n\">F2<\/span><span class=\"p\">]<\/span>\r\n\r\n<span class=\"k\">def<\/span> <span class=\"nf\">dottheta<\/span><span class=\"p\">(<\/span><span class=\"n\">x<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"n\">tini<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">0<\/span>\r\n    <span class=\"n\">tend<\/span> <span class=\"o\">=<\/span> <span class=\"n\">x<\/span>\r\n    <span class=\"n\">t_list<\/span> <span class=\"o\">=<\/span> <span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">linspace<\/span><span class=\"p\">(<\/span><span class=\"n\">tini<\/span><span class=\"p\">,<\/span> <span class=\"n\">tend<\/span><span class=\"p\">)<\/span>\r\n    <span class=\"c1\"># \u521d\u671f\u6761\u4ef6 theta0 \u306f\u30e9\u30b8\u30a2\u30f3\u306b\u306a\u304a\u3057\u3066<\/span>\r\n    <span class=\"n\">y_ini<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span><span class=\"n\">np<\/span><span class=\"o\">.<\/span><span class=\"n\">radians<\/span><span class=\"p\">(<\/span><span class=\"n\">theta0<\/span><span class=\"p\">),<\/span> <span class=\"mi\">0<\/span><span class=\"p\">]<\/span>\r\n\r\n    <span class=\"n\">answer2<\/span> <span class=\"o\">=<\/span> <span class=\"n\">solve_ivp<\/span><span class=\"p\">(<\/span><span class=\"n\">F<\/span><span class=\"p\">,<\/span> <span class=\"p\">[<\/span><span class=\"n\">tini<\/span><span class=\"p\">,<\/span> <span class=\"n\">tend<\/span><span class=\"p\">],<\/span> <span class=\"n\">y_ini<\/span><span class=\"p\">,<\/span> <span class=\"n\">t_eval<\/span> <span class=\"o\">=<\/span> <span class=\"n\">t_list<\/span><span class=\"p\">,<\/span> \r\n                        <span class=\"c1\"># \u30c7\u30d5\u30a9\u30eb\u30c8\u306e\u8a31\u5bb9\u8aa4\u5dee\u306f\u5927\u304d\u3081\u306a\u306e\u3067<\/span>\r\n                        <span class=\"c1\"># \u5c0f\u3055\u3044\u5024\u306b\u8a2d\u5b9a<\/span>\r\n                        <span class=\"n\">rtol<\/span> <span class=\"o\">=<\/span> <span class=\"mf\">1.e-12<\/span><span class=\"p\">,<\/span> \r\n                        <span class=\"n\">atol<\/span> <span class=\"o\">=<\/span> <span class=\"mf\">1.e-15<\/span><span class=\"p\">)<\/span>\r\n    <span class=\"k\">return<\/span> <span class=\"p\">(<\/span><span class=\"n\">answer2<\/span><span class=\"o\">.<\/span><span class=\"n\">y<\/span><span class=\"p\">[<\/span><span class=\"mi\">1<\/span><span class=\"p\">])[<\/span><span class=\"o\">-<\/span><span class=\"mi\">1<\/span><span class=\"p\">]<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[31]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"n\">theta0<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">45<\/span>\r\n<span class=\"n\">ans1<\/span> <span class=\"o\">=<\/span> <span class=\"n\">root_scalar<\/span><span class=\"p\">(<\/span><span class=\"n\">dottheta<\/span><span class=\"p\">,<\/span> <span class=\"n\">bracket<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span><span class=\"mi\">1<\/span><span class=\"p\">,<\/span> <span class=\"mf\">1.5<\/span><span class=\"p\">])<\/span>\r\n<span class=\"n\">t1<\/span> <span class=\"o\">=<\/span> <span class=\"n\">ans1<\/span><span class=\"o\">.<\/span><span class=\"n\">root<\/span>\r\n<span class=\"nb\">print<\/span><span class=\"p\">(<\/span><span class=\"n\">t1<\/span><span class=\"p\">)<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_subarea output_stream output_stdout output_text\">\n<pre>1.0399733431967593\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p>\u5ff5\u306e\u305f\u3081\uff0c\u6b21\u306b\u300c\u3072\u3068\u307e\u308f\u308a\u300d\u3057\u3066\u623b\u3063\u3066\u304f\u308b\u6642\u523b\u306f $2 &lt; t_2 &lt; 2.5$ \u306b\u3042\u308a\u307e\u3059\u3002$t_2$ \u3092\u6c42\u3081\uff0c\u6642\u9593\u9593\u9694 $t_2 &#8211; t_1$ \u3068 $t_1$ \u304c\u7b49\u3057\u3044\u304b\u3069\u3046\u304b\uff0c\u78ba\u8a8d\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[32]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"n\">ans2<\/span> <span class=\"o\">=<\/span> <span class=\"n\">root_scalar<\/span><span class=\"p\">(<\/span><span class=\"n\">dottheta<\/span><span class=\"p\">,<\/span> <span class=\"n\">bracket<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span><span class=\"mi\">2<\/span><span class=\"p\">,<\/span> <span class=\"mf\">2.5<\/span><span class=\"p\">])<\/span>\r\n<span class=\"n\">t2<\/span> <span class=\"o\">=<\/span> <span class=\"n\">ans2<\/span><span class=\"o\">.<\/span><span class=\"n\">root<\/span>\r\n<span class=\"nb\">print<\/span><span class=\"p\">(<\/span><span class=\"s1\">'t1      ='<\/span><span class=\"p\">,<\/span> <span class=\"n\">t1<\/span><span class=\"p\">)<\/span>\r\n<span class=\"nb\">print<\/span><span class=\"p\">(<\/span><span class=\"s1\">'t2 - t1 ='<\/span><span class=\"p\">,<\/span> <span class=\"n\">t2<\/span> <span class=\"o\">-<\/span> <span class=\"n\">t1<\/span><span class=\"p\">)<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_subarea output_stream output_stdout output_text\">\n<pre>t1      = 1.0399733431967593\r\nt2 - t1 = 1.039973343196681\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p>\u5ff5\u306b\u306f\u5ff5\u3092\u3044\u308c\u3066\uff0c$0 &lt; t &lt; 5$ \u306e\u7bc4\u56f2\u3067 $\\dot{\\theta}(t)$ \u304c\u6b63\u306e\u5074\u304b\u3089\u30bc\u30ed\u306b\u306a\u308b\u6642\u523b $t_1, t_2, t_3, \\dots$ \u3092\u6c42\u3081\uff0c\u6642\u9593\u9593\u9694\u304c\u4e00\u5b9a\u3067\u3042\u308b\u304b\uff08\u3064\u307e\u308a\uff0c\u5358\u632f\u308a\u5b50\u306e\u904b\u52d5\u304c\u78ba\u304b\u306b\u5468\u671f\u7684\u3067\u3042\u308b\u304b\uff09\u78ba\u8a8d\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing code_cell rendered\">\n<div class=\"input\">\n<div class=\"prompt input_prompt\">In\u00a0[33]:<\/div>\n<div class=\"inner_cell\">\n<div class=\"input_area\">\n<div class=\" highlight hl-ipython3\">\n<pre><span class=\"n\">t0<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span><span class=\"mi\">0<\/span><span class=\"p\">]<\/span>\r\n<span class=\"k\">for<\/span> <span class=\"n\">i<\/span> <span class=\"ow\">in<\/span> <span class=\"nb\">range<\/span><span class=\"p\">(<\/span><span class=\"mi\">1<\/span><span class=\"p\">,<\/span> <span class=\"mi\">5<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"n\">ans<\/span> <span class=\"o\">=<\/span> <span class=\"n\">root_scalar<\/span><span class=\"p\">(<\/span><span class=\"n\">dottheta<\/span><span class=\"p\">,<\/span> <span class=\"n\">bracket<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span><span class=\"n\">i<\/span><span class=\"p\">,<\/span> <span class=\"n\">i<\/span><span class=\"o\">+<\/span><span class=\"mf\">0.5<\/span><span class=\"p\">],<\/span> <span class=\"n\">xtol<\/span><span class=\"o\">=<\/span><span class=\"mf\">1e-15<\/span><span class=\"p\">)<\/span>\r\n    <span class=\"n\">t0<\/span><span class=\"o\">.<\/span><span class=\"n\">append<\/span><span class=\"p\">(<\/span><span class=\"n\">ans<\/span><span class=\"o\">.<\/span><span class=\"n\">root<\/span><span class=\"p\">)<\/span>\r\n    <span class=\"nb\">print<\/span><span class=\"p\">(<\/span><span class=\"s1\">'t<\/span><span class=\"si\">%1d<\/span><span class=\"s1\"> - t<\/span><span class=\"si\">%1d<\/span><span class=\"s1\"> = <\/span><span class=\"si\">%15.13f<\/span><span class=\"s1\">'<\/span> <span class=\"o\">%<\/span><span class=\"p\">(<\/span><span class=\"n\">i<\/span><span class=\"p\">,<\/span> <span class=\"n\">i<\/span><span class=\"o\">-<\/span><span class=\"mi\">1<\/span><span class=\"p\">,<\/span> <span class=\"n\">t0<\/span><span class=\"p\">[<\/span><span class=\"n\">i<\/span><span class=\"p\">]<\/span><span class=\"o\">-<\/span><span class=\"n\">t0<\/span><span class=\"p\">[<\/span><span class=\"n\">i<\/span><span class=\"o\">-<\/span><span class=\"mi\">1<\/span><span class=\"p\">]))<\/span>\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"output_wrapper\">\n<div class=\"output\">\n<div class=\"output_area\">\n<div class=\"prompt\"><\/div>\n<div class=\"output_subarea output_stream output_stdout output_text\">\n<pre>t1 - t0 = 1.0399733431968\r\nt2 - t1 = 1.0399733431967\r\nt3 - t2 = 1.0399733431966\r\nt4 - t3 = 1.0399733431965\r\n<\/pre>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"cell border-box-sizing text_cell rendered\">\n<div class=\"prompt input_prompt\"><\/div>\n<div class=\"inner_cell\">\n<div class=\"text_cell_render border-box-sizing rendered_html\">\n<p>\u6642\u9593\u9593\u9694\u304c\uff08\u307b\u307c\uff09\u4e00\u5b9a\u3067\u3042\u308b\u3053\u3068\u304c\u78ba\u8a8d\u3067\u304d\u305f\u3089\uff0c\u3053\u308c\u3092 $t=0$ \u306b\u304a\u3051\u308b\u521d\u671f\u6761\u4ef6 $\\theta_0 = 45^{\\circ}, \\ \\dot{\\theta}_0 = 0$ \u306e\u5834\u5408\u306e\u5468\u671f\u3068\u3057\u307e\u3059\u3002<\/p>\n<p>\u540c\u69d8\u306b\u3057\u3066\uff0c$t=0$ \u306b\u304a\u3051\u308b\u521d\u671f\u6761\u4ef6<\/p>\n<ul>\n<li>$\\theta_0 = 1^{\\circ}, \\ \\dot{\\theta}_0 = 0$ \uff08\u5358\u632f\u52d5\u89e3\u3068\u306e\u6bd4\u8f03\u3082\u517c\u306d\u3066\uff09<\/li>\n<li>$\\theta_0 = 60^{\\circ}, \\ \\dot{\\theta}_0 = 0$<\/li>\n<li>$\\theta_0 = 70^{\\circ}, \\ \\dot{\\theta}_0 = 0$<\/li>\n<li>$\\theta_0 = 80^{\\circ}, \\ \\dot{\\theta}_0 = 0$<\/li>\n<\/ul>\n<p>\u306e\u5834\u5408\u306e\u5358\u632f\u308a\u5b50\u306e\u5468\u671f\u3092\u6c42\u3081\u306a\u3055\u3044\u3002\u3053\u306e\u7d50\u679c\u304b\u3089\uff0c\u521d\u671f\u6761\u4ef6\u3068\u3057\u3066\u306e\u632f\u5e45 $\\theta_0$ \u3068\u5468\u671f\u306e\u9593\u306b\u306f\u3069\u306e\u3088\u3046\u306a\u95a2\u4fc2\u304c\u3042\u308b\u304b\uff0c\u8003\u5bdf\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<\/div>\n<\/div>\n<\/div>\n","protected":false},"excerpt":{"rendered":"<p>Python \u3067\u6570\u5024\u89e3\u6790\u3059\u308b\u305f\u3081\u306e\u30e9\u30a4\u30d6\u30e9\u30ea\u3067\u3042\u308b SciPy \u306e\u4f7f\u7528\u4f8b\u3092\u793a\u3057\u307e\u3059\u3002\u30b0\u30e9\u30d5\u306f Matplotlib \u306e pyplot.plot() \u3092\u4f7f\u3063\u3066\u63cf\u304d\u307e\u3059\u3002\u4e09\u89d2\u95a2\u6570\u306a\u3069\u306e\u6570\u5b66\u95a2\u6570\u306b\u3064\u3044\u3066\u306f\uff0cSymPy \u3092\u4f7f\u308f\u305a\uff0c\u5168\u3066 NumPy \u306e\u95a2\u6570\u3092\u4f7f\u3044\u307e\u3059\u3002<\/p><p><a class=\"more-link btn\" href=\"https:\/\/home.hirosaki-u.ac.jp\/relativity\/%e3%82%b3%e3%83%b3%e3%83%94%e3%83%a5%e3%83%bc%e3%82%bf%e6%bc%94%e7%bf%92\/python-%e3%81%a7%e6%95%b0%e5%80%a4%e8%a7%a3%e6%9e%90\/scipy-%e3%81%a7%e6%95%b0%e5%80%a4%e8%a7%a3%e6%9e%90\/\">\u7d9a\u304d\u3092\u8aad\u3080<\/a><\/p>\n","protected":false},"author":33,"featured_media":0,"parent":4481,"menu_order":20,"comment_status":"closed","ping_status":"closed","template":"","meta":{"inline_featured_image":false,"footnotes":""},"class_list":["post-4484","page","type-page","status-publish","hentry","nodate","item-wrap"],"aioseo_notices":[],"_links":{"self":[{"href":"https:\/\/home.hirosaki-u.ac.jp\/relativity\/wp-json\/wp\/v2\/pages\/4484","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/home.hirosaki-u.ac.jp\/relativity\/wp-json\/wp\/v2\/pages"}],"about":[{"href":"https:\/\/home.hirosaki-u.ac.jp\/relativity\/wp-json\/wp\/v2\/types\/page"}],"author":[{"embeddable":true,"href":"https:\/\/home.hirosaki-u.ac.jp\/relativity\/wp-json\/wp\/v2\/users\/33"}],"replies":[{"embeddable":true,"href":"https:\/\/home.hirosaki-u.ac.jp\/relativity\/wp-json\/wp\/v2\/comments?post=4484"}],"version-history":[{"count":11,"href":"https:\/\/home.hirosaki-u.ac.jp\/relativity\/wp-json\/wp\/v2\/pages\/4484\/revisions"}],"predecessor-version":[{"id":9980,"href":"https:\/\/home.hirosaki-u.ac.jp\/relativity\/wp-json\/wp\/v2\/pages\/4484\/revisions\/9980"}],"up":[{"embeddable":true,"href":"https:\/\/home.hirosaki-u.ac.jp\/relativity\/wp-json\/wp\/v2\/pages\/4481"}],"wp:attachment":[{"href":"https:\/\/home.hirosaki-u.ac.jp\/relativity\/wp-json\/wp\/v2\/media?parent=4484"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}