角的定义
在小学或初中已经学习过角的 静态定义 :具有公共端点的两条射线组成的图形叫做角。
但是该定义将角度限制在了 [ 0 , 360 ∘ ] [0, 360^\circ] [ 0 , 36 0 ∘ ] ,这给深入研究带来了一定的困难,还有其他的问题无法解释清,比如:旋转 720 ∘ 720^\circ 72 0 ∘ 是什么意思?
在高中数学,讲了角的 动态定义 :平面内一条射线绕其端点从一个位置旋转到另一个位置形成的图形叫做角。
开始的位置称为 始边 ,结束的位置称为 终边 。并规定:
按 逆时针 方向旋转形成的角叫做 正角 ,其角度为正;
按 顺时针 方向旋转形成的角叫做 负角 ,其角度为负;
终边相对于始边没有做任何旋转的角叫做 零角 ,其角度为 0 ∘ 0^\circ 0 ∘ 。
这样就把角的概念推向了 任意角 。
零角始边和终边重合,但始边和终边重合的角并不都是零角,如以 360 ∘ 360^\circ 36 0 ∘ 为倍数的角。
弧度制
实际应用中经常有角度到各种参数的转换,而使用弧度制描述角可以减少系数的使用。所以接下来,介绍 弧度制 :
把长度等于半径长的弧所对的圆心角称为 1 1 1 弧度的角,用符号 rad \text{rad} rad 表示,读作:弧度。
根据前面的规定,正角的弧度为正,负角的弧度为负,零角的弧度为 0 0 0 ,如果半径为 r r r 的圆的圆心角 α \alpha α 所对弧长为 l l l ,则:
∣ α ∣ = l r |\alpha|=\dfrac{l}{r} ∣ α ∣ = r l
利用这个公式还可以写出弧长和扇形面积公式,在此略过。
于是,360 ∘ 360^\circ 36 0 ∘ 角的弧度为 2 π 2\pi 2 π ,这样有了对应关系之后就可以进行角度值和弧度制的转化了:
k rad = π 180 ∘ n ∘ k \operatorname{rad} = \frac{\pi}{180^\circ} n^\circ k rad = 18 0 ∘ π n ∘
考虑一个角,将其终边再旋转一周,甚至多周,始边位置不动,那么终边位置永远是相同的,称这些角为终边位置相同的角。
与角 α \alpha α 终边位置相同的角的集合很容易得出,为 { φ ∣ φ = α + 2 k π , k ∈ Z } \{\varphi \mid \varphi = \alpha + 2k\pi, k \in \mathbf{Z}\} { φ ∣ φ = α + 2 kπ , k ∈ Z } 。
可以理解为:给这个角的边不停加转一圈,终边位置不变。
目前西方数学界有一些观点认为,「真正的圆周率」应为 2 π 2\pi 2 π ,将这个值记为希腊字母 τ \tau τ 。新圆周率的支持者们选择在 6 月 28 日庆祝「真正的」圆周率日。
比如,在弧度制下,一个周角是 2 π 2\pi 2 π ,直接对 2 π 2\pi 2 π 进行等分可以得到周角的等分。又例如,在复变函数中频繁出现 2 π 2\pi 2 π 的组合,等等。
为了迎合中国各地区约定俗成的习惯,在 OI Wiki ,采用参数 π \pi π 表示圆周率。
在 C/C++ 语言中,一般取 π \pi π 为 acos(-1),只有这个值是最接近 π \pi π 的浮点数。使用 acos(-1) 或者 4 * atan(1) 写出来的 π \pi π 是 3.14159265358979310000 3.14159265358979310000 3.14159265358979310000 。
采用其他值,例如 acos(-1.0/2.0),acos(1.0/2.0),asin(1.0/2.0) 等等,写出来的 π \pi π 是 3.14159265358979360000 3.14159265358979360000 3.14159265358979360000 ,这就不是最接近 π \pi π 的浮点数了。
如果你背得下来,也可以直接写 3.1415926535897932 3.1415926535897932 3.1415926535897932 。
平面直角坐标系
在同一个平面上互相垂直且有公共原点的两条数轴构成平面直角坐标系(Rectangular Coordinates)。
通常,两条数轴分别置于水平位置与垂直位置,取向右与向上的方向分别为两条数轴的正方向。水平的数轴叫做 x x x 轴(x-axis)或横轴,垂直的数轴叫做 y y y 轴(y-axis)或纵轴,x x x 轴 y y y 轴统称为坐标轴,它们的公共原点 O O O 称为平面直角坐标系的原点(origin),以点 O O O 为原点的平面直角坐标系记作平面直角坐标系 x O y xOy x O y 。
x x x 轴 y y y 轴将坐标平面分成了四个象限(quadrant),右上方的部分叫做第一象限,其他三个部分按逆时针方向依次叫做第二象限、第三象限和第四象限。象限以数轴为界,横轴、纵轴上的点及原点不在任何一个象限内。一般情况下,x x x 轴 y y y 轴取相同的单位长度,但在特殊的情况下,也可以取不同的单位长度。
平面直角坐标系下位置的描述
在平面直角坐标系中,对于平面上的任意一点,都有唯一的一个有序数对(即点的坐标(coordinates))与它对应;反过来,对于任意一个有序数对,都有平面上唯一的一点与它对应。
对于平面内任意一点 C C C ,过点 C C C 分别向 x x x 轴、y y y 轴作垂线,垂足在 x x x 轴、y y y 轴上的对应点 a , b a, b a , b 分别叫做点 C C C 的横坐标、纵坐标,有序数对(ordered pair)( a , b ) (a, b) ( a , b ) 叫做点 C C C 的直角坐标。一个点在不同的象限或坐标轴上,其坐标都不一样。
平面极坐标系
考虑实际情况,比如航海,说「点 B B B 在点 A A A 的北偏东 30 ∘ 30^\circ 3 0 ∘ 方向上,距离为 100 100 100 米」,而不是「以 A A A 为原点建立平面直角坐标系,B ( 50 , 50 3 ) B(50,50\sqrt 3) B ( 50 , 50 3 ) 」。
这样:
在平面上选一定点 O O O ,称为 极点 ;
自极点引出一条射线 O x Ox O x ,称为 极轴 ;
选择一个单位长度(在数学问题中通常为 1 1 1 ),一个角度单位(通常为弧度)及其正方向(通常为逆时针方向);
就建立了 极坐标系 。
极坐标系下位置的描述
设 A A A 为平面上一点。
极点 O O O 与 A A A 之间的距离 ∣ O A ∣ |OA| ∣ O A ∣ 称为 极径 ,记为 ρ \rho ρ ;
以极轴为始边,O A OA O A 为终边的角 ∠ x O A \angle xOA ∠ x O A 称为 极角 ,记为 φ \varphi φ ;
那么有序数对 ( ρ , φ ) (\rho,\varphi) ( ρ , φ ) 即为 A A A 的 极坐标 。
由终边相同的角的定义可知,( ρ , φ ) (\rho,\varphi) ( ρ , φ ) 与 ( ρ , φ + 2 k π ) ( k ∈ Z ) (\rho,\varphi + 2k\pi)\ (k\in \mathbf{Z}) ( ρ , φ + 2 kπ ) ( k ∈ Z ) 其实表示的是一样的点。特别地,极点的极坐标为 ( 0 , φ ) ( φ ∈ R ) (0,\varphi)\ (\varphi \in \mathbf{R}) ( 0 , φ ) ( φ ∈ R ) ,于是平面内的点的极坐标表示有无数多种。
如果规定 ρ ≥ 0 , 0 ≤ φ < 2 π \rho \ge 0,0 \le \varphi < 2\pi ρ ≥ 0 , 0 ≤ φ < 2 π ,那么除极点外,其他平面内的点可以用唯一有序数对 ( ρ , φ ) (\rho,\varphi) ( ρ , φ ) 表示,而极坐标 ( ρ , φ ) (\rho,\varphi) ( ρ , φ ) 表示的点是唯一确定的。
平面直角坐标系与极坐标系的相互转换
当然,有时候研究极坐标系下的图形有些不方便。要想转到直角坐标系下研究,有互化公式。点 A ( ρ , φ ) A(\rho,\varphi) A ( ρ , φ ) 的直角坐标 ( x , y ) (x,y) ( x , y ) 可以如下表示:
x = ρ cos φ y = ρ sin φ \begin{aligned}
x &= \rho \cos \varphi \\
y &= \rho \sin \varphi
\end{aligned} x y = ρ cos φ = ρ sin φ
进而可知:
ρ 2 = x 2 + y 2 tan φ = y x ( x ≠ 0 ) \begin{aligned}
\rho^2 &= x^2 + y^2\\
\tan \varphi &= \frac{y}{x}\ \ \ \ (x\not =0)
\end{aligned} ρ 2 tan φ = x 2 + y 2 = x y ( x = 0 )
于是有 ρ = x 2 + y 2 \rho = \sqrt{x^2+y^2} ρ = x 2 + y 2 。
但具有相同 y x \dfrac{y}{x} x y 的 tan φ \tan\varphi tan φ 有两个可能的 φ \varphi φ 的值,此时还需要根据 x , y x, y x , y 的值来确定方向。具体地,定义函数:
atan2 ( y , x ) = { arctan ( y x ) if x > 0 arctan ( y x ) + π if y ≥ 0 , x < 0 arctan ( y x ) − π if y < 0 , x < 0 π / 2 if y > 0 , x = 0 − π / 2 if y < 0 , x = 0 any if y = 0 , x = 0 \operatorname{atan2}(y, x) = \begin{cases}
\arctan(\frac{y}{x}) & \text{if } x > 0 \\
\arctan(\frac{y}{x}) + \pi & \text{if } y \ge 0, x < 0 \\
\arctan(\frac{y}{x}) - \pi & \text{if } y < 0, x < 0 \\
\pi/2 & \text{if } y > 0, x = 0 \\
-\pi/2 & \text{if } y < 0, x = 0 \\
\text{any} & \text{if } y = 0, x = 0
\end{cases} atan2 ( y , x ) = ⎩ ⎨ ⎧ arctan ( x y ) arctan ( x y ) + π arctan ( x y ) − π π /2 − π /2 any if x > 0 if y ≥ 0 , x < 0 if y < 0 , x < 0 if y > 0 , x = 0 if y < 0 , x = 0 if y = 0 , x = 0
则 φ = atan2 ( y , x ) \varphi = \operatorname{atan2}(y, x) φ = atan2 ( y , x ) 。注意上述函数的值域为 ( − π , π ] (-\pi, \pi] ( − π , π ] 。
在 C/C++ 语言的 <math.h> 或 <cmath> 库里定义了 该函数 ,调用 atan2(y, x) 即可。
空间直角坐标系
使用如下方法建立空间直角坐标系:
在空间内选定一点 O O O ;
过点 O O O 作三条互相垂直的数轴 O x → , O y → , O z → \overrightarrow{Ox}, \overrightarrow{Oy}, \overrightarrow{Oz} O x , O y , O z ,分别称作 x x x 轴(横轴),y y y 轴(纵轴),z z z 轴(竖轴),统称为坐标轴;它们的正方向符合右手规则,即以右手握住 z z z 轴,当右手的四个手指 x x x 轴的正向以角度转向 y y y 轴正向时,大拇指的指向就是 z z z 轴的正向;
设定各轴上的长度单位,通常都设为 1 1 1 。
这样就构成了一个空间直角坐标系,称为空间直角坐标系 O − x y z O-xyz O − x yz 。定点 O O O 称为该坐标系的原点。
任意两条坐标轴确定一个平面,这样可确定三个互相垂直的平面,统称为坐标面。其中 x x x 轴与 y y y 轴所确定的坐标面称为 x O y xOy x O y 面,类似地有 y O z yOz y O z 面和 z O x zOx z O x 面。三个坐标面把空间分成八个部分,每一部分称为一个卦限。
空间直角坐标系下位置的描述
取定空间直角坐标系 O − x y z O-xyz O − x yz 后,就可以建立空间的点与三元组之间的一一对应关系。
设点 M M M 为空间的一点,过点 M M M 分别作垂直于 x x x 轴、y y y 轴和 z z z 轴的平面。设三个平面与 x x x 轴、y y y 轴和 z z z 轴的交点依次为 P , Q , R P, Q, R P , Q , R ,点 P , Q , R P, Q, R P , Q , R 分别称为点 M M M 在 x x x 轴、y y y 轴和 z z z 轴上的投影。又设点 P , Q , R P, Q, R P , Q , R 在 x x x 轴、y y y 轴和 z z z 轴上的坐标依次为 x , y , z x, y, z x , y , z ,于是点 M M M 确定了一个三元组 ( x , y , z ) (x, y, z) ( x , y , z ) 。
反之,如果给定一个三元组 ( x , y , z ) (x, y, z) ( x , y , z ) ,可以在 x x x 轴上取坐标为 x x x 的点 P P P ,在 y y y 轴上取坐标为 y y y 的点 Q Q Q ,在 z z z 轴上取坐标为 z z z 的点 R R R ,然后点 P , Q , R P, Q, R P , Q , R 分别作垂直于 x x x 轴、y y y 轴和 z z z 轴的三个平面,它们相交于空间的一点 M M M ,点 M M M 就是由三元组 ( x , y , z ) (x, y, z) ( x , y , z ) 所确定的点。
这样一来,空间的点 M M M 与三元组 ( x , y , z ) (x, y, z) ( x , y , z ) 之间就建立了一一对应的关系。把三元组 ( x , y , z ) (x, y, z) ( x , y , z ) 称为点 M M M 的坐标,记作 M ( x , y , z ) M(x, y, z) M ( x , y , z ) ,其中 x x x 称为横坐标、y y y 称为纵坐标、z z z 称为竖坐标。
空间柱坐标系
空间柱坐标系,将极坐标扩展为三维的方式:从应用于平面工作中的极坐标系开始,然后过极点 O O O 添加垂直于该平面的 z z z 轴,方向朝上。
为了找到由柱坐标 ( ρ , φ , z ) (\rho, \varphi, z) ( ρ , φ , z ) 所描述的点,可以首先在极坐标系下处理 ρ \rho ρ 和 φ \varphi φ ,然后根据 z z z 坐标沿着 z z z 轴「向上」或「向下」移动。
柱坐标系与空间直角坐标系的相互转换
两坐标系下 z z z 的值是相同的。
( x , y ) (x,y) ( x , y ) 与 ( ρ , φ ) (\rho, \varphi) ( ρ , φ ) 的相互转换参见上文 平面直角坐标系与极坐标系的相互转换 。
空间球坐标系
球坐标可以通过以下方法确定:
站在原点,面向水平极轴的方向;垂直轴的指向是从脚指向头部;
手臂向上,指向垂直极轴方向;
逆时针旋转角度 φ \varphi φ ;
将手臂向下旋转角度 ϑ \vartheta ϑ ,手臂指向 φ \varphi φ 和 ϑ \vartheta ϑ 指定的方向;
沿着该方向从原点移位距离 r r r 。
这样即可到达球坐标 ( r , ϑ , φ ) (r,\vartheta,\varphi) ( r , ϑ , φ ) 所描述的点。其中 ϑ \vartheta ϑ 称为 天顶角 ,φ \varphi φ 称为 方位角 。
由于诸多原因,有的地方使用 ϕ \phi ϕ 表示天顶角,用 θ \theta θ 表示方位角。阅读文章遇到球坐标系时请务必注意这一点。
同时,在写文章时,如果用到了球坐标系,建议提前声明清楚使用什么符号表示天顶角和方位角。
柱坐标系与球坐标系的相互转换
两坐标系下 φ \varphi φ 的值是相同的。
从柱坐标系到球坐标系:
r = ρ 2 + z 2 ϑ = { arctan ( ρ z ) if z > 0 π / 2 if z = 0 , ρ ≠ 0 arctan ( ρ z ) + π if z < 0 \begin{aligned}
r &= \sqrt{\rho^2 + z^2} \\
\vartheta &= \begin{cases}
\arctan\left(\frac{\rho}{z}\right) & \text{if }z > 0 \\
\pi/2 & \text{if }z = 0, \rho \not= 0 \\
\arctan\left(\frac{\rho}{z}\right) + \pi & \text{if }z < 0 \\
\end{cases}
\end{aligned} r ϑ = ρ 2 + z 2 = ⎩ ⎨ ⎧ arctan ( z ρ ) π /2 arctan ( z ρ ) + π if z > 0 if z = 0 , ρ = 0 if z < 0
注意对于柱坐标系下的点 ( 0 , 0 , 0 ) (0,0,0) ( 0 , 0 , 0 ) ,其球坐标的 ϑ \vartheta ϑ 不明确。
从球坐标系到柱坐标系:
ρ = r sin ϑ z = r cos ϑ \begin{aligned}
\rho &= r \sin \vartheta \\
z &= r \cos \vartheta
\end{aligned} ρ z = r sin ϑ = r cos ϑ
空间直角坐标系与球坐标系的相互转换
可以结合上文 平面直角坐标系与极坐标系的相互转换 和上文 柱坐标系与球坐标系的相互转换 一起使用,或直接使用下面的公式:
从空间直角坐标系到球坐标系:
r = x 2 + y 2 + z 2 ϑ = arccos ( z x 2 + y 2 + z 2 ) φ = atan2 ( y , x ) \begin{aligned}
r &= \sqrt{x^2 + y^2 + z^2} \\
\vartheta &= \arccos\left(\frac{z}{\sqrt{x^2 + y^2 + z^2}}\right) \\
\varphi &= \operatorname{atan2}(y, x)
\end{aligned} r ϑ φ = x 2 + y 2 + z 2 = arccos ( x 2 + y 2 + z 2 z ) = atan2 ( y , x )
其中 atan2 \operatorname{atan2} atan2 的定义见 平面直角坐标系与极坐标系的相互转换 。
注意对于空间直角坐标系下的点 ( 0 , 0 , 0 ) (0,0,0) ( 0 , 0 , 0 ) ,其球坐标的 ϑ \vartheta ϑ 和 φ \varphi φ 取值不明确。
从球坐标系到空间直角坐标系:
x = r sin ϑ cos φ y = r sin ϑ sin φ z = r cos ϑ \begin{aligned}
x &= r \sin \vartheta \cos \varphi \\
y &= r \sin \vartheta \sin \varphi \\
z &= r \cos \vartheta
\end{aligned} x y z = r sin ϑ cos φ = r sin ϑ sin φ = r cos ϑ