Perform numpy-like analysis on data that remains in someone else's server
Quickstart
Linux macOS* Windowsโ โก
Install syft on Python 3.9 - 3.11
$ pip install -U syft -f https://whls.blob.core.windows.net/unstable/index.htmlLaunch a python dev Domain
# from Jupyter / Python
import syft as sy
sy.requires(">=0.8,<0.8.1")
node = sy.orchestra.launch(name="my-domain", port=8080, dev_mode=True, reset=True)# or from the command line
$ syft launch --name=my-domain --port=8080 --reset=True
Starting syft-node server on 0.0.0.0:8080Connect with our Python Client
import syft as sy
sy.requires(">=0.8,<0.8.1")
domain_client = sy.login(port=8080, email="info@openmined.org", password="changethis")Deploy to a Container Engine or Cloud
-
Install our handy
๐ต cli tool which makes deploying a Domain or Gateway server a one-liner:
pip install -U hagrid -
Then run our interactive jupyter Install ๐ง๐ฝโโ๏ธ WizardBETA:
hagrid quickstart -
In the tutorial you will learn how to install and deploy:
PySyft= ournumpy-like๐ Python library for computing onprivate datain someone else'sDomainPyGrid= our๐ณ docker/๐ง vmDomain&GatewayServers whereprivate datalives -
During quickstart we will deploy
PyGridto localhost with๐ณ docker, however๐ต HAGrid can deploy topodmanor a๐ง ubuntuVM onazure/gcp/ANY_IP_ADDRESSby using๐จ ansibleโ
Docs and Support
๐ API Example Notebooks๐ Docs#supporton Slack
Install Notes
- HAGrid 0.3 Requires:
๐ python๐ git- Run:pip install -U hagrid - Interactive Install ๐ง๐ฝโโ๏ธ WizardBETA Requires
๐ต hagrid: - Run:hagrid quickstart
โWindowsdoes not supportansible, preventing some remote deployment targets - PySyft 0.8 Requires:
๐ python 3.9 - 3.11- Run:pip install -U syft
*macOSApple Silicon users might need cmake:brew install cmake
โกWindowsusers must run this first:pip install jaxlib==0.4.10 -f https://whls.blob.core.windows.net/unstable/index.html - PyGrid Requires:
๐ณ dockeror๐ง ubuntuVM - Run:hagrid launch ...
Versions
0.8.1 (Beta) - dev branch ๐๐ฝ API
0.8.0 (Stable) - API
Deprecated:
0.7.0- Course 3 Updated0.6.0- Course 30.5.1- Course 2 + M1 Hotfix0.2.0-0.5.0
PySyft and PyGrid use the same version and its best to match them up where possible. We release weekly betas which can be used in each context:
PySyft (Stable): pip install -U syft
PyGrid (Stable) hagrid launch ... tag=latest
PySyft (Beta): pip install -U syft --pre
PyGrid (Beta): hagrid launch ... tag=beta
HAGrid is a cli / deployment tool so the latest version of hagrid is usually the best.
What is Syft?
Syft is OpenMined's open source stack that provides secure and private Data Science in Python. Syft decouples private data from model training, using techniques like Federated Learning, Differential Privacy, and Encrypted Computation. This is done with a numpy-like interface and integration with Deep Learning frameworks, so that you as a Data Scientist can maintain your current workflow while using these new privacy-enhancing techniques.
Why should I use Syft?
Syft allows a Data Scientist to ask questions about a dataset and, within privacy limits set by the data owner, get answers to those questions, all without obtaining a copy of the data itself. We call this process Remote Data Science. It means in a wide variety of domains across society, the current risks of sharing information (copying data) with someone such as, privacy invasion, IP theft and blackmail will no longer prevent the vast benefits such as innovation, insights and scientific discovery which secure access will provide.
No more cold calls to get access to a dataset. No more weeks of wait times to get a result on your query. It also means 1000x more data in every domain. PySyft opens the doors to a streamlined Data Scientist workflow, all with the individual's privacy at its heart.
Tutorials
|
|
|
|
|---|---|---|
|
|
|
Terminology
Community
Courses
|
|
|
|
|---|
Contributors
OpenMined and Syft appreciates all contributors, if you would like to fix a bug or suggest a new feature, please see our guidelines.
Supporters
|
|
|
|
|
|
|
|
|
|---|
Open Collective
OpenMined is a fiscally sponsored 501(c)(3) in the USA. We are funded by our generous supporters on Open Collective.
Disclaimer
Syft is under active development and is not yet ready for pilots on private data without our assistance. As early access participants, please contact us via Slack or email if you would like to ask a question or have a use case that you would like to discuss.
License
Apache License 2.0
Person icons created by Freepik - Flaticon
















