Circular mean

In mathematics and statistics, a circular mean or angular mean is a mean designed for angles and similar cyclic quantities, such as times of day, and fractional parts of real numbers.

This is necessary since most of the usual means may not be appropriate on angle-like quantities. For example, the arithmetic mean of 0° and 360° is 180°, which is misleading because 360° equals 0° modulo a full cycle.[1] As another example, the "average time" between 11 PM and 1 AM is either midnight or noon, depending on whether the two times are part of a single night or part of a single calendar day.

The circular mean is one of the simplest examples of directional statistics and of statistics of non-Euclidean spaces. This computation produces a different result than the arithmetic mean, with the difference being greater when the angles are widely distributed. For example, the arithmetic mean of the three angles 0°, 0°, and 90° is (0° + 0° + 90°) / 3 = 30°, but the vector mean is arctan(1/2) = 26.565°. Moreover, with the arithmetic mean the circular variance is only defined ±180°.

Definition

Since the arithmetic mean is not always appropriate for angles, the following method can be used to obtain both a mean value and measure for the variance of the angles:

Convert all angles to corresponding points on the unit circle, e.g., to . That is, convert polar coordinates to Cartesian coordinates. Then compute the arithmetic mean of these points. The resulting point will lie within the unit disk but generally not on the unit circle. Convert that point back to polar coordinates. The angle is a reasonable mean of the input angles. The resulting radius will be 1 if all angles are equal. If the angles are uniformly distributed on the circle, then the resulting radius will be 0, and there is no circular mean. (In fact, it is impossible to define a continuous mean operation on the circle.) In other words, the radius measures the concentration of the angles.

Given the angles a common formula of the mean using the atan2 variant of the arctangent function is

Using complex arithmetic

An equivalent definition can be formulated using complex numbers:

.

In order to match the above derivation using arithmetic means of points, the sums would have to be divided by . However, the scaling does not matter for and , thus it can be omitted.

This may be more succinctly stated by realizing that directional data are in fact vectors of unit length. In the case of one-dimensional data, these data points can be represented conveniently as complex numbers of unit magnitude , where is the measured angle. The mean resultant vector for the sample is then:

The sample mean angle is then the argument of the mean resultant:

The length of the sample mean resultant vector is:

and will have a value between 0 and 1. Thus the sample mean resultant vector can be represented as:

Similar calculations are also used to define the circular variance.

Properties

The circular mean,

The distance is equal to half the squared Euclidean distance between the two points on the unit circle associated with and .

Example

A simple way to calculate the mean of a series of angles (in the interval [0°, 360°)) is to calculate the mean of the cosines and sines of each angle, and obtain the angle by calculating the inverse tangent. Consider the following three angles as an example: 10, 20, and 30 degrees. Intuitively, calculating the mean would involve adding these three angles together and dividing by 3, in this case indeed resulting in a correct mean angle of 20 degrees. By rotating this system anticlockwise through 15 degrees the three angles become 355 degrees, 5 degrees and 15 degrees. The arithmetic mean is now 125 degrees, which is the wrong answer, as it should be 5 degrees. The vector mean can be calculated in the following way, using the mean sine and the mean cosine :

Implementation

In this python code we use day hours to find circular average of them:

import math

def circular_mean(hours):
    # Convert hours to radians
    # To convert from hours to degrees, we need to
    # multiply hour by 360/24 = 15.
    radians = [math.radians(hour * 15) for hour in hours]

    # Calculate the sum of sin and cos values
    sin_sum = sum([math.sin(rad) for rad in radians])
    cos_sum = sum([math.cos(rad) for rad in radians])

    # Calculate the circular mean using arctan2
    mean_rad = math.atan2(sin_sum, cos_sum)

    # Convert the mean back to hours
    mean_hour = (math.degrees(mean_rad) / 15) % 24

    return mean_hour

# Example usage:
hours = [0, 12, 18]
mean_hour = circular_mean(hours)
print("First Circular mean:", round(mean_hour, 2))

hours = [0, 12]
mean_hour = circular_mean(hours)
print("Second Circular mean:", round(mean_hour, 2))

hours = [0, 0, 12, 12, 24]
mean_hour = circular_mean(hours)
print("Third Circular mean:", round(mean_hour, 2))

Generalizations

Spherical mean

A series of N independent unit vectors are drawn from a von Mises–Fisher distribution. The maximum likelihood estimates of the mean direction is simply the normalized arithmetic mean, a sufficient statistic:[2]

Weighted spherical mean

A weighted spherical mean can be defined based on spherical linear interpolation.[3]

See also

References

  1. ^ Christopher M. Bishop: Pattern Recognition and Machine Learning (Information Science and Statistics), ISBN 0-387-31073-8
  2. ^ Mardia, Kanti; Jupp, P. E. (1999). Directional Statistics. John Wiley & Sons Ltd. ISBN 978-0-471-95333-3.
  3. ^ Buss, Samuel R.; Fillmore, Jay P. (2001). "Spherical averages and applications to spherical splines and interpolation". ACM Transactions on Graphics. 20 (2). Association for Computing Machinery (ACM): 95–126. doi:10.1145/502122.502124. ISSN 0730-0301.

Further reading