外為市場介入クレプトピア:美しい国、日本

2026/1/26

 クレプトピアは クレプトクラシー(Kleptocracy)とユートピア(Utopia)を組み合わせた造語です。Kleptocracyは権力者が国の富を奪うことを指します。  1月23日、日銀総裁の会見後に、ドル円レートが2円程シフトしていました。金融関係者の間でレートチェックがあったと噂になっていたようです。  夕方、公金を流用した資本による企業の社員が陽気に騒いでいたので、おそらく外国為替市場で通貨当局によるドル売り介入が実施されたのでしょう。  通貨当局の新しい担当者が、外為市場を経由して、また私的 ...

ReadMore

書評:BLACK WAVE

2026/1/10

Black Wave - Saudi Arabia , Iran And The Rivalry That Unravelled the Middle East Kim Ghattas BLACK WAVE - Saudi Arabia, Iran And The Rivalry That Unravelled The Middle East  2020年の出版物ですが、未読であり、価格がリーズナブルだったので購入しました。  サウジアラビアとイランのライバル関係を軸にイラン革命以後の中東の国際関係のパズ ...

ReadMore

do-Calculus: ベイジアン・ネットワークによるシナリオ分析

2026/1/25

 do-Calculusの概念を解説します。do-演算子(do-operator)と条件確率式で定義してあり、PearlのDAGを元にした因果推論の中心的な概念です。d-Calculusの三つのルールはd-separatorという概念を適用することで、ある確率分布が別の確率分布と等しいことを示すものです。直感的に把握するのは難しい概念であるかもしれません。DAGをイメージして把握した方が良いでしょう。  DAGで示した確率空間でノードの数が少なくなれば、同時確率分布、条件確率分布において計算が簡素化できま ...

ReadMore

企業が不祥事を招くコンテクストとは 書評:The Dark Pattern

2025/9/28

The Dark Pattern: The Hidden Dynamics of Corporate Scandals Palazzo Ph.D, Guido; Hoffrage Ph.D, Ulrich The Dark Pattern: The Hidden Dynamics of Corporate Scandals.  本書は良い人が悪事を働くことについて記されています。ある環境の下では、彼らは嘘をつき、詐欺に関与します。彼らの振る舞いを理解するために、著者らは彼らの性格の欠点に焦点を当てるだけで ...

ReadMore

投資ポートフォリオのストレス・テストーpgmpyベイジアン・ネットワークによるリスク評価

2025/8/6

