Инструменты пользователя

Инструменты сайта


Приёмник GPS/GLONASS/BDS v3 с внешней антенной (Troyka-модуль): инструкция по подключению и примеры использования

Модуль GPS/GLONASS v3 с внешней антенной принимает сигналы спутников глобального позиционирования — GPS, GLONASS, BeiDou и Galileo — и рассчитывает свои географические координаты, скорость перемещения, высоту над уровнем моря и точное локальное время.

Данные передаются на управляющую электронику в текстовом формате NMEA по интерфейсу UART.

Принцип работы систем спутниковой навигации

Спутники непрерывно передают навигационные сигналы на дециметровых волнах. В сигнал входят метки точного времени и координаты самого спутника.

Навигатор по задержке прохождения сигнала со спутника рассчитывает точное расстояние до него. Затем повторяет эту операцию для остальных известных спутников. Эти данные сводятся вместе — так получается точное значение координат приёмника.

Для работы навигаторов нужно открытое небо с минимум четырьмя спутниками в прямой видимости. Чтобы система работала по всей планете, в каждой орбитальной группировке приходится держать более двух десятков спутников.

GPS-модуль общается с управляющей платой с помощью NMEA-сообщений (от «National Marine Electronics Association») — это стандарт передачи данных оборудования навигации, связи и других информационных сетей.

Подключение и настройка

GPS/GLONASS-модуль общается с управляющей платой по протоколу UART. В зависимости от управляющей платформы выберите вариант подключения GPS-модуля.

HardwareSerial

На управляющей плате Iskra JS и Arduino платах с микроконтроллером ATmega32U4 / ATSAMD21G18, данные по USB и общение через пины 0 и 1 осуществляется через два раздельных UART. Это даёт возможность подключить GPS-модуль к аппаратному UART на пинах 0 и 1.

Список поддерживаемых плат:

При подключении удобно использовать Troyka Shield. С Troyka Slot Shield можно обойтись без лишних проводов.

SoftwareSerial

Некоторые платы Arduino, например, Uno, прошиваются через пины 0 и 1. Это означает невозможность использовать одновременно прошивку/отладку по USB и общение с GPS-модулем. Решение проблемы — программный UART. Подключите пины TX и RX GPS-модуля к другим контактам управляющей платы и используйте библиотеку SoftwareSerial.

Для примера подключим управляющие пины GPS-модуля TX и RX — на 4 и 5 контакты управляющей платы.

При подключении удобно использовать Troyka Shield. С Troyka Slot Shield можно обойтись без лишних проводов.

HardwareSerial Mega

На платах форм-фактора Arduino Mega 2560 аппаратный UART, который отвечает за передачу данных через пины 1 и 0, отвечает также за передачу по USB. Это означает невозможность использовать одновременно UART для коммуникации с GPS-модулем и отладки по USB.

Но на платах такого форм-фактора есть ещё дополнительно 3 аппаратных UART:

  • Serial1: пины 19(RX1) и 18(TX1);
  • Serial2: пины 17(RX2) и 16(TX2);
  • Serial3: пины 15(RX3) и 14(TX3).

Список поддерживаемых плат:

Подключим GPS-модуль к объекту Serial1 на пины 18 и 19 на примере платы Arduino Mega 2560

Примеры работы

Рассмотрим примеры работы GPS-модуля в зависимости от управляющей платформы.

Пример для Arduino HardwareSerial

В качестве примера выведем в Serial данные с GPS-модуля. Распарсим строки в отдельные переменные и сохраним их. Для этого скачайте и установите библиотеку TroykaGPS

gpsTestHardwareSerial.ino
// библиотека для работы с GPS устройством
#include <TroykaGPS.h>
 
// serial-порт к которому подключён GPS-модуль
#define GPS_SERIAL Serial1
 
// создаём объект класса GPS и передаём в него объект Serial1
GPS gps(GPS_SERIAL);
 
// задаём размер массива для времени, даты, широты и долготы
#define MAX_SIZE_MASS 16
// массив для хранения текущего времени
char strTime[MAX_SIZE_MASS];
// массив для хранения текущей даты
char strDate[MAX_SIZE_MASS];
// массив для хранения широты в градусах, минутах и секундах
char latitudeBase60[MAX_SIZE_MASS];
// массив для хранения долготы в градусах, минутах и секундах
char longitudeBase60[MAX_SIZE_MASS];
 
void setup() {
    // открываем последовательный порт для мониторинга действий в программе
    // и передаём скорость 9600 бод
    Serial.begin(9600);
    // ждём, пока не откроется монитор последовательного порта
    // для того, чтобы отследить все события в программе
    while (!Serial) { }
    Serial.print("Serial init OK\r\n");
    // открываем Serial-соединение с GPS-модулем на скорости 115200 бод
    GPS_SERIAL.begin(115200);
    // печатаем строку
    Serial.println("GPS init is OK on speed 115200");
    // изменяем скорость обещение GPS-модуля с управляющей платой на 9600 бод
    // используем NMEA-команду «$PMTK251,9600*17\r\n»
    GPS_SERIAL.write("$PMTK251,9600*17\r\n");
    // закрываем Serial-соединение с GPS-модулем
    GPS_SERIAL.end();
    // открываем Serial-соединение с GPS-модулем на скорости 9600 бод
    GPS_SERIAL.begin(9600);
    // печатаем строку
    Serial.print("GPS init is OK on speed 9600");
}
 
void loop() {
    // если пришли данные с GPS-модуля
    if (gps.available()) {
        // считываем данные и парсим
        gps.readParsing();
        // проверяем состояние GPS-модуля
        switch (gps.getState()) {
        // всё OK
        case GPS_OK:
            Serial.println("GPS is OK");
            // выводим координаты широты и долготы
            // 1. в градусах, минутах и секундах
            // 2. градусах в виде десятичной дроби
            Serial.println("GPS Coordinates: ");
            gps.getLatitudeBase60(latitudeBase60, MAX_SIZE_MASS);
            gps.getLongitudeBase60(longitudeBase60, MAX_SIZE_MASS);
            Serial.print("Latitude\t");
            Serial.print(latitudeBase60);
            Serial.print("\t\t");
            Serial.println(gps.getLatitudeBase10(), 6);
            Serial.print("Longitude\t");
            Serial.print(longitudeBase60);
            Serial.print("\t\t");
            Serial.println(gps.getLongitudeBase10(), 6);
            // выводим количество видимых спутников
            Serial.print("Sat: ");
            Serial.println(gps.getSat());
            // выводим текущую скорость
            Serial.print("Speed: ");
            Serial.println(gps.getSpeedKm());
            // выводим высоту над уровнем моря
            Serial.print("Altitude: ");
            Serial.println(gps.getAltitude());
            // выводим текущее время
            Serial.print("Time: ");
            gps.getTime(strTime, MAX_SIZE_MASS);
            gps.getDate(strDate, MAX_SIZE_MASS);
            Serial.write(strTime);
            Serial.println();
            // выводим текущую дату
            Serial.print("Date: ");
            Serial.write(strDate);
            Serial.println("\r\n");
            // каждую переменную дату и времени можно выводить отдельно
            /*    Serial.print(gps.getHour());
                  Serial.print(gps.getMinute());
                  Serial.print(gps.getSecond());
                  Serial.print(gps.getDay());
                  Serial.print(gps.getMonth());
                  Serial.print(gps.getYear());
            */
            break;
        // ошибка данных
        case GPS_ERROR_DATA:
            Serial.println("GPS error data");
            break;
        // нет соединения со спутниками
        case GPS_ERROR_SAT:
            Serial.println("GPS is not connected to satellites!!!");
            break;
        }
    }
}

