Skip to content

モジュール mbcp.mp_math.angle

本模块定义了角度相关的类

class Angle

class AnyAngle(Angle)

method __init__(self, value: float, is_radian: bool = False)

説明: 任意角度。

引数:

  • value: 角度或弧度值
  • is_radian: 是否为弧度,默认为否
ソースコード または GitHubで表示
python
def __init__(self, value: float, is_radian: bool=False):
    if is_radian:
        self.radian = value
    else:
        self.radian = value * PI / 180

@property

method complementary(self) -> AnyAngle

説明: 余角:两角的和为90°。

戻り値: 余角

ソースコード または GitHubで表示
python
@property
def complementary(self) -> 'AnyAngle':
    return AnyAngle(PI / 2 - self.minimum_positive.radian, is_radian=True)

@property

method supplementary(self) -> AnyAngle

説明: 补角:两角的和为180°。

戻り値: 补角

ソースコード または GitHubで表示
python
@property
def supplementary(self) -> 'AnyAngle':
    return AnyAngle(PI - self.minimum_positive.radian, is_radian=True)

@property

method degree(self) -> float

説明: 角度。

戻り値: 弧度

ソースコード または GitHubで表示
python
@property
def degree(self) -> float:
    return self.radian * 180 / PI

@property

method minimum_positive(self) -> AnyAngle

説明: 最小正角。

戻り値: 最小正角度

ソースコード または GitHubで表示
python
@property
def minimum_positive(self) -> 'AnyAngle':
    return AnyAngle(self.radian % (2 * PI))

@property

method maximum_negative(self) -> AnyAngle

説明: 最大负角。

戻り値: 最大负角度

ソースコード または GitHubで表示
python
@property
def maximum_negative(self) -> 'AnyAngle':
    return AnyAngle(-self.radian % (2 * PI), is_radian=True)

@property

method sin(self) -> float

説明: 正弦值。

戻り値: 正弦值

ソースコード または GitHubで表示
python
@property
def sin(self) -> float:
    return math.sin(self.radian)

@property

method cos(self) -> float

説明: 余弦值。

戻り値: 余弦值

ソースコード または GitHubで表示
python
@property
def cos(self) -> float:
    return math.cos(self.radian)

@property

method tan(self) -> float

説明: 正切值。

戻り値: 正切值

ソースコード または GitHubで表示
python
@property
def tan(self) -> float:
    return math.tan(self.radian)

@property

method cot(self) -> float

説明: 余切值。

戻り値: 余切值

ソースコード または GitHubで表示
python
@property
def cot(self) -> float:
    return 1 / math.tan(self.radian)

@property

method sec(self) -> float

説明: 正割值。

戻り値: 正割值

ソースコード または GitHubで表示
python
@property
def sec(self) -> float:
    return 1 / math.cos(self.radian)

@property

method csc(self) -> float

説明: 余割值。

戻り値: 余割值

ソースコード または GitHubで表示
python
@property
def csc(self) -> float:
    return 1 / math.sin(self.radian)

method self + other: AnyAngle => AnyAngle

ソースコード または GitHubで表示
python
def __add__(self, other: 'AnyAngle') -> 'AnyAngle':
    return AnyAngle(self.radian + other.radian, is_radian=True)

method self == other

ソースコード または GitHubで表示
python
def __eq__(self, other):
    return approx(self.radian, other.radian)

method self - other: AnyAngle => AnyAngle

ソースコード または GitHubで表示
python
def __sub__(self, other: 'AnyAngle') -> 'AnyAngle':
    return AnyAngle(self.radian - other.radian, is_radian=True)

method self * other: float => AnyAngle

ソースコード または GitHubで表示
python
def __mul__(self, other: float) -> 'AnyAngle':
    return AnyAngle(self.radian * other, is_radian=True)

@overload

method self / other: float => AnyAngle

ソースコード または GitHubで表示
python
@overload
def __truediv__(self, other: float) -> 'AnyAngle':
    ...

@overload

method self / other: AnyAngle => float

ソースコード または GitHubで表示
python
@overload
def __truediv__(self, other: 'AnyAngle') -> float:
    ...

method self / other

ソースコード または GitHubで表示
python
def __truediv__(self, other):
    if isinstance(other, AnyAngle):
        return self.radian / other.radian
    return AnyAngle(self.radian / other, is_radian=True)

VitePress で構築されたドキュメント | litedoc によって生成されたAPIリファレンス