====== Магнитометр / компас: инструкция, схемы и примеры использования ====== Используйте [[amp>product/troyka-magnetometer-compass?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|магнитометр]] для определения углов между собственными осями сенсора X, Y, Z и силовыми линиями магнитного поля Земли. Отсюда второе имя модуля — электронный компас для определения азимута. {{ :products:troyka-magnetometer-compass:troyka-magnetometer-compass.4.jpg?nolink |}} Если вам необходимо определить положение вашего девайса в пространстве, обратите внимания на [[amp>product/troyka-imu-10-dof?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|IMU-сенсор на 10 степеней свободы]]. В связи с искажениями от внешних магнитных полей, [[articles:troyka-magnetometer-compass-calibrate|откалибруйте магнитометр]] для работы в режиме электронного компаса. ===== Видеообзор ===== Магнитометр в обзоре IMU-модуля. {{youtube>ECVbkKo--YY?large}} ===== Пример работы для Arduino и XOD ===== В качестве мозга для считывания показаний с датчика рассмотрим платформу из серии [[amp>collection/arduino?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|Arduino]], например, [[amp>product/arduino-uno?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|Uno]]. * [[amp>page/arduino-ide?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|Как начать работу с Arduino?]] * [[amp>page/xod-ide?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|Как начать работу с XOD?]] На аппаратном уровне инерционный модуль общается с управляющей электроникой по шине I²C. Но не переживайте о битах и байтах: используйте библиотеку [[https://github.com/amperka/Troyka-IMUm|TroykaIMU]] и на выходе получите готовы данные. ==== Схема устройства ==== Подключите магнитометр к пинам питания и шины I²C — SDA и SCL платформы Arduino Uno. Для коммуникации используйте [[amp>product/wire-fm?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|соединительные провода «мама-папа»]].{{ :products:troyka-magnetometer-compass:troyka-magnetometer-compass-install-arduino.png?nolink |}} Для быстрой сборки и отладки устройства возьмите плату расширения [[amp>product/arduino-troyka-shield?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|Troyka Shield]], которая одевается сверху на Arduino Uno методом бутерброда. Для коммуникации используйте [[amp>product/3-wire-cable-digital-troyka?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|трёхпроводной шлейф «мама-мама»]], который идёт в комплекте с датчиком.{{ :products:troyka-magnetometer-compass:troyka-magnetometer-compass-install-arduino-troyka.png?nolink |}} С [[amp>product/arduino-troyka-slot-shield?utm_source=man&utm_campaign=troyka-troyka-magnetometer-compass&utm_medium=wiki|Troyka Slot Shield]] провода не понадобятся вовсе.{{ :products:troyka-magnetometer-compass:troyka-magnetometer-compass-install-arduino-troyka-slot.png?nolink |}} ==== Вывод данных ==== В качестве примера выведем в Serial-порт значения напряженности магнитного поля по осям X, Y, Z. // Библиотека для работы с модулями IMU #include // Создаём объект для работы с магнитометром/компасом Compass compass; void setup() { // Открываем последовательный порт Serial.begin(9600); // Выводим сообщение о начале инициализации Serial.println("Compass begin"); // Инициализируем компас compass.begin(); // Выводим сообщение об удачной инициализации Serial.println("Initialization completed"); } void loop() { // Выводим напряженность магнитного поля в Гауссах по оси X Serial.print(compass.readMagneticGaussX()); Serial.print("\t\t"); // Выводим напряженность магнитного поля в Гауссах по оси Y Serial.print(compass.readMagneticGaussY()); Serial.print("\t\t"); // Выводим напряженность магнитного поля в Гауссах по оси Z Serial.print(compass.readMagneticGaussZ()); Serial.println(); delay(100); } ===== Пример для Espruino ===== В качестве мозга для считывания показаний с датчика рассмотрим платформы из серии [[amp>collection/espruino?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|Espruino]], например, [[amp>product/iskra-js?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|Iskra JS]]. [[:js:ide|Как начать работу с Espruino?]] ==== Схема устройства ==== Подключите магнитометр к пинам питания и шины I²C — SDA и SCL платформы Iskra JS. Для коммуникации используйте [[amp>product/wire-fm?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|соединительные провода «мама-папа»]].{{ :products:troyka-magnetometer-compass:troyka-magnetometer-compass-install-espruino.png?nolink |}} Для быстрой сборки и отладки устройства возьмите плату расширения [[amp>product/arduino-troyka-shield?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|Troyka Shield]], которая одевается сверху на Iskra JS методом бутерброда. Для коммуникации используйте [[amp>product/3-wire-cable-digital-troyka?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|трёхпроводной шлейф «мама-мама»]], который идёт в комплекте с датчиком.{{ :products:troyka-magnetometer-compass:troyka-magnetometer-compass-install-espruino-troyka.png?nolink |}} С [[amp>product/arduino-troyka-slot-shield?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|Troyka Slot Shield]] провода не понадобятся вовсе.{{ :products:troyka-magnetometer-compass:troyka-magnetometer-compass-install-espruino-troyka-slot.png?nolink |}} ==== Вывод данных ==== В качестве примера выведем в консоль значения азимута. ===== Пример для Raspberry Pi ===== В качестве мозга для считывания показаний с датчика рассмотрим одноплатные компьютеры [[amp>collection/raspberry-pi?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|Raspberry Pi]], например, [[amp>product/raspberry-pi-4-model-b-4-gb?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|Raspberry Pi 4]]. [[articles:rpi-guide|Подготовь Raspberry Pi]] ==== Схема устройства ==== Подключите магнитометр к пинам SDA и SCL шины I²C компьютера Raspberry Pi. {{ :products:troyka-magnetometer-compass:troyka-magnetometer-compass-install-rpi.png?nolink |}} Для быстрой сборки и отладки устройства возьмите плату расширения [[amp>product/raspberry-troyka-cap?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|Troyka Cap]], которая надевается сверху на малину методом бутерброда.{{ :products:troyka-magnetometer-compass:troyka-magnetometer-compass-install-rpi-cap.png?nolink |}} ==== Программная настройка ==== - [[articles:rpi-guide|Подготовь Raspberry Pi]] - [[articles:rpi-interfaces#интерфейс_i_c|Включите шину I²C]] ==== Вывод данных ==== А написать пример кода для Raspberry Pi оставим вам домашним заданием. ===== Элементы платы ===== {{ :products:troyka-magnetometer-compass:troyka-magnetometer-compass-annotation.png?nolink |}} ==== Магнитометр/Компас на LIS3MDL ==== Магнитометр выполнен на чипе {{ :products:troyka-magnetometer-compass:lis3mdl-datasheet.pdf |LIS3MDL}} и представляет собой миниатюрный датчик магнитного поля в трёхмерном пространстве, разработанный по технологии MEMS от компании STMicroelectronics. Адрес устройства по умолчанию равен 0x1С, но может быть изменен на 0x1E. Подробности читайте в разделе [[#смена_адреса_модуля| смена адреса модуля]]. ==== Регулятор напряжения ==== Линейный понижающий регулятор напряжения {{ :products:troyka-magnetometer-compass:ncp698sq33t1g-datasheet.pdf |NCP698SQ33T1G}} обеспечивает питание MEMS-чипа и других компонентов сенсора. Диапазон входного напряжения от 3,3 до 5 вольт. Выходное напряжение 3,3 В с максимальным выходным током 150 мА. ==== Преобразователь логических уровней ==== Преобразователь логических уровней {{ :products:troyka-magnetometer-compass:pca9306dct-datasheet.pdf |PCA9306DCT}} необходим для сопряжения датчика с разными напряжениями логических уровней от 3,3 до 5 вольт. Другими словами сенсор совместим как с 3,3 вольтовыми платами, например, Raspberry Pi, так и с 5 вольтовыми — Arduino Uno. ==== Troyka-контакты ==== Датчик подключается к управляющей электронике через две группы Troyka-контактов: * Питание (V) — соедините с рабочим напряжением микроконтроллера. * Земля (G) — соедините с землёй микроконтроллера. * Сигнальный (D) — пин данных шины I²C. Подключите к пину SDA микроконтроллера. * Сигнальный (C) — пин тактирования шины I²C. Подключите к пину SCL микроконтроллера. ===== Смена адреса модуля ===== Иногда в проекте необходимо использовать несколько магнитометров. Для этого на модуле предусмотрены контактная площадка. Для смена адреса капните каплей припоя на отведённую контактную площадку. ^ Модуль ^ Адрес без перемычки ^ Адрес с перемычкой ^ |Магнитометр | 0x1С | 0x1E | {{ :products:troyka-magnetometer-compass:troyka-magnetometer-compass-changes-address.gif?nolink |}} ===== Принципиальная и монтажная схемы ===== {{:products:troyka-magnetometer-compass:troyka-magnetometer-compass-schematic.png?direct&450 |}} {{ :products:troyka-magnetometer-compass:troyka-magnetometer-compass-layout-top.png?direct&220|}} {{ :products:troyka-magnetometer-compass:troyka-magnetometer-compass-layout-bottom.png?direct&220|}} ===== Габаритный чертёж ===== [[this>_media/products:troyka-magnetometer-compass:troyka-magnetometer-compass-dimensions.pdf|{{:products:troyka-magnetometer-compass:troyka-magnetometer-compass-dimensions.png}}]] ===== Характеристики ===== * MEMS-датчик: магнитометр LIS3MDL * Интерфейс: I²C * I²C-адрес: * без перемычки: 0x1C * с перемычкой: 0x1E * Максимальная чувствительность: 1,46×10-4 Гс * Диапазон измерений: ±4/ ±8/ ±12/ ±16 Гс * Напряжение питания: 3,3–5 В * Потребляемый ток: до 10 мА * Размеры: 25,4×25,4×10,1 мм ===== Ресурсы ===== * [[amp>product/troyka-magnetometer-compass?utm_source=man&utm_campaign=troyka-magnetometer-compass&utm_medium=wiki|Магнитометр]] в магазине * [[https://github.com/amperka/hardware-drawings/blob/master/troyka-magnetometer-compass.svg|Векторное изображение датчика]] * [[:articles:troyka-magnetometer-compass-calibrate|Калибровка компаса]] * [[https://github.com/amperka/Troyka-IMU|Библиотека для Arduino]] * {{ :products:troyka-magnetometer-compass:lis3mdl-datasheet.pdf |Datasheet на магнитометр ST LIS3MDL}}