点と直線の距離

提供: testwiki
ナビゲーションに移動 検索に移動

ユークリッド幾何学において点と直線の距離(てんとちょくせんのきょり、テンプレート:Lang-en-short)とは、直線上の任意の点の距離で最短になるものをいう。点と直線を結ぶ線分で点と直線の距離に等しい長さをもつものは、与えられた直線と直交する性質がある。点と直線の距離を計算する公式は、いくつかの方法によって導出できる。

点と直線の間の最短距離を知ることは様々な場面において有益である。例えば、道路までの最短距離が分かったり、グラフ上の値のちらばりを定量化したりなどである。線形曲線回帰の一種であるデミング回帰では、独立変数従属変数が等しい分散を持つ場合には、近似曲線と各データ点の距離によって近似の精度が測定されるテンプレート:仮リンクに帰着される。

デカルト座標における距離

方程式で定義された直線

ax + by + c = 0の形の方程式により平面上の直線が与えられた場合(但し a, b, c実数の定数で a, b は非零である)、点 (x0, y0) と直線の距離は

distance(ax+by+c=0,(x0,y0))=|ax0+by0+c|a2+b2

となる[1][2]テンプレート:Rp。また直線上の点で、(x0, y0) に最も近い点の座標は以下で与えられる[3]:

x=b(bx0ay0)aca2+b2 and y=a(bx0+ay0)bca2+b2.

軸に平行な直線

一般の直線の方程式 ax + by + c = 0 について、c が 0 でない限り ab がともに 0 になることはない。またそのような場合、方程式はもはやどんな直線も定めない。もし a = 0, b ≠ 0 のときには直線は x 軸に平行で、方程式は y = −c/b となる。この直線と点 (x0, y0) の距離は、上の等式にあてはめることにより長さ |y0 − (−c/b)| = |by0 + c|/|b| の x 軸に垂直な線分から得られる。同様に x 軸に垂直な直線 (b = 0) と点 (x0, y0) との距離も、長さ|ax0 + c|/|a| の x 軸に平行な線分から得られる。

直線が通る2点によって定義された直線

P1=(x1,y1) P2=(x2,y2)の2点を通過する直線と点(x0、y0)の距離は以下で与えられる:

distance(P1,P2,(x0,y0))=|(y2y1)x0(x2x1)y0+x2y1y2x1|(y2y1)2+(x2x1)2.

