スポンサーサイト

上記の広告は1ヶ月以上更新のないブログに表示されています。
新しい記事を書く事で広告が消せます。


AkaiKKRでSrTiO3ペロフスカイト

AkaiKKR(Machikaneyama)を用いてSrTiO3ペロフスカイトのバンド構造を計算しました。ついでにバンド構造を計算するための補助に使うScilabスクリプトも載せます。かなり未完成ですが、とりあえずアップロードしてしまいます。動作は無保証です。


SrTiO3.png
Fig.1: SrTiO3のバンド構造



ペロフスカイト構造


VESTAでLaMnO3ペロフスカイトでは、ペロフスカイト構造を持つLaMnO3の結晶をVESTAで描画しました。ペロフスカイト構造をもつ物質は様々な物性を持つため、物質科学ではよく研究対象になります。

第一原理計算入門 AkaiKKRのページで立方晶SrTiO3ペロフスカイトと、Tiを1%のNi及び2%のTaと置換したものの入力ファイルが公開されているのでこれを計算します。(後者に関してはTiは97%ではないのかとも思いましたが、計算の後で気づいたのでそのまま利用させていただきます。)
既に公開されている入力ファイルを使用するので、go計算とdos計算は簡単です。


stoDOS.png

nitastoDOS.png
Fig. 2-3: SrTiO3とそれにNi, Ta不純物を加えた物質の全状態密度。


バンド構造計算補助のScilabスクリプト


AkaiKKRではspcモードを利用して、ブロッホスペクトル関数の計算ができます。これを計算したいk点のパスに沿って指定すればいわゆるバンド構造(電子のエネルギー分散)の図を描くことができます。
ただし、充分きれいな図を描こうと考えるならば、結構な数のk点を指定しなくてはいけないので、手入力で指定するのは手間がかかります。そこで特徴的なk点を指定すれば、その間をn分割したk点をアウトプットするScilabスクリプトを書きました。

まだ書き散らかした状態のスクリプトでb/aなども指定できるようになっていますが本当に動作するかはわかりません。別にこのエントリに限った話ではありませんが、動作は未保証です。

スクリプトの本体は、下記に示すkvector.sceです。
前述したとおり、指定されたk点をn分割して出力します。出力した結果は2つのテキストファイルに書き込まれます。
akaikkr.txtは、入力ファイルの末尾に挿入するk点のリストです。gnuplot.txtはgnuplotのpm3d mapやplot with imageなどで描きだしたバンド構造に特徴的なk点の名前を入れるべきx座標のリストです。

clear;
// *** 設定ファイルの読み込み ***
// bcc Fe
//exec('bccFe.sce');
// fcc Ni
//exec('fccNi.sce');
// hcp Co
//exec('hcpCo.sce');
// Simple cubic SrTiO3 (perovskite)
exec('scSrTiO3.sce');

// *** 各k点間の分割数 ***
n = 101;

