0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

iRICの格子生成アルゴリズム 多機能格子生成ツール "Multifunction Grid Genarator"について

Last updated at Posted at 2023-01-27

本テキストは公開されている資料や開発者様から提供頂いたソースコードを基に@starfieldKtが作成しています。
そのため開発者様が意図していることと異なる部分がある可能性があることをご注意ください。
また、本テキストに関することを開発者様へお問い合わせ頂かないようお願い申し上げます。

その他格子生成ツールについてはこちら

多機能格子生成ツール "Multifunction Grid Genarator"

項目 内容
名称 Multifunction Grid Genarator
多機能格子生成ツール
開発者 清水康行

注意
本投稿ではiRIC ver4版の多機能格子生成ツール(ver 1.1.23012501)について紹介します。
iRIC ver3のインストーラーに含まれる多機能格子生成ツール(ver 1.0.1)とは異なる部分があります。

概要

この格子生成ツールでは、直線水路および、サイン・ジェネレーテッド・カーブ蛇行水路、蛇行水路に歪度と平坦度を設定した木下蛇行水路の作成ができる。
また、それぞれの水路形状において、複断面の設定、上下流への直線水路追加、縦断方向で変化する水路幅設定ができる。

格子生成条件

水路形状

image.png
image.png

水路形状

水路形状の項目では、水路形状の項目で、水路主要部の形状として直線サインジェネレーテッドカーブ木下迂曲蛇行河道が選択できる。

各格子形状は以下のようになる。蛇行波数を増やした場合、以下に示した形状が蛇行波数分繰り返される。
image.png
image.png
image.png

断面形状

断面形状では単断面複断面を選択可能、各横断形状の例を以下に示す。

image.png

複断面のパターン

複断面のパターンでは低水路と堤防の関係を3種類から選ぶことができる。

  • 堤防と低水路が平行の場合、そのままの意味で低水路と堤防は平行に作成される。
  • 堤防は直線の場合、低水路の形状に関わらず堤防は直線で作成される。
  • 堤防も蛇行の場合、水路形状に関わらず堤防を蛇行させることが出来る。
    image.png

断面形に関するパラメーター

image.png
image.png

断面形状に関するパラメーターグループでは水路の横断面に関する設定を行う。

横断面の形状毎に入力が必要なパラメーターについて整理する。

単断面

横断形状を単断面に設定した場合、入力するパラメータと作成される格子は以下のようになる。

image.png

複断面(堤防と低水路が平行)

横断形状を複断面、複断面のパターンを堤防と低水路が平行に設定した場合、入力するパラメータと作成される格子は以下のようになる。
低水路河岸の幅は低水路河岸法勾配(1:n)低水路河岸深さ(m)から求められる。(以後複断面のものは同様)

image.png

複断面(堤防は直線)

横断形状を複断面、複断面のパターンを堤防は直線に設定した場合、入力するパラメータと作成される格子は以下のようになる。

image.png

この時の低水路、と高水敷の端(堤防)の位置関係は以下のように、低水路の中心線のY軸方向が中央となる位置が堤々間の中心になるようになる。

image.png

複断面(堤防も蛇行)

横断形状を複断面、複断面のパターンを堤防も蛇行に設定した場合、入力するパラメータと作成される格子は以下のようになる。

image.png

堤防と低水路が平行以外のパターンの際の横断面について

上記の3パターンを見比べてお気づきかもしれないが、堤防と低水路が平行堤防は直線堤防も蛇行では高水敷の横断面のとりかたが異なっている。

堤防と低水路が平行において、横断面は高水敷でも低水路中心線に対し垂直のままも生成されているのに対して、堤防は直線堤防も蛇行に関しては低水路河岸の法肩からX軸方向に垂直に堤防に向かって横断面が伸びている。
これに関しては高水敷の格子点の座標の求め方が異なっているためである。

image.png

水路形状に関するパラメーター

image.png
image.png

ここでは水路形状(主に流下方向)に関するパラメータの設定をする。

枠で囲まれていない蛇行波長(m)蛇行波数蛇行角一波長当たりの縦断方向格子数が主要水路のパラメータである。
堤防の平面形状パラメータの枠で囲まれた項目は複断面のパターンで堤防も蛇行を選択した場合のみに設定する項目で堤防の蛇行を水路の蛇行とは別途設定することが出来る。なお、堤防の蛇行に関しては蛇行波数の設定項目が存在しないが、堤防の蛇行波数は主要水路の蛇行波数と同じ値になる。
また、以下の図のように堤防の蛇行波長が主要水路の蛇行波長より短い場合は蛇行終了後、直線堤防となる。
image.png

サインジェネレーテッドカーブ、木下迂曲蛇行河道について

河道形状サインジェネレーテッドカーブ木下迂曲蛇行河道にした場合の低水路の中心線および、複断面のパターン堤防も蛇行を選択した場合の堤防のラインはサインジェネレーテッドカーブまたは木下蛇行曲線から作成される。
この低水路の中心線および堤防のラインの座標を計算する際に上記のパラメーターが使用される。

サインジェネレーテッドカーブおよび木下蛇行曲線については以下のページを参考にしています。

はじめに、河道形状サインジェネレーテッドカーブに設定した際の低水路中心線について、曲線の進行方向を$s$軸、蛇行波長を$L$、蛇行角を$\theta_0$としたとき曲線の進行方向と水平方向の角度$\theta$は以下の$s$に関する式で表される。

\theta=\theta_0\sin\biggl(2\pi\frac{s}{L}\biggr) \tag{1} 

この曲線を$x-y$座標に変換するには微小要素$\Delta s$を$s$軸に沿って逐次加算していき、その都度$\theta$を求め、$\Delta s$と$\theta$から$\Delta x$、$\Delta y$を求め、累加していきます。
微小要素$\Delta s$の$x,y$成分は以下の式で表せます。

\begin{align}
\Delta x=\Delta s \cos \theta\tag{2} \\
\Delta y=\Delta s \sin \theta\tag{3}
\end{align}

image.png

これらの式より、サインジェネレーテッド曲線の$s,x,y$は以下の式で表すことができました。

\begin{align}
s= s_0 + \int_{s_0}^{s}ds\tag{4}\\
x= x_0 + \int_{s_0}^{s}\cos\theta ds\tag{5}\\
y= y_0 + \int_{s_0}^{s}\sin\theta ds\tag{6}
\end{align}

image.png

次に河道形状木下迂曲蛇行河道に設定した場合、低水路中心線は木下蛇行曲線が作成されます。
木下蛇行曲線はサインジェネレーテッドカーブの$(1)$式が次式のようになったものです。
上記のパラメータにおいて、付加項の蛇行角(度)が$\theta_1$、付加項の波数が$n_w$になります。

\theta = \theta_0\sin\Biggl( \frac{2\pi s}{L}\Biggr)+\theta_1\cos \Biggl( n_w\frac{2\pi s}{L}\Biggr)

木下蛇行曲線については、先ほどのページに記載されている式(簡易直線・蛇行水路生成ツールで使用されているのはこちら)とは異なりますが、上式は開発者より提供頂いたソースコード上で記載されているものです。

最後に複断面のパターン堤防も蛇行に設定した際に作成されるサインジェネレーテッドカーブですが、ここでは低水路との位相差を設定することができます。
位相差$s_d$を考慮する場合、$(1)$式が以下のようになります。

\theta=\theta_0\sin\biggl(2\pi\frac{s-s_d}{L}\biggr)

なお、低水路の中心線及び左右岸の堤防のラインの始点$[x_0,y_0]$について、低水路の中心線は$[0,0]$,左岸の堤防ラインは$[0,低水路中心から左岸堤防までの距離]$と$[0,-低水路中心から右岸堤防までの距離]$になります。

河床形状と河道形状

image.png
image.png

ここでは水路の勾配および河床の形状の設定を行います。
河床形状の設定は複断面の設定と併用できますが、この項目を設定することによる変位が高水敷を含めた水路幅全範囲に対して適用されるため、併用は想定されていないものと思われます。

河床形状

河床形状は平坦(砂州無し)交互砂州放物線状の3つから選択できます。
3種類の横断形のイメージと平面図の例を以下に示します。

image.png

平坦

平坦(砂州無し)を選択した場合、横断方向の河床高の変化はありません。

交互砂州

交互砂州を選択した場合、水路の中央を中心とした点対象の河床となります。
また、流下方向における横断形の変化もあります。

image.png

断面$i$での地盤高$y$を考える。
主要水路上流端断面から断面$i$までの流下方向の距離を$s$、右岸端から左岸方向への距離を$x$、水路中央の地盤高を$y_0$、水路幅を$B$、砂州波高を$h$、平面形と河床地形の位相差を$d$、波長を$L$とすると$y$は以下の式で表すことができる。

y=y_0-h\cos\biggl(2\pi\frac{s-d}{L}\biggr)\cos\biggl(\pi\frac{x}{B}\biggr)

image.png

放物線

