-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcentroid.php
More file actions
59 lines (51 loc) · 1.48 KB
/
centroid.php
File metadata and controls
59 lines (51 loc) · 1.48 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
<?php
/**
* Created by PhpStorm.
* User: zjeff
* Date: 5/4/2019
* Time: 6:25 PM
*/
class centroid
{
private $classified_count;
private $in_progress_new_centroid;
//used to calculate euclidean distance
private $x;
private $y;
public function __construct($x, $y)
{
$this->x = $x;
$this->y = $y;
$this->classified_count = 0;
$this->in_progress_new_centroid = new coordinate(0,0);
}
public function get_classified_count()
{
return $this->classified_count;
}
public function new_classified($coordinate)
{
$this->classified_count++;
$x_average = $this->in_progress_new_centroid->get_x() + (($coordinate->get_x() - $this->in_progress_new_centroid->get_x())/$this->classified_count);
$y_average = $this->in_progress_new_centroid->get_y() + (($coordinate->get_y() - $this->in_progress_new_centroid->get_y())/$this->classified_count);
$this->in_progress_new_centroid->set_coordinate($x_average, $y_average);
}
public function relocate_centroid()
{
$this->x = $this->in_progress_new_centroid->get_x();
$this->y = $this->in_progress_new_centroid->get_y();
$this->classified_count = 0;
}
public function get_x()
{
return $this->x;
}
public function get_y()
{
return $this->y;
}
public function pretty_printing()
{
return "Centroid X: " . $this->x . " Centroid Y: " . $this->y. "<br>";
}
}