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!
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.
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 => {
// ...
});
openhps-core.js
: UMDopenhps-core.es.js
: ES6 importworker.openhps-core.js
: UMD workeropenhps-core-lite.js
: UMD lite version for embedded systemsThe documentation for OpenHPS can be found online on the website.
The JOSS paper can be found here: /docs/paper/paper.md
.
Please check https://openhps.org/publications/ for more information.
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
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.
yarn install
npm run build
, this will also transpile Three.jsnpm 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
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.