地政学的リスク 原油価格とインフレーション  天然資源、特に原油価格を主要因に置いたインフレーションとポートフォリオを構成する各資産のストレス・テストのシナリオの一例を図示しています。ストレス・テストとして該当シナリオ1によるポートフォリオの損益を推定します。 図1 原油価格と地政学的リスクのシナリオ  中東の紛争による地政学的リスクの上昇、原油価格の変動は、必ずしも資産価格の下落に繋がりません。これは、資産価格に影響するまでに複数の経路があることが影響しています。  リスク・シナリオをDAG(Direc ...

ReadMore

書評:Autocracy,Inc.

2025/6/16

Autocracy,Inc. The Dictators Who Want to Run the World. Anne Applebaum Autocracy,Inc. The Dictators Who Want to Run the World.  Autocracy,Inc.とは著者の造語です。本書のテーマをわかりやすく表現しています。  Incは通常、Incorporated として会社組織の法人名に使います。xxx Inc.と略し会社名の終わりにつけます。統合した独裁国家、あるいは一体化した専 ...

ReadMore

書評:Our dollar, Your problem

2025/12/23

Our dollar, Your Problem: An Insider's view of seven turbulent decades of global finance, and the road ahead Kenneth Rogoff Our dollar, Your Problem: An Insider's view of seven turbulent decades of global finance, and the road ahead  最近、経済制裁をテーマにした著書にいくつか ...

ReadMore

書評:Chokepoints: American power in the age of economic warfare

2025/6/3

Chokepoints: American power in the age of economic warfare Fishman, Edward 経済制裁は軍事的な脅威に対して兵器を用いず、経済的な影響力を行使することで、該当国を制止することを意図しています。本書に取り上げている5つの出来事を通して、為政者の意思決定の相互作用で作られる現代史と、経済面でのUSドルの影響力を把握することになるでしょう。 Chokepoints: American power in the age of economic ...

ReadMore

書評:Shocks, Crises, and False Alarms: How to Assess True Macroeconomic Risk

2025/4/20

Shocks, Crises, and False Alarms: How to Assess True Macroeconomic Risk Philipp Carlsson-Szlezak, Paul Swartz Shocks, Crises, and False Alarms: How to Assess True Macroeconomic Risk  本書はマクロ経済における近年見られたような、ショック、危機などのリスクを案内します。  マクロ経済のリスクを判断するとき、リスクが実際のショック ...

ReadMore

合衆国の新関税の税率と貿易収支

2026/2/3

2025年4月2日に合衆国の新しい関税の税率が公表されました。現在の貿易収支の状況と導入される関税の税率をまとめます。 合衆国の貿易収支 図1 合衆国の貿易収支2023年(単位:USD million)  図1は、左側が輸出国、右側が輸入国です。マウスポインタを領域の上に置くと、輸出入額(単位:100万USドル)を表示します。 データソースはJETROがまとめている貿易投資年報より参照。 新関税の税率と各国の対米貿易収支 図2 関税率と対米貿易収支 対米貿易収支は、輸出額から輸入額を減算した値(単位:10 ...

ReadMore

ファイナンス リスクモデル

為替レートと地政学的リスク- 割り込まれた時系列データのCausalPyによる分析

 R版の因果推論パッケージCausalImpactの評価のために、軍事侵攻が外国為替レートに与えた影響を、counterfactual推論(注1)の例として紹介しました。このCausalImpactのPython実装版がgoogleから提供されました。これはTensorFlow Probabilityの上に実装されています。その他、Python用の因果推論パッケージが多くリリースされています。その中でPyMCの因果推論ライブラリCausalPyを取り上げ、前述のR版CausalImpactで用いたデータセットを使ってこの実装を評価してみます。

注1:Counterfactual

実際の観測値に反する推論。もしその割り込み(intervention)が発生していなければ、観測データはどうなっていたかを実際とは異なる状況を想定して推論します。ここでは、ツールの評価用に入手が容易な時系列データのサンプルとして為替レートを用います。

因果推論ライブラリ

 ここで評価するツール以外にもPythonの因果推論パッケージが多くリリースされいます。西海岸の企業だけでなく、ハイテク企業やコンピュータサイエンスに力を入れている大学などが、最近、AIへの投資を増加させているので、Googleの他、複数の企業や研究機関からベイジアンと機械学習に関連した因果推論ライブラリが提供されています。別の機会にいくつか紹介したいと思います。

tfCausalImpact

 TensorFlow Probabilityは、当初、EdwordとしてTensorFlowを使って実装されていたPythonのベイジアンライブラリをTensorFlowが本体に取り込んで、機能を追加したものです。TensorFlowがKerasを内部に取り込んで本体のAPIとして提供しているのと同様です。以前のKerasやEdwordは外部ライブラリでなくTensorFlow内のAPIとして提供されています。

  • インストール
pip install tfCausalimpact

 APIの引数の仕様はR版を踏襲しており、ほぼ同じ仕様です。結果の出力も以下の記事で解説しているR版のCαusalImpactと同一の仕様になっています。

CausalPy

 CausalPyはPyMCをベースにした因果推論パッケージです。

 APIの引数の仕様は以下の”割り込まれた時系列データの例”を参照してください。結果の表示におけるHDIはHighest Density Intervalsを意味し0を含む、94%の信頼区間として定義してあります。

  • インストール
pip install CausalPy

割り込まれた時系列データの例

 R版のCausalImpactの評価で用いたデータセット(期間2021-05-12 ~ 2023-03-17のドル円為替レート)を使って、CausalPyの時系列データに対する割り込み(intervention)を評価します。最初にCausalPyをインポートします。

import arviz as az
import pandas as pd

import causalpy as cp
%load_ext autoreload
%autoreload 2
%config InlineBackend.figure_format = 'retina'
seed = 42
The autoreload extension is already loaded. To reload it, use:
  %reload_ext autoreload

 CausalImpactで用いた為替レートのデータ(USDJPY.csv)を読み込みます。

 pd.readcsv(index_colum = 0)でインデックスカラムを指定して読み込んだ場合、dateがindexとして認識されますがデータ型が文字列になります。このままCausalPyのAPIに渡すとindexがTimestamp型でないため、エラーになります。そのため、index_columを設定せずにcsvを読み込み、データフレームのインデックスをTimestamp型に設定します。

urlpath = "./../ファイルパス/USDJPY.csv"

#df_x = pd.read_csv(urlpath,index_col=0)
df_x = pd.read_csv(urlpath)
df_x.index = pd.to_datetime(df_x['date'])
df_x = df_x.drop('date',axis=1)

 割り込みの日時を設定し、新しいデータフレームを作ります。

treatment_time = pd.to_datetime("2022-02-25")
df = pd.DataFrame({ 'x':df_x['t'],'y':df_x['close']})
df.head()

データ系列は以下のようになります。

 モデルを定義し、PyMCのサンプラーを実行します。fomulaの定義"y ~ 1 + x"の最初の項の1は、線形回帰においてインターセプトを適合させるかどうか(0または1)を意味します。

result = cp.pymc_experiments.InterruptedTimeSeries(
    df,
    treatment_time,
    formula="y ~ 1 + x",
    model=cp.pymc_models.LinearRegression(sample_kwargs={"random_seed": seed}),
)

 サンプリングが終了しました。結果を表示します。

fig, ax = result.plot()

 R版CasalImpactと比較して,CausalPy版のCausalImpactも同じ三つのパネルを表示します。同様の結果を確認することができます。

result.summary()

総合的な影響による推論 - Synthetic controlの例

 CausalPyを使った複数のユニットの中の特定のユニットに処置を施す合成コントロール(Synthtic control)の例として、複数の通貨バスケットの中での出来事の影響によるJPYの推移を調べてみます。Synthetic controlのcounterfactualの例を外国為替レートに応用して検証してみましょう。

 日本円以外の主要国の通貨のクロスレートを用いて調べてみます。他通貨との比較をわかりやすくするために、円の為替レートはUSDJPYでなくJPYUSDを使います。通貨のクロスレートの単位を合わせるために、USD 1 : JPY 100でスケールを変換しています。ここで用いるJPYUSDの指標は、実際のJPYUSDレートを100倍しています。

 次の通貨、AUD,CHF,EUR,GBPを使います。counterfactual予測の前に、線形回帰と同様の考えで、これらの通貨を用いてJPYUSDを近似します。これらの通貨をdonor poolとみなし、JPYの結果を予測します。treatmentの時期は、前の割り込み時系列の例と同じ日程の2022年2月末日で設定します。シミュレーション後にtreatment以後のJPYのcounterfactual予測と実際のデータを比較します。

 主要通貨の対ドルレートのデータを’’crossUSD.csv"を読み込みます。

urlpath = "./ファイルパス/crossUSD.csv"

df_x = pd.read_csv(urlpath)
df_x.index = pd.to_datetime(df_x['date'])
df_x = df_x.drop('date',axis=1)
df2 = pd.DataFrame({ 'aud':df_x['Audusd'],'chf':df_x['Chfusd'],'eur':df_x['Eurusd'],'gbp':df_x['Gbpusd'],'y':df_x['Jpyusd']})
df2

 データフレームは以下のようになります。

 Synthetic control estimatorの予測には、pymc_modelsモジュールからWeightedSumFitter()を用います。

model2 = cp.pymc_models.WeightedSumFitter()

 formulaの構造は、以下の定義になります。interceptはfitさせません。

formula2 = 'y ~ 0 + aud + chf + gbp + eur'

 モデルを定義して、サンプラーを動かします。

treatment_time = pd.to_datetime("2022-02-28")
model2 = cp.pymc_models.WeightedSumFitter()
formula2 = 'y ~ 0 + aud + chf + gbp + eur'
results = cp.pymc_experiments.SyntheticControl(
    df2,
    treatment_time,
    formula = formula2,
    model = model2
)

 サンプリングが終了しました。結果を表示します。

fig, ax = results.plot()

results.summary()

 結果を見ると、図のSynthetic Controlとの間で幾らかの乖離があります。出来事の前まで、地域的に近いAUDとの連動の割合が大きかった分、実際の観測値は、AUDの推移より大きな変動をもたらしていることを意味しています。欧州通貨同様にエネルギー需給の影響を強く受けているため、乖離は大きくなってます。

 Synthetic controlの各通貨の重みの係数を表示します。

ax = az.plot_forest(results.idata, var_names="beta", figsize=(6, 3))
ax[0].set(title="Estimated weighting coefficients");

-ファイナンス, リスクモデル
-, , , , , ,