Circular meanIn 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°. DefinitionSince 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 arithmeticAn 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. PropertiesThe circular mean,
ExampleA 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 : ImplementationIn 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))
GeneralizationsSpherical meanA 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 meanA weighted spherical mean can be defined based on spherical linear interpolation.[3] See also
References
Further reading
External links
|