【マサカリ求む】二次元の物体にかかる空気抵抗が完全に理解できたかもしれない話
三行で
既知の二次元図形にかかる空気抵抗を計算したい!!!
だから自分なりに方法を考えてみました!!!
結果はそこそこいい線行ってるんじゃないかとは思いますが実践で使えるかは正直微妙なところです!!!
注釈
この記事は三年ほど前に投降した記事のブラッシュアップ版となります。
思想の話
何故にそんなことを考えたの?
当初の目的は、「空気抵抗を最小限にするにはどんな断面がいいの?」という疑問に対する答えでした。
そのためにこの記事を参考にジュコーフスキー翼を作ってみて、その抗力を調べようと思ったのですが、
「抗力係数が分からねぇ…」という根本的な問題にぶち当たりました(当然ですが)。
で、それじゃあどうやって抗力を求めるの?
そこで色々とGoogle先生に聞いてみるも、ほぼ答えは
(
この記述以外がなかなか見当たらねぇ…。と悩んでいたそんなところ、こんなサイトがあるじゃありませんか。
https://h-a-labo.amebaownd.com/posts/2558036
(現在は撤回されていますが、僕がアクセスした当時は抗力の試算方法も載っていました)
こりゃすげぇ!!と早速試しに円柱の空気抵抗を計算してみたら、既存の式に比べて値が異様に高い…。
(従来の式で約48[N]に対して、上のサイトの方式(以降、「長谷川式」)の抗力は約5023[N])
(円柱は半径0.5[m]の高さ1[m]、標高0[m]で15[℃]の状態、風速は40[km/h]を想定しました)
上のサイトの管理者(以降、長谷川様)に問い合わせても、
この2、3日熟慮しましたが、抗力計算結果の間違いの理由が解明できておりません。
とのこと。
じゃあ、詰んだの?
んな訳はあるめぇ、他に方法があるはずだ、と思い色々な値を見てみました。
その紆余曲折は長い上に面白くないので割愛しますが、ある値に行きつきました。
固有音響インピーダンス
簡単に言えば音の伝わりづらさです。交流電圧とインピーダンスの関係と同じです。
長谷川様の仮説では、
物体が空気中を移動するとき、物体の前面には空気が圧縮されて高気圧域が、後面には空気が膨張して低気圧域が発生する。
ということになっています。これについては僕はとても正しいと思います。ですが同時に、
空気中に生じた気圧差は音速で解消されるのですが、物体の移動が続くと物体の表面に気圧差は発生し続けるのです。
とエビデンスなしに述べております。これには疑問符が付きました。
その点について長谷川様に問い合わせてみても、
小生は「気圧差の解消速度はその場の音の伝播速度」と考えています。もちろん流速でも移動速度でもありません。
「その場の音の伝播速度」とはその場の「音響インピーダンス」を考慮してのことで、上空3000mの音速を考慮してセスナの揚力を計算しています。
という回答で、いまいちピンと来ません。
音響インピーダンスは
で求まるのですが、長谷川式揚力の計算式
(
のどこにも音響インピーダンスを考慮した部分が出てきていません。
「その場の音速」と「雰囲気圧」、で計算することでその場の音響インピーダンスを考慮したつもりでした。
とのことですが…。
さて、何故「音響インピーダンス」にたどり着いたかという話をしていませんでしたが、
気圧差を音速で解消しようとするけれども、「音響インピーダンス」に邪魔されて
実際には音速でない速度で解消されていると考えたからです。
(例えば、団扇で扇いでから実際に風が来るまで意外とタイムラグがあると思います)
話を戻して、数式に空気の固有音響インピーダンスを登場させましょう。
空気の固有音響インピーダンス(厳密には疎密波が正弦波の場合)は、
(
で求まるので、その場の速度
となります。ところで、長谷川様の仮説では物体の前方で上昇した気圧(=物体の後方で降下した気圧)は
となるため、式をまとめると
となります。僕はこの
理論構築の話
圧力に関する立式
上で求めた流速からベルヌーイの定理を用いて圧力を導けば圧力に関する力が導けるはずです。
二次元における非圧縮のベルヌーイの定理では
なので、仮に流れの外側と内側が同じ流体で構成されていて、内側には一切の流速がなく、かつその境界が無限に薄い何かで覆われていると考えれば下の式が成り立ちます。
(
これで圧力に関する抗力は計算できるはずです。
摩擦力に関する立式
空気抵抗には圧力抵抗だけではなくもう一つ重要な要素があります。摩擦抵抗です。
ですが、摩擦抵抗を求めようにも流体は固体と違って塊ではやってこないので少し考え方を工夫する必要があります。
まず流体を塊として捉えるために、適当に流体を切り取ったものが境界表面を滑っていくことを考えます。
そして先の圧力抵抗の式を変形させて、まず垂直抗力を求めます。
(
そしてここに「仮想摩擦係数」とでも呼ぶべきものを導入します。
(文字では
そうすれば、自ずと摩擦抵抗の式が出来上がります。
ただし、摩擦抵抗は摩擦する向きと抗力にカウントされる力の向きは必ずしも一致しない点について注意してください。
そのため、摩擦力に
よって摩擦力による微小部位の空気抵抗
となります。
全抗力に関する立式
この
そしてこの
そして
式に表すと以下のようになります。
手を動かしてみる
\mu{} は具体的にいくつ?
では
ここでは、このサイトから流れに直交する平板の値を取って使います。
まずは圧力抵抗について求めましょう。
が板の表と裏で2回必要なので
が求まります。
続いて摩擦抗力については
となるので、摩擦抵抗はそのまま
となります。
さて、ここで流れに直交する平板の抗力係数は
ここで、
を代入することで、
が求まりました。
さて、この値は果たして正しいのでしょうか。円柱にかかる抗力係数の計算をすることで実証実験をしましょう。
円柱にかかる抗力
本題です。真打です。以下のコードで実験いたします。
ソースコード
/*
パラメータ群
*/
/* 算出精度のパラメータ */
const N0 = 360; // 分割数[個]
/* 抗力係数用比例定数算出に用いるパラメータ */
const P0 = 101325; // 1気圧[Pa]
const C0 = 340.6520138; // 15℃時の音速[m/s]
const RHO0 = 1.225; // 空気の密度[kg/m^3]
const CD0 = 0.63; // 実験的に求めた抗力係数
const MU0 = 0.578280037531404; // 仮想摩擦係数
/* グラフ表示のパラメータ */
const W0 = 720; // 表示するグラフの横幅[px]
const H0 = 480; // 表示するグラフの高さ[px]
/* パラメータのリスト */
/*
空配列:描画および計算のメッシュ量に応じたもの
*/
const arr = [ ...Array( N0 ) ].map( ( k, i ) => i );
/*
形状から圧力の抗力係数を計算する関数
*/
// in : 円(複素数リスト)
// out : 抗力係数(複素数)(実部:圧力の抗力係数, 虚部:摩擦の抗力係数)
const findKCd = ( l, n ) => math.multiply(
( P0 / ( RHO0 * C0 ** 2 ) ) ** 2, // 比例定数みたいなもの
[ ...Array( n ) ].map( ( k, i ) => {
const dX = l[ i ].re - l[ i < n - 2 ? i + 1 : 0 ].re; // X軸上の変化量
const dY = l[ i ].im - l[ i < n - 2 ? i + 1 : 0 ].im; // Y軸上の変化量
const dS = math.sqrt( dX ** 2 + dY ** 2 ); // 変化前と後の距離
const dP = dS == 0 ? 0 : dY ** 5 / dS ** 4; // 圧力抵抗
const dF = dS == 0 ? 0 : dX ** 2 * dY ** 3 / dS ** 4 * MU0; // 摩擦抵抗
return( math.complex( math.abs( dP ), math.abs( dF ) ) );
} ).reduce( ( p, c ) => math.add( p, c ), 0 )
);
/*
変数・リスト群
*/
/* 円(複素数リスト) */
const lstCircle = arr.map( n => math.complex( { r: 1 / 2, phi: n / ( arr.length / 2 ) * math.PI } ) );
/* 45°傾いた正方形(複素数リスト) */
const lstSquare = [ math.complex( 1 / 2, 0 ), math.complex( 0, 1 / 2 ), math.complex( -1 / 2, 0 ), math.complex( 0, -1 / 2 ) ];
/* 円の抗力係数(複素数)(実部:圧力の抗力係数, 虚部:摩擦の抗力係数) */
const cmpKCd = findKCd( lstCircle, lstCircle.length );
/* 正方形の抗力係数(複素数)(実部:圧力の抗力係数, 虚部:摩擦の抗力係数) */
const cmpHCd = findKCd( lstSquare, lstSquare.length );
/* 抗力係数(合計)(実数) */
const fltKCd = math.round( ( cmpKCd.re + cmpKCd.im ) * 1000 ) / 1000;
const fltHCd = math.round( ( cmpHCd.re + cmpHCd.im ) * 1000 ) / 1000;
/* 圧力の抗力係数(実数リスト) */
const lstCdp = [ CD0, cmpKCd.re, cmpHCd.re ];
/* 摩擦の抗力係数(実数リスト) */
const lstCdf = [ 0, cmpKCd.im, cmpHCd.im ];
/*
実際の描画
*/
/* cdの名が付いたdivタグの内容として表示 */
Plotly.newPlot( 'cd',
[ // 表示するグラフ
{
name: 'D<sub>P</sub>',
x: [ 'Conventional', 'Kabasawa Model', 'Hasegawa Model' ], // X軸:抗力係数を求める方式
y: lstCdp, // Y軸:抗力係数リスト
type: 'bar', // 棒グラフ指定
text: lstCdp.map( String ), // 名前分け
marker: {
color: [ // 色分け
'rgba( 219, 64, 82, 0.7 )', // 実験的に求めた抗力係数
'rgba( 55, 128, 191, 0.7 )', // 樺沢式圧力抗力係数
'rgba( 142, 124, 195, 0.7 )' // 長谷川式圧力抗力係数
],
},
textposition: 'auto',
hovertext: 'Conventional: ' + CD0 + '<br>Kabasawa Model: ' + fltKCd + '<br>Hasegawa Model:' + fltHCd
}, {
name: 'D<sub>F</sub>',
x: [ 'Conventional', 'Kabasawa Model', 'Hasegawa Model' ], // X軸:抗力係数を求める方式
y: lstCdf, // Y軸:抗力係数リスト
type: 'bar', // 棒グラフ指定
text: lstCdf.map( String ), // 名前分け
marker: {
color: [ // 色分け
'rgba( 219, 64, 82, 0.7 )', // 実験的に求めた抗力係数
'rgba( 50, 171, 96, 0.7 )', // 樺沢式摩擦抗力係数
'rgba( 55, 83, 109, 0.7 )' // 長谷川式摩擦抗力係数
],
},
textposition: 'auto',
hovertext: 'Conventional: ' + CD0 + '<br>Kabasawa Model: ' + fltKCd + '<br>Hasegawa Model:' + fltHCd
}
], { // レイアウト設定
height: H0, // グラフの高さ
width: W0, // グラフの幅
barmode: 'stack', // 積み重ね棒グラフ
showlegend: false, // 凡例は隠す
xaxis: { // X軸:抗力係数を求める方式
title: 'finding method'
},
yaxis: { // Y軸:抗力係数
range: [ 0, 1.2 ],
title: 'C<sub>D</sub>'
},
title: 'Drag Coefficiency on a 2D Cylinder'
}, { // グラフ描画のプロパティ
editable: true,
scrollZoom: true,
showLink: false,
displaylogo: false,
modeBarButtonsToRemove: ['sendDataToCloud']
}
);
<!doctype html>
<html lang="ja">
<head>
<script src="https://unpkg.com/mathjs/lib/browser/math.js"></script>
<script src="https://cdn.plot.ly/plotly-latest.min.js"></script>
</head>
<body>
<div id="cd"><!-- ここに抗力係数のグラフを表示する --></div>
<script src="cylinder5.js"></script>
</body>
</html>
\結果発表~!!!/
赤い棒が実測値、青い棒が算出した圧力抵抗、その上の緑色の棒が算出した摩擦抵抗です。
詳しい方は優しめにふんわりとマサカリを投げてください。
また、紫色(圧力抵抗)と灰色(摩擦抵抗)で長谷川様の形状単純化モデル
(最前端、最後端、最上端、最下端をそれぞれ計測し、それらで作る四角形について計算する)
を取り入れた計算の結果を示しました。値は
別の図形(例えば、翼型など)ならばより良い結果が得られるのかの検証は必要ですが、少なくとも単純な円柱においては正しくない結果のようです。
考察もどき
今回は流れに直交する平板から「仮想摩擦係数」を約
(ちなみに手で値をいじって探索した結果、約
ただ、任意の形状についてはどのように「仮想摩擦係数」を設定すればよいのか、あるいは
課題とか
まずは「仮想摩擦係数」が
また、この抗力を求める方式を応用して「循環」に依存しない揚力計算も可能なのではないかと考えられるので、その方式を開発することが一つの大きなポイントです。
さらに、上は全て二次元でのお話なので、三次元に拡張した場合どのような変化があるのかについて考える必要があります。
結論らしきもの
以下の考え方を導入して、新たな空気抵抗の計算方法を作成してみました。
- 長谷川様からインスパイアされた、「音の性質を勘案する」という発想
- ベルヌーイの定理から圧力抵抗の値を計算する式の立式
- 「仮想摩擦係数」の概念を取り入れた摩擦抵抗の値を計算する式の立式
結果としては実用に耐えうるとは断言できない微妙な結果となりましたが、あくまで「概算」程度には使えるのではないかと思います。
最後に、マサカリ募集のお知らせ
ここまで偉そうにペラペラと理屈を並べましたが、僕は航空力学についてはずぶのド素人です。
故にいい感じのマサカリは超大歓迎です。
航空力学に詳しい諸兄のご意見、ご感想をお待ちしております。
あ、マサカリを投げるときは優しくふんわりめでお願いしますね。痛いので。
2024/11/27 : 追記
初歩的な計算間違いがあったので少し内容を書き換えました。
結果的に修正前と比べて算出した数値の信頼性が上がったという嬉しい誤算はありましたが、それはそれとして間違った内容を掲出してしまい申し訳ございません。
今後もアップデートする内容があれば随時追記いたします。
2024/12/2 : 追記
長谷川様の形状単純化モデルが通用するのかどうかを確かめるべく、グラフに結果を追記しました。
今回の結果としては良くないものでしたが、今後形状の一般化を模索する際においてはそれなりに考慮すべき内容かと思います。
Discussion