「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > Numpy でループなしで 1D 配列のローリング標準偏差を効率的に計算するにはどうすればよいですか?

Numpy でループなしで 1D 配列のローリング標準偏差を効率的に計算するにはどうすればよいですか?

2024 年 11 月 17 日に公開
ブラウズ:796

How can I efficiently calculate rolling standard deviation for a 1D array in Numpy without loops?

Numpy での 1D 配列の効率的なローリング ウィンドウの実装

ローリング ウィンドウの概念には、データ シーケンスの反復処理と計算の適用が含まれます。指定されたウィンドウ長内のデータのサブセットに変換します。与えられたコンテキストでは、タスクは Python ループを使用せずに Numpy で 1D 配列のローリング標準偏差を計算することです。

標準偏差は Numpy.std を使用して簡単に取得できますが、ローリング ウィンドウ部分はチャレンジ。ただし、ブログ投稿で紹介されている 'rolling_window' 関数を活用することで、その機能を 1D 配列に拡張できます。

'rolling_window' 関数は、一連の重なり合うウィンドウに再配置された入力配列のビューを作成します。これらのウィンドウでの効率的な計算が容易になります。目的の関数 (この場合は Numpy.std) を各ウィンドウに適用すると、目的のローリング計算が得られます。

次のコード スニペットを考えてみましょう。

import numpy as np

# Create a 1D array
observations = np.array([1, 2, 3, 4, 5, 6, 7, 8, 9, 10])

# Specify window length
window_length = 3

# Calculate rolling windows
rolling_windows = rolling_window(observations, window_length)

# Calculate rolling standard deviations
rolling_stds = np.std(rolling_windows, axis=1)

# Print the results
print("Rolling standard deviations:", rolling_stds)

この例では、「rolling_windows」は重複するウィンドウを表し、「rolling_stds」は計算されたローリング標準偏差を取得します。これらの計算に Numpy 関数を採用することで効率が向上し、計算における Python ループの必要性がなくなりました。

最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3