A lightweight Python class for representing and performing calculations with angles.

This is a small class meant to simplify common operations with angle measures. The convention used for the arithmetic and comparison operations is meant to capture the idea that we are primarily interested in the smallest angle between two measures, regardless of the numbers, themselves. In particular this includes the following conventions:

• Angles that differ by an integer number of revolutions are considered equivalent.
• Output angle values are limited in size to ±1/2 full revolution. For example, radian angle measures are restricted to the interval (-π,π], while degree angle measures are restricted to (-180,180].
• Angle comparisons are based on the smallest angle between the two input angles, and on whether the first angle is closer to being clockwise or counterclockwise from the first. By convention we say that A > B if the smallest angle between A and B places A counterclockwise relative to B, and A < B if the smallest angle between A and B places A clockwise relative to B.

Radian, degree, and gradian measure (or any arbitrary subdivision of the circle) are all supported. Methods perform calculations and return results using the measure of their own angle object, converting other angles or floats when necessary.

## Installation and Usage

This package can be downloaded from PyPI using the following console command:

``````\$ pip install angle-headings
``````

It can then be imported into a Python program as the `angle_headings` package.

Since this package defines only a single class, it is recommended to use

``````from angle_headings import Angle
``````

to avoid the need for the `angle_headings` prefix.

## The `angle_headings.Angle` Class

The following is a brief description of selected attributes, custom methods, and overloaded methods for the `angle_headings.Angle` class.

### Attributes

• `measure (float)` -- Current measure of the angle, always normalized to ±1/2 full revolutions.
• `mod (float)` -- Measure of a complete revolution (e.g. for radian measure, 360 for degree measure).
• `unit (str)` -- Name of the unit of measure.

### Methods

• `__init__([measure[, mod]])` -- `angle_headings.Angle` class constructor. Accepts the following keyword arguments:
• `measure (float) [0.0]` -- Initial angle measure.
• `mod (int, float, or str) ["radians"]` -- Specifies measure unit. A numerical argument is treated as the measure of a full revolution, while a string argument is taken as the name of a standard unit (radians, degrees, or gradians).
• `convert(mod)` -- Returns the angle's measure converted to a different unit.
• `reldiff(other)` -- Returns a relative difference between this and another angles' measures, normalized so that 0 represents equality and 1 represents diametrically opposed angles. This is meant to be used as an alternative to direct equality comparisons due to the `float` measures.

### `float`-Valued Operators

• `abs(A)` -- Returns the absolute value of an angle's measure.
• `int(A)` -- Returns an angle's measure, cast as an integer.
• `float(A)` -- Returns an angle's measure, cast as a float.
• `round(A)` -- Returns an angle's measure, rounded to the nearest integer.

### `angle_headings.Angle`-Valued Operators

#### Unary Operators

• `+A` -- Returns an exact copy of the `angle_headings.Angle` object.
• `-A` -- Returns a copy of the `angle_headings.Angle` object with its measure negated.

Each of the following operators accepts either another `angle_headings.Angle` object or a `float` as its second argument. If given another `angle_headings.Angle`, the second `angle_headings.Angle` is converted to the first `angle_headings.Angle`'s unit before the operation is performed. If given a `float`, the number is used directly.

• `A + B` -- Returns an `angle_headings.Angle` object with the sum of two angles' measures.
• `A - B` -- Returns an `angle_headings.Angle` object with the difference between two angles' measures.

#### Scalar Operators

• `A * b` -- Returns an `angle_headings.Angle` object with its measure multiplied by a scalar.
• `A / b` -- Returns an `angle_headings.Angle` object with its measure divided by a scalar.
• `A // b` -- Returns an `angle_headings.Angle` object with its measure floor divided by a scalar.
• `A ** b` -- Returns an `angle_headings.Angle` object with its measure raised to a scalar power.

Each of the following operators accepts either another `angle_headings.Angle` object or a `float` as its second argument. If given another `angle_headings.Angle`, the second `angle_headings.Angle` is converted to the first `angle_headings.Angle`'s unit before the operation is performed. If given a `float`, the number is used directly.

#### Equality Comparisons

Due to the fact that each angle's measure is stored as a `float`, it is not recommended to directly test measure equality, and to instead make use of the `Angle.reldiff()` method.

• `A == B` -- Tests for equality of two measures (after unit conversion and normalization).
• `A != B` -- Tests for inequality of two measures.

#### Order Comparisons

The following comparisons are based on the smallest angle between two given measures.

• `A > B` -- Returns `True` if and only if the smallest angle between `A` and `B` places `A` counterclockwise relative to `B`.
• `A >= B` -- Returns `True` if and only if `A > B` or `A == B`.
• `A < B` -- Returns `True` if and only if the smallest angle between `A` and `B` places `A` clockwise relative to `B`.
• `A <= B` -- Returns `True` if and only if `A < B` or `A == B`.