Skip to main content

Drop-in replacement for fisher-py without dotnet required

Project description

native-fisher-py

PyPI version Tests Documentation Status

Why native-fisher-py?

native-fisher-py is a self-contained alternative to the fisher-py reader. While fisher-py requires a local .NET runtime and pythonnet, this package bundles the necessary components using .NET NativeAOT and Rust to provide a consistent binary bridge.

Features

  • Drop-in Compatible: Designed to match the fisher_py.RawFile API for simplified migration.
  • Bundled .NET Components: No separate .NET runtime installation is required on the host system.
  • Cross-Platform: Pre-built binaries for macOS (ARM64/x64), Linux (x64), and Windows (x64).
  • Reliable Deployment: Easier integration into CI/CD pipelines and specialized Linux environments.

How it works

This project provides a native bridge to the official Thermo Fisher libraries using a three-layer approach:

  1. Official DLLs: Uses the original .dll assemblies provided by Thermo Fisher Scientific.
  2. C# NativeAOT Wrapper: A compiled transition layer (ThermoNativeReader) that interfaces with those DLLs.
  3. Rust PyO3 Layer: A Rust bridge (native-fisher-py) that provides the final Python bindings.

This approach ensures stability and parity with the official reader while providing a dependency-free experience for Python users.

Quick Start

# Just change the import, the rest of your code stays the same!
from native_fisher_py import RawFile

with RawFile("data.raw") as raw:
    print(f"Number of scans: {raw.number_of_scans}")
    
    # Get spectral data as high-speed NumPy arrays
    m, i, c, meta = raw.get_scan_from_scan_number(1)
    print(f"First peak at {m[0]} m/z with intensity {i[0]}")

Migrating from fisher-py

If you are currently using fisher-py, migration is as simple as:

  1. pip install native-fisher-py
  2. Update your imports:
- from fisher_py import RawFile
+ from native_fisher_py import RawFile
  1. (Optional) Uninstall fisher-py: pip uninstall fisher-py

All core methods (get_scan_from_scan_number, get_spectrum, get_chromatogram, get_ms2_scan_number_from_retention_time, etc.) are implemented with identical signatures and return types.

Quick Local Build

For convenience, you can run the included build.sh script to build both parts of the project:

./build.sh

Step-by-Step Manual Build

To build the project from source, you need .NET 8 SDK, Rust (cargo/maturin), and clang.

1. Build the C# NativeAOT Core

Navigate to the C# project and publish the NativeAOT shared library for your platform:

cd native/ThermoNativeReader

# Example for Apple Silicon (macOS arm64)
dotnet publish -r osx-arm64 -c Release -p:PublishAot=true

# Example for Linux (x64)
# dotnet publish -r linux-x64 -c Release -p:PublishAot=true

The output will be in publish/ThermoNativeReader.dylib (or .so / .dll).

2. Build the Rust Bridge

Navigate to the native_fisher_py folder and use maturin to build and install the Python package. You must point to the location of the C# library.

cd native_fisher_py

# Point to your build from Step 1
export THERMO_NATIVE_LIB=$(pwd)/../native/ThermoNativeReader/bin/Release/net8.0/osx-arm64/publish/ThermoNativeReader.dylib

maturin develop

Credits & Legal Notice

This project is powered by the Thermo Fisher Scientific RawFileReader (copyright © 2016-2026 Thermo Fisher Scientific, Inc.). All rights reserved.

The native-fisher-py package includes the official RawFileReader libraries, which remain the property of Thermo Fisher Scientific. By using this software, you agree to the terms specified in their license.

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

native_fisher_py-0.2.3-cp39-abi3-win_amd64.whl (4.9 MB view details)

Uploaded CPython 3.9+Windows x86-64

native_fisher_py-0.2.3-cp39-abi3-manylinux_2_34_x86_64.whl (5.4 MB view details)

Uploaded CPython 3.9+manylinux: glibc 2.34+ x86-64

native_fisher_py-0.2.3-cp39-abi3-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl (10.8 MB view details)

Uploaded CPython 3.9+macOS 10.12+ universal2 (ARM64, x86-64)macOS 10.12+ x86-64macOS 11.0+ ARM64

File details

Details for the file native_fisher_py-0.2.3-cp39-abi3-win_amd64.whl.

File metadata

File hashes

Hashes for native_fisher_py-0.2.3-cp39-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 5e13413b8d171f4133fe2f5c345254a55af17fa74f2ab6edd9065c4404252f24
MD5 df3bf51f2bb301f99c50347565d9ee86
BLAKE2b-256 19bc412215018cd287b8216323ecd4e3f1e81a8a61edbf891f60a6021960af4b

See more details on using hashes here.

Provenance

The following attestation bundles were made for native_fisher_py-0.2.3-cp39-abi3-win_amd64.whl:

Publisher: release.yml on z3rone-org/native-fisher-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file native_fisher_py-0.2.3-cp39-abi3-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for native_fisher_py-0.2.3-cp39-abi3-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 1505cfeba2c4f22d9b9952a0716749d6df917e6ef6441578b6c2dd6eb7a88d2c
MD5 386498476a6f9db72979e36b4bbd2a09
BLAKE2b-256 55fb7ca9c6e1e19d8fcd1db7c4e1297fac1a10aaaa2570bccf85c93998abdad5

See more details on using hashes here.

Provenance

The following attestation bundles were made for native_fisher_py-0.2.3-cp39-abi3-manylinux_2_34_x86_64.whl:

Publisher: release.yml on z3rone-org/native-fisher-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file native_fisher_py-0.2.3-cp39-abi3-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl.

File metadata

File hashes

Hashes for native_fisher_py-0.2.3-cp39-abi3-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl
Algorithm Hash digest
SHA256 c9007e47dcbcddec46159233f8ac11aac1417468707f00cb9a5754b4265fb38e
MD5 da7531321943f64175ceaf7d3e98ec7d
BLAKE2b-256 126f6632b2bbf5157ce36434260827a2f54a23209408cc9416f57aa0ae55aaa3

See more details on using hashes here.

Provenance

The following attestation bundles were made for native_fisher_py-0.2.3-cp39-abi3-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl:

Publisher: release.yml on z3rone-org/native-fisher-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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