Qwiic Micro Magnetometer - MMC5983MA Hookup Guide

Pages
Contributors: Ell C
Favorited Favorite 2

Introduction

The SparkFun Qwiic Micro MMC5983MA Magnetometer is a micro-sized, 0.75in. by 0.30in. sensor that utilizes the highly sensitive triple-axis magnetometer by MEMSIC. We've attached the magnetometer IC onto an incredibly small Qwiic board form factor that we like to call Qwiic Micro! The MMC5983MA is capable of sensing down to 0.4mG, enabling a heading accuracy of ±0.5°. The Qwiic MMC5983MA IMU communicates over I2C by default utilizing our handy Qwiic Connect System, so no soldering is required to connect it to the rest of your boards.

Saturation is a problem for all mag sensors. The MMC5983MA has built-in degaussing circuitry to clear any residual magnetization. Output rates of 1000Hz, ±8G FSR, and 18-bit resolution make the MMC5983MA a phenomenal magnetic sensor for electronic compass applications.

SparkFun Micro Magnetometer - MMC5983MA (Qwiic)

SparkFun Micro Magnetometer - MMC5983MA (Qwiic)

SEN-19921
$15.95
4

Required Materials

To follow along with this tutorial, you will need the following materials. You may not need everything though depending on what you have. Add it to your cart, read through the guide, and adjust the cart as necessary.

Suggested Reading

If you aren’t familiar with the following concepts, we recommend checking out these tutorials before continuing.

Logic Levels

Learn the difference between 3.3V and 5V devices and logic levels.

Accelerometer Basics

A quick introduction to accelerometers, how they work, and why they're used.

I2C

An introduction to I2C, one of the main embedded communications protocols in use today.

Serial Terminal Basics

This tutorial will show you how to communicate with your serial devices using a variety of terminal emulator applications.

Hardware Overview

The beautiful thing about this Qwiic board is that it is extremely simple. Let's dive in and have a look at its features!

MMC5983MA

The MMC5983MA is an AEC-Q100 qualified, fully integrated 3-axis magnetic sensor with on-chip signal processing and integrated I2C/SPI bus. It has superior dynamic range and accuracy with ±8G FSR, 18bit operation, 0.4mG total RMS noise, and can enable heading accuracy of 0.5º. More information can be found in the datasheet.

Magnetometer is located in the center of the board

Qwiic Connector

Our Qwiic Ecosystem makes sensors pretty much plug and play. There's a Qwiic connector on the side of the Qwiic Micro Magnetometer to provide power and I2C connectivity simultaneously. The default I2C address is 0x30.

Qwiic connector is located at the bottom of the board

Pins

We've broken out the interrupt and ground pins to PTH on either side of the board. The interrupt pin is active high - writing “1” will enable the interrupt for completed measurements. Once a measurement is finished, either magnetic field or temperature, an interrupt will be sent to the host.

INT and GND pins are on either side of the mounting hole at the top of the board

Jumpers

I2C

Like our other Qwiic boards, the Qwiic Micro Magnetometer comes equipped with pull-up resistors on the clock and data pins. If you are daisy-chaining multiple Qwiic devices, you will want to cut this jumper; if multiple sensors are connected to the bus with the pull-up resistors enabled, the parallel equivalent resistance will create too strong of a pull-up for the bus to operate correctly. As a general rule of thumb, disable all but one pair of pull-up resistors if multiple devices are connected to the bus. To disable the pull up resistors, use an X-acto knife to cut the joint between the two jumper pads highlighted here.

I2C Jumper is in the center bottom of the back of the board

LED

If power consumption is an issue, cutting this jumper will disable the Power LED on the front of the board.

LED Jumper is in the left bottom of the back of the board

Board Outline

This ultra tiny Qwiic breakout board measures 0.75" x 0.30".

This ultra tiny Qwiic breakout board measures 0.75" x 0.30".

Hardware Hookup

Grab your Qwiic cable and plug one end into the RedBoard Qwiic and the other end into the Qwiic Micro Magnetometer. Voila!

This image shows stuff plugged in

Software Setup and Programming

Note: Make sure you are using the latest stable version of the Arduino IDE on your desktop.

If this is your first time using Arduino, please review our tutorial on installing the Arduino IDE. If you have not previously installed an Arduino library, please check out our installation guide.