Пример для Arduino SoftwareSerial

В отличии от аппаратного UART (HardwareSerial), за работу программного UART (SoftwareSerial) отвечает микроконтроллер, который назначает другие пины в режим работы RX и TX, соответственно и данные которые приходят от модуля GPS обрабатывает сам микроконтроллер во время программы. По умолчанию скорость общения GPS-модуля равна 115200, что значительно выше чем позволяет библиотека SoftwareSerial. В итоге часть информации которая приходит с GPS-модуля будет утеряна.

Решение понизить скорость общения GPS-модуля с управляющей платой. Из описание команд управления GPS-модулем найдём NMEA-команду понижение скорости до 9600бод.

$PMTK251,9600*17

Данную команду придётся выполнять при каждом новом включении GPS-модуля. В качестве примера выведем в Serial данные с GPS-модуля. Распарсим строки в отдельные переменные и сохраним их. Для этого скачайте и установите библиотеку TroykaGPS

SoftwareSerialGpsTest.ino
// библиотека для работы с GPS устройством
#include <TroykaGPS.h>
 
// библиотека для работы программного Serial
#include <SoftwareSerial.h>
 
// создаём объект для работы с программным Serial
// и передаём ему пины TX и RX
SoftwareSerial mySerial(4, 5);
 
// serial-порт к которому подключён GPS-модуль
#define GPS_SERIAL    mySerial
 
// создаём объект класса GPS и передаём в него объект GPS_SERIAL 
GPS gps(GPS_SERIAL);
 
// задаём размер массива для времени, даты, широты и долготы
#define MAX_SIZE_MASS 16
// массив для хранения текущего времени
char strTime[MAX_SIZE_MASS];
// массив для хранения текущей даты
char strDate[MAX_SIZE_MASS];
// массив для хранения широты в градусах, минутах и секундах
char latitudeBase60[MAX_SIZE_MASS];
// массив для хранения долготы в градусах, минутах и секундах
char longitudeBase60[MAX_SIZE_MASS];
 
void setup()
{ 
  // открываем последовательный порт для мониторинга действий в программе
  // и передаём скорость 9600 бод
  Serial.begin(9600);
  // ждём, пока не откроется монитор последовательного порта
  // для того, чтобы отследить все события в программе
  while (!Serial) {
  }
  Serial.print("Serial init OK\r\n");
  // открываем Serial-соединение с GPS-модулем на скорости 115200 бод
  GPS_SERIAL.begin(115200);
  // печатаем строку
  Serial.println("GPS init is OK on speed 115200");
  // изменяем скорость обещение GPS-модуля с управляющей платой на 9600 бод
  // используем NMEA-команду «$PMTK251,9600*17\r\n»
  GPS_SERIAL.write("$PMTK251,9600*17\r\n");
  // закрываем Serial-соединение с GPS-модулем
  GPS_SERIAL.end();
  // открываем Serial-соединение с GPS-модулем на скорости 9600 бод
  GPS_SERIAL.begin(9600);
  // печатаем строку
  Serial.print("GPS init is OK on speed 9600");
}
 
