3
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

金融予測ラベリング応用編: 米雇用統計タートルズ戦略

Last updated at Posted at 2020-05-09

雇用統計とは

米雇用統計とは、米国労働省(U.S. Department of Labor Bureau of Labor Statistics)が毎月発表する、米国の雇用情勢を調べた景気関連の経済指標の事です。全米の企業や政府機関などに対してサンプル調査を行い、10数項目の統計が発表されます(失業率、非農業部門就業者数、建設業就業者数、製造業就業者数、小売業就業者数、金融機関就業者数、週労働時間、平均時給など)。雇用情勢の推移は、個人所得・個人消費などにも関係し、また今後の景気動向にも大きな影響を与えます。この統計の中でも「非農業部門就業者数」と「失業率」の2項目が特に注目されていて、FOMC(連邦公開市場委員会)の金融政策の決定にも大きな影響を与えると言われています。FXにおいては、最大の経済指標と言われており、数字の推移に関係なく変動する場合も多く、イベント化していると言えます。 参照元:YahooJapanファイナンス

2020年の5月8日発表の雇用統計

米国では4月、労働市場が急激に悪化。非農業部門雇用者数は前月から2050万人減少し、失業率は前月の3倍余りとなる14.7%に上昇した。 参照元:Bloomberg

投資対象インデックス

ダウ平均に着目する。アメリカの経済を代表する株価指数で、上場している中でも特に一流の企業たちの株価に基づいて計算されている。

マクロ分析

アメリカの失業者数が増えれば、政府の税収はほとんど個人の所得税からなので、コロナからの大幅な失業者数は政府にとって大損失になる。コロナショックの影響で、ひたすら金融緩和を続けているが、政府の資金で債券や株を大量に購入する状況が続く中、政府の収入も減れば、例えるなら、家族の大黒柱が家族全員失業しても一人で家庭を支えなければいけない状況と一緒で、家庭崩壊する危険性がある。つまり、大家族が15%も失業したら、大黒柱一人では大変だろうから、残りの85%の家族にも付けが回らざるを得ない状況になる。

投資戦略

毎月発表される雇用統計で、マクロ的な観点からも影響はあると見受けられるが、発表後の一か月間にトレンドが実際に存在していたら、前回の記事のタートルズ手法でトレンドに乗ることが出来るはずである。

データセット

データはここ:ダウ平均ここ:失業率からダウンロードする。
ただ、曜日の設定は難易度が高い。というのも、基本的に米雇用統計の発表日は第一金曜日だが、問題は、その日が祝日だと第二金曜日になるということであり、祝日かどうかも米国の祝日なので、ここは大雑把に変更した。取引自体は第二月曜日から日足ベースで行うことにした。

rate
2019-06-10 3.6
2019-07-08 3.7
2019-08-12 3.7
2019-09-09 3.7
2019-10-14 3.5
2019-11-11 3.6
2019-12-09 3.5
2020-01-13 3.5
2020-02-10 3.6
2020-03-09 3.5
2020-04-13 4.4
2020-05-11 14.7

次にダウ平均のデータセットである。ここは特に曖昧な点はないと思われる。

open high low close
date
2020-05-08 24107.82 24349.90 24107.05 24331.32
2020-05-07 23837.21 24094.62 23834.39 23875.89
2020-05-06 23978.88 24054.59 23661.14 23664.64
2020-05-05 23958.88 24169.72 23868.91 23883.09
2020-05-04 23581.55 23769.56 23361.16 23749.76
2020-05-01 24120.78 24120.78 23645.30 23723.69
2020-04-30 24585.57 24585.57 24186.90 24345.72
2020-04-29 24490.37 24764.77 24453.99 24633.86
2020-04-28 24357.17 24512.24 24031.20 24101.55
2020-04-27 23866.15 24207.65 23840.61 24133.78
2020-04-24 23628.24 23826.00 23417.68 23775.27
2020-04-23 23543.09 23885.36 23483.35 23515.26

データセットの分析

Dow_versus_umemployment_rate.png
まずは純粋に過去70年間の失業率とダウ平均について見ていこう。これだけ見ても、正直ダウが強すぎて、むしろ失業率が高くなってもダウは永遠に上がるのではないかと思われるかもしれない。だが、失業率が特に歴史的に高い水準(8%超え)などの場所では、全然違う風景が見えるかもしれない。

scatters.png

これは、全体の散布図である。失業率が高い部分ではむしろ価格が上がる傾向がみられる。株価が上がり続けているのでそういう傾向なのだろうか。しかし、ほとんどランダムではある。この特徴量では正直トレンド予測は出来なさそうだが、一応タートルズ投資戦略を実行してみる。

戦略の実装

戦略のパフォーマンスの実験するために、まずは失業率でフィルタリングせずに、そのまま適用してみよう。今回はあまりにも期間が長く、より一般性を持たせるため、エントリーしてから清算するまでの価格変化率でみることにした。また、ロングもショートも許容している。

T = 20
long_entry = df["High"] > df["High"].rolling(T).max().shift(1)
short_entry = df["Low"] < df["Low"].rolling(T).min().shift(1)
close_long = df["Low"] < df["Low"].rolling(T//5).min().shift(1)
close_short = df["High"] > df["High"].rolling(T//5).max().shift(1)

X = df["Close"].values
N = len(X)
label = [np.nan]*N
long = long_entry.values
short = short_entry.values
l_close = close_long.values
s_close = close_short.values
for n in range(N):
    if long[n]:
        for m in range(n, N):
            if l_close[m]:
                label[n] = (X[m]-X[n])/X[n]
                break
    if short[n]:
        for m in range(n, N):
            if s_close[m]:
                label[n] = (X[n]-X[m])/X[n]
                break
labels = pd.DataFrame(label, index=df.index, columns=["bin"])
labels

なので、パフォーマンスの計測は以下のようになる。

(1+labels.fillna(0)).cumprod()

turtles_strategy.png

今回のタートルズ戦略では、確かに1960年代、1970年代で物凄い利益率を叩き出していた。アメリカでこの手法を用いて伝説的な存在になったトレーダーも大体この時期に取引している。途中で資産が200倍以上になり、最終的には2倍になっている。ただ、こちらはシグナルが連続で出ているときは何度もポジションを保有するため、もしかしたら、めちゃくちゃ賭けているのかもしれない。ただ、1960年代、1970年代で、利益的であったことには間違いない。

失業率でフィルタリングしたときの戦略

今回は失業率が8%以上のときのみ取引しようと思う。そして、失業率が高い時は、ショートのみで戦おうと思う。

import numpy as np
from tqdm import tqdm
T = 20
short_entry = (df["Low"] < df["Low"].rolling(T).min().shift(1)) | (df["unemployment_rate"] > 8)
close_short = df["High"] > df["High"].rolling(T//5).max().shift(1)

X = df["Close"].values
N = len(X)
label = [np.nan]*N
long = long_entry.values
short = short_entry.values
l_close = close_long.values
s_close = close_short.values
for n in tqdm(range(N)):
    if short[n]:
        for m in range(n, N):
            if s_close[m]:
                label[n] = (X[n]-X[m])/X[n]
                break
labels = pd.DataFrame(label, index=df.index, columns=["bin"])
labels

turtles_strategy_with_ur.png

残念ながら、途中で破産してしまった。

結論

実際、失業率でトレンドを検知することは難しそうである。また、ダウ平均が強すぎて、失業率が高くなってもここでショートするのは極めて危険である。また今回のタートルズ手法では、損切ラインを儲けていないため、損失がかなり大きくなりやすく、リスク管理を含めたラベリングをする必要がある。

3
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?