AkaiKKRのSICをOFFにするメモ

  • bccPtの全エネルギーの格子定数依存性に変な不連続
  • SICが原因
  • source/cstate.fの編集で対処可能


bccPt-jump.pngFig.1: bcc Pt の全エネルギージャンプ問題



bccPtの全エネルギーのジャンプ問題


AkaiKKR BBSのStep-wise shift of total energy along with lattice constantsにて体心立方構造(bcc)のプラチナの全エネルギー計算を行うと、特定の格子定数で階段状のエネルギーシフトが起こると報告しています。KKR Administratorさんの返信によると自己相互作用補正(Self-Interaction Correction; SIC)が悪さをしているとのことです。この問題に対処するには明示的にSICをOFFにするなどの方法があります。このためには source/cstate.fsicfalse に指定すればよいとのことです。

問題の再現


まず全エネルギーのジャンプの問題を再現するために以下の入力ファイルのテンプレートを用いて、格子定数を a = 5.2 - 6.6 Bohr の範囲で計算を行いました。

c------------------------------------------------------------
go data/bccPt_ABOHR
c------------------------------------------------------------
c brvtyp a c/a b/a alpha beta gamma
bcc ABOHR, , , , , ,
c------------------------------------------------------------
c edelt ewidth reltyp sdftyp magtyp record
0.001 1.2 sra mjw nmag 2nd
c------------------------------------------------------------
c outtyp bzqlty maxitr pmix
update 4 200 0.01
c------------------------------------------------------------
c ntyp
1
c------------------------------------------------------------
c type ncmp rmt field mxl anclr conc
Pt 1 1 0.0 2
78 100
c------------------------------------------------------------
c natm
1
c------------------------------------------------------------
c atmicx atmtyp
0 0 0 Pt
c------------------------------------------------------------


Fig.1に格子定数と全エネルギーの関係を示します。a = 5.5 Bohr と a = 5.6 Bohr の間で全エネルギーにジャンプがある事がわかります。

source/cstate.fの編集


このエネルギーのジャンプの問題を解決するためには source/cstate.f を編集して再び make し、実行ファイルを作成しなおす必要があります。AkaiKKR BBSでは2種類の解決方法が提示されていますが、今回は単純にSICをOFFにする方法を試します。

source/cstate.f の最初のほうに以下のような記述があります。

      data istop/50/, tol/1d-8/, eb/-20d0/, sic/.true./
& ,eoff/ 1d3, 1d3, 1d3,-4d0/


SICをOFFにするには true の部分を false に編集します。

      data istop/50/, tol/1d-8/, eb/-20d0/, sic/.false./
& ,eoff/ 1d3, 1d3, 1d3,-4d0/


今回のような問題が起こらない場合はSICをONにしておいた方がよいと思われます。私は今回 make した実行ファイルは specx.sicoff という名前で別に保存しました。

SICをOFFにした計算結果をFig.2に示します。

bccPt-SIC-OFF.png
Fig.2: 全エネルギーに不自然なジャンプが無くなった bccPt の格子定数と全エネルギーの関係


全エネルギーに不連続が無くなり a = 5.9 Bohr 付近に平衡格子定数があることが分かります。

関連エントリ




参考URL




付録


このエントリで使用したファイルを添付します。ファイル名末尾の".txt"を削除して、"_"を"."に変更すれば使えるはずです。(参考:ねがてぃぶろぐの付録)


参考文献/使用機器




フィードバック



にほんブログ村 その他趣味ブログ 電子工作へ

 ↑ 電子工作ブログランキング参加中です。1クリックお願いします。


コメント・トラックバックも歓迎です。 ↓      


 ↓ この記事が面白かった方は「拍手」をお願いします。

tag: AkaiKKR machikaneyama KKR SIC 

AkaiKKRのk点メッシュ

AkaiKKR(machikaneyama)の計算に使われるk点の数は、入力ファイルの bzqlty で指定されます。計算で実際に使われた既約的ブリルアンゾーンのk点の数は、出力の nk に表示されます。

