mirror of
https://bitbucket.org/librepilot/librepilot.git
synced 2025-02-10 00:54:15 +01:00
ecac1fb79d
This creates a new UAVObject called GPSSatellites to hold information about which satellites the GPS receiver can see and the quality of their signals. NMEA GSV sentences are now parsed. The full set of GSV data may be split across multiple GSV sentences, each containing info for at most 4 satellites. Once an entire set of GSV records has been collected, the GPSSatellites UAVObject is updated. git-svn-id: svn://svn.openpilot.org/OpenPilot/trunk@1453 ebee16cc-31ac-478f-84a7-5cbb03baadba
187 lines
3.4 KiB
Python
187 lines
3.4 KiB
Python
##
|
|
##############################################################################
|
|
#
|
|
# @file gpssatellites.py
|
|
# @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
|
# @brief Implementation of the GPSSatellites object. This file has been
|
|
# automatically generated by the UAVObjectGenerator.
|
|
#
|
|
# @note Object definition file: gpssatellites.xml.
|
|
# This is an automatically generated file.
|
|
# DO NOT modify manually.
|
|
#
|
|
# @see The GNU Public License (GPL) Version 3
|
|
#
|
|
#############################################################################/
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful, but
|
|
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
# for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License along
|
|
# with this program; if not, write to the Free Software Foundation, Inc.,
|
|
# 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
#
|
|
|
|
|
|
import uavobject
|
|
|
|
import struct
|
|
from collections import namedtuple
|
|
|
|
# This is a list of instances of the data fields contained in this object
|
|
_fields = [ \
|
|
uavobject.UAVObjectField(
|
|
'SatsInView',
|
|
'b',
|
|
1,
|
|
[
|
|
'0',
|
|
],
|
|
{
|
|
}
|
|
),
|
|
uavobject.UAVObjectField(
|
|
'PRN',
|
|
'b',
|
|
16,
|
|
[
|
|
'0',
|
|
'1',
|
|
'2',
|
|
'3',
|
|
'4',
|
|
'5',
|
|
'6',
|
|
'7',
|
|
'8',
|
|
'9',
|
|
'10',
|
|
'11',
|
|
'12',
|
|
'13',
|
|
'14',
|
|
'15',
|
|
],
|
|
{
|
|
}
|
|
),
|
|
uavobject.UAVObjectField(
|
|
'Elevation',
|
|
'f',
|
|
16,
|
|
[
|
|
'0',
|
|
'1',
|
|
'2',
|
|
'3',
|
|
'4',
|
|
'5',
|
|
'6',
|
|
'7',
|
|
'8',
|
|
'9',
|
|
'10',
|
|
'11',
|
|
'12',
|
|
'13',
|
|
'14',
|
|
'15',
|
|
],
|
|
{
|
|
}
|
|
),
|
|
uavobject.UAVObjectField(
|
|
'Azimuth',
|
|
'f',
|
|
16,
|
|
[
|
|
'0',
|
|
'1',
|
|
'2',
|
|
'3',
|
|
'4',
|
|
'5',
|
|
'6',
|
|
'7',
|
|
'8',
|
|
'9',
|
|
'10',
|
|
'11',
|
|
'12',
|
|
'13',
|
|
'14',
|
|
'15',
|
|
],
|
|
{
|
|
}
|
|
),
|
|
uavobject.UAVObjectField(
|
|
'SNR',
|
|
'b',
|
|
16,
|
|
[
|
|
'0',
|
|
'1',
|
|
'2',
|
|
'3',
|
|
'4',
|
|
'5',
|
|
'6',
|
|
'7',
|
|
'8',
|
|
'9',
|
|
'10',
|
|
'11',
|
|
'12',
|
|
'13',
|
|
'14',
|
|
'15',
|
|
],
|
|
{
|
|
}
|
|
),
|
|
]
|
|
|
|
|
|
class GPSSatellites(uavobject.UAVObject):
|
|
## Object constants
|
|
OBJID = 3593446318
|
|
NAME = "GPSSatellites"
|
|
METANAME = "GPSSatellitesMeta"
|
|
ISSINGLEINST = 1
|
|
ISSETTINGS = 0
|
|
|
|
def __init__(self):
|
|
uavobject.UAVObject.__init__(self,
|
|
self.OBJID,
|
|
self.NAME,
|
|
self.METANAME,
|
|
0,
|
|
self.ISSINGLEINST)
|
|
|
|
for f in _fields:
|
|
self.add_field(f)
|
|
|
|
def __str__(self):
|
|
s = ("0x%08X (%10u) %-30s %3u bytes format '%s'\n"
|
|
% (self.OBJID, self.OBJID, self.NAME, self.get_struct().size, self.get_struct().format))
|
|
for f in self.get_tuple()._fields:
|
|
s += ("\t%s\n" % f)
|
|
return (s)
|
|
|
|
def main():
|
|
# Instantiate the object and dump out some interesting info
|
|
x = GPSSatellites()
|
|
print (x)
|
|
|
|
if __name__ == "__main__":
|
|
#import pdb ; pdb.run('main()')
|
|
main()
|