PocketMine-MP 5.36.1 git-eaa7c4834c8fe2f379d24e7f0ee6cc63cfb18ccc
Loading...
Searching...
No Matches
Gaussian.php
1<?php
2
3/*
4 *
5 * ____ _ _ __ __ _ __ __ ____
6 * | _ \ ___ ___| | _____| |_| \/ (_)_ __ ___ | \/ | _ \
7 * | |_) / _ \ / __| |/ / _ \ __| |\/| | | '_ \ / _ \_____| |\/| | |_) |
8 * | __/ (_) | (__| < __/ |_| | | | | | | | __/_____| | | | __/
9 * |_| \___/ \___|_|\_\___|\__|_| |_|_|_| |_|\___| |_| |_|_|
10 *
11 * This program is free software: you can redistribute it and/or modify
12 * it under the terms of the GNU Lesser General Public License as published by
13 * the Free Software Foundation, either version 3 of the License, or
14 * (at your option) any later version.
15 *
16 * @author PocketMine Team
17 * @link http://www.pocketmine.net/
18 *
19 *
20 */
21
22declare(strict_types=1);
23
25
26use function array_sum;
27use function exp;
28use function sqrt;
29
30final class Gaussian{
32 public array $kernel = [];
33
34 public readonly float $weightSum;
35
37 public array $kernel1D = [];
38
39 public readonly float $weightSum1D;
40
41 public function __construct(public int $smoothSize){
42 $bellSize = 1 / $this->smoothSize;
43 $bellHeight = 2 * $this->smoothSize;
44
45 for($sx = -$this->smoothSize; $sx <= $this->smoothSize; ++$sx){
46 $bx = $bellSize * $sx;
47
48 $this->kernel1D[$sx + $this->smoothSize] = sqrt($bellHeight) * exp(-($bx * $bx) / 2);
49
50 $this->kernel[$sx + $this->smoothSize] = [];
51 for($sz = -$this->smoothSize; $sz <= $this->smoothSize; ++$sz){
52 $bz = $bellSize * $sz;
53 $this->kernel[$sx + $this->smoothSize][$sz + $this->smoothSize] = $bellHeight * exp(-($bx * $bx + $bz * $bz) / 2);
54 }
55 }
56
57 $this->weightSum1D = array_sum($this->kernel1D);
58 $this->weightSum = $this->weightSum1D ** 2;
59 }
60}