Metadata-Version: 2.1
Name: feastmo
Version: 0.36.0.0
Summary: Python SDK for Feast
Home-page: https://github.com/feast-dev/feast
Author: Feast
License: Apache
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.7
Requires-Python: >=3.8.0
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: click <9.0.0,>=7.0.0
Requires-Dist: colorama <1,>=0.3.9
Requires-Dist: dill ~=0.3.0
Requires-Dist: mypy-protobuf ==3.1
Requires-Dist: Jinja2 <4,>=2
Requires-Dist: jsonschema
Requires-Dist: mmh3
Requires-Dist: numpy <1.25,>=1.22
Requires-Dist: pandas <3,>=1.4.3
Requires-Dist: protobuf <4.23.4,>3.20
Requires-Dist: proto-plus <2,>=1.20.0
Requires-Dist: pyarrow >=4
Requires-Dist: pydantic >=2.0.0
Requires-Dist: pygments <3,>=2.12.0
Requires-Dist: PyYAML <7,>=5.4.0
Requires-Dist: requests
Requires-Dist: SQLAlchemy[mypy] <2,>1
Requires-Dist: tabulate <1,>=0.8.0
Requires-Dist: tenacity <9,>=7
Requires-Dist: toml <1,>=0.10.0
Requires-Dist: tqdm <5,>=4
Requires-Dist: typeguard >=4.0.0
Requires-Dist: fastapi >=0.68.0
Requires-Dist: uvicorn[standard] <1,>=0.14.0
Requires-Dist: gunicorn
Requires-Dist: dask >=2021.1.0
Requires-Dist: bowler
Requires-Dist: httpx >=0.23.3
Requires-Dist: importlib-resources <7,>=6.0.0
Requires-Dist: importlib-metadata <7,>=6.8.0
Provides-Extra: aws
Requires-Dist: boto3 <2,>=1.17.0 ; extra == 'aws'
Requires-Dist: docker >=5.0.2 ; extra == 'aws'
Requires-Dist: fsspec <=2024.1.0 ; extra == 'aws'
Provides-Extra: azure
Requires-Dist: azure-storage-blob >=0.37.0 ; extra == 'azure'
Requires-Dist: azure-identity >=1.6.1 ; extra == 'azure'
Requires-Dist: SQLAlchemy >=1.4.19 ; extra == 'azure'
Requires-Dist: pyodbc >=4.0.30 ; extra == 'azure'
Requires-Dist: pymssql ; extra == 'azure'
Provides-Extra: bytewax
Requires-Dist: bytewax ==0.15.1 ; extra == 'bytewax'
Requires-Dist: docker >=5.0.2 ; extra == 'bytewax'
Requires-Dist: kubernetes <=20.13.0 ; extra == 'bytewax'
Provides-Extra: cassandra
Requires-Dist: cassandra-driver <4,>=3.24.0 ; extra == 'cassandra'
Provides-Extra: ci
Requires-Dist: build ; extra == 'ci'
Requires-Dist: virtualenv ==20.23.0 ; extra == 'ci'
Requires-Dist: cryptography <43,>=35.0 ; extra == 'ci'
Requires-Dist: flake8 <6.1.0,>=6.0.0 ; extra == 'ci'
Requires-Dist: black <23,>=22.6.0 ; extra == 'ci'
Requires-Dist: isort <6,>=5 ; extra == 'ci'
Requires-Dist: grpcio-testing <2,>=1.56.2 ; extra == 'ci'
Requires-Dist: minio ==7.1.0 ; extra == 'ci'
Requires-Dist: mock ==2.0.0 ; extra == 'ci'
Requires-Dist: moto <5 ; extra == 'ci'
Requires-Dist: mypy >=1.4.1 ; extra == 'ci'
Requires-Dist: avro ==1.10.0 ; extra == 'ci'
Requires-Dist: urllib3 <3,>=1.25.4 ; extra == 'ci'
Requires-Dist: psutil ==5.9.0 ; extra == 'ci'
Requires-Dist: py >=1.11.0 ; extra == 'ci'
Requires-Dist: pytest <8,>=6.0.0 ; extra == 'ci'
Requires-Dist: pytest-cov ; extra == 'ci'
Requires-Dist: pytest-xdist ; extra == 'ci'
Requires-Dist: pytest-benchmark <4,>=3.4.1 ; extra == 'ci'
Requires-Dist: pytest-lazy-fixture ==0.6.3 ; extra == 'ci'
Requires-Dist: pytest-timeout ==1.4.2 ; extra == 'ci'
Requires-Dist: pytest-ordering ~=0.6.0 ; extra == 'ci'
Requires-Dist: pytest-mock ==1.10.4 ; extra == 'ci'
Requires-Dist: Sphinx <7,>4.0.0 ; extra == 'ci'
Requires-Dist: testcontainers <4,>=3.5 ; extra == 'ci'
Requires-Dist: firebase-admin <6,>=5.2.0 ; extra == 'ci'
Requires-Dist: pre-commit <3.3.2 ; extra == 'ci'
Requires-Dist: assertpy ==1.1 ; extra == 'ci'
Requires-Dist: pip-tools ; extra == 'ci'
Requires-Dist: pybindgen ; extra == 'ci'
Requires-Dist: types-protobuf ~=3.19.22 ; extra == 'ci'
Requires-Dist: types-python-dateutil ; extra == 'ci'
Requires-Dist: types-pytz ; extra == 'ci'
Requires-Dist: types-PyYAML ; extra == 'ci'
Requires-Dist: types-redis ; extra == 'ci'
Requires-Dist: types-requests <2.31.0 ; extra == 'ci'
Requires-Dist: types-setuptools ; extra == 'ci'
Requires-Dist: types-tabulate ; extra == 'ci'
Requires-Dist: virtualenv <20.24.2 ; extra == 'ci'
Requires-Dist: google-api-core <3,>=1.23.0 ; extra == 'ci'
Requires-Dist: googleapis-common-protos <2,>=1.52.0 ; extra == 'ci'
Requires-Dist: google-cloud-bigquery[pandas] <3.13.0,>=2 ; extra == 'ci'
Requires-Dist: google-cloud-bigquery-storage <3,>=2.0.0 ; extra == 'ci'
Requires-Dist: google-cloud-datastore <3,>=2.1.0 ; extra == 'ci'
Requires-Dist: google-cloud-storage <3,>=1.34.0 ; extra == 'ci'
Requires-Dist: google-cloud-bigtable <3,>=2.11.0 ; extra == 'ci'
Requires-Dist: fsspec <=2024.1.0 ; extra == 'ci'
Requires-Dist: redis <5,>=4.2.2 ; extra == 'ci'
Requires-Dist: hiredis <3,>=2.0.0 ; extra == 'ci'
Requires-Dist: boto3 <2,>=1.17.0 ; extra == 'ci'
Requires-Dist: docker >=5.0.2 ; extra == 'ci'
Requires-Dist: bytewax ==0.15.1 ; extra == 'ci'
Requires-Dist: kubernetes <=20.13.0 ; extra == 'ci'
Requires-Dist: snowflake-connector-python[pandas] <4,>=3 ; extra == 'ci'
Requires-Dist: pyspark <4,>=3.0.0 ; extra == 'ci'
Requires-Dist: psycopg2-binary <3,>=2.8.3 ; extra == 'ci'
Requires-Dist: pymysql ; extra == 'ci'
Requires-Dist: types-PyMySQL ; extra == 'ci'
Requires-Dist: trino <0.400.0,>=0.305.0 ; extra == 'ci'
Requires-Dist: regex ; extra == 'ci'
Requires-Dist: great-expectations >=0.15.41 ; extra == 'ci'
Requires-Dist: happybase <3,>=1.2.0 ; extra == 'ci'
Requires-Dist: cassandra-driver <4,>=3.24.0 ; extra == 'ci'
Requires-Dist: azure-storage-blob >=0.37.0 ; extra == 'ci'
Requires-Dist: azure-identity >=1.6.1 ; extra == 'ci'
Requires-Dist: SQLAlchemy >=1.4.19 ; extra == 'ci'
Requires-Dist: pyodbc >=4.0.30 ; extra == 'ci'
Requires-Dist: pymssql ; extra == 'ci'
Requires-Dist: rockset >=1.0.3 ; extra == 'ci'
Requires-Dist: hazelcast-python-client >=5.1 ; extra == 'ci'
Requires-Dist: ibis-framework ; extra == 'ci'
Requires-Dist: ibis-substrait ; extra == 'ci'
Requires-Dist: grpcio <2,>=1.56.2 ; extra == 'ci'
Requires-Dist: grpcio-tools <2,>=1.56.2 ; extra == 'ci'
Requires-Dist: grpcio-reflection <2,>=1.56.2 ; extra == 'ci'
Requires-Dist: grpcio-health-checking <2,>=1.56.2 ; extra == 'ci'
Requires-Dist: pandas <2,>=1.4.3 ; (python_version < "3.9") and extra == 'ci'
Provides-Extra: dev
Requires-Dist: mypy-protobuf ==3.1 ; extra == 'dev'
Requires-Dist: grpcio-testing ~=1.0 ; extra == 'dev'
Requires-Dist: build ; extra == 'dev'
Requires-Dist: virtualenv ==20.23.0 ; extra == 'dev'
Requires-Dist: cryptography <43,>=35.0 ; extra == 'dev'
Requires-Dist: flake8 <6.1.0,>=6.0.0 ; extra == 'dev'
Requires-Dist: black <23,>=22.6.0 ; extra == 'dev'
Requires-Dist: isort <6,>=5 ; extra == 'dev'
Requires-Dist: grpcio-testing <2,>=1.56.2 ; extra == 'dev'
Requires-Dist: minio ==7.1.0 ; extra == 'dev'
Requires-Dist: mock ==2.0.0 ; extra == 'dev'
Requires-Dist: moto <5 ; extra == 'dev'
Requires-Dist: mypy >=1.4.1 ; extra == 'dev'
Requires-Dist: avro ==1.10.0 ; extra == 'dev'
Requires-Dist: urllib3 <3,>=1.25.4 ; extra == 'dev'
Requires-Dist: psutil ==5.9.0 ; extra == 'dev'
Requires-Dist: py >=1.11.0 ; extra == 'dev'
Requires-Dist: pytest <8,>=6.0.0 ; extra == 'dev'
Requires-Dist: pytest-cov ; extra == 'dev'
Requires-Dist: pytest-xdist ; extra == 'dev'
Requires-Dist: pytest-benchmark <4,>=3.4.1 ; extra == 'dev'
Requires-Dist: pytest-lazy-fixture ==0.6.3 ; extra == 'dev'
Requires-Dist: pytest-timeout ==1.4.2 ; extra == 'dev'
Requires-Dist: pytest-ordering ~=0.6.0 ; extra == 'dev'
Requires-Dist: pytest-mock ==1.10.4 ; extra == 'dev'
Requires-Dist: Sphinx <7,>4.0.0 ; extra == 'dev'
Requires-Dist: testcontainers <4,>=3.5 ; extra == 'dev'
Requires-Dist: firebase-admin <6,>=5.2.0 ; extra == 'dev'
Requires-Dist: pre-commit <3.3.2 ; extra == 'dev'
Requires-Dist: assertpy ==1.1 ; extra == 'dev'
Requires-Dist: pip-tools ; extra == 'dev'
Requires-Dist: pybindgen ; extra == 'dev'
Requires-Dist: types-protobuf ~=3.19.22 ; extra == 'dev'
Requires-Dist: types-python-dateutil ; extra == 'dev'
Requires-Dist: types-pytz ; extra == 'dev'
Requires-Dist: types-PyYAML ; extra == 'dev'
Requires-Dist: types-redis ; extra == 'dev'
Requires-Dist: types-requests <2.31.0 ; extra == 'dev'
Requires-Dist: types-setuptools ; extra == 'dev'
Requires-Dist: types-tabulate ; extra == 'dev'
Requires-Dist: virtualenv <20.24.2 ; extra == 'dev'
Requires-Dist: google-api-core <3,>=1.23.0 ; extra == 'dev'
Requires-Dist: googleapis-common-protos <2,>=1.52.0 ; extra == 'dev'
Requires-Dist: google-cloud-bigquery[pandas] <3.13.0,>=2 ; extra == 'dev'
Requires-Dist: google-cloud-bigquery-storage <3,>=2.0.0 ; extra == 'dev'
Requires-Dist: google-cloud-datastore <3,>=2.1.0 ; extra == 'dev'
Requires-Dist: google-cloud-storage <3,>=1.34.0 ; extra == 'dev'
Requires-Dist: google-cloud-bigtable <3,>=2.11.0 ; extra == 'dev'
Requires-Dist: fsspec <=2024.1.0 ; extra == 'dev'
Requires-Dist: redis <5,>=4.2.2 ; extra == 'dev'
Requires-Dist: hiredis <3,>=2.0.0 ; extra == 'dev'
Requires-Dist: boto3 <2,>=1.17.0 ; extra == 'dev'
Requires-Dist: docker >=5.0.2 ; extra == 'dev'
Requires-Dist: bytewax ==0.15.1 ; extra == 'dev'
Requires-Dist: kubernetes <=20.13.0 ; extra == 'dev'
Requires-Dist: snowflake-connector-python[pandas] <4,>=3 ; extra == 'dev'
Requires-Dist: pyspark <4,>=3.0.0 ; extra == 'dev'
Requires-Dist: psycopg2-binary <3,>=2.8.3 ; extra == 'dev'
Requires-Dist: pymysql ; extra == 'dev'
Requires-Dist: types-PyMySQL ; extra == 'dev'
Requires-Dist: trino <0.400.0,>=0.305.0 ; extra == 'dev'
Requires-Dist: regex ; extra == 'dev'
Requires-Dist: great-expectations >=0.15.41 ; extra == 'dev'
Requires-Dist: happybase <3,>=1.2.0 ; extra == 'dev'
Requires-Dist: cassandra-driver <4,>=3.24.0 ; extra == 'dev'
Requires-Dist: azure-storage-blob >=0.37.0 ; extra == 'dev'
Requires-Dist: azure-identity >=1.6.1 ; extra == 'dev'
Requires-Dist: SQLAlchemy >=1.4.19 ; extra == 'dev'
Requires-Dist: pyodbc >=4.0.30 ; extra == 'dev'
Requires-Dist: pymssql ; extra == 'dev'
Requires-Dist: rockset >=1.0.3 ; extra == 'dev'
Requires-Dist: hazelcast-python-client >=5.1 ; extra == 'dev'
Requires-Dist: ibis-framework ; extra == 'dev'
Requires-Dist: ibis-substrait ; extra == 'dev'
Requires-Dist: grpcio <2,>=1.56.2 ; extra == 'dev'
Requires-Dist: grpcio-tools <2,>=1.56.2 ; extra == 'dev'
Requires-Dist: grpcio-reflection <2,>=1.56.2 ; extra == 'dev'
Requires-Dist: grpcio-health-checking <2,>=1.56.2 ; extra == 'dev'
Requires-Dist: pandas <2,>=1.4.3 ; (python_version < "3.9") and extra == 'dev'
Provides-Extra: docs
Requires-Dist: build ; extra == 'docs'
Requires-Dist: virtualenv ==20.23.0 ; extra == 'docs'
Requires-Dist: cryptography <43,>=35.0 ; extra == 'docs'
Requires-Dist: flake8 <6.1.0,>=6.0.0 ; extra == 'docs'
Requires-Dist: black <23,>=22.6.0 ; extra == 'docs'
Requires-Dist: isort <6,>=5 ; extra == 'docs'
Requires-Dist: grpcio-testing <2,>=1.56.2 ; extra == 'docs'
Requires-Dist: minio ==7.1.0 ; extra == 'docs'
Requires-Dist: mock ==2.0.0 ; extra == 'docs'
Requires-Dist: moto <5 ; extra == 'docs'
Requires-Dist: mypy >=1.4.1 ; extra == 'docs'
Requires-Dist: avro ==1.10.0 ; extra == 'docs'
Requires-Dist: urllib3 <3,>=1.25.4 ; extra == 'docs'
Requires-Dist: psutil ==5.9.0 ; extra == 'docs'
Requires-Dist: py >=1.11.0 ; extra == 'docs'
Requires-Dist: pytest <8,>=6.0.0 ; extra == 'docs'
Requires-Dist: pytest-cov ; extra == 'docs'
Requires-Dist: pytest-xdist ; extra == 'docs'
Requires-Dist: pytest-benchmark <4,>=3.4.1 ; extra == 'docs'
Requires-Dist: pytest-lazy-fixture ==0.6.3 ; extra == 'docs'
Requires-Dist: pytest-timeout ==1.4.2 ; extra == 'docs'
Requires-Dist: pytest-ordering ~=0.6.0 ; extra == 'docs'
Requires-Dist: pytest-mock ==1.10.4 ; extra == 'docs'
Requires-Dist: Sphinx <7,>4.0.0 ; extra == 'docs'
Requires-Dist: testcontainers <4,>=3.5 ; extra == 'docs'
Requires-Dist: firebase-admin <6,>=5.2.0 ; extra == 'docs'
Requires-Dist: pre-commit <3.3.2 ; extra == 'docs'
Requires-Dist: assertpy ==1.1 ; extra == 'docs'
Requires-Dist: pip-tools ; extra == 'docs'
Requires-Dist: pybindgen ; extra == 'docs'
Requires-Dist: types-protobuf ~=3.19.22 ; extra == 'docs'
Requires-Dist: types-python-dateutil ; extra == 'docs'
Requires-Dist: types-pytz ; extra == 'docs'
Requires-Dist: types-PyYAML ; extra == 'docs'
Requires-Dist: types-redis ; extra == 'docs'
Requires-Dist: types-requests <2.31.0 ; extra == 'docs'
Requires-Dist: types-setuptools ; extra == 'docs'
Requires-Dist: types-tabulate ; extra == 'docs'
Requires-Dist: virtualenv <20.24.2 ; extra == 'docs'
Requires-Dist: google-api-core <3,>=1.23.0 ; extra == 'docs'
Requires-Dist: googleapis-common-protos <2,>=1.52.0 ; extra == 'docs'
Requires-Dist: google-cloud-bigquery[pandas] <3.13.0,>=2 ; extra == 'docs'
Requires-Dist: google-cloud-bigquery-storage <3,>=2.0.0 ; extra == 'docs'
Requires-Dist: google-cloud-datastore <3,>=2.1.0 ; extra == 'docs'
Requires-Dist: google-cloud-storage <3,>=1.34.0 ; extra == 'docs'
Requires-Dist: google-cloud-bigtable <3,>=2.11.0 ; extra == 'docs'
Requires-Dist: fsspec <=2024.1.0 ; extra == 'docs'
Requires-Dist: redis <5,>=4.2.2 ; extra == 'docs'
Requires-Dist: hiredis <3,>=2.0.0 ; extra == 'docs'
Requires-Dist: boto3 <2,>=1.17.0 ; extra == 'docs'
Requires-Dist: docker >=5.0.2 ; extra == 'docs'
Requires-Dist: bytewax ==0.15.1 ; extra == 'docs'
Requires-Dist: kubernetes <=20.13.0 ; extra == 'docs'
Requires-Dist: snowflake-connector-python[pandas] <4,>=3 ; extra == 'docs'
Requires-Dist: pyspark <4,>=3.0.0 ; extra == 'docs'
Requires-Dist: psycopg2-binary <3,>=2.8.3 ; extra == 'docs'
Requires-Dist: trino <0.400.0,>=0.305.0 ; extra == 'docs'
Requires-Dist: regex ; extra == 'docs'
Requires-Dist: great-expectations >=0.15.41 ; extra == 'docs'
Requires-Dist: happybase <3,>=1.2.0 ; extra == 'docs'
Requires-Dist: cassandra-driver <4,>=3.24.0 ; extra == 'docs'
Requires-Dist: azure-storage-blob >=0.37.0 ; extra == 'docs'
Requires-Dist: azure-identity >=1.6.1 ; extra == 'docs'
Requires-Dist: SQLAlchemy >=1.4.19 ; extra == 'docs'
Requires-Dist: pyodbc >=4.0.30 ; extra == 'docs'
Requires-Dist: pymssql ; extra == 'docs'
Requires-Dist: rockset >=1.0.3 ; extra == 'docs'
Requires-Dist: hazelcast-python-client >=5.1 ; extra == 'docs'
Requires-Dist: ibis-framework ; extra == 'docs'
Requires-Dist: ibis-substrait ; extra == 'docs'
Requires-Dist: grpcio <2,>=1.56.2 ; extra == 'docs'
Requires-Dist: grpcio-tools <2,>=1.56.2 ; extra == 'docs'
Requires-Dist: grpcio-reflection <2,>=1.56.2 ; extra == 'docs'
Requires-Dist: grpcio-health-checking <2,>=1.56.2 ; extra == 'docs'
Requires-Dist: pandas <2,>=1.4.3 ; (python_version < "3.9") and extra == 'docs'
Provides-Extra: duckdb
Requires-Dist: ibis-framework[duckdb] ; extra == 'duckdb'
Provides-Extra: gcp
Requires-Dist: google-api-core <3,>=1.23.0 ; extra == 'gcp'
Requires-Dist: googleapis-common-protos <2,>=1.52.0 ; extra == 'gcp'
Requires-Dist: google-cloud-bigquery[pandas] <3.13.0,>=2 ; extra == 'gcp'
Requires-Dist: google-cloud-bigquery-storage <3,>=2.0.0 ; extra == 'gcp'
Requires-Dist: google-cloud-datastore <3,>=2.1.0 ; extra == 'gcp'
Requires-Dist: google-cloud-storage <3,>=1.34.0 ; extra == 'gcp'
Requires-Dist: google-cloud-bigtable <3,>=2.11.0 ; extra == 'gcp'
Requires-Dist: fsspec <=2024.1.0 ; extra == 'gcp'
Provides-Extra: ge
Requires-Dist: great-expectations >=0.15.41 ; extra == 'ge'
Provides-Extra: grpcio
Requires-Dist: grpcio <2,>=1.56.2 ; extra == 'grpcio'
Requires-Dist: grpcio-tools <2,>=1.56.2 ; extra == 'grpcio'
Requires-Dist: grpcio-reflection <2,>=1.56.2 ; extra == 'grpcio'
Requires-Dist: grpcio-health-checking <2,>=1.56.2 ; extra == 'grpcio'
Provides-Extra: hazelcast
Requires-Dist: hazelcast-python-client >=5.1 ; extra == 'hazelcast'
Provides-Extra: hbase
Requires-Dist: happybase <3,>=1.2.0 ; extra == 'hbase'
Provides-Extra: ibis
Requires-Dist: ibis-framework ; extra == 'ibis'
Requires-Dist: ibis-substrait ; extra == 'ibis'
Provides-Extra: mysql
Requires-Dist: pymysql ; extra == 'mysql'
Requires-Dist: types-PyMySQL ; extra == 'mysql'
Provides-Extra: postgres
Requires-Dist: psycopg2-binary <3,>=2.8.3 ; extra == 'postgres'
Provides-Extra: redis
Requires-Dist: redis <5,>=4.2.2 ; extra == 'redis'
Requires-Dist: hiredis <3,>=2.0.0 ; extra == 'redis'
Provides-Extra: rockset
Requires-Dist: rockset >=1.0.3 ; extra == 'rockset'
Provides-Extra: snowflake
Requires-Dist: snowflake-connector-python[pandas] <4,>=3 ; extra == 'snowflake'
Provides-Extra: spark
Requires-Dist: pyspark <4,>=3.0.0 ; extra == 'spark'
Provides-Extra: trino
Requires-Dist: trino <0.400.0,>=0.305.0 ; extra == 'trino'
Requires-Dist: regex ; extra == 'trino'

