Metadata-Version: 2.1
Name: sematic
Version: 0.39.1
Author: Sematic AI, Inc.
Author-email: support@sematic.dev
Home-page: https://sematic.dev
License: Apache License 2.0
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: Science/Research
Classifier: Programming Language :: Python :: 3 :: Only
Classifier: Topic :: Scientific/Engineering :: Artificial Intelligence
Classifier: Topic :: Scientific/Engineering :: Visualization
Classifier: Typing :: Typed
Requires-Python: >=3.8,<3.13
Requires-Dist: SQLAlchemy>2.0.0
Requires-Dist: Cython==0.29.33
Requires-Dist: setuptools
Requires-Dist: python-dateutil
Requires-Dist: six
Requires-Dist: greenlet
Requires-Dist: typing-extensions
Requires-Dist: Flask
Requires-Dist: Jinja2
Requires-Dist: MarkupSafe
Requires-Dist: Werkzeug
Requires-Dist: click
Requires-Dist: importlib-metadata
Requires-Dist: zipp
Requires-Dist: itsdangerous
Requires-Dist: Flask-Cors
Requires-Dist: PyYAML
Requires-Dist: psycopg2-binary
Requires-Dist: cloudpickle
Requires-Dist: google-auth
Requires-Dist: cachetools
Requires-Dist: pyasn1-modules
Requires-Dist: rsa
Requires-Dist: requests
Requires-Dist: certifi
Requires-Dist: charset-normalizer
Requires-Dist: idna
Requires-Dist: urllib3
Requires-Dist: starlette
Requires-Dist: anyio
Requires-Dist: sniffio
Requires-Dist: git-python
Requires-Dist: GitPython
Requires-Dist: gitdb
Requires-Dist: smmap
Requires-Dist: python-socketio
Requires-Dist: bidict
Requires-Dist: python-engineio
Requires-Dist: websocket-client
Requires-Dist: python-magic
Requires-Dist: boto3
Requires-Dist: botocore
Requires-Dist: jmespath
Requires-Dist: s3transfer
Requires-Dist: kubernetes
Requires-Dist: requests-oauthlib
Requires-Dist: oauthlib
Requires-Dist: google-cloud-storage
Requires-Dist: google-api-core
Requires-Dist: googleapis-common-protos
Requires-Dist: protobuf
Requires-Dist: google-cloud-core
Requires-Dist: google-resumable-media
Requires-Dist: google-crc32c
Requires-Dist: asgiref
Requires-Dist: uvicorn
Requires-Dist: h11
Requires-Dist: httptools
Requires-Dist: python-dotenv
Requires-Dist: uvloop
Requires-Dist: watchfiles
Requires-Dist: websockets
Requires-Dist: docker
Requires-Dist: packaging
Provides-Extra: all
Requires-Dist: ray[default]>=2.1.0; extra == 'all'
Provides-Extra: github
Provides-Extra: metrics
Provides-Extra: ray
Requires-Dist: ray[default]>=2.1.0; extra == 'ray'
Version: 0.39.1



.. image:: https://raw.githubusercontent.com/sematic-ai/sematic/main/docs/images/Logo_README.png
   :target: https://raw.githubusercontent.com/sematic-ai/sematic/main/docs/images/Logo_README.png
   :alt: Sematic Logo



.. image:: https://img.shields.io/pypi/v/sematic/0.39.1?style=for-the-badge
   :target: https://img.shields.io/pypi/v/sematic/0.39.1?style=for-the-badge
   :alt: PyPI


.. image:: https://img.shields.io/circleci/build/github/sematic-ai/sematic/main?label=CircleCI&style=for-the-badge&token=60d1953bfee5b6bf8201f8e84a10eaa5bf5622fe
   :target: https://app.circleci.com/pipelines/github/sematic-ai/sematic?branch=main&filter=all
   :alt: CircleCI


.. image:: https://img.shields.io/pypi/l/sematic?style=for-the-badge
   :target: https://img.shields.io/pypi/l/sematic?style=for-the-badge
   :alt: PyPI - License


.. image:: https://img.shields.io/badge/Python-3.8-blue?style=for-the-badge&logo=none
   :target: https://python.org
   :alt: Python 3.8


.. image:: https://img.shields.io/badge/Python-3.9-blue?style=for-the-badge&logo=none
   :target: https://python.org
   :alt: Python 3.9


.. image:: https://img.shields.io/badge/Python-3.10-blue?style=for-the-badge&logo=none
   :target: https://python.org
   :alt: Python 3.10


.. image:: https://img.shields.io/badge/Python-3.11-blue?style=for-the-badge&logo=none
   :target: https://python.org
   :alt: Python 3.11


.. image:: https://img.shields.io/badge/Python-3.12-blue?style=for-the-badge&logo=none
   :target: https://python.org
   :alt: Python 3.12


.. image:: https://img.shields.io/discord/983789877927747714?label=DISCORD&style=for-the-badge
   :target: https://img.shields.io/discord/983789877927747714?label=DISCORD&style=for-the-badge
   :alt: Discord


.. image:: https://img.shields.io/badge/Made_by-Sematic_🦊-E19632?style=for-the-badge&logo=none
   :target: https://sematic.dev
   :alt: Made By Sematic


.. image:: https://img.shields.io/pypi/dm/sematic?style=for-the-badge
   :target: https://img.shields.io/pypi/dm/sematic?style=for-the-badge
   :alt: PyPI - Downloads



