Skip to main content

Emses output manager

Project description

Lang: 日本語 | English

emout

PyPI version Python Docs CodeQL License: MIT

EMSES シミュレーション出力の解析・可視化 Python ライブラリ

emout でできること:

  • .h5 グリッド出力と plasma.inp / plasma.toml を 1 行で読み込めるファサード
  • データの次元に応じて最適な表示を自動選択する 1D / 2D / 3D プロット
  • !!key dx=...,to_c=... ヘッダーから自動生成される EMSES ⇄ SI 単位変換(30 種以上の物理量に対応)
  • EMSES の finbound 境界形状を Python オブジェクトとして操作できる API


インストール

pip install emout

# 3D 可視化(PyVista)を使う場合
pip install "emout[pyvista]"

# インストール済み version と PyPI の更新確認
emout version --check-update

Dask によるリモート実行は Python 3.10 以上で自動的に有効になります(別途インストール不要)。


Codex plugin

emout の Codex plugin emout Context は、シミュレーション出力ディレクトリや別 repo で Codex を起動したときにも、emout の軸順序・単位変換・可視化・remote_figure・トラブルシュートの文脈を使えるようにします。

emout codex install-plugin

このコマンドで Codex marketplace を登録したあと、Codex を起動して /plugins から emout Context を install してください。手動導入や marketplace 更新は Codex plugin 導入手順 を参照してください。


クイックスタート

import emout

data = emout.Emout("output_dir")

