# ``tftanalyze.py`` ドキュメント

## ファイル概要

TFT n-チャネルトランジスタの電気特性を解析するツールです。

詳細説明:
このスクリプトは、TFT (Thin-Film Transistor) のn-チャネルデバイスにおける I-V特性(伝達特性 (ID-VG) および出力特性 (ID-VD))データを読み込み、解析し、結果をExcelレポートとPNGプロットとして出力します。
コマンドラインからの使用例は以下の通りです。

```bash
python tftanalyze.py --mode all --infile_vg transfer.csv --infile_vd output.csv

主な機能:

  • CSV形式の測定データを自動的にエンコーディングを検出して読み込みます。

  • 伝達特性データから閾値電圧 (Vth)、移動度 (Mobility)、サブスレッショルドスイング (S) などの主要なデバイスパラメータを抽出します。

  • 出力特性データから線形領域のコンダクタンス (gd) や移動度 (mu_lin, mu_eff) を評価します。

  • サビツキー・ゴレイフィルターを用いたデータの平滑化をサポートします。

  • 解析結果をインタラクティブなグラフ表示とPNGファイルとして保存します。

  • 全ての解析結果と生データ、平滑化データをExcelファイルに集約して出力します。

関連リンク: tftanalyze_usage

インポートされたライブラリ

標準ライブラリ

  • os

    • オペレーティングシステムに依存する機能、主にファイルパスの操作やディレクトリ作成に使用されます。

  • sys

    • システム固有のパラメータと関数へのアクセスを提供し、標準出力のリダイレクトなどに使用されます。

  • argparse

    • コマンドライン引数を解析するためのライブラリです。

  • csv

    • CSV (Comma Separated Values) ファイルの読み書きをサポートします。

  • pathlib

    • オブジェクト指向のファイルシステムパスを提供し、パス操作を容易にします。

非標準ライブラリ

  • chardet (バージョン 3.0.4 以降が推奨されます)

    • ファイルの文字エンコーディングを検出するために使用されます。

  • numpy

    • 数値計算、特に多次元配列オブジェクトを扱うための基本的なパッケージです。

  • scipy

    • 科学技術計算のためのオープンソースライブラリ群で、ここでは constants モジュール(物理定数)と signal モジュール(Savitzky-Golayフィルター)が使用されています。

  • pandas

    • データ操作と分析のためのライブラリで、データフレーム (DataFrame) 構造を提供します。

  • matplotlib.pyplot

    • Pythonのプロットライブラリで、データの可視化に使用されます。

  • sklearn.linear_model.LinearRegression

    • Scikit-learnライブラリの一部で、線形回帰モデルを提供します。

定数

  • EPS0

    • 真空の誘電率 (scipy.constants.epsilon_0) を表す物理定数です。単位は F/m です。

  • figsize_idvg_quad

    • plot_idvg_quad() 関数で使用されるMatplotlibのプロットのサイズ (幅, 高さ) を定義するタプルです。値は (10, 8) です。

クラス

Tee

stdout / stderr をコンソールとログファイルへ同時出力する簡単な Tee クラスです。

詳細説明: このクラスは、複数のファイルライクオブジェクトに書き込み操作をミラーリングするために使用されます。例えば、標準出力への書き込みと同時にログファイルへの書き込みを行う場合に便利です。

__init__()

コンストラクタです。

引数:

名前

タイプ

説明

streams

file-like objects

データを書き込む対象となる一つ以上のファイルライクオブジェクト。

write()

データを全てのストリームに書き込み、フラッシュします。

引数:

名前

タイプ

説明

data

str

書き込むデータ。

戻り値:

名前

タイプ

説明

returns

None

なし。

flush()

全てのストリームをフラッシュします。

引数:

名前

タイプ

説明

self

Tee

Tee クラスのインスタンス。

戻り値:

名前

タイプ

説明

returns

None

なし。

関数

get_args()

コマンドライン引数をパースします。

詳細説明: この関数は、TFT解析スクリプトに必要な全てのコマンドライン引数を定義し、ユーザーが指定した引数をパースして返します。引数には、入力ファイルパス、解析モード、TFTデバイスの物理的寸法、誘電体定数、電流の閾値、平滑化パラメータ、プロット表示・保存設定などが含まれます。

オプション

デフォルト値

タイプ

説明

--infile_vg

TFT_Vg-Id_STD-ide3 [AS220518TFT-anneal(454) ; 2022_05_25 18_00_33].csv

str

伝達特性 (ID-VG) データファイルへのパス。

--infile_vd

TFT_Vd-Id-ide [AS220518TFT-anneal(455) ; 2022_05_25 18_01_11].csv

str

出力特性 (ID-VD) データファイルへのパス。

--mode

all

str

解析モード (read, analyze_idvg, analyze_idvd, all)。

--out_excel

None

str

出力Excelファイル。省略された場合、モードに依存したファイル名が使用されます。

--L

50.0

float

チャネル長 [um]。

--W

300.0

float

チャネル幅 [um]。

--dg

150.0

float

ゲート絶縁膜厚 [nm]。

--epsg

3.9

float

ゲート絶縁膜の比誘電率。

--ID_S

1e-9

float

S抽出のための参照ドレイン電流 [A]。

--Imin

1e-15

float

対数解析のための最小電流フロア [A]。

--smooth_npoints

5

int

Savitzky-Golayフィルターのウィンドウ長。

--lsq_order

2

int

Savitzky-Golayフィルターの多項式の次数。

--show_plot

True

action

プロットをインタラクティブに表示します (デフォルト: True)。

--no_show_plot

False

action

プロットをインタラクティブに表示しません。

--region_factor

3.0

float

領域チェックのための安全係数。

--save_plot

True

action

解析プロットをPNGファイルとして保存します (デフォルト: True)。

--no_save_plot

False

action

解析プロットを保存しません。

--plot_dir

tft_analysis_plots

str

プロット保存ディレクトリ。

--reverse_vg

False

action

データ読み込み後に VG の符号を反転します。pチャネルデータの前処理を意図しています。

--idx_vg

0

int

VG 掃引データ用セグメントインデックス。

--idx_vd

0

int

VD 掃引データ用セグメントインデックス。

--read_smooth_domain

log

str

mode=read 時の平滑化ドメイン (log または linear)。

--read_keep_edge_raw

True

action

mode=read 時、端点付近の生データを保持します (デフォルト: True)。

--read_smooth_edges

False

action

端点付近でもSavitzky-Golay平滑化を適用します。

戻り値:

名前

タイプ

説明

returns

argparse.Namespace

パースされた引数を含む argparse.Namespace オブジェクト。

calculate_cox()

ゲート酸化膜容量 (Cox) を計算します。

詳細説明: ゲート絶縁膜の厚さ (ナノメートル単位) と比誘電率から、単位面積あたりのゲート酸化膜容量 (F/cm^2) を計算します。物理定数として真空の誘電率 (EPS0) を使用します。

引数:

名前

タイプ

説明

dg_nm

float

ゲート絶縁膜の厚さ [nm]。

epsg

float

ゲート絶縁膜の比誘電率。

戻り値:

名前

タイプ

説明

returns

float

単位面積あたりのゲート酸化膜容量 [F/cm^2]。

default_excel_name()

指定された解析モードに応じたデフォルトのExcelファイル名を返します。

詳細説明: 異なる解析モード(read, analyze_idvg, analyze_idvd, all)に対して、それぞれ適切なデフォルトのExcelファイル名を決定します。指定されたモードが辞書にない場合は、汎用的なレポートファイル名を返します。

引数:

名前

タイプ

説明

mode

str

解析モードを示す文字列。

戻り値:

名前

タイプ

説明

returns

str

デフォルトのExcelファイル名。

_existing_or_first_path()

出力名の基準にする入力ファイルを選びます。存在確認はゆるく行います。

詳細説明: 複数のファイルパスが与えられた場合、最初に空でないパス、または提供されたパスのリストの最初のパスを Path オブジェクトとして返します。ファイルシステムの存在チェックは行いません。

引数:

名前

タイプ

説明

paths

str

検査するファイルパスの可変引数。

戻り値:

名前

タイプ

説明

returns

pathlib.Path

基準として選択されたファイルパスの Path オブジェクト。

prepare_output_paths()

Excel/PNG/log の保存先を入力ファイルと同じディレクトリにそろえます。

詳細説明: 入力ファイルパス (args.infile_vg, args.infile_vd) を基準に、Excelレポート、PNGプロット、ログファイルの出力ディレクトリとファイル名を決定し、args オブジェクトに設定します。これにより、全ての出力が関連する入力ファイルの近くに集約されます。

引数:

名前

タイプ

説明

args

argparse.Namespace

コマンドライン引数を含む argparse.Namespace オブジェクト。 infile_vg, infile_vd, mode, out_excel 属性を使用します。

戻り値:

名前

タイプ

説明

returns

argparse.Namespace

出力パスが設定された argparse.Namespace オブジェクト。

plot_path()

入力stemつきPNG保存パスを作成します。

詳細説明: コマンドライン引数 (args) から取得した出力ステムとプロットディレクトリを基に、指定された名前 (name) でPNGファイルの完全な保存パスを構築します。

引数:

名前

タイプ

説明

args

argparse.Namespace

コマンドライン引数を含む argparse.Namespace オブジェクト。 output_stem および plot_dir 属性を使用します。

name

str

保存するPNGファイルの名前(拡張子なし)。

戻り値:

名前

タイプ

説明

returns

str

生成されたPNGファイルの完全なパス。

savgol_center_only()

サビツキー・ゴレイフィルターを適用し、オプションで端点付近の生データを保持します。

詳細説明: scipy.signal.savgol_filter は端点付近を外挿/補間することがあります。TFT出力曲線では、VD=0 側の点数が少ないため、端点平滑化が系統的なずれのように見えることがあります。keep_edge_raw=True の場合、完全な中心ウィンドウを持つ点のみが平滑化された値に置き換えられ、端点付近のデータは元のクリップされたデータのまま維持されます。データ長が短すぎる場合、またはウィンドウ長が不正な場合は、元のデータが返され、平滑化が適用されなかったことを示すブール配列が返されます。

引数:

名前

タイプ

説明

y

numpy.ndarray or list

平滑化するデータ配列。

win

int

サビツキー・ゴレイフィルターのウィンドウ長。奇数である必要があります。

order

int

フィルターの多項式の次数。

keep_edge_raw

bool

True の場合、完全な中心ウィンドウを持たない端点付近のデータを生データのまま保持します。

戻り値:

名前

タイプ

説明

returns

tuple[numpy.ndarray, numpy.ndarray]

平滑化されたデータ配列と、各点が平滑化に使用されたかを示すブール配列のタプル。

add_read_columns_grouped()

データフレームに電流のクリッピングと平滑化された電流の列を追加します。

詳細説明: この関数は、読み込み/プレビューモードのために、各グループ(またはデータ全体)に対して、以下の列を追加します:

  • ID_abs_floor: ID の絶対値を args.Imin でクリッピングした値。

  • ID_smooth_linear: 線形スケールで平滑化された ID

  • logID_smooth: 対数スケールで平滑化された log10(abs(ID))

  • ID_smooth_log: logID_smooth を元に対数スケールで平滑化された ID

  • ID_smooth: args.read_smooth_domain に応じて ID_smooth_linear または ID_smooth_log

  • savgol_used_linear, savgol_used_log, savgol_used: Savitzky-Golay平滑化が適用された点を示すブールマスク。

重要な点: 伝達特性 (ID-VG) のプレビューは、デフォルトで log10(abs(ID)) の平滑化後に逆変換します。出力特性 (ID-VD) のプレビューは、線形電流平滑化と線形Y軸プロットを強制します。デフォルトでは、端点付近ではSavitzky-Golayフィルターの完全な中心ウィンドウがないため、平滑化は無効化されます。これにより、VD=0 付近の人工的なずれを回避します。

引数:

名前

タイプ

説明

df

pandas.DataFrame

処理対象の DataFrame

xcol

str

データのX軸となる列名(例: 'VG', 'VD')。

groupcol

str

グループ化に使用する列名(例: 'VD', 'VG')。この列が存在しない場合、データ全体が単一のグループとして扱われます。

args

argparse.Namespace

コマンドライン引数を含むオブジェクト。 Imin, lsq_order, smooth_npoints, read_keep_edge_raw, read_smooth_domain 属性を使用します。

戻り値:

名前

タイプ

説明

returns

pandas.DataFrame

クリップおよび平滑化された電流列が追加された DataFrame

plot_read_data()

読み込み/プレビューモードで平滑化されたデータをプロットします。

詳細説明: 生のクリップされたデータ (ID_abs_floor) と平滑化されたデータ (ID_smooth) をX軸 (xcol) に対してプロットします。groupcol が指定されている場合、データはグループごとにプロットされ、凡例に表示されます。Y軸はオプションで対数スケールに設定できます。生成されたプロットは、args.save_plotTrue の場合、指定されたディレクトリにPNGファイルとして保存されます。

引数:

名前

タイプ

説明

df_read

pandas.DataFrame

読み込み/プレビュー用に処理されたデータを含む DataFrame

xcol

str

X軸としてプロットする列名(例: 'VG', 'VD')。

groupcol

str

データをグループ化するための列名(例: 'VD', 'VG')。この列が存在しない場合、データ全体が単一のグループとして扱われます。

title

str

プロットのタイトル。

args

argparse.Namespace

コマンドライン引数を含むオブジェクト。 save_plotplot_dir 属性を使用します。

fname_base

str

保存するPNGファイル名のベース。

yscale

str or None

Y軸のスケール('log' または 'linear')。None の場合、線形スケール。デフォルトは 'log'

戻り値:

名前

タイプ

説明

returns

matplotlib.figure.Figure

生成されたMatplotlibの Figure オブジェクト。

run_read_mode()

読み込み/プレビューモードの処理を実行します。

詳細説明: 指定された入力ファイル(伝達特性と出力特性)を読み込み、Imin で電流をクリッピングし、Savitzky-Golayフィルターで平滑化します。その後、処理されたデータをプロットし、結果の概要をコンソールに出力します。伝達特性 (ID-VG) データは対数電流平滑化がデフォルトですが、出力特性 (ID-VD) データは線形電流平滑化と線形Y軸プロットが強制されます。処理されたデータフレームとサマリー情報は、Excelエクスポートのために返されます。

引数:

名前

タイプ

説明

args

argparse.Namespace

コマンドライン引数を含むオブジェクト。 infile_vg, infile_vd, reverse_vg, idx_vg, idx_vd, Imin, read_smooth_domain, save_plot, plot_dir 属性を使用します。

戻り値:

名前

タイプ

説明

returns

tuple[list[matplotlib.figure.Figure], dict[str, pandas.DataFrame], list[dict]]

Matplotlibの Figure オブジェクトのリスト。読み込まれた/処理されたデータフレームをタグ('vg' または 'vd')で格納した辞書。読み込み処理のサマリー情報を含む辞書(各グループごと)のリスト。

_normalize_tft_column_name()

測定CSVの列名を解析用の標準名へそろえます。

詳細説明: 例: VG(V) -> VG, Id -> ID。既存の解析コードは VG, VD, ID などの大文字列名を仮定しているため、読み込み直後にここで正規化します。

引数:

名前

タイプ

説明

name

str

正規化する列名。

戻り値:

名前

タイプ

説明

returns

str

標準化された列名。

_to_numeric_dataframe()

全列を可能な範囲で数値化します。

引数:

名前

タイプ

説明

df

pandas.DataFrame

数値化する DataFrame

戻り値:

名前

タイプ

説明

returns

pandas.DataFrame

全列が数値化された DataFrame

_float_meta()

4155/4156系CSVメタデータから float 値を取り出します。

引数:

名前

タイプ

説明

metadata

dict

メタデータを含む辞書。

key

str

取得するメタデータのキー。

戻り値:

名前

タイプ

説明

returns

float or None

取得された float 値。変換できない場合は None

_int_meta()

4155/4156系CSVメタデータから int 値を取り出します。

引数:

名前

タイプ

説明

metadata

dict

メタデータを含む辞書。

key

str

取得するメタデータのキー。

戻り値:

名前

タイプ

説明

returns

int or None

取得された int 値。変換できない場合や有効な数値でない場合は None

_infer_smu_sweep_variable()

Primary/Secondary掃引に対応する電圧名を推定します。

詳細説明: Keysight/Agilent 4155系CSVでは、通常 Channel.VName = VD, VS, VGChannel.Func = VAR2, CONST, VAR1 のようなメタデータがあり、VAR1 がPrimary、VAR2 がSecondaryに対応します。

引数:

名前

タイプ

説明

metadata

dict

メタデータを含む辞書。

sweep_role

str

掃引の役割('Primary' または 'Secondary')。

戻り値:

名前

タイプ

説明

returns

str or None

推定された電圧名(例: 'VG', 'VD')。推定できない場合は None

_infer_sweep_values()

Primary/Secondary掃引の値リストをメタデータから推定します。

引数:

名前

タイプ

説明

metadata

dict

メタデータを含む辞書。

role

str

掃引の役割('Primary' または 'Secondary')。

戻り値:

名前

タイプ

説明

returns

list[float]

推定された掃引値のリスト。

_infer_primary_branch_points()

Primary掃引1枝あたりの点数をメタデータから推定します。

引数:

名前

タイプ

説明

metadata

dict

メタデータを含む辞書。

戻り値:

名前

タイプ

説明

returns

int or None

Primary掃引1枝あたりの点数。推定できない場合は None

_is_double_primary_sweep()

Primary掃引がダブル掃引(往復掃引)であるか判定します。

引数:

名前

タイプ

説明

metadata

dict

メタデータを含む辞書。

戻り値:

名前

タイプ

説明

returns

bool

ダブル掃引である場合は True、そうでない場合は False

_add_4155_inferred_columns()

4155系DataName/DataValue CSVに不足しがちな掃引列を補います。

詳細説明: DataName/DataValueブロックにはPrimary変数、ID、IGだけが保存され、Secondary変数(今回の例ではVD)が各行に書かれない場合があります。その場合、メタデータのSecondary Start/Step/Countから各行のVDを復元します。

引数:

名前

タイプ

説明

df

pandas.DataFrame

処理対象の DataFrame

metadata

dict

メタデータを含む辞書。

戻り値:

名前

タイプ

説明

returns

pandas.DataFrame

掃引列が補完された DataFrame

read_4155_dataname_datavalue_csv()

Keysight/Agilent 4155系の DataName/DataValue CSV を読み込みます。

詳細説明: 戻り値は (df, metadata) です。DataValue 行が見つからない場合は (None, metadata) を返し、通常CSV読み込みへフォールバックできるようにします。

引数:

名前

タイプ

説明

filepath

str

読み込むCSVファイルのパス。

encoding

str

ファイルの文字コード。デフォルトは'utf-8-sig'

戻り値:

名前

タイプ

説明

returns

tuple[pandas.DataFrame or None, dict]

データを含む DataFrame とメタデータの辞書のタプル。 DataValue 行が見つからない場合は (None, metadata)。

_read_text_lines_with_detected_encoding()

文字コードをゆるく推定してCSVを行単位で読み込みます。

引数:

名前

タイプ

説明

filepath

str

読み込むCSVファイルのパス。

戻り値:

名前

タイプ

説明

returns

tuple[list[str], str]

ファイルの行リストと推定された文字コードのタプル。

detect_and_load()

CSVファイルからTFT解析用データを自動検出して読み込みます。

詳細説明: 対応形式:

  1. 既存対応の「列ヘッダ行 + 数値データ行」形式

  2. Keysight/Agilent 4155系の DataName / DataValue 形式

後者では、DataValue ブロックに VDVG などのSecondary掃引列が明示されない場合でも、メタデータから VD または VG を復元して既存解析コードへ渡します。

引数:

名前

タイプ

説明

filepath

str

読み込むCSVファイルのパス。

reverse_vg

bool

True の場合、VG の符号を反転します。pチャネルデータの前処理を意図しています。

戻り値:

名前

タイプ

説明

returns

pandas.DataFrame or None

読み込まれたデータを含む DataFrame。ファイルが見つからないかデータが読み込めない場合は None

valid_savgol_window()

指定されたデータ点数に対して有効な奇数のSavitzky-Golayウィンドウ長を返します。

詳細説明: サビツキー・ゴレイフィルターのウィンドウ長は、多項式の次数よりも大きく、かつ奇数である必要があります。また、データ点数を超えることはできません。この関数は、与えられた制約 (n, requested, order) に基づいて、これらの条件を満たす最小かつ有効な奇数のウィンドウ長を計算して返します。

引数:

名前

タイプ

説明

n

int

データ点の総数。

requested

int

要求されたSavitzky-Golayウィンドウ長。

order

int

Savitzky-Golayフィルターの多項式の次数。

戻り値:

名前

タイプ

説明

returns

int

有効な奇数のSavitzky-Golayウィンドウ長。

nearest_row_by_current()

データフレーム内で指定された目標電流 (target_id) に最も近い ID_smooth を持つ行を検索します。

詳細説明: データフレーム dfID_smooth 列を基に、目標電流値 target_id との絶対差が最小となる行を特定します。見つかった行のインデックスとその行全体のデータを返します。データフレームが空の場合、または ID_smooth 列が存在しない場合は、None を返します。

引数:

名前

タイプ

説明

df

pandas.DataFrame

検索対象の DataFrameID_smooth 列が必要です。

target_id

float

検索する目標電流値 [A]。

戻り値:

名前

タイプ

説明

returns

tuple[int or None, pandas.Series or None]

目標電流に最も近い行のインデックスと、その行のPandas Series。データフレームが空の場合は (None, None) を返します。

add_sweep_index()

指定された列の掃引方向の変化に基づいて、掃引セグメントのインデックスを追加します。

詳細説明: データフレームの指定された列 (col) の値の連続的な変化を分析し、掃引方向が反転するたびに掃引セグメントのインデックスを1つ増やします。これにより、多方向掃引データ(例: VG の往復掃引)を個別のセグメントに分割できます。結果のインデックスは新しい列 (idx_col) としてデータフレームに追加されます。

引数:

名前

タイプ

説明

df

pandas.DataFrame

処理対象の DataFrame

col

str

掃引方向を検出する基準となる列名(例: 'VG', 'VD')。

idx_col

str

生成される掃引インデックス列の名前。

戻り値:

名前

タイプ

説明

returns

pandas.DataFrame

掃引セグメントインデックス列が追加された DataFrame

select_sweep_segment()

掃引方向の変化インデックスに基づいて、DataFrameから特定の掃引セグメントを選択します。

詳細説明: この関数は、add_sweep_index を使用して、指定された列 (col) の掃引セグメントインデックスを計算し、その後、要求されたインデックス (idx) に対応するセグメントのみをフィルタリングして返します。要求されたインデックスが存在しない場合、利用可能な最初のセグメントがフォールバックとして選択されます。オプションで、選択されたセグメントを col 列でソートできます。

引数:

名前

タイプ

説明

df

pandas.DataFrame or None

処理対象の DataFrame

col

str

掃引セグメントを識別する基準となる列名(例: 'VG', 'VD')。

idx

int

選択する掃引セグメントのインデックス。

label

str

警告メッセージなどで使用するインデックスのラベル(例: 'idx_vg')。

sort_after

bool

True の場合、選択後に col 列で DataFrame をソートします。デフォルトは True

verbose

bool

True の場合、選択されたセグメントに関する詳細情報を出力します。デフォルトは False

戻り値:

名前

タイプ

説明

returns

pandas.DataFrame or None

選択された掃引セグメントを含む DataFrame。元の DataFrameNone または空の場合、または col 列がない場合は、元の DataFrame または None を返します。

build_analysis_points()

伝達特性解析の主要点をロングフォーマットで返します。

詳細説明: res 辞書から Vth, Smin, mu_max などの主要な解析ポイントを抽出し、Excelサマリーシートに適したリスト形式で提供します。各ポイントは、その VG, ID, 導関数、移動度などの詳細な情報とともに辞書として格納されます。

引数:

名前

タイプ

説明

res

dict

伝達特性解析結果を含む辞書。 df (解析対象の DataFrame) および idx_ で始まるキー (各ポイントのインデックス) が必要です。

戻り値:

名前

タイプ

説明

returns

list[dict]

各解析ポイントのデータを格納した辞書のリスト。

region_check_saturation()

飽和領域動作の条件をチェックします。

詳細説明: トランジスタが飽和領域で動作しているかどうかを判断するために、指定された VG, VD, Vth, および安全係数 (factor) を使用して VD >= factor * (VG - Vth) の条件を確認します。VG-Vth が正でない場合、または条件が満たされない場合は警告が生成されます。

引数:

名前

タイプ

説明

vd

float

ドレイン電圧 [V]。

vg

float

ゲート電圧 [V]。

vth

float

閾値電圧 [V]。

factor

float

飽和領域を保証するための安全係数。デフォルトは3.0

戻り値:

名前

タイプ

説明

returns

dict

飽和領域チェックの結果を含む辞書。 ok (bool), warning (str), VD_abs (float), VG_minus_Vth (float), ratio (float), criterion (str) を含みます。

region_check_linear()

線形領域動作の条件をチェックします。

詳細説明: トランジスタが線形領域で動作しているかどうかを判断するために、指定された VG, VD, Vth, および安全係数 (factor) を使用して VG - Vth >= factor * VD の条件を確認します。VD が正でない場合、VG-Vth が負の場合、または条件が満たされない場合は警告が生成されます。

引数:

名前

タイプ

説明

vd

float

ドレイン電圧 [V]。

vg

float

ゲート電圧 [V]。

vth

float

閾値電圧 [V]。

factor

float

線形領域を保証するための安全係数。デフォルトは3.0

戻り値:

名前

タイプ

説明

returns

dict

線形領域チェックの結果を含む辞書。 ok (bool), warning (str), VD_abs (float), VG_minus_Vth (float), ratio (float), criterion (str) を含みます。

classify_transfer_region()

線形/飽和/中間領域の推奨を返します。

詳細説明: 線形領域チェックと飽和領域チェックの結果に基づいて、現在解析中の動作点が線形、飽和、またはどちらでもない中間領域のどれに属するかを分類します。分類結果と、それに関連する推奨/警告メッセージを返します。

引数:

名前

タイプ

説明

linear_check

dict

region_check_linear() 関数からの結果辞書。

saturation_check

dict

region_check_saturation() 関数からの結果辞書。

戻り値:

名前

タイプ

説明

returns

tuple[str, str]

推奨される領域タイプと、関連する警告/説明メッセージのタプル。

analyze_vg_core()

特定 VD スライスの ID-VG から、線形法と飽和法の両方で Vth/移動度を抽出します。

詳細説明: ID-VG データに基づいて、線形領域(最大相互コンダクタンス gm から)と飽和領域(最大 d(sqrt(ID))/dVg から)の閾値電圧 (Vth) と移動度を抽出します。サブスレッショルドスイング (S) やオフ電流 (Ioff) も計算します。抽出されたポイントの動作領域チェックも行い、推奨される抽出方法を提示します。

引数:

名前

タイプ

説明

df_full

pandas.DataFrame

全ての VG-ID 測定データを含む DataFrame

vd_val

float

解析対象のドレイン電圧 [V]。

args

argparse.Namespace

コマンドライン引数を含むオブジェクト。 smooth_npoints, lsq_order, Imin, L, W, region_factor, ID_S 属性を使用します。

cox

float

単位面積あたりのゲート酸化膜容量 [F/cm^2]。

戻り値:

名前

タイプ

説明

returns

dict or None

特定 VD スライスにおける詳細な解析結果を含む辞書。データが不十分な場合は None

annotate_vline()

Matplotlibのプロットに垂直線とテキストアノテーションを追加します。

詳細説明: 指定されたX座標 (x) に垂直線 (axvline) を引き、その線の近くにテキストラベル (label) を回転させて配置します。Y軸の範囲 (ymin, ymax) が指定されていない場合、現在のプロットのY軸範囲が使用されます。

引数:

名前

タイプ

説明

ax

matplotlib.axes.Axes

プロット対象のMatplotlib Axes オブジェクト。

x

float

垂直線を引くX座標。

label

str

垂直線の横に表示するテキストラベル。

ymin

float or None

垂直線が描画されるY軸の下限。None の場合、現在のY軸の下限が使用されます。

ymax

float or None

垂直線が描画されるY軸の上限。None の場合、現在のY軸の上限が使用されます。

戻り値:

名前

タイプ

説明

returns

None

なし。

plot_idvg_quad()

伝達特性解析結果を 2x2 サブプロットとして可視化します。

詳細説明: ID-VG データに基づいて計算された様々なデバイス特性(ID-VG 曲線、線形抽出、飽和抽出、移動度プロファイル)を2x2のサブプロットとして表示します。各プロットには、Vth, Smin, 移動度最大値などの主要な解析ポイントがアノテーションとして表示されます。プロットはファイルに保存することも可能です。

引数:

名前

タイプ

説明

res

dict

analyze_vg_core() 関数によって生成された、単一 VD スライスの解析結果を含む辞書。

args

argparse.Namespace

コマンドライン引数を含むオブジェクト。 save_plot および plot_dir 属性を使用します。

戻り値:

名前

タイプ

説明

returns

matplotlib.figure.Figure

生成されたMatplotlibの Figure オブジェクト。

interpolate_id_at_vd()

単一の VG 出力曲線内で、要求された VD 値における ID の絶対値を線形補間します。

詳細説明: 与えられたデータフレーム (df_vg) が特定の VG での ID-VD データを含んでいると仮定し、vd_target における abs(ID) の絶対値を線形補間によって推定します。vd_target が測定範囲外の場合、またはデータが不足している場合は np.nan を返します。補間は VDID 列をソートした後に行われます。

引数:

名前

タイプ

説明

df_vg

pandas.DataFrame

単一の VG 値における ID-VD データを含む DataFrameVDID 列が必要です。

vd_target

float

補間したい目標ドレイン電圧 [V]。

戻り値:

名前

タイプ

説明

returns

float

vd_target における補間された abs(ID) の絶対値。データが利用できない場合や範囲外の場合は np.nan

analyze_idvd_logic()

TFTの出力特性 (ID-VD) を解析し、デバイスの線形領域特性と移動度を評価します。

詳細説明: 入力された ID-VD データフレームから、以下の解析を実行します:

  1. 最大の VD 値における伝達特性スライス (df_full) を用いて、参照閾値電圧 (vth_ref) を抽出します。

  2. VG 値における ID-VD 曲線に対して、線形領域(低い VD)での伝達コンダクタンス (gd) を線形回帰で計算します。

  3. 低い VD スライスにおける ID-VG データから、相互コンダクタンス (gm) と S 値を計算します。

  4. 抽出された gdgm、および vth_ref を用いて、実効移動度 (mu_eff) と線形移動度 (mu_lin) を導出します。

  5. 各移動度抽出点に対して線形領域条件のチェック (region_check_linear) を行い、警告情報を記録します。

  6. 解析結果の概要をコンソールに出力し、出力曲線と移動度プロットを生成します。

引数:

名前

タイプ

説明

df

pandas.DataFrame

ID-VD データを含む DataFrameVG, VD, ID 列が必要です。

args

argparse.Namespace

コマンドライン引数を含むオブジェクト。 idx_vg, idx_vd, Imin, L, W, region_factor, save_plot, plot_dir 属性を使用します。

cox

float

単位面積あたりのゲート酸化膜容量 [F/cm^2]。

戻り値:

名前

タイプ

説明

returns

tuple[list[dict], matplotlib.figure.Figure or None]

VG における解析結果の辞書リストと、生成されたMatplotlibの Figure オブジェクトのタプル。有効なデータがない場合は ([], None) を返します。

make_summary_dataframe()

伝達特性解析結果のリストから、Excel出力用のPandas DataFrame を作成します。

詳細説明: t_summary リスト内の各解析結果辞書から、Excelサマリーシートに適した主要なパラメータを抽出します。元のデータフレーム (df) や詳細な分析ポイント (analysis_points)、および内部的なインデックス (idx_ で始まるキー) は除外されます。結果はPandas DataFrame として整形され、Excelへのエクスポートに適した形式で提供されます。

引数:

名前

タイプ

説明

t_summary

list[dict]

VD スライスでの伝達特性解析結果を含む辞書のリスト。

戻り値:

名前

タイプ

説明

returns

pandas.DataFrame

主要な解析結果パラメータを含むPandas DataFrame

run_analysis()

スクリプトのメイン実行ロジックをカプセル化します。

詳細説明: この関数は、コマンドライン引数をパースし、ゲート酸化膜容量 (Cox) を計算します。選択された解析モード (read, analyze_idvg, analyze_idvd, all) に応じて、対応するデータ読み込み、解析、プロット生成の関数を呼び出します。すべての結果(生データ、平滑化データ、解析サマリー、詳細分析ポイント)は集約され、最終的に単一のExcelレポートファイルとPNGプロットとして出力されます。プロットは --show_plot が指定されている場合、インタラクティブに表示されます。

出力されるExcelファイル (args.out_excel) には以下のシートが含まれます:

  • Analysis_Settings: 解析設定の概要。

  • Read_Summary: 読み込みモードのサマリー。

  • Read_Data_VG, Read_Data_VD: 読み込みモードの生データおよび平滑化データ。

  • Summary_Transfer: 伝達特性解析のサマリー。

  • Analysis_Points: 伝達特性解析における主要ポイントの詳細。

  • Data_Transfer_VG_Dep: 伝達特性解析中の VG 依存データ。

  • Data_Output_VG_Dep: 出力特性解析中の VG 依存データ。

引数:

名前

タイプ

説明

args

argparse.Namespace

コマンドライン引数を含む argparse.Namespace オブジェクト。

戻り値:

名前

タイプ

説明

returns

None

なし。解析結果はファイルシステムに出力されます。

main()

プログラムのエントリポイントです。

詳細説明: この関数は、コマンドライン引数をパースし、Excel、PNG、ログファイルの出力パスを準備します。標準出力と標準エラー出力をコンソールとログファイルの両方に出力するように設定した後、run_analysis() 関数を呼び出して主要な解析ロジックを実行します。解析終了後、Tee 機能は解除されます。

戻り値:

名前

タイプ

説明

returns

None

なし。