計算に使用したk点の数の表し方には、既約的ブリルアンゾーンの中のk点数のほかに、全ブリルアンゾーンの中でそれぞれの逆格子ベクトルをメッシュ状に何分割したかを N1 × N2 × N3 のような形で表すやり方もあります。
この分割数の情報は、通常出力されないのですが、必要なら source/bzmesh.fend 文の直前に以下の行を追加することで、出力されるようにできると教えていただきました。

      write(*,'(3x,3(a,i3))')'nfa=',nfa,'  nfb=',nfb,'  nfc=',nfc


fcc等の立方晶の場合は単純に nfa=nfb=nfc=bzqlty となります。

関連エントリ




参考URL




参考文献/使用機器




フィードバック



にほんブログ村 その他趣味ブログ 電子工作へ

 ↑ 電子工作ブログランキング参加中です。1クリックお願いします。


コメント・トラックバックも歓迎です。 ↓      


 ↓ この記事が面白かった方は「拍手」をお願いします。

tag: AkaiKKR machikaneyama KKR bzqlty 

AkaiKKRのewidth対応表

AkaiKKR(machikaneyama)を使って状態密度(dos)やバンド構造(spc)を計算する場合、セルフコンシステント計算(go)のときと ewidth の範囲が異なります。(参考: AkaiKKRのewidth その1, その2)

デフォルトでは、go計算よりdos計算やspc計算のときに1/4だけエネルギー範囲が正の方向へずらしてあります。
したがって、go計算のときにエネルギー範囲の底がコアにかかっていないかを確認したいときには、状態密度(dos)やバンド構造(spc)を計算するときに、すこし大き目の ewidth を選ばなければなら無い事になります。別に厳密な値にしなくてもいいのですが、キリのよさそうな値を一覧にしました。

godos/spc
0.60.8
0.91.2
1.21.6
1.52.0
1.82.4
2.12.8
2.43.2
2.73.6
3.04.0
table.1: go計算とdos計算で計算範囲の底が同じになるようにするためのewidthの設定値


関連エントリ




参考URL




参考文献/使用機器





フィードバック



にほんブログ村 その他趣味ブログ 電子工作へ

 ↑ 電子工作ブログランキング参加中です。1クリックお願いします。


コメント・トラックバックも歓迎です。 ↓      


 ↓ この記事が面白かった方は「拍手」をお願いします。

tag: AkaiKKR machikaneyama KKR ewidth 

AkaiKKRでPd-Rh二相共存領域

二元系の状態図には、全率固溶型や共融型などいくつかのパターンが存在します。Pd-Rhの二元系では、端成分が共に面心立方構造となっています。そのため高温では固溶体となります。しかしながら、低温では二相に分離します。今回はAkaiKKR(machikaneyama)を利用して、この境界となる温度を求めてみます。

Pd-Rh-520.png

Fig.1: Pd-Rh二元系の合金状態図とAkaiKKR(machikaneyama)によって計算された固溶と二相共存の境界温度(紫:マフィンティン近似, 緑:原子球近似)



熱力学


全エネルギーの組成依存性が上に凸の形になる場合、定性的に二相分離が予想されます。境界温度を推定するためには、二相分離した状態と固溶した状態のギブスエネルギーの差がゼロになる条件を探せばよいことが分かります。

\begin{equation}
G = E + PV - TS
\end{equation}

まず、常圧のみを考えると P≒0 としても影響はほとんどありません。エネルギー E の項には、第一原理計算から得られる全エネルギーの他に格子振動の寄与などが考えられますが、二相分離状態と固溶状態の差は小さいと仮定して無視します。

エントロピーSについても配置のエントロピーのほかに格子振動の寄与などが考えられますが、配置のエントロピーのみを考えることにします。するとRh濃度が x のときの全エネルギーの差と、固溶体の配置のエントロピーは、以下の様になります。