# 最終ステップの電位を xz 平面(y=ny/2)でプロット — これだけで SI 単位付きカラーマップ
data.phisp[-1, :, data.inp.ny // 2, :].plot()

変数名は EMSES のファイル名から自動解決されます:

data.phisp          # 電位 (GridDataSeries — 時系列)
data.nd1p           # 種1 数密度
data.j1x            # 種1 電流密度 x成分
data.j1xy           # j1x + j1y 自動結合 → 2D ベクトル
data.j1xyz          # 3D ベクトル
data.icur, data.pbody  # テキスト出力 (pandas DataFrame)

スライスの軸順序は (t, z, y, x) です。


機能ガイド

各機能の詳しい使い方はユーザーガイドを参照してください。

機能 できること ガイド
プロット plot() / cmap() / contour() で 1D/2D プロット → プロット
アニメーション gifplot() で GIF/HTML 生成、複数パネルレイアウト → アニメーション
パラメータ data.inp.nx, data.toml.species[0].wp → パラメータ
単位変換 data.unit.v.reverse(1.0), data.phisp[-1].val_si → 単位変換
境界メッシュ data.boundaries.mesh(), plot_surfaces へのオーバーレイ → 境界メッシュ
バックトレース data.backtrace.get_probabilities(...), get_backtrace(...) → バックトレース
3D (PyVista) plot3d(mode="box"/"stream"/"quiver") → クイックスタート
リモート実行 Dask Actor で計算ノードに処理を委譲、ローカルは画像だけ → リモート実行

代表的な使い方

プロット

data.phisp[-1, 100, :, :].plot()                       # 2D カラーマップ
data.phisp[-1, 100, :, :].contour()                     # 等高線
data.nd1p[-1, 100, :, :].plot(norm="log", vmin=1e-3)    # 対数スケール
data.j1xy[-1, 100, :, :].plot()                          # ストリームライン
data.phisp[-1, :, 32, 32].plot()                         # 1D プロファイル

アニメーション

data.phisp[:, 100, :, :].gifplot()                                  # Jupyter インライン
data.phisp[:, 100, :, :].gifplot(action="save", filename="out.gif") # GIF 保存

単位変換

data.unit.v.trans(1.0)       # SI → EMSES
data.phisp[-1].val_si        # 全 3D 配列を SI [V] で取得

境界メッシュ

data.boundaries[0].mesh()                   # 個別境界の MeshSurface3D
data.phisp[-1].plot_surfaces(               # フィールド上にオーバーレイ
    ax=ax, surfaces=data.boundaries,
)

粒子データ

p4 = data.p4                               # 種4
p4.vx[0].val_si.to_series().hist(bins=200)  # 速度分布
追加出力の結合 / 入出力パスの分離
# 継続出力の結合
data = emout.Emout("output_dir", ad="auto")

# 入力ファイルと出力ディレクトリを分離
data = emout.Emout(input_path="/path/to/plasma.toml", output_directory="output_dir")

リモート実行 (Dask) — 実験的

HPC の計算ノードにデータ処理を委譲し、ログインノードにはプロット画像だけを返します。 新規コードでは Emout.remote() を使う explicit な書き方を推奨します。 従来の「サーバーが起動していれば自動的に remote」という挙動も、後方互換の互換モードとして当面は残しています。

# ターミナルでサーバーを起動(1 回だけ)
emout server start --partition gr20001a --memory 60G

emout server は TLS 認証を自動設定し、デフォルトでは 1 ユーザー 1 サーバーに 制限されます。追加セッションが必要な場合は emout server start --allow-multiple --name <session> を使ってください。

ログインノードで field 配列を誤ってローカル materialize したくない場合は、 emout.disable_local_data_access() または EMOUT_LOCAL_DATA_POLICY=remote_required を使えます。Emout(..., local_data_policy="allow") で小さいデータだけ明示的にローカル読み込みを許可できます。

import matplotlib.pyplot as plt
import emout
from emout.distributed import remote_figure, remote_scope

data = emout.Emout("output_dir").remote()

# 推奨: remote object を明示的に持つ
with remote_scope():
    ymid = int(data.inp.ny // 2)

    with remote_figure():
        plt.figure(figsize=(18, 16))
        data.phisp[-1, 180:400, ymid, :].plot()
        (-data.exz[-1, 180:400, ymid, :]).plot()
        plt.title("remote expression example")

# 互換モード: 既存の plot() コードもそのまま動く
local_data = emout.Emout("output_dir")
local_data.phisp[-1, :, 100, :].plot()    # 2D スライスだけ転送
plt.xlabel("x [m]")                       # ローカル matplotlib で追記可能

# 全操作をサーバーで実行(ローカルにはPNG画像のみ)
with remote_figure():
    local_data.phisp[-1, :, 100, :].plot()
    plt.axhline(y=50, color="red")
    plt.title("カスタムタイトル")

# CLI / バッチ実行ではファイル保存も可能
with remote_figure(savefilepath="figures/phisp.png"):
    local_data.phisp[-1, :, 100, :].plot()
    plt.title("saved remotely")

# 拡張子からフォーマットを推定
with remote_figure(savefilepath="figures/phisp.svg"):
    local_data.phisp[-1, :, 100, :].plot()

# open/close 形式 — 既存コードへの導入が容易
from emout.distributed import RemoteFigure

rf = RemoteFigure()
rf.open()
local_data.phisp[-1, :, 100, :].plot()
rf.close()

# Jupyter セルマジック — セル先頭に書くだけ
# %load_ext emout.distributed.remote_figure
# %%remote_figure
# local_data.phisp[-1, :, 100, :].plot()

savefilepath を指定すると画像はそのまま保存されます。IPython では PNG/JPEG を 従来どおり inline 表示しつつ、CLI / バッチ実行ではローカル表示を行いません。

backtrace の重い計算もサーバーで実行し、可視化パラメータだけ変えて何度でも再描画できます。 data.backtrace.get_probabilities(...) でも data.remote().backtrace.get_probabilities(...) でも、 どちらも専用 proxy を返せるようになっています (バックトレース API 自体の詳細は バックトレースガイド)。

複数シミュレーションの比較も可能です:

data_a = emout.Emout("/sim_a")
data_b = emout.Emout("/sim_b")
result_a = data_a.backtrace.get_probabilities(...)
result_b = data_b.backtrace.get_probabilities(...)

with remote_figure(figsize=(12, 5)):
    plt.subplot(1, 2, 1)
    result_a.vxvz.plot()
    plt.subplot(1, 2, 2)
    result_b.vxvz.plot()

リモート実行ガイド

実験的機能(ポアソン方程式 / バックトレース)
# ポアソン方程式
from emout.utils import poisson
phi = poisson(rho, dx=dx, btypes=btypes, epsilon_0=cn.epsilon_0)

# バックトレース(要 vdist-solver-fortran)
result = data.backtrace.get_probabilities(x, y, z, vx, vy, vz, ispec=0)
result.vxvz.plot()

コントリビュート

バグ報告・機能提案・PR を歓迎します。

  • バグ / 質問: GitHub Issues に再現手順を添えて投稿してください
  • PR: main から作業ブランチを切り、pytest -q がグリーンの状態で送ってください
  • ドキュメント: README.md(日本語)と README.en.md(英語)は対応する形で維持されています。片方を更新したらもう片方にも反映してください

開発環境のセットアップやディレクトリ構成は AGENTS.md にまとまっています。


ライセンス

MIT License

リンク

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

emout-2.16.0.tar.gz (196.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

emout-2.16.0-py3-none-any.whl (210.7 kB view details)

Uploaded Python 3

File details

Details for the file emout-2.16.0.tar.gz.

File metadata

  • Download URL: emout-2.16.0.tar.gz
  • Upload date:
  • Size: 196.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for emout-2.16.0.tar.gz
Algorithm Hash digest
SHA256 78157ac37918d6fad9d48d821a55ede9421965294b0b01a330eda808a3d6d570
MD5 c235a8b39f3b222fdcfbe6b24d0ea508
BLAKE2b-256 743e0a71f92aaebf9f63805e834717d588d3486cb6220fdceb90b22805d25597

See more details on using hashes here.

File details

Details for the file emout-2.16.0-py3-none-any.whl.

File metadata

  • Download URL: emout-2.16.0-py3-none-any.whl
  • Upload date:
  • Size: 210.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for emout-2.16.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9fd7db05438402e854447b05054f4ff3966eac8ca6d2eb7ac68bab4b3ca1573b
MD5 db673eecaf06f5bed4112c3be87c51d3
BLAKE2b-256 f73cddc9e5eb20e7219bebe74187f95b66a616ac13d9e6bb14eaf8372780f7a4

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page