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
| Quintiq file version 2.0
| #parent: #root
| StaticMethod NearestGridPoint (
| Number x,
| Number y,
| output Number gridx_o,
| output Number gridy_o,
| Number gridpointdistance
| ) declarative remote
| {
| Description: 'Get the nearest grid point'
| TextBody:
| [*
| if( x.IsFinite() and y.IsFinite() ) //check if x or y is not MinValue or MaxValue
| {
| gridpointdistance := maxvalue( gridpointdistance, 1 ); //avoid division by zero
|
|
| rx := x mod gridpointdistance;
| gridx_o := ( x - rx ) div gridpointdistance;
| if( 2*rx >= gridpointdistance )
| {
| gridx_o++;
| }
|
| ry := y mod gridpointdistance;
| gridy_o := ( y - ry ) div gridpointdistance;
| if( 2*ry >= gridpointdistance )
| {
| gridy_o++;
| }
| }
| *]
| }
|
|