Я работаю над классификацией простых данных с использованием KNN с евклидовым расстоянием. Я видел пример того, что я хотел бы сделать, это делается с помощью функции MATLAB knnsearch
, как показано ниже:
load fisheriris
x = meas(:,3:4);
gscatter(x(:,1),x(:,2),species)
newpoint = [5 1.45];
[n,d] = knnsearch(x,newpoint,'k',10);
line(x(n,1),x(n,2),'color',[.5 .5 .5],'marker','o','linestyle','none','markersize',10)
Вышеприведенный код принимает новую точку, т.е. [5 1.45]
, и находит 10 ближайших значений для новой точки. Может ли кто-нибудь показать мне алгоритм MATLAB с подробным объяснением того, что делает функция knnsearch
? Есть ли другой способ сделать это?