We've written a simple Arduino library to quickly get started reading data from the Qwiic Micro Magnetometer. Install the library through the Arduino Library Manager tool by searching for "SparkFun MMC5983MA". Users who prefer to manually install it can get the library from the GitHub Repository or download the ZIP by clicking the button below:


Example 1: I2C Simple Measurement

Now that we've got our library installed and our hardware all hooked up, let's look at some examples.

This first example just does some basic measurements. To find Example 1, go to File -> Examples -> SparkFun MMC5983MA Magnetometer Arduino Library -> Example1-I2C_Simple_measurement.

Image shows menu pulldown as described above

Having a hard time seeing the image? Click the image for a closer look.

Make sure you have the correct board and port selected. For this tutorial, your selections should look something like this:

Select the SparkFun RedBoard and the correct COM port

Having a hard time seeing the image? Click the image for a closer look.

Once you're ready to go, go ahead and hit the upload button (the right facing arrow button under the "Edit" menu item). Once your code is uploaded, open the Serial Monitor and you'll see X, Y, and Z values start printing out.

Serial Monitor Output

Having a hard time seeing the image? Click the image for a closer look.

Example 2: I2C Digital Compass

Example 2 shows how to compute the heading based on the basic X/Y/Z readings from the sensor over Qwiic. To find this example, go to File -> Examples -> SparkFun MMC5983MA Magnetometer Arduino Library -> Example2-I2C_Digital_compass.

Image shows menu pulldown as described above

Having a hard time seeing the image? Click the image for a closer look.

Make sure you have the correct board and port selected. For this tutorial, your selections should look something like this:

Select the SparkFun RedBoard and the correct COM port

Having a hard time seeing the image? Click the image for a closer look.

Once you're ready to go, go ahead and hit the upload button (the right facing arrow button under the "Edit" menu item). Once your code is uploaded, open the Serial Monitor and you'll see compass readings start printing out.

Serial Monitor Output

Having a hard time seeing the image? Click the image for a closer look.

If you look at the above image, you'll see where I abruptly changed the direction the sensor was pointing.

Example 3: I2C Continuous Measurement

Example 3 demonstrates how to use interrupts to quickly read the sensor instead of polling. To find this example, go to File -> Examples -> SparkFun MMC5983MA Magnetometer Arduino Library -> Example3-I2C_Continuous_measurement.

Image shows menu pulldown as described above

Having a hard time seeing the image? Click the image for a closer look.

Make sure you have the correct board and port selected. For this tutorial, your selections should look something like this:

Select the SparkFun RedBoard and the correct COM port

Having a hard time seeing the image? Click the image for a closer look.

Once you're ready to go, go ahead and hit the upload button (the right facing arrow button under the "Edit" menu item). Once your code is uploaded, open the Serial Monitor and you'll see compass readings start printing out.

Serial Monitor Output

Having a hard time seeing the image? Click the image for a closer look.

Examples 4 and 5

Troubleshooting

Resources and Going Further

Now that you've successfully got your Qwiic Micro Magnetometer up and running, it's time to incorporate it into your own project!

For more information, check out the resources below:

Need some inspiration for your next project? Check out some of these related tutorials:

APDS-9301 Sensor Hookup Guide

The APDS-9301 sensor is an I2C connected luminosity sensor which returns measurements in lux.

Getting Started with the Artemis Development Kit

This guide covers the general design of the board, the installation of the recommended software used to program the Artemis DK, and some basic examples. For more advanced functionalities, we have separate software development guides for the AmbiqSDK, Arm® Mbed™ OS, and the Arduino IDE platforms that users can reference.

SparkFun GPS-RTK Dead Reckoning ZED-F9K Hookup Guide

The u-blox ZED-F9K is a powerful GPS-RTK unit that uses a fusion of IMU, wheel ticks, a vehicle dynamics model, correction data, and GNSS measurements to provide highly accurate and continuous position for navigation in the difficult conditions. We will quickly get you set up using the Qwiic ecosystem through Arduino so that you can start reading the output!

SparkFun Temperature Sensor - STTS22H (Qwiic) Hookup Guide

Get started with the ultralow-power, high-accuracy, qwiic-enabled SparkFun Temperature Sensor - STTS22H!