Change Password

Please enter the password.
Please enter the password. Between 8-64 characters. Not identical to your email address. Contain at least 3 of: uppercase, lowercase, numbers, and special characters.
Please enter the password.
Submit

Change Nickname

Current Nickname:
Submit

Apply New License

License Detail

Please complete this required field.

  • Ultipa Graph V4

Standalone

Please complete this required field.

Please complete this required field.

The MAC address of the server you want to deploy.

Please complete this required field.

Please complete this required field.

Cancel
Apply
ID
Product
Status
Cores
Applied Validity Period(days)
Effective Date
Excpired Date
Mac Address
Apply Comment
Review Comment
Close
Profile
  • Full Name:
  • Phone:
  • Company:
  • Company Email:
  • Country:
  • Language:
Change Password
Apply

You have no license application record.

Apply
Certificate Issued at Valid until Serial No. File
Serial No. Valid until File

Not having one? Apply now! >>>

Product Created On ID Amount (USD) Invoice
Product Created On ID Amount (USD) Invoice

No Invoice

v4.5
Search
    Français
    v4.5

      kNN (k-Plus Proches Voisins)

      ✓ File Writeback ✕ Property Writeback ✓ Direct Return ✓ Stream Return ✕ Stats

      Vue d’ensemble

      L'algorithme des k plus proches voisins (kNN) est une technique de classification qui classe le "node" cible en fonction des classifications de ses k "nodes" les plus proches (les plus similaires). kNN a été proposé par T.M. Cover et P.E. Hart en 1967 et est depuis devenu l'un des algorithmes de classification les plus simples et les plus utilisés :

      Bien que contenant le mot voisin dans son nom, kNN ne considère pas explicitement les "edges" entre "nodes" lors du calcul de la similarité. Au lieu de cela, il se concentre uniquement sur les "properties" des "nodes".

      Concepts

      Mesure de Similarité

      L'algorithme kNN d'Ultipa calcule la similarité cosinus entre le "node" cible et tous les autres "nodes" dans le "graph", puis sélectionne les k "nodes" avec la plus grande similarité par rapport au "node" cible.

      Vote sur la Classification

      Une "property" de "node" est sélectionnée comme étiquette de classe. Après avoir trouvé les k "nodes" les plus proches pour le "node" cible, attribuez l'étiquette majoritaire parmi les k "nodes" au "node" cible.

      Si plusieurs étiquettes apparaissent avec la même fréquence maximale, l'étiquette du "node" avec la plus grande similarité sera sélectionnée.

      Syntaxe

      • Commande : algo(knn)
      • Paramètres :
      Nom
      Type
      Spéc
      Défaut
      Optionnel
      Description
      node_id _uuid / / Non UUID du "node" cible
      node_schema_property []@<schema>?.<property> Type numérique, doit être de même "schema" que le "node" cible / Non Deux ou plusieurs "properties" de "node" pour calculer la similarité cosinus
      top_k int >0 / Non Le nombre des "nodes" les plus proches à sélectionner
      target_schema_property @<schema>?.<property> Type numérique/chaîne, doit être de même "schema" que le "node" cible / Non "Property" de "node" à utiliser comme étiquette de classe

      Exemples

      Le "graph" d'exemple possède 6 "nodes" d'image (les "edges" sont ignorés), et chaque "node" possède les "properties" d1, d2, d3, d4 et type:

      File Writeback

      Spéc
      Contenu
      Description
      filename Première ligne : attribute_value
      Deuxième ligne et suivantes : _id,similarity
      Première ligne : L'étiquette de classe élue
      Deuxième ligne et suivantes : ID du "node" le plus proche et sa similarité cosinus avec le "node" cible
      algo(knn).params({
        node_id: 1,
        node_schema_property: ['d1', 'd2', 'd3', 'd4'],
        top_k: 4,
        target_schema_property: @image.type
      }).write({
        file:{
          filename: "knn"
          }
      })
      

      Résultats : Fichier knn

      Gold
      top k : image4,0.538975
      image3,0.705072
      image6,0.841922
      image2,0.85516
      

      Direct Return

      Alias Ordinal
      Type
      Description
      Colonnes
      0 KV L'étiquette de classe élue et son nombre d'occurrences parmi les k plus proches voisins attribute_value, count
      1 []perNode Le "node" le plus proche et sa similarité cosinus avec le "node" cible node, similarity
      algo(knn).params({
        node_id: 1,
        node_schema_property: ['d1', 'd2', 'd3', 'd4'],
        top_k: 4,
        target_schema_property: @image.type
      }) as a1, a2 
      return a1, a2
      

      Résultats : a1 et a2

      attribute_value count
      Gold 2
      node similarity
      4 0.538974677919475
      3 0.705071517140301
      6 0.841922130134788
      2 0.855159652306166

      Stream Return

      Alias Ordinal
      Type
      Description
      Colonnes
      0 KV L'étiquette de classe élue et son nombre d'occurrences parmi les k plus proches voisins attribute_value, count
      algo(knn).params({
        node_id: 2,
        node_schema_property: ['@image.d1', '@image.d2', '@image.d3', '@image.d4'],
        top_k: 5,
        target_schema_property: @image.type
      }).stream() as label
      find().nodes({_uuid == 2}) as target
      return case
        when target.type == label.attribute_value then 'True'
        else 'false'
      end
      

      Résultats : false

      find().nodes({@image}) as images
      call {
          with images._uuid as target
          algo(knn).params({
            node_id: target,
            node_schema_property: ['d1', 'd2', 'd3', 'd4'],
            top_k: 3,
            target_schema_property: 'type'
          }).stream() as label
          return label
      }
      return table(images._id, label.attribute_value)
      

      Résultats : table(images._id, label.attribute_value)

      images._id label.attribute_value
      image1 Silver
      image2 Silver
      image3 Gold
      image4 Silver
      image5 Gold
      image6 Gold
      Please complete the following information to download this book
      *
      公司名称不能为空
      *
      公司邮箱必须填写
      *
      你的名字必须填写
      *
      你的电话必须填写