Skip to main content

No project description provided

Project description

Kubeflow Pipelines

Purpose

The purpose of this repository is a place to learn new things. From infrastructure to new LLM training techniques.

State

Data: Currently I have a functional transformer pipeline which learns common n-grams in human speech. This is due to the lack of data primarily.

Model: The transformer model is tested, and has been compared to other implementation. It's prediction time is sensible and small enough for my local hardware.

Future Work

Improved ML: Currently only supervised learning is employed, I expect the performance will plateau without reinforcement learning with human feedback (RLHF). This is to be added to the reddit pipeline.

Improved Logging: After training I'd like a set of input output pairs logged to MlFlow for increased transparency to output deficiencies.

Pipelines

  1. Reddit Iteratively learning to create engaging posts with reddit data.

Reddit

Baremetal Usage

  1. Run notebook notebooks/reddit_training.ipynb
    • Define hyperparameters that make sense for your system
  2. Metrics are recorded locally and can be observed with locally running mlflow or with the verbose=true options, test examples are printed to standard out

Kubeflow Usage

  1. Upload notebook notebooks/reddit_pipeline.ipynb
  2. Define environment variables
  3. Run cells defining training pipeline
  4. Run/Schedule pipeline

Pipeline Description

The pipeline is ran each day. In this process this is done:

  • New data is downloaded
  • The current best model is downloaded and evaluated
  • If the model has degraded or is not proficient, training is ran

Pipeline GUI

At the time of writing this I only have 500 samples in training set, so a test BLEU score of 0 is expected, though I hope in the coming days it will improve.

The pipeline records metrics in mlflow and records the hyperparameters/logs/outputs of each run.

Metrics GUI Hyperparameters GUI

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

ajperry_pipeline-0.1.23.tar.gz (13.4 kB view details)

Uploaded Source

Built Distribution

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

ajperry_pipeline-0.1.23-py3-none-any.whl (19.6 kB view details)

Uploaded Python 3

File details

Details for the file ajperry_pipeline-0.1.23.tar.gz.

File metadata

  • Download URL: ajperry_pipeline-0.1.23.tar.gz
  • Upload date:
  • Size: 13.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.4 CPython/3.10.18 Linux/6.11.0-1018-azure

File hashes

Hashes for ajperry_pipeline-0.1.23.tar.gz
Algorithm Hash digest
SHA256 03120a98c4c51e58df681eda088f43249e2d72375dde3b0c8b6915166f39a4e1
MD5 4d976d7feb081d90f5c0b1b0ff89d2ab
BLAKE2b-256 b4cecc7e195ad9db69ef64a1808212db60dac58032e85e2ff8242a14aa5feaf3

See more details on using hashes here.

File details

Details for the file ajperry_pipeline-0.1.23-py3-none-any.whl.

File metadata

  • Download URL: ajperry_pipeline-0.1.23-py3-none-any.whl
  • Upload date:
  • Size: 19.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.4 CPython/3.10.18 Linux/6.11.0-1018-azure

File hashes

Hashes for ajperry_pipeline-0.1.23-py3-none-any.whl
Algorithm Hash digest
SHA256 2ed1fa7f0675840b581fc2934736dde6637409869c8931e2e4774854d1369054
MD5 90fe7688bffcd620ef7ce0ca93505bb2
BLAKE2b-256 665f59cf61d5fb688d8a3521aeb08fbb6227ec12338ad3f10fc193acfa537fba

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