分母は、点P1と点P2の距離である。分子は、直線上の2点と点(x0,y0)を頂点とする三角形の面積の2倍になっている(参照: en:Area of a triangle#Using coordinates)。 この公式は、三角形の面積を求める公式 A=12bhを変形して得られるh=2Abと同値である。但しbは三角形の底辺の長さを、hはその底辺に対する三角形の高さを表す。

証明

代数的な証明

この証明は、直線が座標軸に対して平行でも垂直でもない場合にのみ、つまり直線の方程式でabも0でない場合にのみ成り立つ証明である。

方程式 ax + by + c = 0 で表される直線の傾きは −a/b であるから、この直線に対して垂直な任意の線分の傾きはb/a(与えられた直線の傾きの逆数の負)である。ここで点(m, n)を、与えられた直線と、点(x0, y0)を通り与えられた直線に直交する直線の交点とする。点(m, n)と点(x0, y0)を通る直線は元の直線に直交するから

y0nx0m=ba.

したがってa(y0n)b(x0m)=0 が得られ、さらに両辺を2乗することで以下を得る:

a2(y0n)2+b2(x0m)2=2ab(y0n)(x0m).

ここで、次の等式を考える。但し第2式から第3式への変形には、上の2乗した等式を用いた。

(a(x0m)+b(y0n))2=a2(x0m)2+2ab(y0n)(x0m)+b2(y0n)2=(a2+b2)((x0m)2+(y0n)2).

 一方で、点(m, n)ax + by + c =0上にあることから、次の式も成り立つ:

(a(x0m)+b(y0n))2=(ax0+by0ambn)2=(ax0+by0+c)2.

したがって

(a2+b2)((x0m)2+(y0n)2)=(ax0+by0+c)2,

となり、点(m, n)と点(x0, y0)を結ぶ線分の距離を求めることができた:

d=(x0m)2+(y0n)2=|ax0+by0+c|a2+b2[4].

幾何学的な証明

幾何学的証明の概念図

この証明も、直線が軸に水平または垂直でない場合にのみ成り立つ[5]

P(x0, y0)からAx + By + C =0で表される直線に垂線を下ろし、垂線の足を点Rとする。また点Pからy軸に平行な直線を引き、それと元の直線の交点を点Sとする。次に、直線上に点Tを任意にとり、直角三角形TVUを描く。但しTUを斜辺とし、残り2辺はそれぞれx軸、y軸に平行とする。さらにx軸に平行な辺TVの長さは|B|となるようにする(図参照)。こうすることで、直線の傾きが −A/B であるからy軸に平行な辺VUの長さは |A| となる。

ここで、∆PRSと∆TVU相似である。なぜならば両者とも直角三角形であり、さらにPS と UV が平行で同位角が等しいからである[注釈 1]。したがって対応する辺の長さの比は等しいので、

|PR||PS|=|TV||TU|.

また点Sの座標を(x0,m)とすると|PS|=|y0m|で、点Pと直線の距離|PR|は、

|PR|=|y0m||B|A2+B2.

ところで点Sは直線上の点だから、mの値はA, B, Cを用いて

m=Ax0CB,

と表せるので、これを代入すれば結局[6]:

|PR|=|Ax0+By0+C|A2+B2.

なお、類似の証明として、点Vを点Pと同一の点とし、∆UVTの面積を2通りの方法で求めることにより点Pと直線の距離の公式を導く方法がある。点Vと点Pを同一の点とした時、∆UVTの面積はまず で求められる。一方で、TUを底辺と考えることで、点Pから直線におろした垂線の長さを高さとして面積を求められる。TU, VU, VTの長さは点Pの座標と直線の方程式の係数を用いて表せるので、そこから点と直線の距離の公式が導けるテンプレート:要出典

ベクトルの射影を用いた証明

図のベクター投影証
図のベクター投影証

P(x0, y0)と、ax + by + c =0で与えられる直線を考える。また、点Q(x1, y1)を直線上の任意の点とし、ベクトルn(a, b)を点Qを始点とする法線ベクトルとする。このとき、点Pと直線の距離dは、ベクトルQPn直交射影したものの長さと等しい。この射影したベクトルの長さは、

d=|QP𝐧|𝐧.

となる。いま、

QP=(x0x1,y0y1),

なので、

QP𝐧=a(x0x1)+b(y0y1), 𝐧=a2+b2,

であるから、

d=|a(x0x1)+b(y0y1)|a2+b2.

Qが直線上の点であることと c=ax1by1から[7]

d=|ax0+by0+c|a2+b2.

その他の公式

点と直線の最短距離を表す公式は他にも考えられる。以下の導出は、やはり直線がx軸にもy軸にも平行でないことを必要とする。

P(x0, y0)と方程式y=mx+kで与えられる直線を考える。すると、点Pを通る法線の方程式はy=x0xm+y0となる。

この2直線の交点は、直線上の点の中で点Pから最も近い点である。したがって、

mx+k=x0xm+y0.

これをxについて解けば、

x=x0+my0mkm2+1.

交点のy座標は、いま得られたx座標の式を直線の方程式に代入すれば求められて、

y=m(x0+my0mk)m2+1+k.

2点間の距離はd=(X2X1)2+(Y2Y1)2で求められるから、ここから点と直線の距離の公式として以下を得る。

d=(x0+my0mkm2+1x0)2+(mx0+my0mkm2+1+ky0)2=|k+mx0y0|1+m2.

なお、ここでは直線の方程式をy=mx+kとしたが、ax+by+c=0と比較するとm =-a/bk =- c/bである。これを上式に代入し整理すれば、最初に導出した点と直線の公式が確かに得られる[8]

ベクトルを用いた公式

ベクトルを用いた公式の図解

直線の方程式は、ベクトル方程式として与えることもできる:

𝐱=𝐚+t𝐧

ここで テンプレート:Math は直線のある点を表す位置ベクトルで、 テンプレート:Math は直線の方向を表す単位ベクトル である。またtスカラー変数で、テンプレート:Mathが直線の軌跡となる。

ここで、平面の任意の点 テンプレート:Mathとこの直線の距離は以下のように与えられる:

distance(𝐱=𝐚+t𝐧,𝐩)=(𝐚𝐩)((𝐚𝐩)𝐧)𝐧.

この公式は次のように導出できる: 𝐚𝐩は点テンプレート:Mathから点テンプレート:Mathへのベクトルである。(𝐚𝐩)𝐧 はそのベクトルを直線に射影したものの長さなので、

((𝐚𝐩)𝐧)𝐧

は、𝐚𝐩を直線に正射影したベクトルである。したがって、

(𝐚𝐩)((𝐚𝐩)𝐧)𝐧

は、直線に垂直な𝐚𝐩の成分である。つまり点と直線の距離は、このベクトルのノルムそのものである[9]。この公式は、二次元に限らず適用できるように一般化できる。

その他のベクトルを用いた公式

もしベクトル空間正規直交系ならば、方向ベクトルuを持ち点Aを通る直線lを考えると点Pと直線lの距離は、

d(P,l)=AP×uu

ここでAP×u はベクトルAPu外積で、uuのノルムである。

但し、外積が存在するのは3次元と7次元の場合に限ることに注意せねばならない。

脚注

テンプレート:脚注ヘルプ

注釈

テンプレート:Reflist

出典

テンプレート:Reflist

参考文献

関連項目

外部リンク


引用エラー: 「注釈」という名前のグループの <ref> タグがありますが、対応する <references group="注釈"/> タグが見つかりません