K NEAREST NEIGHBORS ALGORITHM
data:image/s3,"s3://crabby-images/de732/de732870cc0e4b90f466f159381d66e0f1fed1f4" alt=""
data:image/s3,"s3://crabby-images/202f7/202f74c2726af15416924ecfa16a50b9720ceda4" alt=""
PREREQUISITE KNOWLEDGE PYTHON • • • • • • MATHEMATICS ��(����,����)������(����,����) �� =√(���� ����)2 +(���� ����)2 HARDWARESOFTWARE • • •
data:image/s3,"s3://crabby-images/f6cf0/f6cf05e147b35931bad97fb2fe4ce35733eb8947" alt=""
OBJECTIVE
data:image/s3,"s3://crabby-images/69e60/69e605ee684210ccc4974c99d348c8c73114e4a6" alt=""
INTRODUCTION MACHINE LEARNING AND SUPERVISED LEARNING • • • �� ≈ ��(��)
STUDY SITUATION ET TRAINING SET OF THE ALPHAI ROBOT • • •
data:image/s3,"s3://crabby-images/627b0/627b0dabcdcb81ae9f5f9d7943aa00e3392d2e33" alt=""
data:image/s3,"s3://crabby-images/9e15b/9e15ba2a38ab2729ff14b9e299b5894009eeb381" alt=""
data:image/s3,"s3://crabby-images/cb41e/cb41ecfcde828685407a9dd56bef3efe6bd59572" alt=""
data:image/s3,"s3://crabby-images/06bce/06bce26c00aac547f06ee2d78b5cd72a88a9f3b3" alt=""
data:image/s3,"s3://crabby-images/85a7f/85a7fb6e4f3acf4a81ad54c1b6b8fe5775c8052e" alt=""
data:image/s3,"s3://crabby-images/92980/9298045ac322f0ae5e46289e9a296f09d55715ac" alt=""
data:image/s3,"s3://crabby-images/92980/9298045ac322f0ae5e46289e9a296f09d55715ac" alt=""
data:image/s3,"s3://crabby-images/f3f73/f3f738505564f2a0c30f8cbf5c14da04381eed7d" alt=""
data:image/s3,"s3://crabby-images/92980/9298045ac322f0ae5e46289e9a296f09d55715ac" alt=""
data:image/s3,"s3://crabby-images/92980/9298045ac322f0ae5e46289e9a296f09d55715ac" alt=""
data:image/s3,"s3://crabby-images/2de01/2de012dddc0c5232c3c35d17fcbdfeb8f96c779e" alt=""
data:image/s3,"s3://crabby-images/2de01/2de012dddc0c5232c3c35d17fcbdfeb8f96c779e" alt=""
from PIL import Image import numpy as np import matplotlib.pyplot as plt def read_image(name): return np.array(Image.open(name, "r")) img1=read_image("forward_0.jpg ") # give the image path plt.show()plt.imshow(img1)
data:image/s3,"s3://crabby-images/f3f73/f3f738505564f2a0c30f8cbf5c14da04381eed7d" alt=""
data:image/s3,"s3://crabby-images/63a38/63a385f75f96096adb9750d550d61b0f859a0a8b" alt=""
data:image/s3,"s3://crabby-images/63a38/63a385f75f96096adb9750d550d61b0f859a0a8b" alt=""
data:image/s3,"s3://crabby-images/682f3/682f3f25b4ee184417a59d84c0d10ff99f751e57" alt=""
• • • def rgb2gray(rgb): return np.dot(rgb[...,:3], [0.299, 0.587, 0.144]) img2=rgb2gray(img1) plt.imshow(img2, cmap=”gray”) def��������(������,��,��,ℎ������ℎ��,��������ℎ) def get_two_values(img, x1=10, y1=28, x2=42, y2=28, height=16, width=13): value1 = average(img, x1, y1, height, width) value2 = average(img, x2, y2, height, width) return np.array((value1, value2))
data:image/s3,"s3://crabby-images/4f849/4f849a55be2597b8e71cc96e1f73bb95888b2566" alt=""
data:image/s3,"s3://crabby-images/e5927/e592721a39d932513c9438a11d1a438e24b39b59" alt=""
data:image/s3,"s3://crabby-images/0d1d1/0d1d14fbdd5335cd147cb32211b7543a94d1f2ea" alt=""
THE K NEAREST NEIGHBORS ALGORITHM, KNN
data:image/s3,"s3://crabby-images/35b6f/35b6f1bb6c861f7e646c94615d2e8f00b69fd112" alt=""
data:image/s3,"s3://crabby-images/961d7/961d714e62dcedb49958cdfa2aac349aab0a3d11" alt=""
Start Algorithm Input data: • a dataset D, corresponding to the elaborated training set • a function for calculating the distance between the two considered points of coordinates [x1,y1] and [x2,y2].�� =√(��2 ��1)2 +(��2 ��1)2 • An integer k, representing the number of neighbors to be considered For a new observation X of which we want to predict his decision Y Do: 1. Calculate all distances of this observation X with the other observations in dataset D 2. Retain the K observations of dataset D closest to X using the distance calculation function d 3. Take the values of Y of the k observations retained. Perform a regression and calculate the mean (or median) of Y retained 4. Return the value calculated in step 3 as the value that was predicted by K NN for observation X. End Algorithm def����������������(����������1,����������2)
ROBOT TRAINING PREPARATION PHASE OF THE WORK ENVIRONMENT → → → →
data:image/s3,"s3://crabby-images/afe54/afe541e1a491a6ab3ff83809123696035d562b49" alt=""
data:image/s3,"s3://crabby-images/71ecd/71ecdaea21c3b830a42e03e7476753a55b20f54e" alt=""
TRAINING PHASE • • • •
data:image/s3,"s3://crabby-images/bfc2b/bfc2be828aed9a20a4a512a9d0c086aa8310062d" alt=""
data:image/s3,"s3://crabby-images/107c0/107c0cedd6a6201a32ae6d3b8e100bf2ac634a7b" alt=""
data:image/s3,"s3://crabby-images/f52fb/f52fb6def77aa01420904f5db96d0f323216ec89" alt=""
data:image/s3,"s3://crabby-images/d5e6e/d5e6e1172b9c495baabd96ee36c607720c04bd12" alt=""
data:image/s3,"s3://crabby-images/7f9e9/7f9e9904defddd4170ad0ec7ce8ae4be14b8bc3b" alt=""
data:image/s3,"s3://crabby-images/7bb0b/7bb0b729d2fe556aa80848612a5d9e92a7803d82" alt=""
TESTING PHASE GO FURTHER:
TO
PROGRAM THE K'S NEAREST NEIGHBORS ALGORITHM → → → → PROGRAM THE ROBOT DIRECTLY def�������� ����������������(��������������:��������)→������
data:image/s3,"s3://crabby-images/0395d/0395d2c9634b47bc6dc9a2a9aae0593d42c813db" alt=""
data:image/s3,"s3://crabby-images/fd0ac/fd0acc5f4d5fb7172a82d477a52659fa8d4389b9" alt=""
ALGORITHM PROGRAMMING DISTANCE CALCULATION def����������������(��:��������,��:��������) →���������� �� =[����,����]������ =[����,����] �� =√(���� ����)2 +(���� ����)2 import math y = math.sqrt(x) y = x**2
# compute distance a = [0, 0] b = [1, print("distance",2] distance(a, b)) CALCULATION OF ALL DISTANCES def������ ������������������(��:��������[����������],���������� ��������������:��������[��������[����������]])→��������[����������] �� =[��0,��0] ���������� �������������� =[[��1,��1],[��2,��2],…,[����,����]] # compute all distances a = [0.4, train_sensors0.6]= [[0, 0], [0, 1], [1, 0]] distance_list = all_distances(a, train_sensors) print('distances to data', distance_list) FIND THE SMALLEST ELEMENT OF A TABLE def�������� ��������������(����������:��������[����������])→������
# minimum in a list idx_min = print('indexfind_minimum(distance_list)ofminimum',idx_min) NEAREST NEIGHBOR def�������������� ��������ℎ������ ����������������(���������� ��������������:��������[��������[����������]],���������� ������������������:��������[������],��:��������[����������]) →������ �� =[��0,��0]���� ���������� �������������� =[[��1,��1],[��2,��2], ,[����,����]] ���������� ������������������ = [��1,…,����] ���� [����,����] # KNN a = [0.4, train_sensors0.6]= [[0, 0], [0, 1], [1, 0]] train_decisions = [1, 2, 0] decision = nearest_neighbor_decision(train_sensors, train_decisions, a) print('KNN', decision)
USING YOUR ALGORITHM WITH THE ROBOT train_sensors = train_decisions = None def learn(X_train, y_train): global train_sensors, train_decisions train_sensors, train_decisions = X_train, y_train loss = 0 return loss def iftake_decision(sensors):train_sensorsisNone : return 0 return nearest_neigbor_decision(train_sensors, train_decisions, sensors)
data:image/s3,"s3://crabby-images/107c0/107c0cedd6a6201a32ae6d3b8e100bf2ac634a7b" alt=""
data:image/s3,"s3://crabby-images/f52fb/f52fb6def77aa01420904f5db96d0f323216ec89" alt=""
data:image/s3,"s3://crabby-images/f52fb/f52fb6def77aa01420904f5db96d0f323216ec89" alt=""
data:image/s3,"s3://crabby-images/107c0/107c0cedd6a6201a32ae6d3b8e100bf2ac634a7b" alt=""
TO GO FURTHER K NEAREST NEIGHBORS �� >1,�� ∈ℕ INTRODUCTION TO NEURAL NETWORKS CONCLUSION :
data:image/s3,"s3://crabby-images/550f7/550f726eeb5a79a3622dac087468a7c4f510f638" alt=""
data:image/s3,"s3://crabby-images/490b2/490b2d2cd427c40a299d69edff66d51ae9d9d7a7" alt=""
data:image/s3,"s3://crabby-images/752d5/752d51105e322e46bccfe9ca3453d683fc2f88dd" alt=""