\begin{equation}
\Delta E(x) = E_{\mathrm{Pd_{1-x}Rh_{x}}} - \{ (1-x)E_{\mathrm{Pd}} + x E_{\mathrm{Rh}} \} \\
S_m(x) = - k_B \{ (1-x)\ln (1-x) + x \ln (x) \}
\end{equation}

したがって求める温度は以下のようになります。

\begin{equation}
T(x) = \frac{\Delta E(x)}{S_m(x)}
\end{equation}

計算手法


AkaiKKR(machikaneyama)を用いてPd-Rh合金系の全エネルギーを計算しました。交換相関汎関数にはpbeを用いました。シェルスクリプトPdRh_sh.txtを用いて、組成と格子定数を変化させながら、各組成における最安定な格子定数とそのときの全エネルギーを決定しました。ポテンシャルの形状は、マフィンティン近似と原子球近似(ASA)の両方を試しました。

全エネルギーを計算する際に、状態密度の計算も行いました。端成分の状態密度に関してはecaljでも計算し、クロスチェックしました。

結果と議論


Fig.2-3に純粋なPdとRhの状態密度を示します。AkaiKKRで計算した結果とecaljで計算した結果が良く一致していることが分かります。

Pd-DOS.png
Fig.2: Pdの状態密度

Rh-DOS.png
Fig.3: Rhの状態密度


Fig.4にPdの体積と全エネルギーの関係をプロットしたものを示します。ゼロ気圧における体積V0とそのときの全エネルギーE0を得るためにBirch-Murnaghanの状態方程式にフィッティングしました。

\begin{equation}
E(V) = E_0 + \frac{9V_0B_0}{16}\left\lbrace \left[ \left( \frac{V_0}{V} \right)^{\frac{2}{3}} -1 \right]^3 B_0^\prime \\
+ \left[ \left( \frac{V_0}{V} \right)^{\frac{2}{3}} -1 \right]^2 \left[ 6 -4 \left( \frac{V_0}{V} \right)^{\frac{2}{3}} \right] \right\rbrace
\end{equation}

PdRh_0.png
Fig.4: Pdの体積と全エネルギーの関係


フィッティングする体積の範囲はV0付近でフィッティング結果が良くなるように適切に選びます。

得られた全エネルギーから固溶と二相分離の境界の温度をプロットしたのがFig.1です。計算結果は、二元合金状態図集の状態図と比較してあります。Pd-Rh合金の計算ではASAの結果が実験結果を驚くほどよく再現しています。しかしながら、今回のような良い結果が得られるのは、どうやら周期表で同じ周期に隣接している元素同士の合金だけのようです。

関連エントリ




参考URL




付録


このエントリで使用したファイルを添付します。ファイル名末尾の".txt"を削除して、"_"を"."に変更すれば使えるはずです。(参考:ねがてぃぶろぐの付録)


参考文献/使用機器




フィードバック



にほんブログ村 その他趣味ブログ 電子工作へ

 ↑ 電子工作ブログランキング参加中です。1クリックお願いします。


コメント・トラックバックも歓迎です。 ↓      


 ↓ この記事が面白かった方は「拍手」をお願いします。

tag: AkaiKKR machikaneyama KKR CPA 二相共存 状態密度 DOS 

AkaiKKRのspc計算の入出力フォーマット その2

AkaiKKRのspc計算の入出力フォーマットでは、AkaiKKR(machikaneyama)の26 Augsut 2015のバージョンを利用して、それよりも以前の 22 May 2015 のバージョンと同じspcの入出力フォーマットに戻す方法を書きました。入力フォーマットの変更は簡単だったのですが、出力フォーマットの指定方法の変更は、少し面倒くさい感じでした。最新版の 22 July 2016 バージョンのAkaiKKRでは、この出力フォーマットの指定方法も簡単になりました。

