mbcp/docs/ja/api/mp_math/angle.md
snowy fae4707b63 Merge remote-tracking branch 'origin/main'
# Conflicts:
#	docs/.vitepress/config/index.ts
#	docs/api/mp_math/equation.md
#	docs/api/mp_math/line.md
#	docs/api/mp_math/plane.md
#	docs/api/mp_math/point.md
#	docs/api/mp_math/utils.md
#	docs/api/mp_math/vector.md
#	docs/api/presets/model/index.md
#	docs/en/api/mp_math/angle.md
#	docs/en/api/mp_math/const.md
#	docs/en/api/mp_math/equation.md
#	docs/en/api/mp_math/line.md
#	docs/en/api/mp_math/mp_math_typing.md
#	docs/en/api/mp_math/plane.md
#	docs/en/api/mp_math/point.md
#	docs/en/api/mp_math/segment.md
#	docs/en/api/mp_math/utils.md
#	docs/en/api/mp_math/vector.md
#	docs/en/api/presets/model/index.md
#	docs/ja/api/mp_math/angle.md
#	docs/ja/api/mp_math/const.md
#	docs/ja/api/mp_math/equation.md
#	docs/ja/api/mp_math/line.md
#	docs/ja/api/mp_math/mp_math_typing.md
#	docs/ja/api/mp_math/plane.md
#	docs/ja/api/mp_math/point.md
#	docs/ja/api/mp_math/segment.md
#	docs/ja/api/mp_math/utils.md
#	docs/ja/api/mp_math/vector.md
#	docs/ja/api/presets/model/index.md
#	mkdoc.bat
2024-08-29 13:23:30 +08:00

4.2 KiB
Raw Blame History

title
mbcp.mp_math.angle

任意角度。

  • value: 角度或弧度值

  • is_radian: 是否为弧度,默认为否

def __init__(self, value: float, is_radian: bool=False):
    """
        任意角度。
        Args:
            value: 角度或弧度值
            is_radian: 是否为弧度,默认为否
        """
    if is_radian:
        self.radian = value
    else:
        self.radian = value * PI / 180

@property

余角两角的和为90°。

  • 余角
@property
def complementary(self) -> 'AnyAngle':
    """
        余角两角的和为90°。
        Returns:
            余角
        """
    return AnyAngle(PI / 2 - self.minimum_positive.radian, is_radian=True)

@property

补角两角的和为180°。

  • 补角
@property
def supplementary(self) -> 'AnyAngle':
    """
        补角两角的和为180°。
        Returns:
            补角
        """
    return AnyAngle(PI - self.minimum_positive.radian, is_radian=True)

@property

角度。

  • 弧度
@property
def degree(self) -> float:
    """
        角度。
        Returns:
            弧度
        """
    return self.radian * 180 / PI

@property

最小正角。

  • 最小正角度
@property
def minimum_positive(self) -> 'AnyAngle':
    """
        最小正角。
        Returns:
            最小正角度
        """
    return AnyAngle(self.radian % (2 * PI))

@property

最大负角。

  • 最大负角度
@property
def maximum_negative(self) -> 'AnyAngle':
    """
        最大负角。
        Returns:
            最大负角度
        """
    return AnyAngle(-self.radian % (2 * PI), is_radian=True)

@property

正弦值。

  • 正弦值
@property
def sin(self) -> float:
    """
        正弦值。
        Returns:
            正弦值
        """
    return math.sin(self.radian)

@property

余弦值。

  • 余弦值
@property
def cos(self) -> float:
    """
        余弦值。
        Returns:
            余弦值
        """
    return math.cos(self.radian)

@property

正切值。

  • 正切值
@property
def tan(self) -> float:
    """
        正切值。
        Returns:
            正切值
        """
    return math.tan(self.radian)

@property

余切值。

  • 余切值
@property
def cot(self) -> float:
    """
        余切值。
        Returns:
            余切值
        """
    return 1 / math.tan(self.radian)

@property

正割值。

  • 正割值
@property
def sec(self) -> float:
    """
        正割值。
        Returns:
            正割值
        """
    return 1 / math.cos(self.radian)

@property

余割值。

  • 余割值
@property
def csc(self) -> float:
    """
        余割值。
        Returns:
            余割值
        """
    return 1 / math.sin(self.radian)
def __add__(self, other: 'AnyAngle') -> 'AnyAngle':
    return AnyAngle(self.radian + other.radian, is_radian=True)
def __eq__(self, other):
    return approx(self.radian, other.radian)
def __sub__(self, other: 'AnyAngle') -> 'AnyAngle':
    return AnyAngle(self.radian - other.radian, is_radian=True)
def __mul__(self, other: float) -> 'AnyAngle':
    return AnyAngle(self.radian * other, is_radian=True)

@overload

@overload
def __truediv__(self, other: float) -> 'AnyAngle':
    ...

@overload

@overload
def __truediv__(self, other: 'AnyAngle') -> float:
    ...
def __truediv__(self, other):
    if isinstance(other, AnyAngle):
        return self.radian / other.radian
    return AnyAngle(self.radian / other, is_radian=True)