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:
minimizes the sum of a certain distance on the circle, more precisely
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:
importmathdefcircular_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)forhourinhours]# Calculate the sum of sin and cos valuessin_sum=sum([math.sin(rad)forradinradians])cos_sum=sum([math.cos(rad)forradinradians])# Calculate the circular mean using arctan2mean_rad=math.atan2(sin_sum,cos_sum)# Convert the mean back to hoursmean_hour=(math.degrees(mean_rad)/15)%24returnmean_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))
^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. ISSN0730-0301.
Further reading
Jammalamadaka, S. Rao and SenGupta, A. (2001). Topics in Circular Statistics, Section 1.3, World Scientific Press, Singapore. ISBN981-02-3778-2