数値微分と結果が一致することを確認できた
コサイン類似度: \( cos(X, Y) = \frac{\sum_{i=1}^{N}(X_i Y_i)}{\sqrt{\sum_{i=1}^{N}(X_i^2)} \sqrt{\sum_{i=1}^{N}(Y_i^2)}} \)
目標とする類似度: \(t\)
コサイン類似度からなる損失関数: \( L(X, Y, t) = (t- cos(X, Y))^2 \)
より
コサイン類似度からなる損失関数を\(X_i\)について偏微分した式
を求める。
より
学習においては実はこれはいらんかった説がある。極小値で勾配出すやつで問題ないというか、計算量的にそこまでヘヴィでない可能性が高い。
つまるところ、下記のコードでいったんは事足りる。速度が欲しくなったら微分の計算をガチれば良い。
func dcos_sim_minimum(X []float64, Y []float64, t float64) []float64 {
d := 1e-10
outputs := []float64{}
for i := range X {
dX := make([]float64, len(X))
copy(dX, X)
dX[i] += d
outputs = append(outputs, math.Pow(cos_sim(dX, Y)-t, 2)/d)
}
return outputs
}