放物線を選択した場合、水路の中央を中心に左右対称の放物線状の河床となります。
縦断方向での横断形の変化はありません。
image.png

断面$i$での地盤高$y$を考える。
水路中央からの距離を右岸側を正として$x$とし、水路中央の地盤高を$y_0$、水路幅を$B$、砂州波高を$h$とすると$y$は以下の式で表すことができる。

y=y_0+\frac{4h}{B^2}x^2-h

image.png

水路勾配

水路勾配を指定すると、主要水路の上流端を基準に指定した勾配で縦断方向の距離に応じて河床の変化を与えます。
image.png

上下流の条件

image.png
image.png

ここでは主要水路の上下流に追加する直線水路の設定ができる。
水路を付加するを選択した場合、上流に追加する断面(格子)数上流に追加する断面(格子)数で指定した数だけ上下流に断面が追加される。
この時の追加断面は非常に単純に、主要水路の上下流端断面の格子点からX軸方向に$\frac{蛇行波長}{一波あたりの縦断方向格子数}$の間隔で格子点を指定した断面数分だけ追加するものである。そのため、上下流端断面のY軸方向に対する傾きに関係なく同じ断面の傾きのまま水平方向(X軸方向)へ直線水路が作成されるので流心線(水路中心線)と横断面が直交しないことがある。

image.png

また、勾配は上の図のように主要水路と同じ勾配が適用されるが、河床形状交互砂州を選択した場合は河床形が縦断方向で変化するのは主要水路だけであるので注意が必要となる。
上の図の水路の勾配を0、河床形状を交互砂州に設定した場合の水路を以下に示すが、追加水路の河床形状は主要水路上下流端と同じになっていることが確認できる。

image.png

簡易直線・蛇行水路生成ツールでは複断面を設定できませんが、上下流追加水路の勾配を別途設定できるほか、上下流追加水路にも交互砂州が適用されます。

川幅の水路方向変化

image.png
image.png

ここでは川幅変化の方法の選択内容で左右岸両方、またはどちらかの低水路の川幅を流下方向距離に応じて川幅変化量(m)で指定した値を最大値として変化させることが出来る。特徴として以下があげられる。

  • 川幅が変化するのは主要水路部の低水路のみである。
  • 川幅変化量(m)の値が正の場合は川幅が拡幅され、負の場合川幅を縮小させる。
  • 両岸を設定した場合、指定した川幅変化量(m)分だけ左右岸それぞれ拡幅or縮小される。

image.png

拡幅方向の変化量を正とした時、左右岸それぞれにおける変化量$y$は、主要水路部上流端からの距離を$s$、指定した川幅変化量(m)を$b$、波長を$L$とすると以下の式で表すことができる。

y=b\frac{1-\cos\biggl(2\pi\frac{s}{L}\biggr)}{2}

河床の状況

image.png
image.png

ここでは格子作成の際にセル属性として河床の状況粗度を与えることができる。
属性を与えるセルの範囲は低水路と高水敷に分かれておりそれぞれに異なるセル属性を与えることが可能です。

なお、高水敷の範囲には低水路の河岸法面部分のセルも含みます。
image.png

格子が作成されるまでの流れ

サインジェネレーテッドカーブ、単断面、水路幅変動あり、交互砂州、追加水路ありの条件で格子が作成される例をもとに格子作成までのプログラム的な流れを整理します。

  1. 水路中心線に沿って各断面の中心の座標が計算される。
    image.png
  2. 各断面の水路幅に応じて断面が水路中心線に直交するような各断面の両端の座標(複断面の場合は高水敷、河岸法面、低水路それぞれの両端の座標)を求める。この時すでに川幅の変化は適用されている。
    image.png
  3. 各断面で両端の座標から按分して横断方向の格子点の座標を求める。この時、勾配と上流端から各断面までの距離に応じた標高を一律で各断面の格子点に与える。
    image.png
  4. 各横断面において、指定した河床形状になるよう上流端から各断面までの距離に応じた各断面の格子点の変位量を計算し、各格子点に変位量を加算する。
    image.png
  5. 上下流に水路を追加する場合、上下流端の断面の座標から追加の水路を作成する。
    image.png

複断面の場合、複断面のパターンによって2~3での高水敷の端の座標の設定方法が異なりますが全体の流れとしては大体同じになります。長くなるため解説はしませんが、要望があれば追記するかもしれません。

格子作成例

低水路と平行な堤防に囲まれた幅が変化する蛇行水路
image.png

直線堤防に囲まれた幅が変化する蛇行水路
image.png

0
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?