GitXplorerGitXplorer
b

es51922

public
4 stars
0 forks
16 issues

Commits

List of commits on branch master.
Verified
949a3d9d5114994082538442c0dbebf9f6b74b0a

chore(release): 0.1.1

bboneskull committed 5 years ago
Verified
8b5da7656bc143681785fed40da668601378f036

fix(security): upgrades for npm audit

bboneskull committed 5 years ago
Verified
e6a0f294070fd677d33b322c14d1e0dc765e794b

chore(release): 0.1.0

bboneskull committed 6 years ago
Verified
4ed0837b64a4affe93343ef568f182ce96d38fe1

chore(kaitai): rename kaitai doc to use .yml ext

bboneskull committed 6 years ago
Verified
4823c256d41398e75cea17a73e5609db14846898

chore(pkg): upgrade deps, add some tests, and ready for first release

bboneskull committed 6 years ago
Verified
ea0011b884885586cf22e2e22ba0758adf3dc8b7

chore(pkg): sort package.json

bboneskull committed 6 years ago

README

The README file for this repository.

es51922

Streaming Cyrustek ES51922 DMM data protocol implementation over serial

The Cyrustek ES51922 is an IC found in several multimeters with "data-out" capability, including the UNI-T UT61E and Wintex TD2200 (source: sigrok.org).

The es51922 module provides both Observable (RxJS) and object-mode Readable Stream APIs.

Install

$ npm install es51922

Usage

Observable API

import {fromES51922} from 'es51922';

fromES51922('/dev/ttyUSB0').subscribe(data => {
  console.log(`${data.value} ${data.range.unit}`);
});

Example output:

3.269 V
3.209 V
3.268 V
3.268 V
3.267 V

Node.js Stream API

This is equivalent to the above:

import {readES51922Stream} from 'es51922';

readES51922Stream('/dev/ttyUSB0').on('data', data => {
  console.log(`${data.value} ${data.range.unit}`);
});

Data Format

TODO (describe shape of object)

Environment

Define the ES51922_PORT environment variable to avoid needing to pass it directly to the API. This module also accepts an .env file (for dotenv).

Development

src/es51922.ksy.yml contains a Kaitai Struct format description of the data protocol. The Kaitai Struct compiler generates the parser, which lives in vendor/es51922.js.

The reference Kaitai Struct compiler is implemented in Scala, so it would be a hassle to compile as part of a build step. The Kaitai Struct team publishes a pure-JS implementation to npm, but it has not kept pace with the Scala implementation; it fails to parse our format description file.

Until the JS implementation ready for use, you can install the Kaitai Struct compiler from kaitai.io, and execute npm run compile-posix (Windows users may need to tweak the run script). This (should) update vendor/es51922.js.

Notes

  • Temperature and ADP modes are unimplemented (and will likely remain so).
  • The Python ut61e package helped immensely w/ understanding the protocol.
  • This module won't work with Hoitek HE2325U or WCH CH9325 USB/HID adapter cables.
  • I'm using a FTDI FT232R-based RS232-to-USB converter. YMMV.
  • AFAIK there's no graphical viewer which supports this format available on macOS.
  • My ultimate goal is to use this module in a nice graphical interface with real-time interactive charts and shit.

See Also

Contributing

PR's welcome! Please use the Conventional Commits specification.

License

Copyright © 2019 Christopher Hiller. Licensed Apache-2.0