Skip to main content

ASAM MDF measurement data file parser

Project description

asammdf is a fast parser and editor for ASAM (Association for Standardization of Automation and Measuring Systems) MDF (Measurement Data Format) files.

asammdf supports MDF versions 2 (.dat), 3 (.mdf) and 4 (.mf4).

asammdf works on Python >= 3.8

Status

Continuous Integration Coveralls Codacy ReadTheDocs
continuous integration Coverage Status Codacy Badge Documentation Status
PyPI conda-forge
PyPI version conda-forge version

Project goals

The main goals for this library are:

  • to be faster than the other Python based mdf libraries
  • to have clean and easy to understand code base
  • to have minimal 3-rd party dependencies

Features

  • create new mdf files from scratch

  • append new channels

  • read unsorted MDF v3 and v4 files

  • read CAN and LIN bus logging files

  • extract CAN and LIN signals from anonymous bus logging measurements

  • filter a subset of channels from original mdf file

  • cut measurement to specified time interval

  • convert to different mdf version

  • export to HDF5, Matlab (v7.3), CSV and parquet

  • merge multiple files sharing the same internal structure

  • read and save mdf version 4.10 files containing zipped data blocks

  • space optimizations for saved files (no duplicated blocks)

  • split large data blocks (configurable size) for mdf version 4

  • full support (read, append, save) for the following map types (multidimensional array channels):

    • mdf version 3 channels with CDBLOCK

    • mdf version 4 structure channel composition

    • mdf version 4 channel arrays with CNTemplate storage and one of the array types:

      • 0 - array
      • 1 - scaling axis
      • 2 - look-up
  • add and extract attachments for mdf version 4

  • handle large files (for example merging two fileas, each with 14000 channels and 5GB size, on a RaspberryPi)

  • extract channel data, master channel and extra channel information as Signal objects for unified operations with v3 and v4 files

  • time domain operation using the Signal class

    • Pandas data frames are good if all the channels have the same time based
    • a measurement will usually have channels from different sources at different rates
    • the Signal class facilitates operations with such channels
  • graphical interface to visualize channels and perform operations with the files

Major features not implemented (yet)

  • for version 3

    • functionality related to sample reduction block: the samples reduction blocks are simply ignored
  • for version 4

    • experimental support for MDF v4.20 column oriented storage
    • functionality related to sample reduction block: the samples reduction blocks are simply ignored
    • handling of channel hierarchy: channel hierarchy is ignored
    • full handling of bus logging measurements: currently only CAN and LIN bus logging are implemented with the ability to get signals defined in the attached CAN/LIN database (.arxml or .dbc). Signals can also be extracted from an anonymous bus logging measurement by providing a CAN or LIN database (.dbc or .arxml)
    • handling of unfinished measurements (mdf 4): finalization is attempted when the file is loaded, however the not all the finalization steps are supported
    • full support for remaining mdf 4 channel arrays types
    • xml schema for MDBLOCK: most metadata stored in the comment blocks will not be available
    • full handling of event blocks: events are transferred to the new files (in case of calling methods that return new MDF objects) but no new events can be created
    • channels with default X axis: the default X axis is ignored and the channel group's master channel is used
    • attachment encryption/decryption using user provided encryption/decryption functions; this is not part of the MDF v4 spec and is only supported by this library

Usage

from asammdf import MDF

mdf = MDF('sample.mdf')
speed = mdf.get('WheelSpeed')
speed.plot()

important_signals = ['WheelSpeed', 'VehicleSpeed', 'VehicleAcceleration']
# get short measurement with a subset of channels from 10s to 12s
short = mdf.filter(important_signals).cut(start=10, stop=12)

# convert to version 4.10 and save to disk
short.convert('4.10').save('important signals.mf4')

# plot some channels from a huge file
efficient = MDF('huge.mf4')
for signal in efficient.select(['Sensor1', 'Voltage3']):
   signal.plot()

Check the examples folder for extended usage demo, or the documentation http://asammdf.readthedocs.io/en/master/examples.html

https://canlogger.csselectronics.com/canedge-getting-started/ce3/log-file-tools/asammdf-gui/

Documentation

http://asammdf.readthedocs.io/en/master

And a nicely written tutorial on the CSS Electronics site

Contributing & Support

Please have a look over the contributing guidelines

If you enjoy this library please consider making a donation to the numpy project or to danielhrisca using liberapay <a href="https://liberapay.com/danielhrisca/donate"><img alt="Donate using Liberapay" src="https://liberapay.com/assets/widgets/donate.svg"></a>

Contributors

Thanks to all who contributed with commits to asammdf:

Installation

asammdf is available on

pip install asammdf
# for the GUI 
pip install asammdf[gui]
# or for anaconda
conda install -c conda-forge asammdf

In case a wheel is not present for you OS/Python versions and you lack the proper compiler setup to compile the c-extension code, then you can simply copy-paste the package code to your site-packages. In this way the python fallback code will be used instead of the compiled c-extension code.

Dependencies

asammdf uses the following libraries

  • numpy : the heart that makes all tick
  • numexpr : for algebraic and rational channel conversions
  • wheel : for installation in virtual environments
  • pandas : for DataFrame export
  • canmatrix : to handle CAN/LIN bus logging measurements
  • natsort
  • lxml : for canmatrix arxml support
  • lz4 : to speed up the disk IO performance
  • python-dateutil : measurement start time handling

optional dependencies needed for exports

  • h5py : for HDF5 export
  • hdf5storage : for Matlab v7.3 .mat export
  • fastparquet : for parquet export
  • scipy: for Matlab v4 and v5 .mat export

other optional dependencies

  • PySide6 : for GUI tool
  • pyqtgraph : for GUI tool and Signal plotting
  • matplotlib : as fallback for Signal plotting
  • faust-cchardet : to detect non-standard Unicode encodings
  • chardet : to detect non-standard Unicode encodings
  • pyqtlet2 : for the GPS window
  • isal : for faster zlib compression/decompression
  • fsspec : access files stored in the cloud

Benchmarks

http://asammdf.readthedocs.io/en/master/benchmarks.html

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

asammdf-8.0.0.tar.gz (805.0 kB view details)

Uploaded Source

Built Distributions

asammdf-8.0.0-cp312-cp312-win_amd64.whl (891.3 kB view details)

Uploaded CPython 3.12 Windows x86-64

asammdf-8.0.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl (920.8 kB view details)

Uploaded CPython 3.12 manylinux: glibc 2.17+ x86-64 manylinux: glibc 2.28+ x86-64

asammdf-8.0.0-cp312-cp312-macosx_11_0_arm64.whl (888.2 kB view details)

Uploaded CPython 3.12 macOS 11.0+ ARM64

asammdf-8.0.0-cp311-cp311-win_amd64.whl (891.3 kB view details)

Uploaded CPython 3.11 Windows x86-64

asammdf-8.0.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl (920.3 kB view details)

Uploaded CPython 3.11 manylinux: glibc 2.17+ x86-64 manylinux: glibc 2.28+ x86-64

asammdf-8.0.0-cp311-cp311-macosx_11_0_arm64.whl (888.1 kB view details)

Uploaded CPython 3.11 macOS 11.0+ ARM64

asammdf-8.0.0-cp310-cp310-win_amd64.whl (891.3 kB view details)

Uploaded CPython 3.10 Windows x86-64

asammdf-8.0.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl (920.2 kB view details)

Uploaded CPython 3.10 manylinux: glibc 2.17+ x86-64 manylinux: glibc 2.28+ x86-64

asammdf-8.0.0-cp310-cp310-macosx_11_0_arm64.whl (888.1 kB view details)

Uploaded CPython 3.10 macOS 11.0+ ARM64

asammdf-8.0.0-cp39-cp39-win_amd64.whl (891.3 kB view details)

Uploaded CPython 3.9 Windows x86-64

asammdf-8.0.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl (920.2 kB view details)

Uploaded CPython 3.9 manylinux: glibc 2.17+ x86-64 manylinux: glibc 2.28+ x86-64

asammdf-8.0.0-cp39-cp39-macosx_11_0_arm64.whl (888.1 kB view details)

Uploaded CPython 3.9 macOS 11.0+ ARM64

File details

Details for the file asammdf-8.0.0.tar.gz.

File metadata

  • Download URL: asammdf-8.0.0.tar.gz
  • Upload date:
  • Size: 805.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.5

File hashes

Hashes for asammdf-8.0.0.tar.gz
Algorithm Hash digest
SHA256 bf2850c934a37a7c7b2f790bc1cd5dc3244e5a2cdcec9b38c674b76257c47a15
MD5 0dde575a35e155277c1017fba71d0670
BLAKE2b-256 49bf7b45ed80e558e33119c07ae9b34ebf6a151b2e3d3604f27bfd7197425670

See more details on using hashes here.

File details

Details for the file asammdf-8.0.0-cp312-cp312-win_amd64.whl.

File metadata

  • Download URL: asammdf-8.0.0-cp312-cp312-win_amd64.whl
  • Upload date:
  • Size: 891.3 kB
  • Tags: CPython 3.12, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.5

File hashes

Hashes for asammdf-8.0.0-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 619ac4567451fd9e4a1369e7400b3120a892eb33df1c3cc187ebeeec07c3f26f
MD5 6cf3c8e9690719e3eee708d79861fb80
BLAKE2b-256 b41b3ec05cb240726d1587ef4fd8eaced017b771fdb6e4307fa42ca142ab50fe

See more details on using hashes here.

File details

Details for the file asammdf-8.0.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for asammdf-8.0.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 1b0e2fde9a0897e198095621decce2736cc2787c704e083f1d53a312ede16b14
MD5 0ac4fe92311bfd114aa6e1d2141446ce
BLAKE2b-256 e10f36bfb2fefaa836316535b6dbc7eddeecb29c99a7598ebf117d26a2e02db8

See more details on using hashes here.

File details

Details for the file asammdf-8.0.0-cp312-cp312-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for asammdf-8.0.0-cp312-cp312-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 c590c6665af1d7261e45e0dfc17b8e24948ccd00c894ffdc8a563752e4979351
MD5 3958ff5fbccca404c72942bbd6c2cb15
BLAKE2b-256 cb57db8a6b6c777cb15b2497b2baab8f2e2a25e79dab2f55f4b67619bbcf54b7

See more details on using hashes here.

File details

Details for the file asammdf-8.0.0-cp311-cp311-win_amd64.whl.

File metadata

  • Download URL: asammdf-8.0.0-cp311-cp311-win_amd64.whl
  • Upload date:
  • Size: 891.3 kB
  • Tags: CPython 3.11, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.5

File hashes

Hashes for asammdf-8.0.0-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 c89236733195f160a8d65171909f63e311de1799b001a8274308d5699e704ce5
MD5 250cfb99f71b7a59ddc5a06ea6bb0120
BLAKE2b-256 9185c3da84add00fdfd9de85d775285587d6b7326f596ff06426cdbc3990017e

See more details on using hashes here.

File details

Details for the file asammdf-8.0.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for asammdf-8.0.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 23795b83978f148a5659bf9c002011fdbb5d8607e5c0d4521c52cf094f11b6cb
MD5 e94626b99ed8cc46462a222627dd4dc6
BLAKE2b-256 4c2bbd436f68effa2f8992b160bc4b214514ff27d35ddfde531d9a86a40f92c1

See more details on using hashes here.

File details

Details for the file asammdf-8.0.0-cp311-cp311-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for asammdf-8.0.0-cp311-cp311-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 a577c175600c462a59217f365b1d82dd74a6ab7e69ccdbf49a2819b89f37524a
MD5 ac17cdaf2080be7796d71a2e7d5a1cff
BLAKE2b-256 c92fbf6b205ded6c830f128484e0bdfb8b4e6c0c0b05f73752924ab33e612a01

See more details on using hashes here.

File details

Details for the file asammdf-8.0.0-cp310-cp310-win_amd64.whl.

File metadata

  • Download URL: asammdf-8.0.0-cp310-cp310-win_amd64.whl
  • Upload date:
  • Size: 891.3 kB
  • Tags: CPython 3.10, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.5

File hashes

Hashes for asammdf-8.0.0-cp310-cp310-win_amd64.whl
Algorithm Hash digest
SHA256 86b1cda4b0f8a77cc1bdbbb6dec53aeb8dbad87bc577bbb8da219f170dd9605c
MD5 c19506a5722c0c2e4e88af3d008637c2
BLAKE2b-256 6bb714dbff56e6324d6566a108370a94223620394763d76eeb0eb6766916d181

See more details on using hashes here.

File details

Details for the file asammdf-8.0.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for asammdf-8.0.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 20517d37773b54a904dd25d3a8a04ed3430aa8299c29f3235214ba02c254954b
MD5 2bd261210a6611479c7e6a45a55e5aac
BLAKE2b-256 e1591d391e27b0233dde9710b69a25033b1a101e226e24a710cef8de6008177c

See more details on using hashes here.

File details

Details for the file asammdf-8.0.0-cp310-cp310-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for asammdf-8.0.0-cp310-cp310-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 b2079f8e35fda809fc11f93c11eca55f2e50b0572937b0f31c5059829b4de780
MD5 a0cf8b9e8bf2e241351d0ed612afe7a8
BLAKE2b-256 a4892ffd56234cd47e606474347a43e81ae2324baba1ee9e86e6fe7294c144cb

See more details on using hashes here.

File details

Details for the file asammdf-8.0.0-cp39-cp39-win_amd64.whl.

File metadata

  • Download URL: asammdf-8.0.0-cp39-cp39-win_amd64.whl
  • Upload date:
  • Size: 891.3 kB
  • Tags: CPython 3.9, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.5

File hashes

Hashes for asammdf-8.0.0-cp39-cp39-win_amd64.whl
Algorithm Hash digest
SHA256 bef64914e87b381898c0dde0dd8851e39485dc40e680b16a3358fb5a9ba3dc6b
MD5 bdad2bee29be0211eaa32b345b2a0a18
BLAKE2b-256 3b0fdb78167931d03033c707ca35d58ae2cad5fb0977858d1cbaada0adc4f0e8

See more details on using hashes here.

File details

Details for the file asammdf-8.0.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for asammdf-8.0.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 ccdb75b32a081e4f77a9bd4862242d28e64031038d22ccdefac4696c95eb2dc6
MD5 d044d73610080a1424a917a4fb074699
BLAKE2b-256 756386671ab03dd7e4d548e91a8620069e9ed9d969ac1ac4cb0eb8ae2b5b7e71

See more details on using hashes here.

File details

Details for the file asammdf-8.0.0-cp39-cp39-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for asammdf-8.0.0-cp39-cp39-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 2844dbf828d4f2a0af131cebf499b6738ebc17d9918095569a010bd4ba72970c
MD5 9a16d7a1ee3150e84da48ec0ef3b399e
BLAKE2b-256 d279756576da02fb87ac48d5cf040039c724953237aa99b96dfbf07e79138cdf

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page