forked from SignalK/nmea0183-signalk
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathRMB.js
More file actions
112 lines (93 loc) · 3.29 KB
/
RMB.js
File metadata and controls
112 lines (93 loc) · 3.29 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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
/**
* Copyright 2016 Signal K <info@signalk.org> and contributors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an 'AS IS' BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
'use strict'
const utils = require('@signalk/nmea0183-utilities')
const moment = require('moment-timezone')
/*
RMC Sentence
$GPRMB,A,0.66,L,003,004,4917.24,N,12309.57,W,001.3,052.5,000.5,V*20
values:
- RMB Recommended minimum navigation information
[0] A Data status A = OK, V = Void (warning)
[1][2] 0.66,L Cross-track error (nautical miles, 9.99 max),
steer Left to correct (or R = right)
[3] 003 Origin waypoint ID
[4] 004 Destination waypoint ID
[5][6] 4917.24,N Destination waypoint latitude 49 deg. 17.24 min. N
[7][8] 12309.57,W Destination waypoint longitude 123 deg. 09.57 min. W
[9] 001.3 Range to destination, nautical miles (999.9 max)
[10] 052.5 True bearing to destination
[11] 000.5 Velocity towards destination, knots
[12] V Arrival alarm A = arrived, V = not arrived
- *20 checksum
*/
module.exports = function (input) {
const { id, sentence, parts, tags } = input
let latitude = -1
let longitude = -1
let bearing = 0.0
let vmg = 0.0
let distance = 0.0
let crossTrackError = 0.0
latitude = utils.coordinate(parts[5], parts[6])
longitude = utils.coordinate(parts[7], parts[8])
if (isNaN(latitude) || isNaN(longitude)) {
return null
}
bearing = utils.float(parts[10])
bearing = (!isNaN(bearing)) ? bearing : 0.0
vmg = utils.float(parts[11])
vmg = (!isNaN(vmg) && vmg > 0) ? vmg : 0.0
distance = utils.float(parts[9])
distance = (!isNaN(distance)) ? distance : 0.0
crossTrackError = utils.float(parts[1])
crossTrackError = (!isNaN(crossTrackError)) ? crossTrackError : 0.0
crossTrackError = parts[2] == 'R' ? crossTrackError : -crossTrackError;
const delta = {
updates: [
{
source: tags.source,
timestamp: tags.timestamp,
values: [
{
'path': 'navigation.courseRhumbline.nextPoint',
'value': {
longitude,
latitude
}
},
{
'path': 'navigation.courseRhumbline.nextPoint.bearingTrue',
'value': utils.transform(bearing, 'deg', 'rad')
},
{
'path': 'navigation.courseRhumbline.nextPoint.velocityMadeGood',
'value': utils.transform(vmg, 'knots', 'ms')
},
{
'path': 'navigation.courseRhumbline.nextPoint.distance',
'value': utils.transform(distance, 'nm', 'km') * 1000
},
{
'path': 'navigation.courseRhumbline.crossTrackError',
value: utils.transform(crossTrackError, 'nm', 'km') * 1000
}
]
}
],
}
return delta
}