• 検索結果がありません。

金融工学 アプリケーションにおける 数理計画法の実際

N/A
N/A
Protected

Academic year: 2021

シェア "金融工学 アプリケーションにおける 数理計画法の実際"

Copied!
76
0
0

読み込み中.... (全文を見る)

全文

(1)

金融工学

アプリケーションにおける 数理計画法の実際

田辺隆人

[email protected]

[email protected]

(株)数理システム

(2)

ポートフォリオ

( )

j j t

j Asset

R x r x r x

  

j

1 ,

j Asset

x

  x

j

0

(3)

収益率の期待値とリスク

( )

j j t

j Asset

E R x r x r x

  

 

,

( )

ij i j t

i j Asset

V R x Q x x x Qx

  

(4)

ファクターモデル(収益率)

j j jk k j

k

r      f  

r      

f

(5)

ファクターモデル

(分散共分散)

2

, , ,

,

f

ij k l j k i l ij i

k l Factor

Q Q    

   

Q f

Q

t

2

(6)

中間変数の導入

(

2

)

t t f t t

x QxxQxx diagx

(

2

) ,

t f t

s Q s x diagx

 

x s  

t

m×m m×n

n×n

(7)

中間変数 なし .vs. あり

計算結果

内点法 有効制約法

計算時間 メモリ所要 計算時間 メモリ所要

なし 201 550M 74 550M

あり 1 30M 0.75 30M

