OpenHPS

OpenHPS: A Modular Framework to Facilitate the Development of FAIR Positioning Systems - Published in JOSS (2025)

https://github.com/openhps/openhps-core

Science Score: 93.0%

This score indicates how likely this project is to be science-related based on various indicators:

  • CITATION.cff file
  • codemeta.json file
    Found codemeta.json file
  • .zenodo.json file
    Found .zenodo.json file
  • DOI references
    Found 1 DOI reference(s) in JOSS metadata
  • Academic publication links
  • Committers with academic emails
  • Institutional organization owner
  • JOSS paper metadata
    Published in Journal of Open Source Software

Keywords from Contributors

mesh
Last synced: 6 months ago · JSON representation

Repository

OpenHPS: Core Component

Basic Info
  • Host: GitHub
  • Owner: OpenHPS
  • License: apache-2.0
  • Language: TypeScript
  • Default Branch: master
  • Homepage:
  • Size: 58.6 MB
Statistics
  • Stars: 29
  • Watchers: 1
  • Forks: 1
  • Open Issues: 11
  • Releases: 2
Created over 5 years ago · Last pushed 9 months ago
Metadata Files
Readme Contributing License Security

README.md

OpenHPS
@openhps/core

Build Status npm version TypeScript License: Apache 2.0 Email: info@openhps.org

Getting StartedExamplesAPI


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. bash 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.

```typescript import { ModelBuilder, DataObject, Absolute2DPosition, SMAFilterNode, ReferenceSpace, Euler, AngleUnit } from '@openhps/core'; import { MouseSourceNode } from './MouseSourceNode'; import { ChartSinkNode } from './ChartSinkNode';

const mouseReferenceSpace = new ReferenceSpace() .translation(0, 200) .rotation(new Euler(180, 0, 0, 'ZXY', AngleUnit.DEGREE));

ModelBuilder.create() // Step 1. Obtain X,Y location from mouse (active source node) .from(new MouseSourceNode("trackArea")) // Step 2. Flip the axis .convertFromSpace(mouseReferenceSpace) // Step 3. Simple moving average of the X,Y position (average of 40 readings) .via(new SMAFilterNode((obj: DataObject) => ([ { key: "x", value: (obj.position as Absolute2DPosition).x }, { key: "y", value: (obj.position as Absolute2DPosition).y } ]), (key: string, value: number, obj: DataObject) => { obj.position[key] = value }, { taps: 40 }) ) // Step 4. Plot the results .to(new ChartSinkNode("mouseChart")) .build().then(model => { // ... }); ``` See https://openhps.org/docs/tutorials/mouse/ for the implementation of the source and sink node

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

