私はthisの存在を認識しており、このトピックについては this を使用しています。しかし、今回はPythonでの実際の実装についてまとめたいと思います。
私の唯一の問題は、肘のポイントがコードのさまざまなインスタンス化から変化しているように見えることです。この投稿に示されている 2 つのプロットを観察してください。視覚的には似ているように見えますが、エルボー ポイントの値が大幅に変更されています。両方の曲線は、20 回の異なる実行の平均から生成されました。それでも、エルボーポイントの値には大きな変化があります。値が特定の範囲内に収まるようにするには、どのような予防措置を講じることができますか?
私の試みを以下に示します。
def elbowPoint(points):
secondDerivative = collections.defaultdict(lambda:0)
for i in range(1, len(points) - 1):
secondDerivative[i] = points[i+1] + points[i-1] - 2*points[i]
max_index = secondDerivative.values().index(max(secondDerivative.values()))
elbow_point = max_index + 1
return elbow_point
points = [0.80881476685027154, 0.79457906121371058, 0.78071124401504677, 0.77110686192601441, 0.76062373158581287, 0.75174963969985187, 0.74356408965979193, 0.73577573557299236, 0.72782434749305047, 0.71952590556748364, 0.71417942487824781, 0.7076502559300516, 0.70089375208028415, 0.69393584640497064, 0.68550490458450741, 0.68494440529025913, 0.67920157634796108, 0.67280267176628761]
max_point = elbowPoint(points)