Metadata-Version: 2.1
Name: tfx
Version: 1.7.2
Summary: TensorFlow Extended (TFX) is a TensorFlow-based general-purpose machine learning platform implemented at Google.
Home-page: https://www.tensorflow.org/tfx
Download-URL: https://github.com/tensorflow/tfx/tags
Author: Google LLC
Author-email: tensorflow-extended-dev@googlegroups.com
License: Apache 2.0
Keywords: tensorflow tfx
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: Education
Classifier: Intended Audience :: Science/Research
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3 :: Only
Classifier: Topic :: Scientific/Engineering
Classifier: Topic :: Scientific/Engineering :: Artificial Intelligence
Classifier: Topic :: Scientific/Engineering :: Mathematics
Classifier: Topic :: Software Development
Classifier: Topic :: Software Development :: Libraries
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Requires-Python: >=3.7,<3.9
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: ml-pipelines-sdk (==1.7.2)
Requires-Dist: absl-py (<2.0.0,>=0.9)
Requires-Dist: ml-metadata (<1.8.0,>=1.7.0)
Requires-Dist: packaging (<21,>=20)
Requires-Dist: portpicker (<2,>=1.3.1)
Requires-Dist: protobuf (<4,>=3.13)
Requires-Dist: docker (<5,>=4.1)
Requires-Dist: google-apitools (<1,>=0.5)
Requires-Dist: google-api-python-client (<2,>=1.8)
Requires-Dist: jinja2 (<4,>=2.7.3)
Requires-Dist: apache-beam[gcp] (<3,>=2.36)
Requires-Dist: attrs (<21,>=19.3.0)
Requires-Dist: click (<8,>=7)
Requires-Dist: google-cloud-aiplatform (<2,>=1.6.2)
Requires-Dist: google-cloud-bigquery (<3,>=2.26.0)
Requires-Dist: grpcio (<2,>=1.28.1)
Requires-Dist: keras-tuner (<2,>=1.0.4)
Requires-Dist: kubernetes (<13,>=10.0.1)
Requires-Dist: numpy (<2,>=1.16)
Requires-Dist: pyarrow (<6,>=1)
Requires-Dist: pyyaml (<6,>=3.12)
Requires-Dist: tensorflow (!=2.0.*,!=2.1.*,!=2.2.*,!=2.3.*,!=2.4.*,!=2.5.*,!=2.6.*,!=2.7.*,<2.9,>=1.15.5)
Requires-Dist: tensorflow-hub (<0.13,>=0.9.0)
Requires-Dist: tensorflow-data-validation (<1.8.0,>=1.7.0)
Requires-Dist: tensorflow-model-analysis (<0.39,>=0.38.0)
Requires-Dist: tensorflow-serving-api (!=2.0.*,!=2.1.*,!=2.2.*,!=2.3.*,!=2.4.*,!=2.5.*,!=2.6.*,!=2.7.*,<3,>=1.15)
Requires-Dist: tensorflow-transform (<1.8.0,>=1.7.0)
Requires-Dist: tfx-bsl (<1.8.0,>=1.7.0)
Provides-Extra: airflow
Requires-Dist: apache-airflow[mysql] (<2.3,>=1.10.14) ; extra == 'airflow'
Provides-Extra: all
Requires-Dist: apache-airflow[mysql] (<2.3,>=1.10.14) ; extra == 'all'
Requires-Dist: kfp (<2,>=1.8.5) ; extra == 'all'
Requires-Dist: kfp-pipeline-spec (<0.2,>=0.1.10) ; extra == 'all'
Requires-Dist: pytest (<7,>=5) ; extra == 'all'
Requires-Dist: tensorflowjs (<4,>=3.6.0) ; extra == 'all'
Requires-Dist: tensorflow-ranking (<0.4,>=0.3.3) ; extra == 'all'
Requires-Dist: struct2tensor (<0.39,>=0.38) ; extra == 'all'
Requires-Dist: tensorflow-decision-forests (==0.2.4) ; extra == 'all'
Requires-Dist: presto-python-client (<0.8,>=0.7) ; extra == 'all'
Requires-Dist: slackclient (<3,>=2.8.2) ; extra == 'all'
Requires-Dist: websocket-client (<1,>=0.57) ; extra == 'all'
Requires-Dist: tensorflow-text (<3,>=1.15.1) ; extra == 'all'
Requires-Dist: flatbuffers (<3,>=1.12) ; extra == 'all'
Requires-Dist: tflite-support (<0.2.1,>=0.1.0a1) ; extra == 'all'
Requires-Dist: scikit-learn (<0.24,>=0.23) ; extra == 'all'
Requires-Dist: jax (<0.2.17,>=0.2.13) ; extra == 'all'
Requires-Dist: jaxlib (<0.2,>=0.1.64) ; extra == 'all'
Requires-Dist: flax (<0.4,>=0.3.3) ; extra == 'all'
Requires-Dist: tensorflow-cloud (<0.2,>=0.1) ; extra == 'all'
Provides-Extra: docker-image
Requires-Dist: kfp-pipeline-spec (<0.2,>=0.1.10) ; extra == 'docker-image'
Requires-Dist: mmh (<3,>=2.2) ; extra == 'docker-image'
Requires-Dist: python-snappy (<0.6,>=0.5) ; extra == 'docker-image'
Requires-Dist: tensorflow-cloud (<0.2,>=0.1) ; extra == 'docker-image'
Requires-Dist: tensorflow-io (<=0.24.0,>=0.9.0) ; extra == 'docker-image'
Provides-Extra: examples
Requires-Dist: presto-python-client (<0.8,>=0.7) ; extra == 'examples'
Requires-Dist: slackclient (<3,>=2.8.2) ; extra == 'examples'
Requires-Dist: websocket-client (<1,>=0.57) ; extra == 'examples'
Requires-Dist: tensorflow-text (<3,>=1.15.1) ; extra == 'examples'
Requires-Dist: flatbuffers (<3,>=1.12) ; extra == 'examples'
Requires-Dist: tflite-support (<0.2.1,>=0.1.0a1) ; extra == 'examples'
Requires-Dist: scikit-learn (<0.24,>=0.23) ; extra == 'examples'
Requires-Dist: jax (<0.2.17,>=0.2.13) ; extra == 'examples'
Requires-Dist: jaxlib (<0.2,>=0.1.64) ; extra == 'examples'
Requires-Dist: flax (<0.4,>=0.3.3) ; extra == 'examples'
Requires-Dist: tensorflow-cloud (<0.2,>=0.1) ; extra == 'examples'
Provides-Extra: kfp
Requires-Dist: kfp (<2,>=1.8.5) ; extra == 'kfp'
Requires-Dist: kfp-pipeline-spec (<0.2,>=0.1.10) ; extra == 'kfp'
Provides-Extra: test
Requires-Dist: apache-airflow[mysql] (<2.3,>=1.10.14) ; extra == 'test'
Requires-Dist: kfp (<2,>=1.8.5) ; extra == 'test'
Requires-Dist: kfp-pipeline-spec (<0.2,>=0.1.10) ; extra == 'test'
Requires-Dist: pytest (<7,>=5) ; extra == 'test'
Provides-Extra: tf-ranking
Requires-Dist: tensorflow-ranking (<0.4,>=0.3.3) ; extra == 'tf-ranking'
Requires-Dist: struct2tensor (<0.39,>=0.38) ; extra == 'tf-ranking'
Provides-Extra: tfdf
Requires-Dist: tensorflow-decision-forests (==0.2.4) ; extra == 'tfdf'
Provides-Extra: tfjs
Requires-Dist: tensorflowjs (<4,>=3.6.0) ; extra == 'tfjs'