void loop()
{
  // если пришли данные с gps-модуля
  if (gps.available()) {
    // считываем данные и парсим
    gps.readParsing();
    // проверяем состояние GPS-модуля
    switch(gps.getState()) {
      // всё OK
      case GPS_OK:
        Serial.println("GPS is OK");
        // выводим координаты широты и долготы
        // 1. в градусах, минутах и секундах
        // 2. градусах в виде десятичной дроби
        Serial.println("GPS Coordinates: ");
        gps.getLatitudeBase60(latitudeBase60, MAX_SIZE_MASS);
        gps.getLongitudeBase60(longitudeBase60, MAX_SIZE_MASS);
        Serial.print("Latitude\t");
        Serial.print(latitudeBase60);
        Serial.print("\t\t");
        Serial.println(gps.getLatitudeBase10(), 6);
        Serial.print("Longitude\t");
        Serial.print(longitudeBase60);
        Serial.print("\t\t");
        Serial.println(gps.getLongitudeBase10(), 6);
        // выводим количество видимых спутников
        Serial.print("Sat: ");
        Serial.println(gps.getSat());
        // выводим текущую скорость
        Serial.print("Speed: ");
        Serial.println(gps.getSpeedKm());
        // выводим высоту над уровнем моря
        Serial.print("Altitude: ");
        Serial.println(gps.getAltitude());
        // выводим текущее время
        Serial.print("Time: ");
        gps.getTime(strTime, MAX_SIZE_MASS);
        gps.getDate(strDate, MAX_SIZE_MASS);
        Serial.write(strTime);
        Serial.println();
        // выводим текущую дату
        Serial.print("Date: ");
        Serial.write(strDate);
        Serial.println("\r\n");
        // каждую переменную дату и времени можно выводить отдельно
  /*    Serial.print(gps.getHour());
        Serial.print(gps.getMinute());
        Serial.print(gps.getSecond());
        Serial.print(gps.getDay());
        Serial.print(gps.getMonth());
        Serial.print(gps.getYear());
  */   
        break;
      // ошибка данных
      case GPS_ERROR_DATA:
        Serial.println("GPS error data");
        break;
      // нет соединение со спутниками
      case GPS_ERROR_SAT:
        Serial.println("GPS no connect to satellites!!!");
        break;
    }
  }
}

Пример кода для Iskra JS

Выведем данные о координатах, высоте над уровнем моря, количестве видимых спутников и точном времени в консоль Web IDE.

testGPS.js
Serial3.setup(115200, {rx: P0, tx: P1});
var gps = require("GPS").connect(Serial3, function(data) {
  console.log(data);
});

Каждую секунду в консоль будет выводится информация от модуля.

{ "time":"16:35:29", "lat":53.068403,"lon":-4.076282,"fix":1,"satellites":7,"altitude":1085.0 }

Формат сообщений NMEA

GPS-модуль общается с управляющей платой с помощью NMEA-сообщений (от «National Marine Electronics Association») — это стандарт передачи данных оборудования навигации, связи и других информационных сетей. NMEA — это так же простой и понятный формат, который позволяет не только обеспечить обмен данными между GPS приемниками и навигационными программами, но и дает пользователям некоторое представление о принципах работы спутниковой навигационной аппаратуры.

Исходящие сообщения NMEA

Данные с GPS-модуля передаются на управляющую электронику в текстовом формате NMEA, состоят из последовательного набора данных, разделенных запятыми. Каждое NMEA сообщение начинается с $, заканчивается \n (перевод строки) и не может быть длиннее 80 символов.

Список сообщений

  • AAM – Прибытие в путевую точку
  • ALM – Данные альманаха
  • АPA – Данные автопилота «А»
  • APB – Данные автопилота «В»
  • BOD – Азимут на пункт назначения
  • DTM – Используемый датум
  • GGA – Информация о фиксированном решении
  • GLL – Данные широты и долготы
  • GSA – Общая информация о спутниках
  • GSV – Детальная информация о спутниках
  • MSK – Передача управлению базовому приемнику
  • MSS – Статус базового приемника
  • RMA – Рекомендованный набор данных системы «Loran»
  • RMB – Рекомендованный набор навигационных GPS данных
  • RMC – Рекомендованный минимальный набор GPS данных
  • RTE – Маршрутная информация VTG – Вектор движения и скорости
  • WCV – Данные скорости вблизи путевой точки
  • WPL – Данные путевой точки
  • XTC – Ошибка отклонения от трека
  • XTE – Измеренная ошибка отклонения от трека
  • ZTG – UTC время и оставшееся время до прибытия в точку назначения
  • ZDA – Дата и время.