```mermaid

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 { <> +uid: string +parent: TransformationSpace +update() Promise~void~ +transform() Out } class SpaceTransformationOptions { <> +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.

Owner

  • Name: OpenHPS
  • Login: OpenHPS
  • Kind: organization
  • Email: info@openhps.org
  • Location: Brussels, BE

Open Source Hybrid Positioning System

JOSS Publication

OpenHPS: A Modular Framework to Facilitate the Development of FAIR Positioning Systems
Published
June 05, 2025
Volume 10, Issue 110, Page 8113
Authors
Maxim Van de Wynckel ORCID
Vrije Universiteit Brussel, Web & Information Systems Engineering Lab, Brussels, Belgium
Beat Signer ORCID
Vrije Universiteit Brussel, Web & Information Systems Engineering Lab, Brussels, Belgium
Editor
Daniel S. Katz ORCID
Tags
Hybrid positioning Interoperability FAIR Stream processing

GitHub Events

Total
  • Issues event: 7
  • Watch event: 6
  • Delete event: 11
  • Issue comment event: 33
  • Push event: 59
  • Pull request review comment event: 2
  • Pull request review event: 12
  • Pull request event: 19
  • Create event: 10
Last Year
  • Issues event: 7
  • Watch event: 6
  • Delete event: 11
  • Issue comment event: 33
  • Push event: 59
  • Pull request review comment event: 2
  • Pull request review event: 12
  • Pull request event: 19
  • Create event: 10

Committers

Last synced: 10 months ago

All Time
  • Total Commits: 1,502
  • Total Committers: 4
  • Avg Commits per committer: 375.5
  • Development Distribution Score (DDS): 0.244
Past Year
  • Commits: 56
  • Committers: 2
  • Avg Commits per committer: 28.0
  • Development Distribution Score (DDS): 0.375
Top Committers
Name Email Commits
Maxim Van de Wynckel m****l@v****e 1,135
CI ci@o****g 356
dependabot[bot] 4****] 9
Maxim Van de Wynckel M****l 2
Committer Domains (Top 20 + Academic)

Issues and Pull Requests

Last synced: 6 months ago

All Time
  • Total issues: 8
  • Total pull requests: 211
  • Average time to close issues: about 1 year
  • Average time to close pull requests: 10 days
  • Total issue authors: 3
  • Total pull request authors: 2
  • Average comments per issue: 1.38
  • Average comments per pull request: 1.76
  • Merged pull requests: 1
  • Bot issues: 0
  • Bot pull requests: 210
Past Year
  • Issues: 5
  • Pull requests: 21
  • Average time to close issues: 13 days
  • Average time to close pull requests: 21 days
  • Issue authors: 2
  • Pull request authors: 2
  • Average comments per issue: 1.0
  • Average comments per pull request: 1.57
  • Merged pull requests: 1
  • Bot issues: 0
  • Bot pull requests: 20
Top Authors
Issue Authors
  • floe (4)
  • Maximvdw (3)
  • parakhsid (1)
Pull Request Authors
  • dependabot[bot] (245)
  • danielskatz (1)
Top Labels
Issue Labels
enhancement (2) question (1) dependencies (1)
Pull Request Labels
dependencies (245) javascript (11)

Packages

  • Total packages: 1
  • Total downloads:
    • npm 2,018 last-month
  • Total dependent packages: 20
  • Total dependent repositories: 20
  • Total versions: 359
  • Total maintainers: 1
npmjs.org: @openhps/core

Open Hybrid Positioning System - Core component

  • Homepage: https://openhps.org
  • License: Apache-2.0
  • Latest release: 1.0.16
    published 9 months ago
  • Versions: 359
  • Dependent Packages: 20
  • Dependent Repositories: 20
  • Downloads: 2,018 Last month
Rankings
Dependent packages count: 1.2%
Dependent repos count: 2.7%
Downloads: 2.9%
Average: 5.3%
Stargazers count: 7.9%
Forks count: 11.6%
Maintainers (1)
Last synced: 6 months ago

Dependencies

.github/workflows/auto-merge.yml actions
  • actions/checkout v3 composite
  • ahmadnassri/action-dependabot-auto-merge v2 composite
.github/workflows/main.yml actions
  • EnricoMi/publish-unit-test-result-action v1 composite
  • JS-DevTools/npm-publish v1 composite
  • actions/cache v2 composite
  • actions/checkout v3 composite
  • actions/setup-node v3 composite
  • actions/upload-artifact v2 composite
  • codecov/codecov-action v2 composite
  • peaceiris/actions-gh-pages v3 composite
  • ts-graphviz/setup-graphviz v1 composite
package-lock.json npm
  • 940 dependencies
package.json npm
  • @babel/cli ^7.18.9 development
  • @babel/core ^7.18.9 development
  • @babel/preset-env ^7.18.9 development
  • @commitlint/cli ^17.0.3 development
  • @commitlint/config-conventional ^17.0.3 development
  • @size-limit/preset-small-lib ^7.0.8 development
  • @types/benchmark ^2.1.1 development
  • @types/chai ^4.3.1 development
  • @types/deasync ^0.1.2 development
  • @types/mocha ^9.1.1 development
  • @types/node ^18.6.2 development
  • @types/three ^0.143.0 development
  • @types/uuid ^8.3.4 development
  • @typescript-eslint/eslint-plugin ^5.31.0 development
  • @typescript-eslint/parser ^5.31.0 development
  • babel-plugin-replace-imports ^1.0.2 development
  • benchmark ^2.1.4 development
  • chai ^4.3.6 development
  • componentsjs-generator ^3.0.5 development
  • csv-parser ^3.0.0 development
  • eslint ^8.20.0 development
  • eslint-config-prettier ^8.5.0 development
  • eslint-plugin-deprecation ^1.3.2 development
  • eslint-plugin-import ^2.26.0 development
  • eslint-plugin-jsdoc ^39.3.3 development
  • eslint-plugin-prettier ^4.2.1 development
  • husky ^8.0.1 development
  • microtime ^3.1.0 development
  • mocha ^10.0.0 development
  • mocha-junit-reporter ^2.0.2 development
  • mocha-multi-reporters ^1.5.1 development
  • npm-run-all ^4.1.5 development
  • nyc ^15.1.0 development
  • prettier ^2.7.1 development
  • shx ^0.3.4 development
  • size-limit ^7.0.8 development
  • standard-version ^9.5.0 development
  • terser-webpack-plugin ^5.3.3 development
  • three ^0.143.0 development
  • ts-node ^10.9.1 development
  • typedoc ^0.23.9 development
  • typedoc-umlclass ^0.7.0 development
  • typescript ^4.7.4 development
  • webpack ^5.74.0 development
  • webpack-cli ^4.10.0 development
  • webpack-inject-plugin ^1.5.5 development
  • reflect-metadata >=0.1.13
  • threads ^1.7.0
  • typedjson ^1.8.0
  • uuid ^8.3.2