using System.Collections.Generic; namespace ZeroLevel.HNSW { public class SplittedLALGraph { private readonly IDictionary _graphs = new Dictionary(); public void Append(LALGraph graph, int c) { _graphs.Add(c, graph); } public IEnumerable KNearest(int k, IDictionary contexts) { var partial_k = 1 + (k / _graphs.Count); var result = new List(); foreach (var graph in _graphs) { var context = contexts[graph.Key]; if (context.EntryPoints != null) { result.AddRange(graph.Value.KNearest(partial_k, context)); } } return result; } } }