npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

nodejs-qmc5883l

v2.0.0

Published

A NodeJS driver for the QMC5883L magnetometer

Downloads

28

Readme

NodeJS-QMC5883L

!!! Compatible with NodeJS versions 10.X - 12.X !!!

1. Table of contents

  • Overview & Installation
  • Usage
  • Hardware Compatibility
  • Libraries Used
  • License
  • TODO

2. Overview & Installation

This is a simple NodeJS module that talks to the DA5883 magnetometer (on the QMC5883L board). You can install it by running npm install --save nodejs-qmc5883l. Every magnetometer reading is a bit mistaken (caused e.g. by soft and hard iron effect), but that can be corrected by calibrating the compass. Calibration gives you an offset matrix and a scale matrix that needs to be applied on raw magnetometer data before any further computation. To do this, run node calibrate in the module's main directory, rotate the magnetometer in all directions until the script finishes running and the matrixes will be printed in the console, and then call setOffsetMatrix and setScaleMatrix on the module object. After doing so, you can read the compensated data via the readCorrectedData() function (if you use the readAzimuth function, then the azimuth is computed on the already compensated data).

3. Usage

The module is very simple - it provides three methods:

Before you start Simply require the module library and assign it to a variable:

var compass = require("nodejs-qmc5883l");

1. initialize()

  • always returns true (in the future will return false if the compass cannot be initialized)
  • is obligatory to be called before any data is read
  • sets the compass mode to continuous, output data rate to 200Hz, the RNG to 8 Gauss and over-sampling ratio to 256

2. readRawData()

  • returns a javascript Object of format { x: value, y: value, z: value } with raw magnetometer data (without scale & offset matrixes)
  • if the initialize() function had not been called earlier, the x, y & z value are 0

3. readCorrectedData()

  • returns a javascript Object of format { x: value, y: value, z: value } with compensated magnetometer data (with scale & offset matrixes applied)
  • if the initialize() function had not been called earlier, the x, y & z value are 0

4. setOffsetMatrix(offsetX, offsetY, offsetZ)

  • sets the offset matrix used by the readCorrectedData()

5. setScaleMatrix(scaleX, scaleY, scaleZ)

  • sets the scale matrix used by the readCorrectedData()

6. readAzimuth()

  • returns an azimuth value (calculated using the atan2 function) in degrees
  • it takes the readCorrectedData() function for data input
  • if the initialize() function had not been called earlier, returns 0

7. setDeclinationAngle(declinationAngle)

  • takes a single declinationAngle parameter of any number type
  • sets the declination angle that is added to the azimuth when calling readAzimuth() to correct the magnetic field differences
  • you can calculate the angle using the following formula: declinationAngle = (degrees + (minutes / 60.0)) / (180 / PI) (see test.js)

4. Example

A functional example is located in the test.js file in the module's main directory (you can also run it by executing npm run test in it).

5. Hardware Compatibility

The module works on the Raspberry PI 3 (tested) on NodeJS 8, but You can clone the repo and change the proper fields (I2C bus device path, I2C device address, I2C device register, etc.) in the binding.cc & other files, so that it is compatible with Your device.

6. Libraries Used

The module utilises Jeff Rowberg's I2Cdev library for talking to I2C devices and uses modified parts of code from MechaQMC5883 library, which contains all needed register addresses. The calibration code is based on the one used in this HMC5883 library.

7. License

This project is licensed under the GNU General Public License v3. You're allowed to clone the code, modify it and use provided that You mention the author (artus9033) and provide a link to this repository.

8. TODO

  1. Add a function to the binding to set the RNG, OSR, ODR & Mode parameters
  2. Make the initialize() function return false if connection didn't succeed