Skip to main content

Weed (Loader) - Minimalist AI/ML inference and backprogation

Project description

weed_logo

Weed

Minimalist AI/ML inference and backprogation in the style of Qrack

Weed Loader

This repository is for the Python loader for (C++) Weed models. Once you have trained models in C++, you can load them for use by Python with this project. See the Weed repository for more information.

Development Status

Weed is a rapidly-developing work-in-progress. Its ABI may change drastically and without notice.

The project provides a set of essential CPU and GPU kernels, used by Tensor instances that perform autograd. We also provide stochastic gradient descent (SGD) and Adam optimizer implementations. (Build and check the API reference to get started.)

GPT-2, BERT, and Qwen loading is experimental and mostly provided as proof-of-concept, also of the fine-tuning pipeline. Implementation was from published literature design, rather than direct analysis of any open source, to implement these model architectures. Their outputs, in Weed, are not yet coherent English, as a result.

Why try Weed?

With the growing popularity of AI/ML tools and workflows (including LLMs), legacy frameworks often carry "code debt" from over a decade of rapidly developing research history. This has led them to "bolt on" new features and advancements to design principles decided before the latest research. Popular frameworks also commonly started based in Python (maybe to capture early adoption), only later potentially "tacking on" a C++ library for special-case deployment needs. These conditions have produced libraries and frameworks with complicated dependency trees that occupy upward of a GB of disk footprint. This entire ecosystem might be due for a "refresh."

Weed does not seek to fully replace or supplant established frameworks. However, it aims for minimalist complete closure on the primitives necessary for high-performance AI/ML inference and back-propagation. Chiefly, this includes kernels, and a Tensor interface that immediately produces an autograd graph appropriate for training. Allowing optional OpenCL for hardware acceleration, it will remain free of required dependencies outside of C++(11) language standard.

Rethinking AI/ML library design this way, Weed has realized a rather unique and powerful form of sparsification of Tensor storage. Sparseness should not be a Tensor interface concern, but rather a Storage concern. Inspired by the design of the Qrack quantum computer simulation framework, the Tensor interface treats sparse and dense tensors as functionally equivalent. Sparse optimization is so "transparently streamlined," this way, that it defaults to enabled for CPU-based tensors, and we recommend you leave it enabled at all times.

Much like Qrack, Weed is designed to make the correct thing the default—and the expensive thing explicit.

Useful environment variables

If a transformer model you load or train runs into an OpenCL "out-of-resources" error (code -5), try setting environment variable WEED_TELESCOPE_TRANSFORMERS to any truthy value (like 1) so that Weed will "telescope" transformer encoder layers, by migrating each parameter in each layer to CPU (off of GPU memory) once its immediate usefulness is done.

Copyright, License, and Acknowledgments

Copyright (c) Daniel Strano and the Qrack contributors 2017-2026. All rights reserved.