// *** k点のグリッドを作成 ***
kpath = [linspace(k(1,1),k(2,1),n)', linspace(k(1,2),k(2,2),n)', linspace(k(1,3),k(2,3),n)'];

for i = 2:(size(k,'r') - 1) do
kx = linspace(k(i,1),k(i + 1,1),n)';
ky = linspace(k(i,2),k(i + 1,2),n)';
kz = linspace(k(i,3),k(i + 1,3),n)';
kpath = [kpath;
[kx(2:$), ky(2:$), kz(2:$)]];
end

// *** k点をつなぐパスの表示 ***
param3d(kpath(:,1),kpath(:,2),kpath(:,3));

// *** k点をつなぐパスの道のり ***
klength = [0];

for i = 2:size(k,'r') do
dkx = (k(i,1) - k(i - 1,1)) * %pi / a;
dky = (k(i,2) - k(i - 1,2)) * %pi / (boa * a);
dkz = (k(i,3) - k(i - 1,3)) * %pi / (coa * a);
klength = [klength, (klength($) + sqrt(dkx ^ 2 + dky ^ 2 + dkz ^ 2))];
end

// *** ファイルの書き出し ***
fprintfMat("akaikkr.txt",kpath);
fprintfMat("gnuplot.txt",klength);


このスクリプトファイルに対して、個別の結晶構造に関するパラメータの部分だけを別ファイルにしたものを読み込ませます。
例えば今回の立方晶SrTiO3ペロフスカイトの場合は、下記のscSrTiO3.sceを作成します。

// 格子定数 bohr
a = 7.38; // 格子定数 a (bohr)
boa = 1; // b/a
coa = 1; // c/a

// *** 計算するk点のパス ***
// sc
// kx ky kz
k = [(1 / 2), (1 / 2), 0 ; // M
(1 / 2), (1 / 2), (1 / 2); // R
0 , 0 , 0 ; // Gamma
(1 / 2), 0 , 0 ; // X
(1 / 2), (1 / 2), 0 ; // M
0 , 0 , 0 ] // Gamma


また、ほかのサンプルとしてニッケル・鉄・コバルトの入力ファイルに対応するデータも載せておきます。(参照: AkaiKKRでニッケル・鉄・コバルト)


結局、AkaiKKRの入力ファイルはSrTiO3_in.txtSrTiNiTaO3_in.txtになります。

バンド構造


出力されたspcファイルからGNUPLOTを用いてプロットしたバンド構造を示します。


SrTiNiTaO3_up.png

SrTiNiTaO3_dn.png
Fig.4-5: Sr(Ti,Ni,Ta)O3のバンド構造。上がupスピン、下がdownスピンです。


比較用としてはABINITによる第一原理電子構造計算例:ABO3(PDF)にSrTiO3ペロフスカイトのバンド構造の計算例が載っています。

関連エントリ




参考URL




付録


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


参考文献/使用機器




フィードバック



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

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


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


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


tag: AkaiKKR machikaneyama KKR CPA Scilab 

comment

Secret

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

LTspiceAkaiKKRmachikaneyamaScilabKKRPSoC強磁性CPAPICOPアンプecalj状態密度モンテカルロ解析常微分方程式トランジスタodeDOSインターフェースPDS5022定電流スイッチング回路分散関係半導体シェルスクリプトレベルシフト乱数HP6632A可変抵抗トランジスタ技術R6452AI2C温度解析ブレッドボードバンドギャップ確率論反強磁性セミナーバンド構造数値積分偏微分方程式非線形方程式ソルバ熱設計絶縁三端子レギュレータISO-I2CA/DコンバータシュミットトリガフォトカプラカオスPWscfGW近似LM358LEDマフィンティン半径発振回路USB数値微分TL431PC817Cサーボアナログスイッチ直流動作点解析補間カレントミラー74HC4053bzqltyチョッパアンプFFT2ちゃんねる開発環境量子力学単振り子電子負荷VESTAQuantumESPRESSO標準ロジックパラメトリック解析ブラべ格子イジング模型アセンブラLDA基本並進ベクトルBSchSMPTLP621失敗談六方最密充填構造コバルト位相図QSGWGGAスイッチト・キャパシタewidth状態方程式VCAキュリー温度繰り返し最適化仮想結晶近似不規則合金熱伝導gfortran相対論抵抗FETMaximaQuantum_ESPRESSOcygwinランダムウォークラプラス方程式スピン軌道相互作用スレーターポーリング曲線マントルシュレディンガー方程式ZnO自動計測QNAP固有値問題ダイヤモンドデータロガー井戸型ポテンシャルTLP552CIFxcrysdenゼーベック係数熱力学条件分岐MCU最小値UPS格子比熱最大値ガイガー管平均場近似過渡解析Writer509スーパーセルFXA-7020ZR差し込みグラフ第一原理計算テスタ起電力OpenMP三角波ubuntuLM555NE555ブラウン運動詰め回路ハーフメタルawkfsolveUbuntuフェルミ面TLP521トランスMAS830LPGACK1026OPA2277フィルタトレーナーバトルEAGLEノコギリ波負帰還安定性ナイキスト線図MBEP-10LMC6622SC1815CapSenseAACircuitPIC16F785入出力固定スピンモーメントFSMTeX結晶磁気異方性全エネルギーc/a合金multiplotgnuplot非線型方程式ソルバL10構造正規分布等高線ジバニャン方程式ヒストグラム確率論初期値interp1fcc面心立方構造ウィグナーザイツ胞半金属デバイ模型磁気モーメント電荷密度重積分SIC不純物問題擬ポテンシャル状態図cif2cellPWgui二相共存ウルツ鉱構造edeltquantumESPRESSOフォノンリジッドバンド模型スワップ領域BaO岩塩構造ルチル構造マテリアルデザインspecx.fフラクタルマンデルブロ集合キーボードRealforceクーロン散乱三次元疎行列縮退化学反応関数フィッティング最小二乗法Excel直流解析PCTS-110TS-112日本語パラメータ・モデル等価回路モデル文字列ポケモンGO熱拡散方程式HiLAPW両対数グラフ片対数グラフ陰解法Crank-Nicolson法ifort境界条件連立一次方程式グラフの分割軸ラベルヒストグラム不規則局所モーメントスーパーリーグ円周率Gimp凡例線種シンボルトラックボール

最新コメント
リンク

にほんブログ村 その他趣味ブログ 電子工作へ
上記広告は1ヶ月以上更新のないブログに表示されています。新しい記事を書くことで広告を消せます。