AkaiKKRとgfortranの出力バッファリング

gfortran の出力バッファリングによるとgfortranは、デフォルトで出力をバッファリングするようになっているとのことです。AkaiKKRの実行コマンドで書いたように出力ファイルを tail -f で監視する際に邪魔になるので、環境変数を利用してバッファリングしないようにしてみました。

ちなみに私の環境では ifort でコンパイルした specx では、このようなバッファリングの問題は起こっていません。


gfortranの出力バッファリングの無効化


AkaiKKRの実行コマンドではAkaiKKR(machikaneyama)の実行ファイルである specx を使うときに必要となるコマンドやリダイレクトを紹介しました。このエントリの中で tail -f で出力ファイルをリアルタイムに監視する方法を書いたところで環境によっては出力ファイルへの書き込みがリアルタイムに行われず、ある程度バッファしてから行われることがあるようです。と書きました。

gfortran の出力バッファリングによると、この挙動はgfortranの仕様であるとのことです。更にgfortran の出力バッファリングのエントリでは、fortranのソースコードを編集する方法と環境変数を利用する方法の2種類の解決方法が紹介されています。

AkaiKKRのソースコードを変更するのは大変そうなので、環境変数を使う方法を試してみます。
具体的には specx の前に GFORTRAN_UNBUFFERED_ALL=y をつけて実行するだけです。

GFORTRAN_UNBUFFERED_ALL=y specx out/outfile &


このようにすることで、出力ファイルが逐次書き込まれ tail -f で中身をリアルタイムに確認することができるようになります。

.bashrc等への記述


しかしながら GFORTRAN_UNBUFFERED_ALL=y を毎回すべて打つのは大変なので .bashrc などに記述しておくことを考えます。
一番シンプルなのは、そのまま .bashrc などに記述してしまうことです。

export GFORTRAN_UNBUFFERED_ALL=y


csh系なら、下記のようになるでしょうか。

setenv GFORTRAN_UNBUFFERED_ALL=y


これらの方法は簡単でよいのですが、AkaiKKR以外のプログラムにgfortranを使っている場合、そのプログラムの挙動にも影響を与えてしまう副作用があります。
したがって .bashrc などに記述してしまうよりは specx を呼び出すシェルスクリプトなどに記述しておくほうが良いかもしれません。
あるいは、エイリアスを使う方法も考えられます。たとえば、以下のような記述を .bashrc に書いておきます。

alias specx='GFORTRAN_UNBUFFERED_ALL=y specx'


こうすることによって単純に specx とタイプすることによって、環境変数付きで specx を実行することができるようになります。

関連エントリ




参考URL




フィードバック



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

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


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


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


tag: AkaiKKR machikaneyama gfortran 

comment

Secret

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

最新コメント
リンク

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