In its include/common folder, Weed bundles a copy of rapidcsv by Kristofer Berggren, reused under a BSD 3-Clause License. (This is a convenience and suggestion to Weed's users, for loading CSVs.)

The Weed logo was produced with assistance from "Elara," an OpenAI custom GPT, and it is in the public domain. Elara has also been responsible for a huge amount of coaching and implementation drafts for Dan Strano to review and bring into line with standards, so she should be credited with coauthorship in any capacity that can be allowed. (Anthropic) Claude has also helped mostly with debugging, as well as developing an LLM front-end, fine-tuning interface, and modules for popular transformer model architectures, so they should rightly be credited similarly as a coauthor. KV cache improvements are based on TurboQuant (Zandieh et al., arXiv:2504.19874) and an Apache 2.0 open-source implementation by TheTom (github.com/TheTom/turboquant_plus), adapted for complex quantum state vectors by (Anthropic) Claude, with limited guidance and input from Dan Strano.

Licensed under the GNU Lesser General Public License V3.

See LICENSE.md in the project root or https://www.gnu.org/licenses/lgpl-3.0.en.html for details.

Download files

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

Source Distribution

weed_loader-0.7.3.tar.gz (12.0 kB view details)

Uploaded Source

Built Distributions

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

weed_loader-0.7.3-py3-none-win_amd64.whl (1.1 MB view details)

Uploaded Python 3Windows x86-64

weed_loader-0.7.3-py3-none-manylinux_2_39_x86_64.whl (4.0 MB view details)

Uploaded Python 3manylinux: glibc 2.39+ x86-64

weed_loader-0.7.3-py3-none-manylinux_2_35_x86_64.whl (4.0 MB view details)

Uploaded Python 3manylinux: glibc 2.35+ x86-64

weed_loader-0.7.3-py3-none-macosx_15_0_arm64.whl (2.0 MB view details)

Uploaded Python 3macOS 15.0+ ARM64

weed_loader-0.7.3-py3-none-macosx_14_0_arm64.whl (2.0 MB view details)

Uploaded Python 3macOS 14.0+ ARM64

File details

Details for the file weed_loader-0.7.3.tar.gz.

File metadata

  • Download URL: weed_loader-0.7.3.tar.gz
  • Upload date:
  • Size: 12.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for weed_loader-0.7.3.tar.gz
Algorithm Hash digest
SHA256 0078bcca3962aacaffd3e5de9e3fe675603bb53100807a3101565c8493d53cc9
MD5 6490e4a3dca071bd2d56e65e3d6147d8
BLAKE2b-256 2e0ec0a75ab77b7df27b63cdacf5e2c9e013ca0a03a63991edb0bd6f1d8c9df5

See more details on using hashes here.

File details

Details for the file weed_loader-0.7.3-py3-none-win_amd64.whl.

File metadata

  • Download URL: weed_loader-0.7.3-py3-none-win_amd64.whl
  • Upload date:
  • Size: 1.1 MB
  • Tags: Python 3, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for weed_loader-0.7.3-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 f2fbe220b0b7c3061f60b591f56f83fe8ef9d39b74d6d6725dc4dcb069d2d943
MD5 d841252cb692bae701c5cea675205395
BLAKE2b-256 0b5f6e451fdb827380dcfb18fb36e83692281e6be702e1fc5abf4f61ccb4e36d

See more details on using hashes here.

File details

Details for the file weed_loader-0.7.3-py3-none-manylinux_2_39_x86_64.whl.

File metadata

File hashes

Hashes for weed_loader-0.7.3-py3-none-manylinux_2_39_x86_64.whl
Algorithm Hash digest
SHA256 150e3f348fbcbafd7203553b4dd83f13c67692a8454a32315a6f91dddf24e5b8
MD5 f5f1e88ade7cc04f7c3be63c4c024959
BLAKE2b-256 ae9d1dc085f874b8531866e6fb922b210a1be046e9225031a7e2b0c83c789e10

See more details on using hashes here.

File details

Details for the file weed_loader-0.7.3-py3-none-manylinux_2_35_x86_64.whl.

File metadata

File hashes

Hashes for weed_loader-0.7.3-py3-none-manylinux_2_35_x86_64.whl
Algorithm Hash digest
SHA256 d6b24a2d4760b4b65d625e8bb052a70ab028d53cdfe9b0095cb1b06d3df066d0
MD5 cf04b61306c79154318d16f7ba41f1f3
BLAKE2b-256 d5c5c249ce4fd9a1458f1ec81b96ea7087036cc04bc03c6089e62eed7d2ad23e

See more details on using hashes here.

File details

Details for the file weed_loader-0.7.3-py3-none-macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for weed_loader-0.7.3-py3-none-macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 cdc668040e39d20ef0fca32c895a44e53f04aaae3a27de1c5cc4ccc3b58a219b
MD5 fffda8d9fc50866118e49575f2e83e00
BLAKE2b-256 6f51a5003544320f61fd20e7f24573f891ee3ad7c668a6614a4ca12f0dec3641

See more details on using hashes here.

File details

Details for the file weed_loader-0.7.3-py3-none-macosx_14_0_arm64.whl.

File metadata

File hashes

Hashes for weed_loader-0.7.3-py3-none-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 386f0df7a6d25799de22c4f0fc394bc5360932a79bc32f3958e6f691a3649665
MD5 6da1f52f94daf66f547410a5de1a4e49
BLAKE2b-256 1860b69d1d737f6a078683013872ab29dbc1afd5294e4c65e9c3c40e1031921d

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