mirror of
https://github.com/onyx-and-iris/grokking-algorithms.git
synced 2025-01-18 16:50:53 +00:00
move average calculation out of knn()
This commit is contained in:
parent
c2dab280ac
commit
f310eda779
@ -30,10 +30,7 @@ def knn(point: Point, neighbours):
|
|||||||
neighbour.distance = np.linalg.norm(point.array - neighbour.array)
|
neighbour.distance = np.linalg.norm(point.array - neighbour.array)
|
||||||
logger.debug(f"{neighbour.identifier}: {neighbour.distance}")
|
logger.debug(f"{neighbour.identifier}: {neighbour.distance}")
|
||||||
|
|
||||||
total = 0
|
return sorted(neighbours, key=lambda x: x.distance)[:K]
|
||||||
for n in sorted(neighbours, key=lambda x: x.distance)[:K]:
|
|
||||||
total += n.sold
|
|
||||||
return total / K
|
|
||||||
|
|
||||||
|
|
||||||
neighbours = [
|
neighbours = [
|
||||||
@ -47,7 +44,13 @@ neighbours = [
|
|||||||
|
|
||||||
point = Point("T", 4, True, False)
|
point = Point("T", 4, True, False)
|
||||||
K = 4
|
K = 4
|
||||||
average_distance = knn(point, neighbours)
|
|
||||||
|
|
||||||
logger.debug(average_distance)
|
k_nearest = knn(point, neighbours)
|
||||||
print(f"Number of loaves to make: {int(round(average_distance, 0))}")
|
|
||||||
|
average_sold = 0
|
||||||
|
for n in k_nearest:
|
||||||
|
average_sold += n.sold
|
||||||
|
average_sold = average_sold / K
|
||||||
|
|
||||||
|
logger.debug(average_sold)
|
||||||
|
print(f"Number of loaves to make: {int(round(average_sold, 0))}")
|
||||||
|
Loading…
Reference in New Issue
Block a user