「ComplexRI」の版間の差分
179行目: | 179行目: | ||
<div id="入力07" style="font-size: 150%; color:Aqua;">チュートリアル07:実験で用いた基質の種類</div> | <div id="入力07" style="font-size: 150%; color:Aqua;">チュートリアル07:実験で用いた基質の種類</div> | ||
全反射実験で用いた基質の種類を入力してほしい。これはn1の屈折率を指定することになっている。 | 全反射実験で用いた基質の種類を入力してほしい。これはn1の屈折率を指定することになっている。 | ||
[[File:FILE_全反射実験.png|500px]] | |||
選択肢は次の4つである。 | 選択肢は次の4つである。 | ||
(1)diamond。屈折率は2.38と設定される。 | (1)diamond。屈折率は2.38と設定される。 | ||
189行目: | 189行目: | ||
<div id="入力08" style="font-size: 150%; color:Aqua;">チュートリアル08:入射角</div> | <div id="入力08" style="font-size: 150%; color:Aqua;">チュートリアル08:入射角</div> | ||
全反射実験の光の入射角を指定してほしい。 | 全反射実験の光の入射角を指定してほしい。 | ||
[[File:FILE_全反射実験.png|500px]] | |||
上の図でいうところの<math>{\theta}_i</math>である。 | 上の図でいうところの<math>{\theta}_i</math>である。 | ||
デフォルトは45°になっている。 | デフォルトは45°になっている。 | ||
241行目: | 241行目: | ||
: <math>\gamma</math>は15とする。これは参考文献[1]<ref name = "ref1">から、<math>\gamma</math>は15付近であるという傾向がわかっているからだ。 | : <math>\gamma</math>は15とする。これは参考文献[1]<ref name = "ref1">から、<math>\gamma</math>は15付近であるという傾向がわかっているからだ。 | ||
: <math>A</math>は7.5とする。これは参考文献[1]<ref name = "ref1">から、<math>A</math>と<math>\gamma</math>の間に<math>\frac{A}{\gamma} = {\kappa}_{max}</math>という関係があり、さらに<math>{\kappa}_{max}</math>が0.5付近の値を多くとるということがわかっているからだ。 | : <math>A</math>は7.5とする。これは参考文献[1]<ref name = "ref1">から、<math>A</math>と<math>\gamma</math>の間に<math>\frac{A}{\gamma} = {\kappa}_{max}</math>という関係があり、さらに<math>{\kappa}_{max}</math>が0.5付近の値を多くとるということがわかっているからだ。 | ||
: 最後に<math>\nu_l</math> | : 最後に<math>\nu_l</math>についてこれは入力④で与えられた解析範囲において入力⑤で読み込みを指定した列の反射率が最小になるところとしている。これはローレンツ関数<math>\frac{A}{\nu_l-\nu-i\gamma}</math>を実部と虚部に分けたとき、<math>\frac{A\gamma}{{\nu_l-\nu}^2 + {\gamma}^2} + i\frac{{\nu_l-\nu}^2}{{\nu_l-\nu}^2 + {\gamma}^2}</math>となり、虚部が吸収を表すことが関係している。虚部において最大になるところこそが<math>\nu_l</math>であり、この時吸収は最大である。これは反射が最小に対応する。ゆえにこのように与えている。 | ||
1つずつ与える。 | 1つずつ与える。 | ||
: 最小二乗法を行う際、パラメータの範囲はそれぞれ<math>A</math>は-200から200。<math>\nu_l</math>入力④で与えられた範囲。<math>\gamma</math>は0から500で行っている。 | : 最小二乗法を行う際、パラメータの範囲はそれぞれ<math>A</math>は-200から200。<math>\nu_l</math>入力④で与えられた範囲。<math>\gamma</math>は0から500で行っている。 | ||
248行目: | 248行目: | ||
: これが入力の⑩で与えられた値より小さければ結果を返す。 | : これが入力の⑩で与えられた値より小さければ結果を返す。 | ||
: 大きければ、ローレンツ関数を1つ増やす。この時、1つ目の初期値は今回の最小二乗法で求まった値を用いる。 | : 大きければ、ローレンツ関数を1つ増やす。この時、1つ目の初期値は今回の最小二乗法で求まった値を用いる。 | ||
: 2つ目の初期値の作り方を説明する。これは、1つ目のローレンツ関数を用いて計算される <math>\left | r \right \vert_{calc}^2</math>を<math>\left | r \right \vert_{exp}^2</math> | : 2つ目の初期値の作り方を説明する。これは、1つ目のローレンツ関数を用いて計算される <math>\left | r \right \vert_{calc}^2</math>を<math>\left | r \right \vert_{exp}^2</math>から引いた値計算する。その様子を模式的に図にすると以下のようになる。 | ||
[[File:FILE_差の関数.png|500px]] | |||
: このうち絶対値が最も大きい値に対応する波数を2つ目の<math>\nu_l</math>の初期値として与える。 | |||
: つまり | |||
[[File:FILE_nuの与え方.png|500px]] | |||
: <math>A</math>の大きさは1つ目で求まったAの半分としている。これは屈折率の分散の概形が一つ目で与えられていると考え、足りない部分を補うという考えから、一つ目のAより小さいと考えたためである。今回はAの符号も検討する必要がある。これは、差の値が入力ファイルのように反射率が下に凸とは限らないからだ。よってνに対応する値が最小値なら正、最大値なら負というように与えている。最小値の場合、正として与えるのは1つ目の時と同じで反射率が最小の時吸収が最大になると考えるからである。逆の場合は、物理的な意味は考えづらいが数学的に符号を反対にすることが妥当だと考えたからである。 | |||
: 2回目以降も同じように残差が入力値より小さいかを判定して、小さければ結果を返し、大きければ1つ増やして、初期値を与えて、最小二乗法行う。これを結果が出るまで繰り返す。2回目以降の残差が大きかった場合の初期値の与え方は1回目と同じである。求まったパ:ラメータから計算される <math>\left | r \right \vert_{calc}^2</math>を<math>\left | r \right \vert_{exp}^2</math>から引いた値計算する。このうち絶対値が最も大きい値に対応する波数を2つ目の<math>\nu_l</math>の初期値として与える。<math>A</math>の大きさは1つ目で求まった<math>A</math>の半分としている。これは屈折率の分散の概形が一つ目で与えられていると考え、足りない部分を補うという考えから、一つ目のAより小さいと考えたためである。<math>A</math>の符号は<math>\nu_l</math>に対応する値が最小値なら正、最大値なら負というように与えている。 | : 2回目以降も同じように残差が入力値より小さいかを判定して、小さければ結果を返し、大きければ1つ増やして、初期値を与えて、最小二乗法行う。これを結果が出るまで繰り返す。2回目以降の残差が大きかった場合の初期値の与え方は1回目と同じである。求まったパ:ラメータから計算される <math>\left | r \right \vert_{calc}^2</math>を<math>\left | r \right \vert_{exp}^2</math>から引いた値計算する。このうち絶対値が最も大きい値に対応する波数を2つ目の<math>\nu_l</math>の初期値として与える。<math>A</math>の大きさは1つ目で求まった<math>A</math>の半分としている。これは屈折率の分散の概形が一つ目で与えられていると考え、足りない部分を補うという考えから、一つ目のAより小さいと考えたためである。<math>A</math>の符号は<math>\nu_l</math>に対応する値が最小値なら正、最大値なら負というように与えている。 | ||
: ここまで、入力の⑪がNOの場合の説明をしてきた。次に、入力の⑪がYESの場合の説明をしよう。 | : ここまで、入力の⑪がNOの場合の説明をしてきた。次に、入力の⑪がYESの場合の説明をしよう。 |
2021年11月29日 (月) 05:55時点における版
概要
本ComplexRIは全反射実験から得られた反射率あるいは吸光度のデータをもとにして媒質の複素屈折率の分散を出力するWebアプリケーションである。 1⃣実験の結果、 2⃣ファイル形式に関する入力、 3⃣実験の条件、 4⃣解析に関する条件 という四つの情報を入力として与えると、解析が行える。
チュートリアル
- チュートリアルでは4種類全10個の入力について、実際に解析を行い、その結果をもとに説明する。
目次 |
---|
チュートリアル01:ファイルを入れて解析する(入力1⃣を与える練習) |
チュートリアル02:解析に関する条件を指定する(入力4⃣を与える練習) |
チュートリアル03:ファイルの形式を変える(入力2⃣を与える練習) |
チュートリアル04:実験条件を正しく与える(入力3⃣を与える練習) |
- ここでは1⃣実験の結果を入力として与えて解析結果を出力させてみよう。
- 実験結果のファイルはComplexRIのMANUALページのFile Listからダウンロードできる。
- 今回はDownload the File01のボタンを押してダウンロードしてこれを使用してほしい。
- ダウンロードが出来たらLSRページに行きファイルを入れてみよう。
- 入力は①から⑩の10個だ。今回は②Fileにダウンロードしたファイルを与えるだけでFよい。
- それではexecute LSRボタンをクリックして解析してみよう。
- 解析結果は以下の画像のようなったはずである。
- ここまでComplexRIの基本的な流れを体験してもらった。
- ここで入れたファイルについて簡単に説明する。
- この様になっているはずである。
- 一列目には波数、二列目に一列目の波数の光が入射した時の反射率が(%)単位が並んだ構成になっている。
- この様に解析に必要な実験結果は波数とそれに対応する反射率の二種類だけであり、これだけの実験結果から解析が行えるということである。
- 結果については次のチュートリアルで説明する。
- ここでは4⃣解析に関する条件を入力として与えてみよう。
- まず、先程と同様にLSRページに行き②Fileにファイルを与える。これは前回と同じものを使用してほしい。
- 先程はこれで実行していたが、以下のように④と⑩に追加の設定をしてみよう。
- それではexecute LSRボタンをクリックして解析してみよう。
- 解析結果は以下のようなったはずである。
- ④と⑩の入力の意味を説明する前に、結果の見方について簡単に説明する。
- (1)数字、(2)表、(3)グラフが並んでいる。
- (2)表の数値はフィッティング関数のパラメータである。このフィッティング関数を足し合わせることで、左側の(3)グラフを描いている。また、このグラフの各点の値から反射率を計算してプロットしたのが右側の(3)グラフのcalculateである。実際の回帰ではこの表の数値をいろいろ試して、右側の(3)グラフのcalculateとexperimentと比較するということを行っている。ここで、experimentは入力ファイルとして与えられた反射率の値である。(1)数字は解析が終了した時点で、この比較の差がどれくらい小さくなったかを示している。具体的なフィッティング関数の形や方法については内部処理の説明01:フィッティング方法を参考にしてほしい。
- これを踏まえて、④と⑩の入力の意味を説明していこう。
- 説明は今回の結果をチュートリアル01の時と比較しながら行っていく。
- 図の比較は以下のようになる。
- 左がチュートリアル01の結果。右がチュートリアル02➡チュートリアル01の結果を直接見る。の結果。
- ④の入力をしたことは、グラフの横軸の幅を設定することなっている。確かに、[入力4の図]と同じ範囲になっている。デフォルトの値で行われたチュートリアル01の時と比べると変化がわかりやすいと思う。
- このグラフの幅の設定は、言い換えると、解析する波数の範囲設定したことになっている。これは直前に説明した解析の原理から考えればわかる。(3)グラフのcalculateとexperimentを比較するのであった。このときグラフの横幅を変えれば、比べる範囲つまり解析の範囲を変えることに相当するということだ。
- 次に⑩について説明する。今回は[入力10の図]のように0.01した。解析は(1)数字がこの値より小さくなったら終了するようになっている。つまり解析の正確さもしくは厳しさを設定することになっている。これは小さくしすぎないように注意してほしい。なぜなら、比較の差分がこれよりも小さくならず、解析がとても長くなることがあるからだ。目安としてはデフォルトの0.02から0.01がよい。これは適宜試してみてほしい。
- ここでは2⃣ファイル形式に関する条件を入力として与えてみよう。
- チュートリアル01の時と同様にMANUALページのFile Listからファイルをダウンロードしてほしい。
- 今回はFile02を使う。
- ダウンロード出来たら、LSRページに行き②Fileにファイルを与える。
- 今回は③,⑤,⑥の入力を以下のように変更してみよう。
- それではexecute LSRボタンをクリックして解析してみよう。
- 解析結果は以下のようなったはずである。
- じつはこれはチュートリアル01と同じ結果になっている。
- 左がチュートリアル01の結果。右がチュートリアル03の結果。➡チュートリアル01の結果を直接見る。
- これは全く同じになっている。
- これは同じ実験結果を入力したことを意味している。しかし、チュートリアル01と02で使用した入力ファイルと今回使用した入力ファイルを比較すると、以下のように一見同じには見えない。これが同じであることを説明する。(一部分のみ示す。)
- 左がチュートリアル01の入力ファイル。右がチュートリアル02の入力ファイル。
- 異なる点は2つある。
- 1つは行が3行になっていることである。これは波数、反射率、吸光度の順に並んでいる。ここで新しく出てきた吸光度というのは反射率と等価な情報を表している。なぜなら、(証明)という関係式が成り立っており、これによって吸光度を反射率に変換することができるからだ。
- もう1つは波数と反射率の並びが昇順から降順になっていることだ。ここで、吸光度はこの様に並び替えた後で反射率から計算したので波数に対応している。
- このように形は異なるが等価な実験結果を与えた。だから結果が同じだったのだ。
- ③,⑤,⑥の入力はこのファイルの形の違いをアプリ側に考慮させるために入力した。
- ⑤では読み込む列の番号を与えたことになっている。今回は入力として1行目の波数と3行目の吸光度を使うのでこのように設定した。
- 吸光度を使うときは、忘れずに③をabsorptanceに設定してほしい。すると、解析時に反射率に変換して解析する。
- この設定はデフォルトではreflectanceになっているのでこれまでは変更する必要がなかった。
- 最後に⑥はデータの波数のの並び方昇順か降順かを入力している。今回は降順なのでこのように設定した。デフォルトは昇順なので今までは設定する必要がなかった。
- ここでは3⃣実験の条件を入力として与えてみよう。
- LSRページに行き②Fileにファイルを与える。これはチュートリアル01と02で使ったものと同じものを使ってほしい。
- 今回は⑦,⑧,⑨の入力を以下のように変更してみよう。
- それではexecute LSRボタンをクリックして解析してみよう。
- 解析結果は以下のようなったはずである。
- チュートリアル01とグラフを比較してみると以下のようになる。
- 左がチュートリアル04の結果。右がチュートリアル01の結果。➡チュートリアル01の結果を直接見る。
- 同じファイル、つまり同じ実験結果を与えているが、実験条件が違えば、出力も異なることがわかる。正しい分散を求めるには自身の行った実験の条件を正しく与える必要があるということだ。
- 各入力を説明しよう。
- ⑦では全反射実験のときに使った基質の種類を指定している。
- ⑧では全反射実験のときの入射光の角度を指定している。
- ⑨では分散のバックグラウンドを与えている。これは測定する基質の赤外領域での屈折率を与える必要がある。
- これは可視光領域の光に対する屈折率からコーシの方程式のパラメータを求め、これを外挿することによって求めることができる。
- 詳しい求め方は内部処理の説明02:屈折率のバックグラウンドを参考にしてほしい。
チュートリアルtopへ
マニュアル
目次 |
---|
入力01:タイトル |
入力02:ファイル |
入力03:反射率か吸光度か? |
入力04:波数範囲 |
入力05:データの列の指定 |
入力06:昇順か降順か? |
入力07:実験で用いた基質の種類 |
入力08:入射角 |
入力09:吸収がないときの屈折率 |
入力10:残差の指定 |
入力11:フィッティング関数のパラメータの設定の有無 |
- これはアウトプットファイルの名前になる。自分のわかりやすいようにつけてほしい。デフォルトはno-titleである。
ここでは実験結果のファイルを入力してほしい。以下に例を示す。(ファイル全体が大きすぎるので一部を示している。) 形式の指定は以下の3つです。 (1)Txtファイルである。 (2)波数とそれに対応する反射率もしくは吸光度が列ごとに並んでいる。 (3)列と列の間は空白で区切られている。
結果のファイルで吸光度と反射率のどちらを読み込ませようとしているかを指定してほしい。 選択肢は次の3つである。 (1)反射率で単位が(%)である。 (2)反射率で単位が(%)ではない。 (3)吸光度 デフォルトは(1)です。
屈折率の分散を解析する波数範囲を指定してほしい。
入力ファイルのうち解析に用いる列を指定してほしい。 波数、反射率(あるいは吸光度)についてそれぞれ指定してほしい。 デフォルトは波数が1行目、反射率(あるいは吸光度)が2行目になっている。
データの並び方を指定してほしい。これは波数の並び方が昇順か降順かを与えてほしい。 デフォルトは降順になっている。
全反射実験で用いた基質の種類を入力してほしい。これはn1の屈折率を指定することになっている。 500px 選択肢は次の4つである。 (1)diamond。屈折率は2.38と設定される。 (2)zinc selenide。屈折率は2.40と設定される。 (3)germanium。屈折率は4.0と設定される。 (4)上記以外。これは屈折率を自由に設定できる。実際の実験で上記3つの基質以外を使った場合を想定している。しかし上記3つの基質のいずれかを使った場合でも、より厳密に屈折率を指定したい場合はこれを用いることも可能である。。 デフォルトは(1)になっている。
全反射実験の光の入射角を指定してほしい。 500px 上の図でいうところのである。 デフォルトは45°になっている。
吸収がないときの屈折率を入力してください。 これはコーシーの方程式から計算できる。解析したい物質及び波数範囲に合わせて適切なパラメータ及び波長を与え、求めた値を入力してほしい。 「参考サイト」
ここでの解析を終了するための指標になる。内部処理の説明01:フィッティング方法で述べるように最小二乗法を繰り返し行い、残差がここでの入力値より小さいかどうかで解析の終了、続行を判定している。 注意!!小さすぎると終わらないことがある。
フィッティング関数の初期の本数およびパラメータの初期値を手動で与えるか自動で設定するかを選択できる。 自動の場合は内部処理の説明01:フィッティング方法で述べたように決定している。 手動で決定する場合は、まず、Lor_numにローレンツ関数の本数を入力してほしい。最大は5となっている。 次に、Lor_numの値に応じて、INIT_A1, INIT_N1, INIT_G1と出てくる。これはローレンツ関数のパラメータに相当している。 最後の数字が同じINIT_A, INIT_N, INIT_G3つが一組となって一つのローレンツ関数のパラメータの初期を与えることになる。それぞれ、INIT_Aは, INIT_Nは, INIT_Gはに対応している。
マニュアルtopへ
内部処理
目次 |
---|
説明01:フィッティング方法 |
説明01:フィッティング方法
- 屈折率の分散をパラメータを使って表したい。ローレンツ関数の重ね合わせによってのように表せると考えている。理由は詳細01参照。
- 光の強度反射率について最小二乗法を行ってパラメータを決める。つまり、という式について最小二乗法を行っている。
- ここでは両方とも電場の反射率である。光の強度反射率が電場の反射率の2乗になる理由は引用エラー:
<ref>
タグに対応する</ref>
タグが不足しています
ComplexRIページtopへ]