(使用環境:NUOPT9.1 Core2 1.6GHz メモリ2GBytes

(8)

中間変数 なし .vs. あり

サンプル点 における収益率

全サンプル点の収益率

k

( )

k

j j j Asset

R x r x

 

k

k

r

j

x R x

   

 

(9)

中間変数 なし .vs. あり

Qx x

x x

Q

j t

Asset j

i

i

ij

,

1 1

( ) ( ) ,

t t t

x R R R R x s s

K K

   

x R

R

s  (  )

n×n

|K|×n

(10)

中間変数 なし .vs. あり

• |K| = 60の場合

内点法 有効制約法

n=1000 n=2000 n=1000 n=2000

なし 40 219 1 6 あり 1 4 0.3 0.5

(使用環境:NUOPT9.1 Core2 1.6GHz メモリ2GBytes

(11)

中間変数 なし .vs. あり

その他にも

あえて変数を消去しない方が有利な ケースあり

x z  

1

x   z

(12)

内点法 .vs. 有効制約法

A

t

O

Q D

A

非零な変数に対応する列

(13)

内点法 .vs. 有効制約法

インデックス運用の場合の目的関数

, , ,

, ,

2 2

( ) ( )

( )( )

( )

B

f B B

k l j k j l i i j j

i j Asset k l Factor

B

j j j

j Asset

V R x R x

Q x x x x

x x

 

 

の非零が多いと

有効制約法は不利B

x

(14)

内点法 .vs. 有効制約法

組み入れ

銘柄数 内点法 有効制約

リスク 最小化 指向

782 1.0 2.6

中庸 404 1.0 1.2

収益率 最大化 指向

179 1.0 0.8

の組み入れ銘柄数

x

B 1329

(使用環境:NUOPT9.1 Core2 1.6GHz メモリ2GBytes

(15)

内点法 .vs. 有効制約法

有効制約法

○基底が得られる

○リスタートの効率が良い

○組み入れ銘柄が尐ない

内点法

○縮退に関する情報が得られる

(16)

リスク尺度の一般化

サンプル点 における収益率

k

( )

k

j j j Asset

R x r x

 

k

(17)

リスク尺度の一般化

リスク尺度 意味

分散

絶対偏差

下方リスク で負のものの絶対値の和

一次の下方積分積率

が所与の定数値を下回るものの 和の合計

CVaR最小化 の最大から p(所与)個の平均値

Maximum drawdown の部分列の最大と最小の差

k ( ) R x

k ( )

R x

k ( ) k( )

2

E R x  E R x

( ) ( )

k k

E R x  E R x

k ( ) R x

k ( ) R x

(18)

CVaR 最小化

1

k k Sample

p s

 

k

( ) s

k

    R x

k

0,

sx 

最小化 制約

投資可能集合

(19)

分散.vs.CVaR

分散最小化による社債ポートフォリオ 期待収益率=1.281(最小)

(20)

分散.vs.CVaR

分散最小化による社債ポートフォリオ 期待収益率=1.4

(21)

分散.vs.CVaR

分散最小化による社債ポートフォリオ 期待収益率=1.5

(22)

分散.vs.CVaR

CVaR最小化による社債ポートフォリオ 期待収益率=1.504(最小)

(23)

一般の分布

分散最小化による社債ポートフォリオ 期待収益率=1.55

(24)

分散.vs.CVaR

分散最小化による社債ポートフォリオ 期待収益率=1.6

(25)

分散 .vs.CVaR

分散

○簡便

×fat tail なケースへの対処

• CVaR

×大量データ必要

○LPとなる

fat tail なケースのコントロール

(26)

内点法 .vs. 単体法

CVaR最小化

サンプル数 内点法 単体法

5000 0.6 3.3

10000 2.1 24.3

20000 4.7 107.5

50000 12.9 ――

100000 42.3 ――

(使用環境:NUOPT9.1 Core2 1.6GHz メモリ2GBytes

(27)

内点法 .vs. 単体法

CVaR最小化の双対問題

内点法 単体法

5000 0.4 0.2

10000 1.5 0.7

20000 4.0 2.6

50000 18.6 15.0

100000 41.7 67.9

サンプル数

(使用環境:NUOPT9.1 Core2 1.6GHz メモリ2GBytes

(28)

内点法 .vs. 単体法

CVaR

最小化でフロンティア曲線

内点法+クロスオーバー

⇒基底解⇒リスタート

クロスオーバー 0.1

リスタート時間平均 23.7

リスタート時間最小 12.8

リスタート時間最大 24.9

総合計 397.8

16点の描画,サンプル数10000

(使用環境:NUOPT9.1 Core2 1.6GHz メモリ2GBytes

(29)

組み入れ比率の定義

ロング・ショートモデル

0

long short buy sell

j j j j j j

xxxxdd

, , , 0

long short buy sell

j j j j

x x d d

(30)

整数変数不要な要件

ターンオーバー上限制約

取引コスト最小化

buy sell

j j

j

ddT

buy sell

j j

j

d d

  

最小化

(31)

整数変数が必要となる要件

ポジションの等式制約

一般の投資制約

long j j

xLT

i long i

j j j

A xb

ij buyj i

j

C dd

(32)

整数変数の導入

ロング・ショート

購入・売却

, (1 )

long long long short short long

j j j j j j

xU

xU

, (1 )

buy buy buy sell sell buy

j j j j j j

dU

dU

(33)

分枝限定法の性能

収益率最大化>リスク最小化

⇒ 組み入れ銘柄数

相補性制約>>銘柄数制約 ⇒ 効率的な補強の有無

(34)

ロングショートモデルの補強

制約追加

表現の変更

0

,

buy long buy

j j j j

short sell

j j

d x x d

x d j Long

  

 

2 2 2

(x j )  (xlongj )  (xshortj )

(35)

16点のフロンティア曲線描画

ロングショートモデルの性能

計算時間平均 23.7 計算時間最小 11.2 計算時間最大 34.0 総時間合計 392.3

(使用環境:NUOPT9.1 Core2 1.6GHz メモリ2GBytes

(36)

非線形計画法の用途

フィッティング

誤差最小化

判別分析

誤判別最小化

(37)

一階微係数のみ .vs. 二階微係数

主双対内点法の理論的成果

メリット関数(バリアペナルティ関数)

のもとでの大域的収束

適当な の更新方法のもとでの 超一次収束

 ( ) log( ) ( ) )

,

(x f x x g x

F   ii

H. Yamashita, H. Yabe, and T. Tanabe,

A globally and superlinearly convergent primal-dual interior point trust region method for large scale constrained optimization, Mathematical Programming Ser.B,January 2005, Vol.102, Number 1, pp.111-151 (2005)

(38)

超一次収束(

n=20000

解近傍では

Newton法が効果を発揮

(39)

一階微係数のみ .vs. 二階微係数

実務的なフィッティング問題

方法 反復回数 停留条件残差 誤差二乗和 計算時間

二階微係数 112 5.0e-7 1257.6 67.8 一階微係数のみ 300 1.8e-2 2452.8 105.5

(使用環境:NUOPT9.1 Core2 1.6GHz メモリ2GBytes

(40)

一階微係数のみ .vs. 二階微係数

実務的なフィッティング問題

(41)

一階微係数のみ .vs. 二階微係数

格付け推移確率行列推定問題

方法 反復回数 微係数計算

時間 誤差二乗和 二階微係数 9 925 1 一階微係数のみ 128 3676 3

二階微係数 計算コストに 見合う効果

(使用計算機:PentiumM1.4GHz,メモリ1.5GBytes

(42)

一階微係数のみ

.vs.

二階微係数

格付け推移確率行列推定問題

繰り返し構造を利用した

自動微分法の工夫

微係数計算時間

925秒 ⇒ 100秒

田辺隆人,

数理計画法に適した自動微分算法の開発と実装 中央大学博士論文

(使用計算機:PentiumM1.4GHz,メモリ1.5GBytes

(43)

微係数が連続 .vs. 不連続

絶対値関数の扱い

イディオム 最小化 f

最小化 s

s f s

  

制約

0

s

(44)

微係数が連続 .vs. 不連続

絶対値関数の扱い

(45)

判別分析

計測結果から性質を予想する

(46)

判別分析

計測結果から性質を予想する

Iris virsinica Iris versicolor

Iris versicolor Iris virsinica

(47)

数理計画モデル

変数

目的関数

0 1 1 2 2 3 3 4 4

a a X a X a X a X

 

0

, ,

1 2

,

3

,

4

(

a a a a a

パラメータ)

1 versicolor e

e

なのに が1/2以上になる (誤判定)確率

1, 2, 3, 4 (

X X X X 計測データ)

(48)

判別分析

ロジスティクス関数

 ( ) 

versicolor virsinica

(49)

判別の実際(パラメータ推定)

NUOPT

入力 出力

非線形最適化 アルゴリズム

判別モデルパラメータ 数理計画

モデル

(50)

判別の実際(予測力検証)

正解率100%

(51)

判別分析

ロジスティクス関数

ηの値によって倒産確率が決定

( ) 

(52)

η :財務諸表の関数形

線形モデル

0 1 1 2 2 3 3 4 4

0

t

a a X a X a X a X a

     

  a X

1

,

2

,

3

,

4

( )

X X X XX

財務諸表の値

0

, ,

1 2

,

3

,

4

( )

a a a a aa

パラメータ

(53)

η :財務諸表の値の関数

二次モデル

0

t t

  aa X X QX

11 12 13 14

21 22 23 24

31 32 33 34

41 42 43 44

q q q q

q q q q

q q q q

q q q q

 

 

  

 

 

 

 

Q

パラメータ

(二次項)

表現力 増大

(54)

倒産判別のための 数理計画モデル

変数

目的関数

0

t t

  aa X X QX

0

, ,

a a Q

(パラメータ)

1 1

e e e

e

倒産データについては が1に近い 存続データについては が0に近い

(55)

倒産判別のための 数理計画モデル

制約

Q

が半正定値

予測力 向上

(56)

半正定値制約の意義

倒産・存続の境界線の形状(制約なし)

X

2

X

1

囲われる領域は 非有界

(57)

半正定値制約の意義

倒産・存続の境界線の形状(制約あり)

X

2

X

1

予測力向上

(58)

切除平面法による解法

1. 内点法起動

2. 半正定値性のチェック(OKなら終了)

3. カットの追加,1へ

ループ(~30回)

(59)

切除平面法.vs.非線形SDP用内点法

方法 尤度 計算時間

切除平面法 143.745 30.3

非線形SDP 143.747 1.5

(使用計算機:Pentium4 3.2GHz,メモリ1GBytes

(60)

ノルム最小化問題

GX

F

0 X

最小化 制約

Given

非線形SDPの応用例

⇒相関行列の生成

(61)

相関を持った乱数を発生したい

相関行列

G

を恣意的に決定したい

アセット1とアセット2は逆相関だから

G[1,2] = -0.6くらいかな

アセット2とアセット3は強い相関があるので

G[2,3] = 0.8 にしたい

...

相関行列は と分解できねばならない

⇒ 正定値でなければならない

GLL

T

(62)

正定値?

固有値がすべて正

あらゆる について

v

t

0

v Gv

無限個の制約が必要

半正定値:最小固有値で0を許す

(63)

半正定値行列

ノルム最小化問題

GX

F

:

X  I

半正定値

最小化 制約

最も近い相関行列の生成

(64)

SIMPLE によるモデル記述

Set N; // 行列の各要素

Element i(set=N),j(set=N);

Variable x(index=(i,j));

Parameter a(index=(i,j)); // 与えられた行列の要素 SymmetricMatrix m((i,j));

Parameter minEig; // 出力される相関行列の最小固有値 m[i,i] = 1 - minEig; // 対角は 1 とする

m[i,j] = x[i,j], i > j; // 下三角部分の定義 m >= 0; // 半正定値制約

Objective diffnrm(type=minimize); // 差の行列のノルム diffnrm = sum(pow(x[i,j]-a[i,j],2),(i,j,i < j));

(65)

実行

(66)

ロバストポートフォリオ

収益率のぶれ(線形)

収益率のぶれ(二次)

共分散のぶれ

1 2

{ | ( )

t

( ) }

r r

U r r r

r r

{ || | }

U

r

r r   r

{ |

U L

}

U

Q

Q Q   Q Q

(67)

non- ロバスト

マルコビッツモデル

max

. . 1

T T

x

T

r x x Qx s t x e

リスク回避係数

Qの変動を考慮しない

(68)

ロバスト

分散のぶれを考慮

 

 

max max

. . 1

L U

T T

w Q Q Q

T

r x x Qx

s t x e

 

(69)

ロバストマルコビッツモデル

等価な問題への変形

 

max

. . 1

1 0 0, 0

T

U L

x

T

T

r x Q U Q L

s t x e

U L x x

U L

 

Fabozzi Kolm, Pachamanova Focardi,

Robust Portfolio Optimization and Management,2007

(70)

実行

(71)

ロバスト性の検証

正定値行列100ケースについて

リスクを比較

(72)

端株処理

組み入れ比率 ⇒ 購入量を得たい

long long j

j j

j

rd y mb

mb

long long long

j j j j

y rd mb d

理想購入量

最小取引金額

(価格情報含む)

実現可能購入量 丸めは上か下か

(0-1変数)

(73)

端株処理

目的関数(例)

指定した購入,売却量との差

理想購入量との差

その他リスク尺度

2 2

1 1

long long short short

j j

j T j T

y M y M

   

2 2

1 1

long long short short

j j j j

j T j T

y y y y

   

 

(74)

銘柄分割

ポートフォリオを全体属性

(金額,ファクター構成)の制約下で

グループ分け

,

1

k j k

u

銘柄jはグループk

に属するか(0-1変数)

(75)

銘柄分割

制約

,

m m

k j j k

j J

F f u

 

m m m

HIGH k LOW

FFF

銘柄jmという属性の値 グループkの属性値

属性値に関する制約

(76)

メタヒューリスティクスアルゴリズム の利用

離散計画について

妥当な時間で良質な実行可能解

⇒ グルーピング 端株処理

には好適

参照

関連したドキュメント

By us- ing a merit function, a sequential quadratic programming method associated with global trust regions bypasses the non-convex problem.. This method is established by following

Veeramani, “On existence of equilibrium pair for constrained generalized games,” Fixed Point Theory and Applications, vol.. Veeramani, “On best proximity pair theorems and

[文献] Ballarino, Gabriele and Fabrizio Bernardi, 2016, “The Intergenerational Transmission of Inequality and Education in Fourteen Countries: A Comparison,” Fabrizio Bernardi

We present and analyze a preconditioned FETI-DP (dual primal Finite Element Tearing and Interconnecting) method for solving the system of equations arising from the mortar

施工計画書 1)工事概要 2)計画工程表 3)現場組織表 4)主要機械 5)主要資材 6)施工方法 7)施工管理計画. 8)緊急時の体制及び対応

奥村 綱雄 教授 金融論、マクロ経済学、計量経済学 木崎 翠 教授 中国経済、中国企業システム、政府と市場 佐藤 清隆 教授 為替レート、国際金融の実証研究.

紀陽インターネット FB へのログイン時の認証方式としてご導入いただいている「電子証明書」の新規

入学願書✔票に記載のある金融機関の本・支店から振り込む場合は手数料は不要です。その他の金融機