Skip to main content

A Library for Private, Secure Deep Learning

Project description

Introduction

Binder Build Status Chat on Slack FOSSA Status

PySyft is a Python library for secure, private Deep Learning. PySyft decouples private data from model training, using Federated Learning, Differential Privacy, and Multi-Party Computation (MPC) within PyTorch. Join the movement on Slack.

PySyft in Detail

A more detailed explanation of PySyft can be found in the paper on arxiv

PySyft has also been explained in video form by Siraj Raval

Pre-Installation

Optionally, we recommend that you install PySyft within the Conda virtual environment, for its simplicity in installation. If you are using Windows, we suggest installing Anaconda and using the Anaconda Prompt to work from the command line.

conda create -n pysyft python=3
conda activate pysyft # some older version of conda require "source activate pysyft" instead.
conda install jupyter notebook

Another alternative is to use python venvs. Those are our preferred environments for development purposes. We provide a direct install instructions in our makefile.

make venv

Installation

PySyft supports Python >= 3.6 and PyTorch 1.1

pip install syft[udacity]

This will auto-install the PyTorch and TF Encrypted dependencies, which are required for running the tutorials from Udacity's "Secure & Private AI" course (recommended).

You can install syft without these dependencies with the usual pip install syft, but you will need to install framework dependencies (i.e. PyTorch, TensorFlow, or TF Encrypted) yourself. If you feel you've received an unexpected installation error related to PyTorch or TF Encrypted, please open an issue on Github or reach out to #team_pysyft in Slack.

If you have an installation error regarding zstd, run this command and then re-try installing syft.

pip install --upgrade --force-reinstall zstd

If this still doesn't work, and you happen to be on OSX, make sure you have OSX command line tools installed and try again.

If this still fails, and you are on a Conda environment. It could be because conda provides its own compiler and linker tools which might conflict with your system's. In that case we recommend to use a python venv and try again.

You can also install PySyft from source on a variety of operating systems by following this installation guide.

Run Local Notebook Server

All the examples can be played with by running the command

make notebook

This assumes you want to use a local virtual environment. It installs it independently to the conda environment in case you installed one, or any other virtual environment you might have set up.

Once the jupyter notebook launches on your browser select the pysyft kernel.

Use the Docker image

Instead of installing all the dependencies on your computer, you can run a notebook server (which comes with Pysyft installed) using Docker. All you will have to do is start the container like this:

$ docker container run openmined/pysyft-notebook

You can use the provided link to access the jupyter notebook (the link is only accessible from your local machine).

NOTE: If you are using Docker Desktop for Mac, the port needs to be forwarded to localhost. In that case run docker with: bash $ docker container run -p 8888:8888 openmined/pysyft-notebook to forward port 8888 from the container's interface to port 8888 on localhost and then access the notebook via http://127.0.0.1:8888/?token=...

You can also set the directory from which the server will serve notebooks (default is /workspace).

$ docker container run -e WORKSPACE_DIR=/root openmined/pysyft-notebook

You could also build the image on your own and run it locally:

$ cd docker-image
$ docker image build -t pysyft-notebook .
$ docker container run pysyft-notebook

More information about how to use this image can be found on docker hub

Try out the Tutorials

A comprehensive list of tutorials can be found here

These tutorials cover how to perform techniques such as federated learning and differential privacy using PySyft.

High-level Architecture

alt text

Start Contributing

The guide for contributors can be found here. It covers all that you need to know to start contributing code to PySyft in an easy way.

Also join the rapidly growing community of 5000+ on Slack. The slack community is very friendly and great about quickly answering questions about the use and development of PySyft!

Troubleshooting

We have written an installation example in this colab notebook, you can use it as is to start working with PySyft on the colab cloud, or use this setup to fix your installation locally.

Organizational Contributions

We are very grateful for contributions to PySyft from the following organizations!

Udacity coMind Arkhn Dropout Labs

Disclaimer

Do NOT use this code to protect data (private or otherwise) - at present it is very insecure. Come back in a couple months.

License

Apache License 2.0

FOSSA Status

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

syft-0.2.0a1.tar.gz (210.7 kB view details)

Uploaded Source

Built Distributions

syft-0.2.0a1-py3.7.egg (787.6 kB view details)

Uploaded Source

syft-0.2.0a1-py3-none-any.whl (339.0 kB view details)

Uploaded Python 3

File details

Details for the file syft-0.2.0a1.tar.gz.

File metadata

  • Download URL: syft-0.2.0a1.tar.gz
  • Upload date:
  • Size: 210.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.4

File hashes

Hashes for syft-0.2.0a1.tar.gz
Algorithm Hash digest
SHA256 88b2628b1cd7572396221c3cb2dcba8dccb48531af5a848d02895101dcdcc60f
MD5 a5f8794836a6d2e5e5ce45c90fc5b2d7
BLAKE2b-256 27c36a2a4119d2a4acc555a5e009190a9465446edaaf31c18254a0d07daf4343

See more details on using hashes here.

File details

Details for the file syft-0.2.0a1-py3.7.egg.

File metadata

  • Download URL: syft-0.2.0a1-py3.7.egg
  • Upload date:
  • Size: 787.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.3

File hashes

Hashes for syft-0.2.0a1-py3.7.egg
Algorithm Hash digest
SHA256 7be3fad58bf21077d6597562669c93573e1a48c7148e984193a622e70f85dbad
MD5 29064827d1fd468613b98f3127409acb
BLAKE2b-256 d988d289ef35d16d6de7f9b5800c8562e9a96724d39a1d51bf119f7793a45d7b

See more details on using hashes here.

File details

Details for the file syft-0.2.0a1-py3-none-any.whl.

File metadata

  • Download URL: syft-0.2.0a1-py3-none-any.whl
  • Upload date:
  • Size: 339.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.4

File hashes

Hashes for syft-0.2.0a1-py3-none-any.whl
Algorithm Hash digest
SHA256 e2c68037156e7f42d914e0b8f1978c09b6e708a1f8b25c47eba8c8a16cda5145
MD5 2739c1e41ee544166430af161d68f2a6
BLAKE2b-256 73eec69e76e410f895f253f805810ca1ec89b99576398651bf9868b548f0ef62

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page