I want to calculate the weighted mean of a set of angles.
In this Question, there's an answer how to calculate the mean as shown in this page.
Now I'm trying to figure out how to calculate the weighted average. That is, for each angle there is a weight (the weights sum up to 1)
0.25, 0 degrees 0.5, 20 degrees 0.25, 90 degrees
The weighted avg should (if I didn't make a mistake) be 32 degrees.
OK, my attemp was to just multiply the values with the weights:
def circular_mean(weights, angles):
x = y = 0.
for angle, weight in zip(angles, weights):
x += math.cos(math.radians(angle)) * weight
y += math.sin(math.radians(angle)) * weight
mean = math.degrees(math.atan2(y, x))
return mean
It SEEMS to work correct. I have to think of good test data.
Depending on your application the question has different answers. As mentioned above you may need to normalize your values and you may need to have signed angles, or you may not wish to. Unless you know what the angle generating function is there may not be a unique answer.
This was a sufficient problem for me (working in geometry) I wrote my own Angle class.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With