.. image:: https://raw.githubusercontent.com/sematic-ai/sematic/main/docs/images/Screenshot_README_2.png
   :target: https://raw.githubusercontent.com/sematic-ai/sematic/main/docs/images/Screenshot_README_2.png
   :alt: Sematic Screenshot


`Sematic <https://sematic.dev>`_ is an open-source ML development platform. It
lets ML Engineers and Data Scientists write arbitrarily complex end-to-end
pipelines with simple Python and execute them on their local machine, in a cloud
VM, or on a Kubernetes cluster to leverage cloud resources.

Sematic is based on learnings gathered at top self-driving car companies. It
enables chaining data processing jobs (e.g. Apache Spark) with model training
(e.g. PyTorch, Tensorflow), or any other arbitrary Python business logic into
type-safe, traceable, reproducible end-to-end pipelines that can be monitored
and visualized in a modern web dashboard.

Read our `documentation <https://docs.sematic.dev>`_ and join our `Discord
channel <https://discord.gg/4KZJ6kYVax>`_.

Why Sematic
-----------


* **Easy onboarding** – no deployment or infrastructure needed to get started,
  simply install Sematic locally and start exploring.
* **Local-to-cloud parity** – run the same code on your local laptop and on your
  Kubernetes cluster.
* **End-to-end traceability** – all pipeline artifacts are persisted, tracked,
  and visualizable in a web dashboard.
* **Access heterogeneous compute** – customize required resources for each
  pipeline step to optimize your performance and cloud footprint (CPUs, memory,
  GPUs, Spark cluster, etc.)
* **Reproducibility** – rerun your pipelines from the UI with guaranteed
  reproducibility of results

Getting Started
---------------

To get started locally, simply install Sematic in your Python environment:

.. code-block:: shell

   $ pip install sematic

Start the local web dashboard:

.. code-block:: shell

   $ sematic start

Run an example pipeline:

.. code-block:: shell

   $ sematic run examples/mnist/pytorch

Create a new boilerplate project:

.. code-block:: shell

   $ sematic new my_new_project

Or from an existing example:

.. code-block:: shell

   $ sematic new my_new_project --from examples/mnist/pytorch

Then run it with:

.. code-block:: shell

   $ python3 -m my_new_project

To deploy Sematic to Kubernetes and leverage cloud resources, see our
`documentation <https://docs.sematic.dev>`_.

Features
--------


* **Lightweight Python SDK** – define arbitrarily complex end-to-end pipelines
* **Pipeline nesting** – arbitrarily nest pipelines into larger pipelines
* **Dynamic graphs** – Python-defined graphs allow for iterations, conditional
  branching, etc.
* **Lineage tracking** – all inputs and outputs of all steps are persisted and
  tracked
* **Runtime type-checking** – fail early with run-time type checking
* **Web dashboard** – Monitor, track, and visualize pipelines in a modern web UI
* **Artifact visualization** – visualize all inputs and outputs of all steps in
  the web dashboard
* **Local execution** – run pipelines on your local machine without any
  deployment necessary
* **Cloud orchestration** – run pipelines on Kubernetes to access GPUs and other
  cloud resources
* **Heterogeneous compute resources** – run different steps on different
  machines (e.g. CPUs, memory, GPU, Spark, etc.)
* **Helm chart deployment** – install Sematic on your Kubernetes cluster
* **Pipeline reruns** – rerun pipelines from the UI from an arbitrary point in
  the graph
* **Step caching** – cache expensive pipeline steps for faster iteration
* **Step retry** – recover from transient failures with step retries
* **Metadata and collaboration** – Tags, source code visualization, docstrings,
  notes, etc.
* **Numerous integrations** – See below

Integrations
------------


* **Apache Spark** – on-demand in-cluster Spark cluster
* **Ray** – on-demand Ray in-cluster Ray resources
* **Snowflake** – easily query your data warehouse (other warehouses supported
  too)
* **Plotly, Matplotlib** – visualize plot artifacts in the web dashboard
* **Pandas** – visualize dataframe artifacts in the dashboard
* **Grafana** – embed Grafana panels in the web dashboard
* **Bazel** – integrate with your Bazel build system
* **Helm chart** – deploy to Kubernetes with our Helm chart
* **Git** – track git information in the web dashboard

Community and resources
-----------------------

Learn more about Sematic and get in touch with the following resources:


* `Sematic landing page <https://sematic.dev>`_
* `Documentation <https://docs.sematic.dev>`_
* `Discord channel <https://discord.gg/4KZJ6kYVax>`_
* `YouTube channel <https://www.youtube.com/@sematic-ai>`_
* `Our Blog <https://sematic.dev/blog>`_

Contribute!
-----------

To contribute to Sematic, check out `open issues tagged "good first
issue" <https://github.com/sematic-ai/sematic/issues?q=is%3Aopen+is%3Aissue+label%3A%22good+first+issue%22>`_\ ,
and get in touch with us on `Discord <https://discord.gg/4KZJ6kYVax>`_.
You can find instructions on how to get your development environment set up
in our `developer docs <./developer-docs/README.md>`_. If you'd like to add
an example, you may also find
`this guide <https://docs.sematic.dev/project/contributor-guide/contribute-example>`_
helpful.


.. image:: https://static.scarf.sh/a.png?x-pxid=80c3593f-25a0-4b06-90a1-0b670a6567d4
   :target: https://static.scarf.sh/a.png?x-pxid=80c3593f-25a0-4b06-90a1-0b670a6567d4
   :alt: scarf pixel


