Bayes-Turchinの方法による EXAFSカーブフィッティング - SPring-8産業

SPring-8講習会!
<産業利用に役立つXAFSによる先端材料の局所状態解析2014>!
Bayes-Turchinの方法による
EXAFSカーブフィッティング
千葉大学 小西健久
SPring-8講習会!
<産業利用に役立つXAFSによる先端材料の局所状態解析2014>!
Bayes-Turchinの方法による
EXAFSカーブフィッティング
宣伝役(開発者ではありません): 千葉大学 小西健久
•
H. J. Krappe, H. H. Rossner, Phys. Rev. B 61, 6596 (2000)
Error analysis of XAFS measurements!
•
H. J. Krappe, H. H. Rossner, Phys. Rev. B 66, 184303 (2002)
Bayes-Turchin approach to x-ray absorption fine structure data analysis!
•
H. J. Krappe, H. H. Rossner, Phys. Rev. B 70, 104102 (2004)
Bayesian approach to background subtraction for data from the extended x-ray-absorption fine
structure
•
J. J. Rehr, J. Kozdon, J. Kas, H. J. Krappe, H. H. Rossner, J. Synchrotron Rad., 12, 70 (2005)
Bayes-Turchin approach to XAS analysis!
•
H. H. Rossner, D. Schmitz, P. Imperia, H. J. Krappe, J. J. Rehr, Phys. Rev. B 74, 134107 (2006)
Bayes-Turchin analysis of x-ray absorption data above the Fe L2,3-edges!
•
H. J. Krappe, H. H. Rossner, Phys. Scr. 79, 048302 (2009)
The Bayes–Turchin approach to the analysis of extended x-ray absorption fine-structure data
H. J. Krappe and H. H. Rossner
Helmholtz-Zentrum Berlin für Materialien und Energie
(formerly: Hahn-Meitner Institut Berlin)
EXAFSフィッティングの別の方法?
•
もうじゅうぶん確立している,誰でも使えて信頼できるやりかた
があるのに?
—— 構造/モデルが複雑な( “注意を要する” )ケース
—— EXAFSの通常の解析には(良くも悪くも)art 的な部分
( “トレーニング” “永年の経験” )がある(かもしれない)!
•
そういう怪しげなことをやって何のメリットが?
—— 普通の方法とそんなに違うわけではない(怪しくはない…)
—— いくつか良いことはある(かもしれない)
何をしたいのか①
「決まらないパラメータ」
2
EXAFSのパラメータ: E0, N, r, σ ,etc.
•
パラメータの数が多い or 何かの事情で決まるかどうか微妙なパラメータがある場合!
パラメータが多くなる/決まるかどうか微妙な例:
— EXAFSがそのパラメータに敏感でない 遠いシェル — 構造が複雑 マルチシェ
ルの解析をどうにか…— 吸収端が重なっている 3d 遷移金属の L edge… etc.
無理そうに見えても可能なこともある
“EXAFSのプロには出来る” ような場合 → プロでなくてもやりたい…
プロでも諦めるような場合でも … データに情報が含まれていることもあるかも
→ うまく状況をほぐせばなんとかなるかも
* 嘘は駄目:出来ないものは出来ないという結果が出てほしい
何をしたいのか①
「決まらないパラメータ」
!
!
パラメータの数が多い or
何かの事情で決まるかどうか微妙なパラメータがある!
•
決まらないものは拘束・固定するしかない
→ 普通は以下のように対処
→ Q1. どれを? — A1. 値が判っているもの・独立でないもの
リーズナブルな仮定が可能なもの
決まるはずのないもの
→ Q2. いくつ? — A2. パラメータの数がデータの自由度以下になるまで
EXAFSのデータの自由度:
Nfree =
2 rfilt k
何をしたいのか①
「決まらないパラメータ」
•
決まらないものは拘束・固定するしかない
→ 決まるパラメータに影響がないように
拘束・固定するとは…
•
パラメータの値についてあらかじめ持っている
知識(もしくは先入観…)を入れる
→ Bayesian で考えることができる:事前確率
Bayes の定理
P (A|B) :B が与えられたときの
A A∩B B
A の条件付き確率
Ω
P(A B)
P(A B)
P (A|B) =
, P(B|A) =
P(B)
P(A)
P (B|A)P (A)
P (A|B) =
P (B)
P (B|A)P (A)
パラメータの事前知識による拘束
簡単な例:直線のフィット
{yi } , i = 1, 2, · · · , L
•
データ:
•
モデルによるデータの表現:
•
パラメータ:傾き
•
y
yi = axi +
i
a
x
ノイズ: 分散 i
i の正規分布を仮定
y
a
パラメータ を与えたときの = {yi } の条件付き確率
L
Pcond (y|a)
exp
i=1
axi )2
(yi
2
2
i
パラメータの事前知識による拘束
!
簡単な例:直線のフィット
y
y
a
パラメータ を与えたときの = {yi } の条件付き確率
L
Pcond (y|a)
exp
axi )2
(yi
2
i=1
2
i
x
!
パラメータに関する事前の知識:事前確率
Pprior (a)
正規分布を仮定:
Pprior (a)
exp
2
a 0 )2
(a
2
2
a
a0
a
a
パラメータの事前知識による拘束
簡単な例:直線のフィット
!
y
条件付き確率:
!
L
Pcond (y|a)
exp
Pprior (a)
(a
exp
a0 )
2
事後確率:Bayes の定理
Ppost (a|y)
axi )
2
i=1
事前確率:
!
(yi
2
2
i
2
2
a
x
Pprior (a)
Pcond (y|a)Pprior (a)
L
exp
i=1
= exp
1
2
axi )2
(yi
2
2
i
a 0 )2
(a
2
2
a
L
2
2
post
a0
a
a
パラメータの事前知識による拘束
簡単な例:直線のフィット
!
Bayesian フィッティング:事後確率を最大にするパラメータを求める
Ppost (a|y)
L
i=1
= exp
1
2
axi )2
(yi
exp
!
y
Pcond (y|a)P (a)
2
a 0 )2
(a
2
i
2
2
a
2
post
を最大に,すなわち
L
!
2
post
=
(yi
i=1
axi )2
2
i
+
(a
x
a 0 )2
2
a
Pprior (a)
a
を最小にする が最適解
•
P(a) = const. (事前知識なし)のとき,通常の最小2乗法になる!
•
通常の最小2乗法にペナルティを付けた形で事前知識が入る!
•
データが事前知識を修正する!
•
EXAFSへの適用:直線の式をEXAFS公式に置き換えればよい
2
a0
a
a
何をしたいのか②
「決定したパラメータの誤差評価」
•
EXAFSカーブフィッティングで決定したパラメータの誤差評価
•
最小2乗フィッティングの誤差は通常の方法で見積もれる
しかし,これと併せて
•
データの偶然誤差/系統誤差,データの前処理,FEFFの
理論値の系統誤差等が,最終的にフィッティングで得ら
れるパラメータにどう伝播するかを評価するのは,一般
に容易ではない
通常のEXAFSカーブフィッティング解析
測定 → μ(E )
•
データ処理
χ(k) の抽出
•
-
バックグラウンド(解析する吸収端以外の寄与)を引く
規格化
μ0を引く
χexp(k)
or χexp(R)
フーリエ変換 → フーリエ・フィルタリング
•
(フィッティングに用いるデータに含まれる散乱パスを限定)
最小2乗フィッティング"
構造パラメータ
•
構造モデル:構造パラメータを含む"
•
FEFF 等:後方散乱振幅,位相シフト,非弾性減衰因子,etc.
•
EXAFS公式
モデル
χmodel(k)
or χmodel(R)
通常のEXAFSカーブフィッティング解析
測定 → μ(E )
•
データ処理
χ(k) の抽出
•
-
バックグラウンド(解析する吸収端以外の寄与)を引く
規格化
μ0を引く
χexp(k)
or χexp(R)
誤差の伝播を追えない
-
フーリエ変換 → フーリエ・フィルタリング
•
(フィッティングに用いるデータに含まれる散乱パスを限定)
最小2乗フィッティング"
構造パラメータ
•
構造モデル:構造パラメータを含む"
•
FEFF 等:後方散乱振幅,位相シフト,非弾性減衰因子,etc.
•
EXAFS公式
モデル
χmodel(k)
or χmodel(R)
Krappe-Rossner のやり方
データ処理
•
測定 → μ(E ) → FEFFの μ0 へ規格化
•
μmodel の構築
μexp(k)
μmodel = μ0, model (1+ χmodel )
μ0, model : FEFFで計算した μ0 + スプライン
•
Bayes-Turchinフィッティング"
モデルパラメータ
χmodel の構築"
•
構造モデル:構造パラメータを含む"
•
FEFF
[ 後方散乱振幅,位相シフト,非弾性減衰因子, etc. ]
•
多重散乱を含むEXAFS公式
→(多重)散乱パスの打ち切り → χmodel
μmodel(k)
モデル
Krappe-Rossner のやり方
データ処理
•
測定 → μ(E ) → FEFFの μ0 へ規格化
•
μmodel の構築
μexp(k)
μmodel = μ0, model (1+ χmodel )
μ0, model : FEFFで計算した μ0 + スプライン
•
Bayes-Turchinフィッティング"
誤差の伝播を追える
モデルパラメータ
χmodel の構築"
•
構造モデル:構造パラメータを含む"
•
FEFF
[ 後方散乱振幅,位相シフト,非弾性減衰因子, etc. ]
•
多重散乱を含むEXAFS公式
→(多重)散乱パスの打ち切り → χmodel
μmodel(k)
モデル
何をしたいのか②
「決定したパラメータの誤差評価」
•
考慮すべき誤差のソース
•
実験データのノイズ,ばらつき(偶然誤差)
•
モデル(FEFF)の誤差(系統誤差)
•
散乱振幅,位相,非弾性減衰因子に含まれる誤差(多
体効果の近似的扱い等に起因)
•
多重散乱/遠いシェルのパスを打ち切ったことによる
誤差
これらを Pcond のなかに表現する
何をしたいのか②
「決定したパラメータの誤差評価」
•
実験データ: {µi } , i = 1, 2, · · · , L
•
パラメータ:
•
g(x)
モデル による実験データの表現:
•
{xi } , i = 1, 2, · · · , N
i = 1, 2, · · · , L
µi = gi (x) +
i,
Ppost (x|µ)
Pcond (µ|x)Pprior (x)
Bayes:
何をしたいのか②
「決定したパラメータの誤差評価」
•
実験データのノイズ,ばらつき(偶然誤差)
Pexp (µ|µ )
2
exp
2
e
L
2
exp
=
(µl
µl )Fll (µl
µl ), Fl,l =
l,l =1
•
モデル(FEFF)の誤差(系統誤差)
Pmodel (µ |g(x))
e
2
model
2
L
2
model
=
(gl (x)
l,l =1
µl ) Bll (gl (x)
µl )
ll
µ2l
何をしたいのか②
「決定したパラメータの誤差評価」
•
条件付き確率 Pcond
L
Pexp (µ|µ )Pmodel (µ |g(x)) d µ
Pcond (µ|x)
µ
µ
g(x)
x
実験誤差 モデルの誤差 EXAFS公式 パラメータ
Pcond (µ|x)
2
cond
2
e
L
2
cond
(µ, g(x)) =
(gl (x)
l,l =1
C = (F
合成誤差
1
実験誤差
+B
1
)
1
モデルの誤差
µl )Cll (gl (x)
µl )
何をしたいのか②
「決定したパラメータの誤差評価」
•
条件付き確率 Pcond
Pcond (µ|x)
2
cond
2
e
L
2
cond
(µ, g(x)) =
(gl (x)
µl )Cll (gl (x)
µl )
l,l =1
C = (F
合成誤差
1
実験誤差
+B
1
)
1
モデルの誤差
•
Pcond 最大化 → 最小2乗法に相当!
•
決定されるパラメータの誤差にはモデル,実験の
誤差が反映される
EXAFS のフィッティング
1. モデルの線型化
•
(0)
初期値 x
のまわりで1次近似
N
gl (x) = gl (x0 ) +
Gln (xn
x(0)
n )
n=1
2
cond (x, µ)
T
= x Qx
T
2b x + µ
g(x
(0)
)
T
C µ
g(x(0) )
x0
x)
T
Q = G CG :情報行列
b = GT C µ
•
2
χ cond
の最小化
2
x cond = 0
g(x(0) )
Qx = b
(x
:正規方程式
Qの固有値に小さいものがあると,!
その固有ベクトルに対応するパラメータ(の線形結合)は決定できない
EXAFS のフィッティング
2. Pprior(x),Bayes
•
事前確率の導入
Pprior (x)
e
2
prior
2
N
2
prior
=
(xn
x(prior) )Ann (xn
n,n =1
Ann =
•
n nn
Bayes
Ppost (x|µ)
•
, x(prior) = x(0)
x(prior) )
の形を仮定
αn 大 → 事前確率の幅 小
Pcond (µ|x)Pprior (x)
Ppost の最大化
2
x post
=0
(Q + A)x = b :正規方程式
事前確率の入ったフィッティング Q+Aの最小の固有値 > αmin
何をしたいのか③
事前確率をデータから決めたい:Turchin
• これでOKか?
•
n 番めのパラメータに,
幅
1/
の事前確率を入れている:
n
Pprior! (x)
e
2
prior
2
N
2
prior
=
(xn
x(prior) )Ann (xn
n,n =1
Ann =
n nn
, x
(prior)
フィットにおける実験データと事前確率の
相対的な比重は αnで決まる。
•
x(prior) )
事前確率に支配されるパラメータの選択,幅の決定?
(0)
=x
再考:何をしたいのか①
「決まらないパラメータ」
!
!
パラメータの数が多い or
何かの事情で決まるかどうか微妙なパラメータがある!
•
決まらないものは拘束・固定するしかない
→ Q1. どれを? — A1. 値が判っているもの・独立でないもの
リーズナブルな仮定が可能なもの
決まるはずのないもの
→ Q2. いくつ? — A2. パラメータの数がデータの自由度以下になるまで
EXAFSのデータの自由度:
Nfree =
2 rfilt k
再考:何をしたいのか①
「決まらないパラメータ」
!
!
パラメータの数が多い or
何かの事情で決まるかどうか微妙なパラメータがある!
•
決まらないものは拘束・固定するしかない
→ Q1. どれを? — A1. 値が判っているもの・独立でないもの
実験データから決まるものと!
リーズナブルな仮定が可能なもの
決まらないもの!
決まるはずのないもの
を見分けるアルゴリズムが必要
→ Q2. いくつ? — A2. パラメータの数がデータの自由度以下になるまで
EXAFSのデータの自由度:
Nfree =
2 rfilt k
これは最大値,この数までokの保証なし
再考:何をしたいのか①
「決まらないパラメータ」
!
!
パラメータの数が多い or
何かの事情で決まるかどうか微妙なパラメータがある!
•
決まらないものは拘束・固定するしかない どういう場合に決まらないか?!
→ 情報行列 Q の小さい固有値に対応するパラメータが決まらない
(決まらないパラメータは最初にとったパラメータとは限らない)
!
!
X2
!
x2
χcond の等高線
左のケースでは,X1が Q の小さい固有値に対応し,
実験データから決まらない。
X1
!
X2 は実験結果から決まる。事前確率に支配されると
!
他のパラメータの結果を歪めてしまう。
!
!
x1,x2 も,事前確率に支配されると他のパラメータ
x1
の結果を歪める
何をしたいのか③
事前確率をデータから決めたい:Turchin
•
Turchin:実験データそのものから αn を決める — 質の良いデー
タは大きい αn を必要としないであろう etc. !
実験データに依存する αn の確率分布の存在を仮定:
•
!
P (µ| ) =
!
Pcond (µ|x)Pprior (x; )dN x
det A
P (µ| ) = const. ·
det(Q + A)
1/2
1 T
exp b (Q + A)
2
1
b
!
P ( |µ)
P (µ| )Pprior ( )
:Bayes. !
α の事前分布として幅広のものを仮定!
→ 実験データから α を決める
何が良いのか?
•
大きいパラメータ空間をそのまま扱える
•
データから決まる/決まらないパラメータの弁別
•
誤差解析
→ 難しい解析が出来る場合がある(かもしれない)
試してみたい方は…
•
解析プログラム(written by H. H. Rossner )は提供いたします
konishi@faculty.chiba-u.jp (千葉大 小西)
までご連絡ください。
•
まだドキュメント等不十分ですが、千葉までいらっしゃること
が可能であれば,プログラムの使い方もお教えいたします。
•
ただし、現状ではとても user unfriendly
— user interface 開発中,マニュアルも含めweb公開予定
•
適用例がまだ少ないので興味のある方はぜひ。