Некоторые из NMEA сообщений могут содержать одинаковые поля данных, либо полностью содержать данные других, меньших по размеру, NMEA сообщений.

Содержание NMEA сообщений

GGA - информация о фиксированном решении

Самое популярное и наиболее используемое NMEA сообщение с информацией о текущем фиксированном решении – горизонтальные координаты, значение высоты, количество используемых спутников и тип решения.

$GPGGA,123519,4807.038,N,01131.000,E,1,08,0.9,545.4,M,46.9,M,,*47
  • GGA – NMEA Заговолок
  • 123519 –UTC время 12:35:19
  • 4807.038, N – Широта, 48 градусов 7.038 минуты северной широты
  • 01131.000, Е – Долгота, 11 градусов 31.000 минуты восточной долготы
  • 1 – тип решение, StandAlone решение
    • 0 – нет решения,
    • 1 – StandAlone,
    • 2 – DGPS,
    • 3 – PPS,
    • 4 – фиксированный RTK,
    • 5 – не фиксированный RTK,
    • 6 – использование данных инерциальных систем,
    • 7 – ручной режим,
    • 8 – режим симуляции
  • 08 – количество используемых спутников
  • 0.9 – геометрический фактор, HDOP
  • 545.4, М – высота над уровнем моря в метрах
  • 46.9, М – высота геоида над эллипсоидом WGS 84
  • [пустое поле] – время прошедшее с момента получения последней DGPS поправки. Заполняется при активизации DGPS режима
  • [пустое поле] – идентификационный номер базовой станции. Заполняется при активизации DGPS режима.
RMC — рекомендованный минимальный набор GPS данных

Это NMEA сообщение содержит весь наборы, так называемых «PVT» данных. «PVT» — общепринятое сокращение от «position, velocity, time» (позиция, скорость, время).

$GPRMC,123519,A,4807.038,N,01131.000,E,022.4,084.4,230394,003.1,W*6A
  • RMC – NMEA заголовок
  • 123419 – UTC время, 12:34:59
  • А – статус (А- активный, V- игнорировать)
  • 4807.038,N – Широта, 48 градусов 07.038 минут северной широты
  • 01131.000,Е – Долгота, 11 градусов 31.000 минута восточной долготы
  • 022.4 – Скорость, в узлах
  • 084.4 – Направление движения, в градусах
  • 230394 – Дата, 23 марта 1994 года
  • 003.1,W – Магнитные вариации

Входящие сообщения NMEA

По умолчанию в GPS-модуле установлены дефолтные настройки. Например частота отдачи данных на принимающее устройство или скорость общение с управляющей платой. При желании можно модуль настроить под себя.

Управление работой GPS-модуля осуществляется при помощи специальных NMEA – подобных команд.

GPS-модуль не сохраняет настройки в своей памяти. После сброса питания, модуль вернётся в своё первоначальное состояние.

Пример команды установки скорости общения 9600 бод.

$PMTK251,9600*17\r\n

Каждое входное NMEA-сообщение должно начинаться с символа $ и заканчивается символами \r\n:

  • $ — служебный символ;
  • PMTK — идентификатор;
  • 251 — тип команды (в данном случае команда смена скорости);
  • 9600 — данные (в данном случае установка 9600);
  • * — символ окончания данных;
  • 17 — контрольная сумма;
  • \r — возврат каретки <CR>;
  • \n — начало строки <CL>.

Контрольная сумма — восьмибитная (исключающая ИЛИ) всех символов сообщения, включая пробелы, расположенных между разделителями $ и *. Для нахождения контрольной суммы используйте NMEA Checksum Calculator.

Пример работы для HardwareSerial

