All Downloads are FREE. Search and download functionalities are using the official Maven repository.

commonMain.com.aallam.openai.client.extension.internal.CosineSimilarity.kt Maven / Gradle / Ivy

There is a newer version: 4.0.0-beta01
Show newest version
package com.aallam.openai.client.extension.internal

import kotlin.math.pow
import kotlin.math.sqrt

internal object Cosine {

    /**
     * Compute similarity between two [Double] vectors.
     */
    fun similarity(vec1: List, vec2: List): Double {
        if (vec1 == vec2) return 1.0
        return (vec1 dot vec2) / (norm(vec1) * norm(vec2))
    }

    /**
     * Compute distance between two [Double] vectors.
     */
    fun distance(vec1: List, vec2: List): Double {
        return 1.0 - similarity(vec1, vec2)
    }

    /** Dot product */
    private infix fun List.dot(vector: List): Double {
        return zip(vector).fold(0.0) { acc, (i, j) -> acc + (i * j) }
    }

    /** Compute the norm L2 : sqrt(sum(v²)). */
    private fun norm(vector: List): Double {
        val sum = vector.fold(0.0) { acc, cur -> acc + cur.pow(2) }
        return sqrt(sum)
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy