Skip to main content

NTSC encoder implemented as a pybind11 extension

Project description

ntsc-encoder (pybind11)

This directory builds the ntsc_encoder Python extension module using C++/pybind11.

Requirements

  • Python 3.9+
  • A C++ compiler + CMake 3.18+
  • No OpenCV dependency is required to build/install this wheel. The input is a NumPy HxWx3 uint8 array (e.g. produced by cv2.imread() + cv2.cvtColor).
  • Build tools:
    • python -m pip install -U build twine

Build a wheel/sdist locally

From this directory (Code/Encoder):

python -m pip install -U pip
python -m pip install -U build twine scikit-build-core pybind11 numpy
python -m build

Artifacts will appear in dist/.

Check metadata:

twine check dist/*

Upload to PyPI

Recommended: upload to TestPyPI first.

# TestPyPI
python -m twine upload -r testpypi dist/*

# PyPI
python -m twine upload dist/*

You’ll need an API token configured in ~/.pypirc or exported via environment variables.

Building wheels for multiple platforms (recommended)

To avoid requiring end users to have a compiler + OpenCV dev libs, publish prebuilt wheels. Typical approach: GitHub Actions + cibuildwheel.

High-level steps:

  1. Add cibuildwheel workflow
  2. Build wheels for Linux (manylinux), macOS, Windows
  3. Upload wheels + sdist with twine

If you want, I can add a ready-to-use GitHub Actions workflow for cibuildwheel.

Troubleshooting

If pip install ntsc-encoder succeeds but import ntsc_encoder fails, it usually means the wheel did not contain the compiled extension (or it was installed into the wrong location). For scikit-build-core, ensure CMakeLists.txt has install(TARGETS ntsc_encoder ... DESTINATION ${SKBUILD_PLATLIB_DIR}).

Project details


Download files

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

Source Distribution

ntsc_encoder-0.1.8.tar.gz (107.4 kB view details)

Uploaded Source

Built Distribution

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

ntsc_encoder-0.1.8-cp314-cp314-macosx_26_0_arm64.whl (81.6 kB view details)

Uploaded CPython 3.14macOS 26.0+ ARM64

File details

Details for the file ntsc_encoder-0.1.8.tar.gz.

File metadata

  • Download URL: ntsc_encoder-0.1.8.tar.gz
  • Upload date:
  • Size: 107.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for ntsc_encoder-0.1.8.tar.gz
Algorithm Hash digest
SHA256 92c18c5ccd798b38717ab3a7a5d0d0d74551f3fb0b59b4bc524b8412b0358e7b
MD5 b78fb8b2c35ebe107f69dfdda10ffa0d
BLAKE2b-256 4447974ee43d6040440c78caf4bd98c6edbd4184d7bde905434f3b8d6b0d79fb

See more details on using hashes here.

File details

Details for the file ntsc_encoder-0.1.8-cp314-cp314-macosx_26_0_arm64.whl.

File metadata

File hashes

Hashes for ntsc_encoder-0.1.8-cp314-cp314-macosx_26_0_arm64.whl
Algorithm Hash digest
SHA256 da982cd9ff869bf799fa7c69fd3d7e6aa99226454b746371e95bb2a6be40217d
MD5 479f8a7b4490f962d0038e174fb8cf4e
BLAKE2b-256 4f8aa45e753eab5b83c8f98b0ca064c62bca42c0a0dabbd190d83a239f4b9d0e

See more details on using hashes here.

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