<!--Do not modify this file. It is auto-generated from a template (infra/templates/README.md.jinja2)-->

<p align="center">
    <a href="https://feast.dev/">
      <img src="docs/assets/feast_logo.png" width="550">
    </a>
</p>
<br />

[![unit-tests](https://github.com/feast-dev/feast/actions/workflows/unit_tests.yml/badge.svg?branch=master&event=push)](https://github.com/feast-dev/feast/actions/workflows/unit_tests.yml)
[![integration-tests-and-build](https://github.com/feast-dev/feast/actions/workflows/master_only.yml/badge.svg?branch=master&event=push)](https://github.com/feast-dev/feast/actions/workflows/master_only.yml)
[![java-integration-tests](https://github.com/feast-dev/feast/actions/workflows/java_master_only.yml/badge.svg?branch=master&event=push)](https://github.com/feast-dev/feast/actions/workflows/java_master_only.yml)
[![linter](https://github.com/feast-dev/feast/actions/workflows/linter.yml/badge.svg?branch=master&event=push)](https://github.com/feast-dev/feast/actions/workflows/linter.yml)
[![Docs Latest](https://img.shields.io/badge/docs-latest-blue.svg)](https://docs.feast.dev/)
[![Python API](https://img.shields.io/readthedocs/feast/master?label=Python%20API)](http://rtd.feast.dev/)
[![License](https://img.shields.io/badge/License-Apache%202.0-blue)](https://github.com/feast-dev/feast/blob/master/LICENSE)
[![GitHub Release](https://img.shields.io/github/v/release/feast-dev/feast.svg?style=flat&sort=semver&color=blue)](https://github.com/feast-dev/feast/releases)

## Overview

Feast (**Fea**ture **St**ore) is an open source feature store for machine learning. Feast is the fastest path to manage existing infrastructure to productionize analytic data for model training and online inference.


Feast allows ML platform teams to:

* **Make features consistently available for training and serving** by managing an _offline store_ (to process historical data for scale-out batch scoring or model training), a low-latency _online store_ (to power real-time prediction)_,_ and a battle-tested _feature server_ (to serve pre-computed features online).
* **Avoid data leakage** by generating point-in-time correct feature sets so data scientists can focus on feature engineering rather than debugging error-prone dataset joining logic. This ensure that future feature values do not leak to models during training.
* **Decouple ML from data infrastructure** by providing a single data access layer that abstracts feature storage from feature retrieval, ensuring models remain portable as you move from training models to serving models, from batch models to realtime models, and from one data infra system to another.

Please see our [documentation](https://docs.feast.dev/) for more information about the project.

## 📐 Architecture
![](docs/assets/feast_marchitecture.png)

The above architecture is the minimal Feast deployment. Want to run the full Feast on Snowflake/GCP/AWS? Click [here](https://docs.feast.dev/how-to-guides/feast-snowflake-gcp-aws).

## 🐣 Getting Started

### 1. Install Feast
```commandline
pip install feast
```

### 2. Create a feature repository
```commandline
feast init my_feature_repo
cd my_feature_repo/feature_repo
```

### 3. Register your feature definitions and set up your feature store
```commandline
feast apply
```

### 4. Explore your data in the web UI (experimental)

![Web UI](ui/sample.png)
```commandline
feast ui
```

### 5. Build a training dataset
```python
from feast import FeatureStore
import pandas as pd
from datetime import datetime

entity_df = pd.DataFrame.from_dict({
    "driver_id": [1001, 1002, 1003, 1004],
    "event_timestamp": [
        datetime(2021, 4, 12, 10, 59, 42),
        datetime(2021, 4, 12, 8,  12, 10),
        datetime(2021, 4, 12, 16, 40, 26),
        datetime(2021, 4, 12, 15, 1 , 12)
    ]
})

store = FeatureStore(repo_path=".")

training_df = store.get_historical_features(
    entity_df=entity_df,
    features = [
        'driver_hourly_stats:conv_rate',
        'driver_hourly_stats:acc_rate',
        'driver_hourly_stats:avg_daily_trips'
    ],
).to_df()

print(training_df.head())

# Train model
# model = ml.fit(training_df)
```
```commandline
            event_timestamp  driver_id  conv_rate  acc_rate  avg_daily_trips
0 2021-04-12 08:12:10+00:00       1002   0.713465  0.597095              531
1 2021-04-12 10:59:42+00:00       1001   0.072752  0.044344               11
2 2021-04-12 15:01:12+00:00       1004   0.658182  0.079150              220
3 2021-04-12 16:40:26+00:00       1003   0.162092  0.309035              959

```

### 6. Load feature values into your online store
```commandline
CURRENT_TIME=$(date -u +"%Y-%m-%dT%H:%M:%S")
feast materialize-incremental $CURRENT_TIME
```

```commandline
Materializing feature view driver_hourly_stats from 2021-04-14 to 2021-04-15 done!
```

### 7. Read online features at low latency
```python
from pprint import pprint
from feast import FeatureStore

store = FeatureStore(repo_path=".")

feature_vector = store.get_online_features(
    features=[
        'driver_hourly_stats:conv_rate',
        'driver_hourly_stats:acc_rate',
        'driver_hourly_stats:avg_daily_trips'
    ],
    entity_rows=[{"driver_id": 1001}]
).to_dict()

pprint(feature_vector)

# Make prediction
# model.predict(feature_vector)
```
```json
{
    "driver_id": [1001],
    "driver_hourly_stats__conv_rate": [0.49274],
    "driver_hourly_stats__acc_rate": [0.92743],
    "driver_hourly_stats__avg_daily_trips": [72]
}
```

## 📦 Functionality and Roadmap

The list below contains the functionality that contributors are planning to develop for Feast.

* We welcome contribution to all items in the roadmap!

* **Data Sources**
  * [x] [Snowflake source](https://docs.feast.dev/reference/data-sources/snowflake)
  * [x] [Redshift source](https://docs.feast.dev/reference/data-sources/redshift)
  * [x] [BigQuery source](https://docs.feast.dev/reference/data-sources/bigquery)
  * [x] [Parquet file source](https://docs.feast.dev/reference/data-sources/file)
  * [x] [Azure Synapse + Azure SQL source (contrib plugin)](https://docs.feast.dev/reference/data-sources/mssql)
  * [x] [Hive (community plugin)](https://github.com/baineng/feast-hive)
  * [x] [Postgres (contrib plugin)](https://docs.feast.dev/reference/data-sources/postgres)
  * [x] [Spark (contrib plugin)](https://docs.feast.dev/reference/data-sources/spark)
  * [x] Kafka / Kinesis sources (via [push support into the online store](https://docs.feast.dev/reference/data-sources/push))
* **Offline Stores**
  * [x] [Snowflake](https://docs.feast.dev/reference/offline-stores/snowflake)
  * [x] [Redshift](https://docs.feast.dev/reference/offline-stores/redshift)
  * [x] [BigQuery](https://docs.feast.dev/reference/offline-stores/bigquery)
  * [x] [Azure Synapse + Azure SQL (contrib plugin)](https://docs.feast.dev/reference/offline-stores/mssql.md)
  * [x] [Hive (community plugin)](https://github.com/baineng/feast-hive)
  * [x] [Postgres (contrib plugin)](https://docs.feast.dev/reference/offline-stores/postgres)
  * [x] [Trino (contrib plugin)](https://github.com/Shopify/feast-trino)
  * [x] [Spark (contrib plugin)](https://docs.feast.dev/reference/offline-stores/spark)
  * [x] [In-memory / Pandas](https://docs.feast.dev/reference/offline-stores/file)
  * [x] [Custom offline store support](https://docs.feast.dev/how-to-guides/customizing-feast/adding-a-new-offline-store)
* **Online Stores**
  * [x] [Snowflake](https://docs.feast.dev/reference/online-stores/snowflake)
  * [x] [DynamoDB](https://docs.feast.dev/reference/online-stores/dynamodb)
  * [x] [Redis](https://docs.feast.dev/reference/online-stores/redis)
  * [x] [Datastore](https://docs.feast.dev/reference/online-stores/datastore)
  * [x] [Bigtable](https://docs.feast.dev/reference/online-stores/bigtable)
  * [x] [SQLite](https://docs.feast.dev/reference/online-stores/sqlite)
  * [x] [Dragonfly](https://docs.feast.dev/reference/online-stores/dragonfly)
  * [x] [Azure Cache for Redis (community plugin)](https://github.com/Azure/feast-azure)
  * [x] [Postgres (contrib plugin)](https://docs.feast.dev/reference/online-stores/postgres)
  * [x] [Cassandra / AstraDB (contrib plugin)](https://docs.feast.dev/reference/online-stores/cassandra)
  * [x] [Custom online store support](https://docs.feast.dev/how-to-guides/customizing-feast/adding-support-for-a-new-online-store)
* **Feature Engineering**
  * [x] On-demand Transformations (Alpha release. See [RFC](https://docs.google.com/document/d/1lgfIw0Drc65LpaxbUu49RCeJgMew547meSJttnUqz7c/edit#))
  * [x] Streaming Transformations (Alpha release. See [RFC](https://docs.google.com/document/d/1UzEyETHUaGpn0ap4G82DHluiCj7zEbrQLkJJkKSv4e8/edit))
  * [ ] Batch transformation (In progress. See [RFC](https://docs.google.com/document/d/1964OkzuBljifDvkV-0fakp2uaijnVzdwWNGdz7Vz50A/edit))
* **Streaming**
  * [x] [Custom streaming ingestion job support](https://docs.feast.dev/how-to-guides/customizing-feast/creating-a-custom-provider)
  * [x] [Push based streaming data ingestion to online store](https://docs.feast.dev/reference/data-sources/push)
  * [x] [Push based streaming data ingestion to offline store](https://docs.feast.dev/reference/data-sources/push)
* **Deployments**
  * [x] AWS Lambda (Alpha release. See [RFC](https://docs.google.com/document/d/1eZWKWzfBif66LDN32IajpaG-j82LSHCCOzY6R7Ax7MI/edit))
  * [x] Kubernetes (See [guide](https://docs.feast.dev/how-to-guides/running-feast-in-production))
* **Feature Serving**
  * [x] Python Client
  * [x] [Python feature server](https://docs.feast.dev/reference/feature-servers/python-feature-server)
  * [x] [Java feature server (alpha)](https://github.com/feast-dev/feast/blob/master/infra/charts/feast/README.md)
  * [x] [Go feature server (alpha)](https://docs.feast.dev/reference/feature-servers/go-feature-server)
* **Data Quality Management (See [RFC](https://docs.google.com/document/d/110F72d4NTv80p35wDSONxhhPBqWRwbZXG4f9mNEMd98/edit))**
  * [x] Data profiling and validation (Great Expectations)
* **Feature Discovery and Governance**
  * [x] Python SDK for browsing feature registry
  * [x] CLI for browsing feature registry
  * [x] Model-centric feature tracking (feature services)
  * [x] Amundsen integration (see [Feast extractor](https://github.com/amundsen-io/amundsen/blob/main/databuilder/databuilder/extractor/feast_extractor.py))
  * [x] DataHub integration (see [DataHub Feast docs](https://datahubproject.io/docs/generated/ingestion/sources/feast/))
  * [x] Feast Web UI (Beta release. See [docs](https://docs.feast.dev/reference/alpha-web-ui))


## 🎓 Important Resources

Please refer to the official documentation at [Documentation](https://docs.feast.dev/)
 * [Quickstart](https://docs.feast.dev/getting-started/quickstart)
 * [Tutorials](https://docs.feast.dev/tutorials/tutorials-overview)
 * [Running Feast with Snowflake/GCP/AWS](https://docs.feast.dev/how-to-guides/feast-snowflake-gcp-aws)
 * [Change Log](https://github.com/feast-dev/feast/blob/master/CHANGELOG.md)

## 👋 Contributing
Feast is a community project and is still under active development. Please have a look at our contributing and development guides if you want to contribute to the project:
- [Contribution Process for Feast](https://docs.feast.dev/project/contributing)
- [Development Guide for Feast](https://docs.feast.dev/project/development-guide)
- [Development Guide for the Main Feast Repository](./CONTRIBUTING.md)

## ✨ Contributors

Thanks goes to these incredible people:

<a href="https://github.com/feast-dev/feast/graphs/contributors">
  <img src="https://contrib.rocks/image?repo=feast-dev/feast" />
</a>
