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

@openhps/core

v1.0.5

Published

Open Hybrid Positioning System - Core component

Downloads

1,126

Readme

This repository contains the core component for OpenHPS (Open Source Hybrid Positioning System). It includes concepts for creating the model, nodes and data object definitions. The core component acts as the main repository for OpenHPS. However, additional modules expand OpenHPS with additional data storage techniques, positioning algorithms and enable the interoperability of the data produced by systems created with OpenHPS.

OpenHPS is a data processing positioning framework. It is designed to support many different use cases ranging from simple positioning such as detecting the position of a pawn on a chessboard using RFID, to indoor positioning methods using multiple cameras. Already have a hybrid mobile application that you wish to expand with a positioning system? No problem, OpenHPS integrates well into any hybrid mobile applications!

Features

  • 🌍 2D, 3D and Geographical positioning.
  • 📍 Relative positioning.
  • 🧮 Basic positioning algorithms (e.g. trilateration, triangulation, fingerprinting, dead reckoning...)
  • 🤖 Advanced positioning algorithms (e.g. computer vision through @openhps/opencv)
  • 🔧 Extremely extensible.
  • 🛠️ Open source.

Add-ons

Positioning Algorithms

  • @openhps/imu - Adds IMU processing nodes for fusing IMU sensors.
  • @openhps/rf - Adds RF processing nodes and data objects.
  • @openhps/fingerprinting - Adds various fingerprinting nodes and services for offline and offline positioning models.
  • @openhps/video - Provides general data objects and data frames for working with images, video data or cameras.
  • @openhps/opencv - Provides linkage with opencv4nodejs and OpenCV.js for computer vision algorithms on the server or browser.
  • @openhps/openvslam - Provides bindings to OpenVSLAM
  • @openhps/orb-slam3 - Provides bindings to ORB-SLAM3

Abstractions

  • @openhps/geospatial - Enables the concept of geospatial spaces (e.g. building, room) on top of reference spaces.

Data Services

Communication

  • @openhps/socket - Provides node communication through Socket.IO for remote models.
  • @openhps/rest - Provides node communication through restful endpoints.
  • @openhps/mqtt - MQTT client node communication and standalone MQTT server.

Smartphone

Misc

  • @openhps/sphero - Example implementation for controlling and receiving sensor data from Sphero toys.
  • @openhps/csv - Read and write data frames from/to CSV files.
  • @openhps/dht - Distributed hash tables for discovering positioning systems based on a rough geographical location.

Getting Started

If you have npm installed, start using @openhps/core with the following command.

npm install @openhps/core --save

The core idea and goals of OpenHPS are outlined in the technical paper: OpenHPS: An Open Source Hybrid Positioning System.

Usage

OpenHPS uses a process network to create a positioning system. This process network is created using the ModelBuilder. Every model starts with the creation of a new model that starts from a source node and passed via a set of processing nodes until it arrives to a sink node.

import { ModelBuilder } from '@openhps/core';

ModelBuilder.create()
    .from(/* ... */)
    .via(/* ... */)
    .to(/* ... */)
    .build().then(model => {
         // ...
    });

Browser

  • openhps-core.js: UMD
  • openhps-core.es.js: ES6 import
  • worker.openhps-core.js: UMD worker
  • openhps-core-lite.js: UMD lite version for embedded systems

Documentation

The documentation for OpenHPS can be found online on the website.

JOSS Paper

The JOSS paper can be found here: /docs/paper/paper.md.

Publications

Please check https://openhps.org/publications/ for more information.

Data Objects


classDiagram


class ActuatorProperty{
            +name: string
+callback: (...args: any[]) =~ Promise~any~
            
        }
class ActuatorObject{
            #properties: Map~string, ActuatorProperty~
            +invoke() Promise~any~
        }
DataObject<|--ActuatorObject
class DataObject{
            +displayName: string
+createdTimestamp: number
+uid: string
-_position: AbsolutePosition
-_relativePositions: Map~string, Map~string, RelativePosition~any, Unit~~~
+parentUID: string
            +getPosition() AbsolutePosition
+setPosition() this
+setUID() this
+setParent() this
+removeRelativePositions() void
+addRelativePosition() this
+getRelativePositions() RelativePosition~any, Unit~[]
+getRelativePosition() RelativePosition~any, Unit~
+hasRelativePosition() boolean
+bind() DataObjectBinding~this~
+clone() T
        }
class SensorCalibrationData~T~{
            +unit?: Unit
+offset?: T
+multiplier?: T
            
        }
class SensorObject~T~{
            +value: T
+frequency: number
+calibrationData?: SensorCalibrationData~T~
            
        }
DataObject<|--SensorObject~T~
class ReferenceSpace{
            -_translationMatrix: Matrix4
-_transformationMatrix: Matrix4
-_scaleMatrix: Matrix4
-_rotation: Quaternion
-_unit: LengthUnit
-_parent: TransformationSpace
            +fromDataObject() ReferenceSpace$
+update() Promise~void~
+orthographic() ReferenceSpace
+perspective() ReferenceSpace
+reset() ReferenceSpace
+referenceUnit() ReferenceSpace
+translation() ReferenceSpace
+scale() ReferenceSpace
+rotation() ReferenceSpace
+transform() Out
        }
DataObject<|--ReferenceSpace
TransformationSpace<|..ReferenceSpace
class TransformationSpace {
            <<interface>>
            +uid: string
+parent: TransformationSpace
            +update() Promise~void~
+transform() Out
        }
class SpaceTransformationOptions {
            <<interface>>
            +inverse?: boolean
            
        }
TransformationSpace  --  TransformationSpace

Contributing

Use of OpenHPS, contributions and feedback is highly appreciated. Please read our contributing guidelines for more information. If you want to contribute to the core of OpenHPS, you will want to build the repo.

  1. Using yarn, install the dependencies yarn install
  2. Build OpenHPS using npm run build, this will also transpile Three.js
  3. Run the tests using npm run test

Before submitting a PR, make sure to test the code using npm run test and to fix any linting issues using npm run lint -- --fix

License

Copyright (C) 2019-2025 Maxim Van de Wynckel & Vrije Universiteit Brussel

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

https://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.