По умолчания GPS-модуль отдаёт данные раз в секунду. В качестве примера выведем сырые данные в формате NMEA-сообщений и и увеличим отдачу данных до 10 раз в секунду.

  1. Прошейте плату Arduino скетчем проброса данных с USB на аппаратный UART.
    HardwareSerialGpsToUsb.ino
    // serial-порт к которому подключён GPS-модуль
    #define GPS_SERIAL    Serial1
     
    void setup()
    {
      // открываем последовательный порт для мониторинга действий в программе
      // и передаём скорость 115200 бод
      Serial.begin(115200);
      while (!Serial) {
      }
      Serial.print("\r\nSerial init OK\r\n");
      // открываем Serial-соединение с GPS-модулем
      // и передаём скорсть 115200 бод
      GPS_SERIAL.begin(115200);
    }
     
    void loop()
    {
      // если приходят данные из GPS-модуля - отправим их в порт компьютера
      if (GPS_SERIAL.available()) {
        Serial.write(GPS_SERIAL.read());
      }
      // если приходят данные из компьютера - отправим их в GPS-модуль
      if (Serial.available()) {
        GPS_SERIAL.write(Serial.read());
      }
    }
  2. Откройте монитор Serial-порта, нажав на иконку лупы.
  3. Установите скорость обмена данными на 115200 бод и установите дополнительные параметры NL— новой строки и CR — возврат каретки. В итоге каждую секунду вы будете получать данные в формате NMEA-сообщений.
  4. Из документации на NMEA-команды находим команду:
    $PMTK220,variable*<CS><CR><LF>
    1. variable — значение от 100 до 10000 в миллисекундах, нашем случае это 100.
    2. CS — контрольная сумма;
    3. CR — возврат каретки \r;
    4. LF — новая строка \n.
  5. Перейдите на сайт NMEA Checksum Calculator.
  6. Введите команду PMTK220,100 в поле ввода Command и нажмите кнопку Enter. В окне With checksum вы получите команду вместе с контрольной суммой.
  7. В окне ввода информации введите вместе с контрольной суммой NMEA-команду смены скорости отдачи данных до десяти раз в секунду и нажмите кнопку Отправить
    $PMTK220,100*2F

Если всё прошло правильно, теперь данные с GPS-модуля будут приходить до десяти раз в секунду.

Пример работы для SoftwareSerial

В качестве примера выведем сырые данные в формате NMEA-сообщений с GPS-модуля.

  1. Прошейте плату Arduino скетчем проброса данных с USB на программный UART.
    SoftwareSerialGpsToUsb.ino
    // библиотека для работы программного Serial
    #include <SoftwareSerial.h>
     
    // создаём объект для работы с программным Serial
    // и передаём ему пины TX и RX
    SoftwareSerial mySerial(4, 5);
     
    // serial-порт к которому подключён GPS-модуль
    #define GPS_SERIAL    mySerial
     
    void setup()
    {
      // открываем последовательный порт для мониторинга действий в программе
      // и передаём скорость 9600 бод
      Serial.begin(9600);
      // ждём, пока не откроется монитор последовательного порта
      // для того, чтобы отследить все события в программе
      while (!Serial) {
      }
      Serial.print("Serial init OK\r\n");
      // открываем Serial-соединение с GPS-модулем на скорости 115200 бод
      GPS_SERIAL.begin(115200);
      // печатаем строку
      Serial.println("GPS init is OK on speed 115200");
      // изменяем скорость обещение GPS-модуля с управляющей платой на 9600 бод
      // используем NMEA-команду «$PMTK251,9600*17\r\n»
      GPS_SERIAL.write("$PMTK251,9600*17\r\n");
      // закрываем Serial-соединение с GPS-модулем
      GPS_SERIAL.end();
      // открываем Serial-соединение с GPS-модулем на скорости 9600 бод
      GPS_SERIAL.begin(9600);
      // печатаем строку
      Serial.print("GPS init is OK on speed 9600");
    }
     
    void loop()
    {
      // если приходят данные из GPS-модуля - отправим их в порт компьютера
      if (GPS_SERIAL.available()) {
        Serial.write(GPS_SERIAL.read());
      }
      // если приходят данные из компьютера - отправим их в GPS-модульl
      if (Serial.available()) {
        GPS_SERIAL.write(Serial.read());
      }
    }
  2. Откройте монитор Serial-порта, нажав на иконку лупы.
  3. Установите скорость обмена данными на 9600 бод и установите дополнительные параметры NL— новой строки и CR — возврат каретки. В итоге вы должны увидеть данные в полном формате NMEA-сообщений.
  4. Из документации на NMEA-команды находим команду:
    $PMTK220,variable*<CS><CR><LF>
    1. variable — значение от 100 до 10000 в миллисекундах, нашем случае это 100.
    2. CS — контрольная сумма;
    3. CR — возврат каретки \r;
    4. LF — новая строка \n.
  5. Перейдите на сайт NMEA Checksum Calculator.
  6. Введите команду PMTK220,100 в поле ввода Command и нажмите кнопку Enter. В окне With checksum вы получите команду вместе с контрольной суммой.
  7. В окне ввода информации введите вместе с контрольной суммой NMEA-команду смены скорости отдачи данных до десяти раз в секунду и нажмите кнопку Отправить
    $PMTK220,100*2F

