Skip to main content

CrunchDAO example packages for machine learning competitions

Project description

CrunchDAO Crunch Example

This package provides example utilities and base classes for CrunchDAO machine learning competitions.

Installation

pip install crunchdao-crunch-example

Usage

Iris Classification

The crunchdao_crunch_example package provides base classes for iris classification models:

from crunchdao_crunch_example import IrisModelBase
import pandas as pd

class MyIrisModel(IrisModelBase):
    def train(self, train_data: pd.DataFrame) -> None:
        # Implement your training logic here
        # train_data contains features and target labels
        pass
    
    def infer(self, dataframe: pd.DataFrame) -> pd.DataFrame:
        # Implement your inference logic here
        # dataframe contains features to predict on
        predictions = [0, 1, 2]  # Your model predictions
        
        return pd.DataFrame({
            'prediction': predictions
        })

# Use your model
model = MyIrisModel()

# Training data with features and target
train_data = pd.DataFrame({
    'sepal_length': [5.1, 4.9, 4.7],
    'sepal_width': [3.5, 3.0, 3.2],
    'petal_length': [1.4, 1.4, 1.3],
    'petal_width': [0.2, 0.2, 0.2],
    'species': [0, 0, 0]  # 0=setosa, 1=versicolor, 2=virginica
})

model.train(train_data)

# Test data with just features
test_data = pd.DataFrame({
    'sepal_length': [6.1, 5.9],
    'sepal_width': [2.9, 3.0],
    'petal_length': [4.7, 4.2],
    'petal_width': [1.4, 1.5]
})

predictions = model.infer(test_data)
print(predictions)

Package Structure

The package provides a simple, direct structure:

  • model_base.py - IrisModelBase abstract class
  • models/ - Example model implementations
    • neural_network/ - Multi-layer perceptron with sklearn
    • random_forest/ - Ensemble tree-based classifier
    • svm/ - Support vector machine classifier
  • scripts/ - Utility scripts for training and model management

Model Examples

The package includes complete model implementations:

  • Neural Network (models/neural_network/) - Multi-layer perceptron with sklearn
  • Random Forest (models/random_forest/) - Ensemble tree-based classifier
  • SVM (models/svm/) - Support vector machine classifier

Each model includes:

  • Pre-trained model files in resources/
  • Implementation code in submissions/main.py
  • Dependencies in submissions/requirements.txt

Utility Scripts

The scripts/ directory contains:

  • pretrain_models.py - Train all models on iris dataset
  • pretrain_neural_network.py - Specific neural network training
  • sync_models.py - Sync models with storage systems
  • cleanup_docker.py - Docker environment cleanup

Development

Requirements

  • Python 3.11+
  • uv (for dependency management)

Setup

# Clone the repository
git clone https://github.com/crunchdao/coordinator-setup
cd coordinator-setup/examples/crunch_examples

# Install dependencies
uv sync

# Install in development mode
uv pip install -e .

Testing

uv run pytest

Building

# Build the package
uv build

# Upload to PyPI (requires authentication)
uv publish

License

MIT License - see LICENSE file for details.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

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

crunchdao_crunch_example-0.2.0.tar.gz (168.0 kB view details)

Uploaded Source

Built Distribution

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

crunchdao_crunch_example-0.2.0-py3-none-any.whl (177.0 kB view details)

Uploaded Python 3

File details

Details for the file crunchdao_crunch_example-0.2.0.tar.gz.

File metadata

File hashes

Hashes for crunchdao_crunch_example-0.2.0.tar.gz
Algorithm Hash digest
SHA256 f0af5dc028e7ccc7e1fb387da3df33d86731724de8ee85bae655bce552bb1c67
MD5 35bc01fc7b8bfd7fb561882bceaaf19c
BLAKE2b-256 de436d51411d01642c04c702e01dbb9ba499ee8a094a7a78888c47b5856f7697

See more details on using hashes here.

File details

Details for the file crunchdao_crunch_example-0.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for crunchdao_crunch_example-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e8814675b057725152165cd300f01572b8e5d7ae25d44299b787d38a849a1e02
MD5 65b5ad68a93ff2982b64e5567a4f246d
BLAKE2b-256 38764a5fe403082aa196f65c5b5137a63e4ad4264341c8b3e0d3150f30791051

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