<!-- See: www.tensorflow.org/tfx/ -->

# TFX

[![Python](https://img.shields.io/pypi/pyversions/tfx.svg?style=plastic)](https://github.com/tensorflow/tfx)
[![PyPI](https://badge.fury.io/py/tfx.svg)](https://badge.fury.io/py/tfx)
[![TensorFlow](https://img.shields.io/badge/TensorFow-page-orange)](https://www.tensorflow.org/tfx)

[TensorFlow Extended (TFX)](https://tensorflow.org/tfx) is a
Google-production-scale machine learning platform based on TensorFlow. It
provides a configuration framework to express ML pipelines consisting of TFX
components. TFX pipelines can be orchestrated using
[Apache Airflow](https://airflow.apache.org/) and
[Kubeflow Pipelines](https://www.kubeflow.org/). Both the components themselves
as well as the integrations with orchestration systems can be extended.

TFX components interact with a
[ML Metadata](https://github.com/google/ml-metadata) backend that keeps a record
of component runs, input and output artifacts, and runtime configuration. This
metadata backend enables advanced functionality like experiment tracking or
warmstarting/resuming ML models from previous runs.

![TFX Components](https://raw.githubusercontent.com/tensorflow/tfx/master/docs/guide/images/prog_fin.png)

## Documentation

### User Documentation

Please see the
[TFX User Guide](https://github.com/tensorflow/tfx/blob/master/docs/guide/index.md).

### Development References

#### Roadmap

The TFX [Roadmap](https://github.com/tensorflow/tfx/blob/master/ROADMAP.md),
which is updated quarterly.

#### Release Details

For detailed previous and upcoming changes, please
[check here](https://github.com/tensorflow/tfx/blob/master/RELEASE.md)

#### Requests For Comment

TFX is an open-source project and we strongly encourage active participation
by the ML community in helping to shape TFX to meet or exceed their needs. An
important component of that effort is the RFC process.  Please see the listing
of [current and past TFX RFCs](RFCs.md). Please see the
[TensorFlow Request for Comments (TF-RFC)](https://github.com/tensorflow/community/blob/master/governance/TF-RFCs.md)
process page for information on how community members can contribute.

## Examples

*   [Chicago Taxi Example](https://github.com/tensorflow/tfx/tree/master/tfx/examples/chicago_taxi_pipeline)

## Compatible versions

The following table describes how the `tfx` package versions are compatible with
its major dependency PyPI packages. This is determined by our testing framework,
but other *untested* combinations may also work.

tfx                                                                       | apache-beam[gcp] | ml-metadata | pyarrow | tensorflow        | tensorflow-data-validation | tensorflow-metadata | tensorflow-model-analysis | tensorflow-serving-api | tensorflow-transform | tfx-bsl
------------------------------------------------------------------------- | ---------------- | ----------- | ------- | ----------------- | -------------------------- | ------------------- | ------------------------- | ---------------------- | -------------------- | -------
[GitHub master](https://github.com/tensorflow/tfx/blob/master/RELEASE.md) | 2.38.0           | 1.7.0       | 5.0.0   | nightly (1.x/2.x) | 1.7.0                      | 1.7.0               | 0.38.0                    | 2.8.0                  | 1.7.0                | 1.7.0
[1.7.2](https://github.com/tensorflow/tfx/blob/v1.7.2/RELEASE.md)         | 2.38.0           | 1.7.0       | 5.0.0   | 1.15.5 / 2.8.0    | 1.7.0                      | 1.7.0               | 0.38.0                    | 2.8.0                  | 1.7.0                | 1.7.0
[1.7.1](https://github.com/tensorflow/tfx/blob/v1.7.1/RELEASE.md)         | 2.36.0           | 1.7.0       | 5.0.0   | 1.15.5 / 2.8.0    | 1.7.0                      | 1.7.0               | 0.38.0                    | 2.8.0                  | 1.7.0                | 1.7.0
[1.7.0](https://github.com/tensorflow/tfx/blob/v1.7.0/RELEASE.md)         | 2.36.0           | 1.7.0       | 5.0.0   | 1.15.5 / 2.8.0    | 1.7.0                      | 1.7.0               | 0.38.0                    | 2.8.0                  | 1.7.0                | 1.7.0
[1.6.0](https://github.com/tensorflow/tfx/blob/v1.6.0/RELEASE.md)         | 2.35.0           | 1.6.0       | 5.0.0   | 1.15.5 / 2.7.0    | 1.6.0                      | 1.6.0               | 0.37.0                    | 2.7.0                  | 1.6.0                | 1.6.0
[1.5.0](https://github.com/tensorflow/tfx/blob/v1.5.0/RELEASE.md)         | 2.34.0           | 1.5.0       | 5.0.0   | 1.15.2 / 2.7.0    | 1.5.0                      | 1.5.0               | 0.36.0                    | 2.7.0                  | 1.5.0                | 1.5.0
[1.4.0](https://github.com/tensorflow/tfx/blob/v1.4.0/RELEASE.md)         | 2.33.0           | 1.4.0       | 5.0.0   | 1.15.0 / 2.6.0    | 1.4.0                      | 1.4.0               | 0.35.0                    | 2.6.0                  | 1.4.0                | 1.4.0
[1.3.4](https://github.com/tensorflow/tfx/blob/v1.3.4/RELEASE.md)         | 2.32.0           | 1.3.0       | 2.0.0   | 1.15.0 / 2.6.0    | 1.3.0                      | 1.2.0               | 0.34.1                    | 2.6.0                  | 1.3.0                | 1.3.0
[1.3.3](https://github.com/tensorflow/tfx/blob/v1.3.3/RELEASE.md)         | 2.32.0           | 1.3.0       | 2.0.0   | 1.15.0 / 2.6.0    | 1.3.0                      | 1.2.0               | 0.34.1                    | 2.6.0                  | 1.3.0                | 1.3.0
[1.3.2](https://github.com/tensorflow/tfx/blob/v1.3.2/RELEASE.md)         | 2.32.0           | 1.3.0       | 2.0.0   | 1.15.0 / 2.6.0    | 1.3.0                      | 1.2.0               | 0.34.1                    | 2.6.0                  | 1.3.0                | 1.3.0
[1.3.1](https://github.com/tensorflow/tfx/blob/v1.3.1/RELEASE.md)         | 2.32.0           | 1.3.0       | 2.0.0   | 1.15.0 / 2.6.0    | 1.3.0                      | 1.2.0               | 0.34.1                    | 2.6.0                  | 1.3.0                | 1.3.0
[1.3.0](https://github.com/tensorflow/tfx/blob/v1.3.0/RELEASE.md)         | 2.32.0           | 1.3.0       | 2.0.0   | 1.15.0 / 2.6.0    | 1.3.0                      | 1.2.0               | 0.34.1                    | 2.6.0                  | 1.3.0                | 1.3.0
[1.2.1](https://github.com/tensorflow/tfx/blob/v1.2.1/RELEASE.md)         | 2.31.0           | 1.2.0       | 2.0.0   | 1.15.0 / 2.5.0    | 1.2.0                      | 1.2.0               | 0.33.0                    | 2.5.1                  | 1.2.0                | 1.2.0
[1.2.0](https://github.com/tensorflow/tfx/blob/v1.2.0/RELEASE.md)         | 2.31.0           | 1.2.0       | 2.0.0   | 1.15.0 / 2.5.0    | 1.2.0                      | 1.2.0               | 0.33.0                    | 2.5.1                  | 1.2.0                | 1.2.0
[1.0.0](https://github.com/tensorflow/tfx/blob/v1.0.0/RELEASE.md)         | 2.29.0           | 1.0.0       | 2.0.0   | 1.15.0 / 2.5.0    | 1.0.0                      | 1.0.0               | 0.31.0                    | 2.5.1                  | 1.0.0                | 1.0.0
[0.30.0](https://github.com/tensorflow/tfx/blob/v0.30.0/RELEASE.md)       | 2.28.0           | 0.30.0      | 2.0.0   | 1.15.0 / 2.4.0    | 0.30.0                     | 0.30.0              | 0.30.0                    | 2.4.0                  | 0.30.0               | 0.30.0
[0.29.0](https://github.com/tensorflow/tfx/blob/v0.29.0/RELEASE.md)       | 2.28.0           | 0.29.0      | 2.0.0   | 1.15.0 / 2.4.0    | 0.29.0                     | 0.29.0              | 0.29.0                    | 2.4.0                  | 0.29.0               | 0.29.0
[0.28.0](https://github.com/tensorflow/tfx/blob/v0.28.0/RELEASE.md)       | 2.28.0           | 0.28.0      | 2.0.0   | 1.15.0 / 2.4.0    | 0.28.0                     | 0.28.0              | 0.28.0                    | 2.4.0                  | 0.28.0               | 0.28.1
[0.27.0](https://github.com/tensorflow/tfx/blob/v0.27.0/RELEASE.md)       | 2.27.0           | 0.27.0      | 2.0.0   | 1.15.0 / 2.4.0    | 0.27.0                     | 0.27.0              | 0.27.0                    | 2.4.0                  | 0.27.0               | 0.27.0
[0.26.4](https://github.com/tensorflow/tfx/blob/v0.26.4/RELEASE.md)       | 2.28.0           | 0.26.0      | 0.17.0  | 1.15.0 / 2.3.0    | 0.26.1                     | 0.26.0              | 0.26.0                    | 2.3.0                  | 0.26.0               | 0.26.0
[0.26.3](https://github.com/tensorflow/tfx/blob/v0.26.3/RELEASE.md)       | 2.25.0           | 0.26.0      | 0.17.0  | 1.15.0 / 2.3.0    | 0.26.0                     | 0.26.0              | 0.26.0                    | 2.3.0                  | 0.26.0               | 0.26.0
[0.26.1](https://github.com/tensorflow/tfx/blob/v0.26.1/RELEASE.md)       | 2.25.0           | 0.26.0      | 0.17.0  | 1.15.0 / 2.3.0    | 0.26.0                     | 0.26.0              | 0.26.0                    | 2.3.0                  | 0.26.0               | 0.26.0
[0.26.0](https://github.com/tensorflow/tfx/blob/v0.26.0/RELEASE.md)       | 2.25.0           | 0.26.0      | 0.17.0  | 1.15.0 / 2.3.0    | 0.26.0                     | 0.26.0              | 0.26.0                    | 2.3.0                  | 0.26.0               | 0.26.0
[0.25.0](https://github.com/tensorflow/tfx/blob/v0.25.0/RELEASE.md)       | 2.25.0           | 0.24.0      | 0.17.0  | 1.15.0 / 2.3.0    | 0.25.0                     | 0.25.0              | 0.25.0                    | 2.3.0                  | 0.25.0               | 0.25.0
[0.24.1](https://github.com/tensorflow/tfx/blob/v0.24.1/RELEASE.md)       | 2.24.0           | 0.24.0      | 0.17.0  | 1.15.0 / 2.3.0    | 0.24.1                     | 0.24.0              | 0.24.3                    | 2.3.0                  | 0.24.1               | 0.24.1
[0.24.0](https://github.com/tensorflow/tfx/blob/v0.24.0/RELEASE.md)       | 2.24.0           | 0.24.0      | 0.17.0  | 1.15.0 / 2.3.0    | 0.24.1                     | 0.24.0              | 0.24.3                    | 2.3.0                  | 0.24.1               | 0.24.1
[0.23.1](https://github.com/tensorflow/tfx/blob/v0.23.1/RELEASE.md)       | 2.24.0           | 0.23.0      | 0.17.0  | 1.15.0 / 2.3.0    | 0.23.1                     | 0.23.0              | 0.23.0                    | 2.3.0                  | 0.23.0               | 0.23.0
[0.23.0](https://github.com/tensorflow/tfx/blob/v0.23.0/RELEASE.md)       | 2.23.0           | 0.23.0      | 0.17.0  | 1.15.0 / 2.3.0    | 0.23.0                     | 0.23.0              | 0.23.0                    | 2.3.0                  | 0.23.0               | 0.23.0
[0.22.2](https://github.com/tensorflow/tfx/blob/v0.22.2/RELEASE.md)       | 2.21.0           | 0.22.1      | 0.16.0  | 1.15.0 / 2.2.0    | 0.22.2                     | 0.22.2              | 0.22.2                    | 2.2.0                  | 0.22.0               | 0.22.1
[0.22.1](https://github.com/tensorflow/tfx/blob/v0.22.1/RELEASE.md)       | 2.21.0           | 0.22.1      | 0.16.0  | 1.15.0 / 2.2.0    | 0.22.2                     | 0.22.2              | 0.22.2                    | 2.2.0                  | 0.22.0               | 0.22.1
[0.22.0](https://github.com/tensorflow/tfx/blob/v0.22.0/RELEASE.md)       | 2.21.0           | 0.22.0      | 0.16.0  | 1.15.0 / 2.2.0    | 0.22.0                     | 0.22.0              | 0.22.1                    | 2.2.0                  | 0.22.0               | 0.22.0
[0.21.5](https://github.com/tensorflow/tfx/blob/v0.21.5/RELEASE.md)       | 2.17.0           | 0.21.2      | 0.15.0  | 1.15.0 / 2.1.0    | 0.21.5                     | 0.21.1              | 0.21.5                    | 2.1.0                  | 0.21.2               | 0.21.4
[0.21.4](https://github.com/tensorflow/tfx/blob/v0.21.4/RELEASE.md)       | 2.17.0           | 0.21.2      | 0.15.0  | 1.15.0 / 2.1.0    | 0.21.5                     | 0.21.1              | 0.21.5                    | 2.1.0                  | 0.21.2               | 0.21.4
[0.21.3](https://github.com/tensorflow/tfx/blob/v0.21.3/RELEASE.md)       | 2.17.0           | 0.21.2      | 0.15.0  | 1.15.0 / 2.1.0    | 0.21.5                     | 0.21.1              | 0.21.5                    | 2.1.0                  | 0.21.2               | 0.21.4
[0.21.2](https://github.com/tensorflow/tfx/blob/v0.21.2/RELEASE.md)       | 2.17.0           | 0.21.2      | 0.15.0  | 1.15.0 / 2.1.0    | 0.21.5                     | 0.21.1              | 0.21.5                    | 2.1.0                  | 0.21.2               | 0.21.4
[0.21.1](https://github.com/tensorflow/tfx/blob/0.21.1/RELEASE.md)        | 2.17.0           | 0.21.2      | 0.15.0  | 1.15.0 / 2.1.0    | 0.21.4                     | 0.21.1              | 0.21.4                    | 2.1.0                  | 0.21.2               | 0.21.3
[0.21.0](https://github.com/tensorflow/tfx/blob/0.21.0/RELEASE.md)        | 2.17.0           | 0.21.0      | 0.15.0  | 1.15.0 / 2.1.0    | 0.21.0                     | 0.21.0              | 0.21.1                    | 2.1.0                  | 0.21.0               | 0.21.0
[0.15.0](https://github.com/tensorflow/tfx/blob/0.15.0/RELEASE.md)        | 2.16.0           | 0.15.0      | 0.15.0  | 1.15.0            | 0.15.0                     | 0.15.0              | 0.15.2                    | 1.15.0                 | 0.15.0               | 0.15.1
[0.14.0](https://github.com/tensorflow/tfx/blob/0.14.0/RELEASE.md)        | 2.14.0           | 0.14.0      | 0.14.0  | 1.14.0            | 0.14.1                     | 0.14.0              | 0.14.0                    | 1.14.0                 | 0.14.0               | n/a
[0.13.0](https://github.com/tensorflow/tfx/blob/0.13.0/RELEASE.md)        | 2.12.0           | 0.13.2      | n/a     | 1.13.1            | 0.13.1                     | 0.13.0              | 0.13.2                    | 1.13.0                 | 0.13.0               | n/a
[0.12.0](https://github.com/tensorflow/tfx/blob/0.12.0/RELEASE.md)        | 2.10.0           | 0.13.2      | n/a     | 1.12.0            | 0.12.0                     | 0.12.1              | 0.12.1                    | 1.12.0                 | 0.12.0               | n/a

## Resources

*   [TFX tutorials ](https://www.tensorflow.org/tfx/tutorials)
*   [TensorFlow Extended (YouTube)](https://www.youtube.com/playlist?list=PLQY2H8rRoyvxR15n04JiW0ezF5HQRs_8F)
*   [ MLOps Specialization ](https://www.coursera.org/specializations/machine-learning-engineering-for-production-mlops)
*   [ML Pipelines on Google Cloud](https://www.coursera.org/learn/ml-pipelines-google-cloud?specialization=preparing-for-google-cloud-machine-learning-engineer-professional-certificate)
*   [Manage a production ML pipeline with TFX](https://www.youtube.com/watch?v=QQ13-Tkrbls)
*   [How to build an ML pipeline with TFX](https://www.youtube.com/watch?v=17l3VR2MIeg)
