mirror of https://github.com/ogoun/Zero.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
30 lines
833 B
30 lines
833 B
using System.Collections.Generic;
|
|
|
|
namespace ZeroLevel.HNSW
|
|
{
|
|
public class SplittedLALGraph
|
|
{
|
|
private readonly IDictionary<int, LALGraph> _graphs = new Dictionary<int, LALGraph>();
|
|
|
|
public void Append(LALGraph graph, int c)
|
|
{
|
|
_graphs.Add(c, graph);
|
|
}
|
|
|
|
public IEnumerable<int> KNearest(int k, IDictionary<int, SearchContext> contexts)
|
|
{
|
|
var partial_k = 1 + (k / _graphs.Count);
|
|
var result = new List<int>();
|
|
foreach (var graph in _graphs)
|
|
{
|
|
var context = contexts[graph.Key];
|
|
if (context.EntryPoints != null)
|
|
{
|
|
result.AddRange(graph.Value.KNearest(partial_k, context));
|
|
}
|
|
}
|
|
return result;
|
|
}
|
|
}
|
|
}
|