<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/">
  <channel>
    <title>Python on Sunfit Brain Lab.</title>
    <link>https://blog.sunfit-brain.com/tags/python/</link>
    <description>Recent content in Python on Sunfit Brain Lab.</description>
    <generator>Hugo -- gohugo.io</generator>
    <language>ja-jp</language>
    <lastBuildDate>Sat, 29 Apr 2023 20:20:00 +0900</lastBuildDate><atom:link href="https://blog.sunfit-brain.com/tags/python/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>Jaxを使った常微分方程式の数値解析</title>
      <link>https://blog.sunfit-brain.com/posts/ode_jax/</link>
      <pubDate>Sat, 29 Apr 2023 20:20:00 +0900</pubDate>
      
      <guid>https://blog.sunfit-brain.com/posts/ode_jax/</guid>
      <description>Jax.numpy使いたいし力学系も解析したい 今のところ、Jax.numpyの速さを実感しつつもメカニズムは理解していない。 が、どうせJax.numpyを使う機会が増えるので、力学系解析もJax.numpyでできるようにする。
ライブラリは、Diffraxを用いる。
https://github.com/patrick-kidger/diffrax
ODEだけではなく、SDEも簡単に扱える。今回はODEだけ。 CDE（Controlled Differeitial Equation）も扱えるらしいが、これが何かはまだ分かっていない。
とりあえず、Duffing方程式の時間発展までを行ってコードを確認する。
$$ \begin{aligned} \dot{x} &amp;amp;= v,\ \dot{v} &amp;amp;= x - x^3 - ev + \gamma\cos(\omega t). \end{aligned} $$
importとソルバーに入れる関数は以下。
import jax.numpy as jnp from diffrax import diffeqsolve, ODETerm, Dopri5, SaveAt, PIDController def Duffing(t, X, args): x, v = X dx = v dv = x - x**3 - args[&amp;#39;e&amp;#39;]*v + args[&amp;#39;g&amp;#39;]*jnp.cos(t) return [dx, dv] 関数の引数は、scipyのodeintと同じで、時間 tと変数 Xとパラメータ argsとする。
パラメータの与え方はいくつか考えられるが、今回は辞書型で与えている。
次に、実際に時間発展させるコードを見る。
ARGS = {&amp;#39;e&amp;#39;: 0.</description>
    </item>
    
  </channel>
</rss>
