Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Allow custom drivers and pin types #315

Open
jdawang opened this issue Oct 4, 2024 · 1 comment
Open

Allow custom drivers and pin types #315

jdawang opened this issue Oct 4, 2024 · 1 comment

Comments

@jdawang
Copy link

jdawang commented Oct 4, 2024

I'm looking at using pins to version various model assets, but one of the pain points I'm running into is custom drivers for reading and writing. Many of our model artifacts are serialized to YAML or ONNX or a custom serialization, but there's no driver for those. There's friction too if we wanted, say a polars driver to read a csv or parquet directly into polars.

This leaves pin_upload and pin_download, which while workable, doesn't provide the same level of integration as pin_read and pin_write. If you use a user-defined helper with pin_download to read a custom type, then users have to know in advance to use that helper, versus just board.pin_read(name) for officially supported types.

For example, to show the difference in experience between a csv file and yaml:

import pandas as pd
import yaml
from pins import board_temp

board = board_temp()
data = pd.DataFrame({"a": [1,2,3]})
board.pin_write(data, "pandas_data", type="csv")

with open("data.yml", "w") as f:
    yaml.dump({"a": [1,2,3]}, f)

board.pin_upload("data.yml", name="yaml_data")

# Reading

pandas_data_read = board.pin_read("pandas_data")

yaml_path = board.pin_download("yaml_data")[0]
with open(yaml_path) as f:
    yaml_data_read = yaml.safe_load(f)

# Using helper

def pin_read_yaml(board, *args, **kwargs):
    yaml_path = board.pin_download(*args, **kwargs)[0]
    with open(yaml_path) as f:
        return yaml.safe_load(f)

yaml_helper_read = pin_read_yaml(board, "yaml_data")  # need to know in advance to use yaml, not just pin_read(name)

Optimally, I want to be able to specify custom types that are associated with custom drivers. The custom type would be written to data.txt, which would allow for dispatching to the associated driver on pin_read like is done for officially supported types, without needing to know in advance to use a user-defined helper.

I'm also seeing similarities between this problem and "dynamic artifact handling" in another library we work on (lazyscribe/lazyscribe#56), where we used handler classes and entrypoints to allow users to define custom artifact serializers/deserializers.

Anyway, please let me know if I'm missing anything here and what you think!

@isabelizimm
Copy link
Collaborator

Hello there 👋 Thank you for this feedback--I'm glad you were able to make pin_upload/pin_download work for your use case! At this point in time, there are not plans to allow for a custom pin type for base reading and writing, as there is pin_upload/pin_download in place as an escape hatch for this purpose. That being said, I'll leave this issue open in case others in the community have input.

I am going to break out supporting yaml as a built in type as a separate issue, since I think that is a super reasonable driver to have for reading and writing!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants