


Detailed introduction to the KNN algorithm (k-nearest neighbor algorithm) in Python (with examples)
This article brings you a detailed introduction to the KNN algorithm (k-nearest neighbor algorithm) in Python (with examples). It has certain reference value. Friends in need can refer to it. I hope it will be helpful to you. helped.
The KNN algorithm is a data classification algorithm. The category of the k nearest neighbor data from the sample represents the category of the sample, so it is also called the k-nearest neighbor algorithm. The KNN algorithm is one of the simplest methods in data mining and can be roughly divided into the following steps:
Training data: data of all data categories in the original data set.
Test data: The data sample we will use for testing.
Processing data
The test data we get is usually of different dimensions than the training data. At this time, we need to upgrade the test data The dimension is the same as the training data. Python's numpy comes with a tile() function that can help us increase the dimension of the test data.
Vectorize the data
After the dimensionality of the test data is increased, in order to calculate the distance from the sample point, we need to vectorize the data at this time , the so-called vectorization is very simple, that is, subtracting two data of the same dimension.
Calculate the Euclidean distance
The Euclidean distance, that is, the Euclidean distance, can be calculated using the Pythagorean theorem. The square and square root of each vector in the vector group obtained by subtracting the test data and training data can be used to obtain a vector group composed of distances.
Classification based on distance
Select k data with the smallest distance from the sample point, and count which data categories among these k data With the highest frequency of occurrence, the data category of the sample point can be determined.
Algorithm implementation:
1. First we need to introduce numpy and operator, enter from numpy import *
and import operator
.
2. Next we need to define a knn function. In the knn function we need to introduce four parameters, namely k, training data, test data and data category.
3. Next, we need to perform dimensionality enhancement operation on the data first. We need to use the tile(a,(b,c)) function under numpy. a is the data to be performed on the dimensionality enhancement operation, that is Test data, b is the row data to be upgraded to the test data, and c is the column data to be upgraded to the test data.
4. In the previous operation, we generally need to obtain the number of rows and columns of the training data. In this case, we need to use shape() Function, the shape() function returns a tuple consisting of rows and columns of the training data. If we want to know the number of rows or columns of the training data, we only need to reference it through the array element subscript.
5. After the dimensions of the data are the same, we need to subtract the two data to get a vector, and then calculate the sum of the squares of each value of this vector The square root of is the distance from the test data to the training data, and then calls the argsort() function to sort the distances in ascending order, but this function returns the subscript of the array element.
6. Next, in order to intuitively see the number of occurrences of different data categories, we need to set up an empty dictionary to store the data. After getting After the dictionary, we need to sort the dictionary in descending order according to the number of occurrences of different data categories, and then return the first value of the dictionary to get the data category of the test data.
7. The algorithm code is as follows:
from numpy import * import operator def knn(k, test_data, train_data, labels): train_size = train_data.shape[0] #获取训练数据的行数 test_size = tile(test_data, (train_size, 1)) #将测试数据的行升维 minus = test_size-train_data #得到向量 sq_minus = minus**2 sum_sq_minus = sq_minus.sum(axis=1) #得到平方后的每个数组内元素的和 distc = sum_sq_minus**0.5 sort_distc = distc.argsort() #将距离按升序排列 static = {} for i in range(0, k): vote = labels[sort_distc[i]] #获取数据类型 static[vote] = static.get(vote, 0)+1 #统计每个数据类型的出现次数 sort_static = sorted(static.items(), key=operator.itemgetter(1), reverse=True) #将字典中的元素按出现次数降序排列 return sort_static[0][0] #返回出现次数最多的数据类型
8. The dictionary needs to be sorted in the algorithm, so the sorted() function needs to be used. The sorted() function has three parameters, namely items. (), operator.itemgetter(), reverse, the default sorting is ascending order. If we want to sort in descending order, we need to set the third parameter to True. Here we are sorting according to the values of the dictionary, so we need to enter sorted(static.items(), key=operator.itemgetter(1), reverse=True)
, when the value in the operator.itemgetter() function is 1, it is sorted according to the values of the dictionary, and the value is 0 When, it is sorted according to the key of the dictionary.
9. The way to access elements after sorting is the same as the way to access two-dimensional array elements
The above is the detailed content of Detailed introduction to the KNN algorithm (k-nearest neighbor algorithm) in Python (with examples). For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



This article will explain how to improve website performance by analyzing Apache logs under the Debian system. 1. Log Analysis Basics Apache log records the detailed information of all HTTP requests, including IP address, timestamp, request URL, HTTP method and response code. In Debian systems, these logs are usually located in the /var/log/apache2/access.log and /var/log/apache2/error.log directories. Understanding the log structure is the first step in effective analysis. 2. Log analysis tool You can use a variety of tools to analyze Apache logs: Command line tools: grep, awk, sed and other command line tools.

Python excels in gaming and GUI development. 1) Game development uses Pygame, providing drawing, audio and other functions, which are suitable for creating 2D games. 2) GUI development can choose Tkinter or PyQt. Tkinter is simple and easy to use, PyQt has rich functions and is suitable for professional development.

PHP and Python each have their own advantages, and choose according to project requirements. 1.PHP is suitable for web development, especially for rapid development and maintenance of websites. 2. Python is suitable for data science, machine learning and artificial intelligence, with concise syntax and suitable for beginners.

The readdir function in the Debian system is a system call used to read directory contents and is often used in C programming. This article will explain how to integrate readdir with other tools to enhance its functionality. Method 1: Combining C language program and pipeline First, write a C program to call the readdir function and output the result: #include#include#include#includeintmain(intargc,char*argv[]){DIR*dir;structdirent*entry;if(argc!=2){

This article discusses the DDoS attack detection method. Although no direct application case of "DebianSniffer" was found, the following methods can be used for DDoS attack detection: Effective DDoS attack detection technology: Detection based on traffic analysis: identifying DDoS attacks by monitoring abnormal patterns of network traffic, such as sudden traffic growth, surge in connections on specific ports, etc. This can be achieved using a variety of tools, including but not limited to professional network monitoring systems and custom scripts. For example, Python scripts combined with pyshark and colorama libraries can monitor network traffic in real time and issue alerts. Detection based on statistical analysis: By analyzing statistical characteristics of network traffic, such as data

To maximize the efficiency of learning Python in a limited time, you can use Python's datetime, time, and schedule modules. 1. The datetime module is used to record and plan learning time. 2. The time module helps to set study and rest time. 3. The schedule module automatically arranges weekly learning tasks.

This article will guide you on how to update your NginxSSL certificate on your Debian system. Step 1: Install Certbot First, make sure your system has certbot and python3-certbot-nginx packages installed. If not installed, please execute the following command: sudoapt-getupdatesudoapt-getinstallcertbotpython3-certbot-nginx Step 2: Obtain and configure the certificate Use the certbot command to obtain the Let'sEncrypt certificate and configure Nginx: sudocertbot--nginx Follow the prompts to select

Configuring an HTTPS server on a Debian system involves several steps, including installing the necessary software, generating an SSL certificate, and configuring a web server (such as Apache or Nginx) to use an SSL certificate. Here is a basic guide, assuming you are using an ApacheWeb server. 1. Install the necessary software First, make sure your system is up to date and install Apache and OpenSSL: sudoaptupdatesudoaptupgradesudoaptinsta