Если всё прошло правильно, теперь данные с GPS-модуля будут приходить до десяти раз в секунду.

Элементы платы

Модуль Neoway G7A-B1

Чипсет Neoway использует весь спектр спутниковых систем: GPS, GLONASS, BeiDou и Galileo.

Neoway G7A-B1 отличается высокой чувствительностью, малым энергопотреблением и быстрым временем первой фиксации (TTFF). Связь с модулем осуществляется через UART, данные выводятся по протоколу NMEA.

Контакты подключения трёхпроводных шлейфов

На модуле выведены две группы Troyka-контактов.

Нижняя группа

  • Сигнальный (TX) — цифровой выход GPS-модуля. Подключите к пину RX микроконтроллера.
  • Питание (V) — соедините с рабочим напряжением микроконтроллера.
  • Земля (G) — соедините с землёй микроконтроллера.

Верхняя группа

  • Сигнальный (RX) — цифровой вход GPS-модуля. Подключите к пину TX микроконтроллера.
  • Сигнальный (P) — пин синхронизации GPS-модуля. Подключите к цифровому пину микроконтроллера.

Антенна

Внешняя активная антенна с трёхметровым кабелем необходима для приёма сигнала от навигационных спутников.

Преобразователь логических уровней

Необходим для сопряжения устройств с разными напряжениями логических уровней.

В нашем случае это может быть управляющее устройство Arduino с 5 вольтовой логикой и GPS/GLONASS модуль с 3,3 вольтовой логикой.

Светодиодная индикация

Имя светодиода Назначение
RX и TX Мигают при обмене данными между GPS/GLONASS модулем и управляющим устройством.
P Пин синхронизации GPS-модуля. Подключите к цифровому пину микроконтроллера.

Обновление прошивки

Периодически выходят новые версии прошивки для GPS-приёмников с улучшениями и новыми функциями.

Принципиальная и монтажная схемы

Характеристики

  • Чипсет: Neoway G7A-B1
  • Навигационные системы: GPS, GLONASS, BeiDou
  • Рабочие частоты:
    • GPS L1: 1575,42 МГц
    • GLONASS L1: 1602,5625 МГц
    • BDS L1: 1561,098 МГц
  • Протоколы передачи данных: NMEA
  • Скорость передачи данных по умолчанию: 9600 бод
  • Размеры антенны: 40×40 мм
  • Длина кабеля: 3 м
  • Поляризация: RHCP (правая круговая поляризация)
  • Погрешность позиционирования: менее 3 м
  • Горячий старт: 1 с
  • Холодный старт: 32 с
  • Рабочее напряжение: 3,3–5 В
  • Потребляемый ток: до 30 мА
  • Габариты: 25,4×25,4 мм

Ресурсы