具体的には source/spmain.firdfmt の値を変更することによって入力のフォーマットを、また、 iwrtfmt の値を変更することによって出力のフォーマットを変更できます。22 May 2015 のバージョンと同じspcの入出力フォーマットに戻すには、両方とも 1 を指定します。デフォルトの 3 を指定しておくほうがバンド構造のテスト計算には便利かもしれません(参考:AkaiKKRでバンド構造(分散関係))。しかしながら、ねがてぃぶろぐでは、今後とも基本的に22 May 2015 のバージョンと同じ入出力フォーマットで計算をすることにします。

関連エントリ




参考URL




フィードバック



にほんブログ村 その他趣味ブログ 電子工作へ

 ↑ 電子工作ブログランキング参加中です。1クリックお願いします。


コメント・トラックバックも歓迎です。 ↓      


 ↓ この記事が面白かった方は「拍手」をお願いします。

tag: AkaiKKR machikaneyama 分散関係 

FC2カウンター
カテゴリ
ユーザータグ

LTspiceAkaiKKRmachikaneyamaScilabKKRPSoCOPアンプPICCPA強磁性常微分方程式モンテカルロ解析odeトランジスタ状態密度インターフェーススイッチング回路ecaljPDS5022DOS定電流半導体シェルスクリプト乱数レベルシフトHP6632Aブレッドボード分散関係温度解析R6452Aトランジスタ技術I2C可変抵抗反強磁性セミナー数値積分確率論偏微分方程式バンド構造非線形方程式ソルババンドギャップ絶縁熱設計シュミットトリガLEDA/Dコンバータ三端子レギュレータLM358ISO-I2CGW近似カオスフォトカプラマフィンティン半径TL431数値微分PC817Cアナログスイッチ直流動作点解析発振回路USBサーボカレントミラー74HC4053パラメトリック解析LDAbzqltyチョッパアンプ量子力学FFT2ちゃんねるアセンブラBSch開発環境電子負荷ブラべ格子イジング模型補間基本並進ベクトル標準ロジック単振り子キュリー温度繰り返しMaxima状態方程式失敗談相対論スピン軌道相互作用FETランダムウォーク熱伝導六方最密充填構造コバルトewidthTLP621GGAQSGW不規則合金位相図抵抗SMPcygwinラプラス方程式スレーターポーリング曲線gfortranスイッチト・キャパシタ詰め回路TLP552三角波格子比熱TLP521条件分岐LM555MCUNE555QNAPマントルテスタ過渡解析FXA-7020ZRダイヤモンドデータロガーガイガー管自動計測Writer509UPSシュレディンガー方程式ブラウン運動awk差し込みグラフ熱力学平均場近似仮想結晶近似VCAfsolve井戸型ポテンシャルVESTA起電力スーパーセルOpenMP第一原理計算ubuntu固有値問題L10構造OPA2277interp12SC1815fccウィグナーザイツ胞面心立方構造フィルタジバニャン方程式ヒストグラム確率論マテリアルデザインspecx.f等高線正規分布PGAフェルミ面非線型方程式ソルバ初期値固定スピンモーメントスワップ領域ルチル構造リジッドバンド模型edeltquantumESPRESSO岩塩構造BaOSIC二相共存ZnOウルツ鉱構造フォノンデバイ模型c/aノコギリ波全エネルギーFSMTeXgnuplotmultiplotハーフメタルCapSense半金属合金結晶磁気異方性Ubuntu文字列入出力TS-110TS-112疎行列Excel直流解析ヒストグラム円周率不規則局所モーメントトラックボールPC等価回路モデルパラメータ・モデルキーボードRealforce三次元マンデルブロ集合フラクタル化学反応重積分縮退日本語最小二乗法関数フィッティングGimpMAS830LHiLAPW熱拡散方程式両対数グラフナイキスト線図負帰還安定性陰解法Crank-Nicolson法P-10クーロン散乱境界条件連立一次方程式片対数グラフEAGLEPIC16F785LMC662トランスシンボルCK1026線種凡例MBEAACircuitグラフの分割軸ラベルifort

最新コメント
リンク

にほんブログ村 その他趣味ブログ 電子工作へ