Skip to main content

TF-Shell: Privacy preserving machine learning with Tensorflow and the SHELL encryption library, built for python 3.10.

Project description

tf-shell

The tf-shell library supports privacy preserving machine learning with homomorphic encryption via the SHELL library and tensorflow.

This is not an officially supported Google product.

Getting Started

pip install tf-shell

See ./examples/ for how to use the library.

Background

Homomorphic encryption allows computation on encrypted data. For example, given two ciphertexts a and b representing the numbers 3 and 4, respectively, one can compute a ciphertext c representing the number 7 without decrypting a or b. This is useful for privacy preserving machine learning because it allows training a model on encrypted data.

The SHELL encryption library supports homomorphic encryption with respect to addition and multiplication. This means that one can compute the sum of two ciphertexts or the product of two ciphertexts without decrypting them. SHELL does not support fully homomorphic encryption, meaning computing functions of ciphertexts with arbitrary depth. That said, because machine learning models are of bounded depth, the performance benefits of leveled schemes (without bootstrapping, e.g. SHELL) outweight limitations in circuit depth.

Design

This library has two modules, tf_shell which supports Tensorflow Tensors containing ciphertexts with homomorphic properties, and tf_shell_ml some (very) simple machine learning tools supporting privacy preserving training.

tf-shell is designed for Label-DP SGD where training data is vertically partitioned, e.g. one party holds features while another party holds labels. The party who holds the features would like to train a model without learning the labels. The resultant trained model is differentially private with respect to the labels.

Building

Build From Source

  1. Install bazel and python3 or use the devcontainer.

  2. Run the tests.

    bazel test ...
    
  3. Build the code.

    bazel build //:wheel
    bazel run //:wheel_rename
    
  4. (Optional) Install the wheel, e.g. to try out the ./examples/. You may first need to copy the wheel out of the devcontainer's filesystem.

    cp -f bazel-bin/*.whl ./  # Run in devcontainer if using.
    

    Then install.

    pip install --force-reinstall tf_shell-*.whl  # Run in target environment.
    

Note the cpython api is not compatible across minor python versions (e.g. 3.10, 3.11) so the wheel must be rebuilt for each python version.

Code Formatters and Counters

bazel run //:bazel_formatter
bazel run //:python_formatter
bazel run //:clang_formatter
cloc ./ --fullpath --not-match-d='/(bazel-.*|.*\.venv)/'

Update Python Dependencies

Update requirements.in and run the following to update the requirements files for each python version.

for ver in 3_9 3_10 3_11 3_12; do
  rm requirements_${ver}.txt
  touch requirements_${ver}.txt
  bazel run //:requirements_${ver}.update
done

bazel clean --expunge

If updating the tensorflow dependency, other dependencies may also need to change, e.g. abseil (see MODULE.bazel). This issue usually manifests as a missing symbols error in the tests when trying to import the tensorflow DSO. In this case, c++filt will help to decode the mangled symbol name and nm --defined-only .../libtensorflow_framework.so | grep ... may help find what the symbol changed to, and which dependency is causing the error.

Contributing

See CONTRIBUTING.md for details.

License

Apache 2.0; see LICENSE for details.

Disclaimer

This project is not an official Google project. It is not supported by Google and Google specifically disclaims all warranties as to its quality, merchantability, or fitness for a particular purpose.

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

tf_shell-0.1.9-cp311-cp311-manylinux_2_35_x86_64.whl (1.9 MB view details)

Uploaded CPython 3.11 manylinux: glibc 2.35+ x86-64

tf_shell-0.1.9-cp310-cp310-manylinux_2_35_x86_64.whl (1.9 MB view details)

Uploaded CPython 3.10 manylinux: glibc 2.35+ x86-64

tf_shell-0.1.9-cp39-cp39-manylinux_2_35_x86_64.whl (1.9 MB view details)

Uploaded CPython 3.9 manylinux: glibc 2.35+ x86-64

File details

Details for the file tf_shell-0.1.9-cp311-cp311-manylinux_2_35_x86_64.whl.

File metadata

File hashes

Hashes for tf_shell-0.1.9-cp311-cp311-manylinux_2_35_x86_64.whl
Algorithm Hash digest
SHA256 c485cbbb671c2b120369edc9c80eae8ccc3a825e13776171b7cf752e776bab42
MD5 236d72931c68f5468a60786374cd50de
BLAKE2b-256 d2358a877cc633a3a5920618f9e6e63fcea7b6f5e3428bc1d426d461fa344ac5

See more details on using hashes here.

Provenance

The following attestation bundles were made for tf_shell-0.1.9-cp311-cp311-manylinux_2_35_x86_64.whl:

Publisher: GitHub
  • Repository: google/tf-shell
  • Workflow: wheel.yaml
Attestations:
  • Statement type: https://in-toto.io/Statement/v1
    • Predicate type: https://docs.pypi.org/attestations/publish/v1
    • Subject name: tf_shell-0.1.9-cp311-cp311-manylinux_2_35_x86_64.whl
    • Subject digest: c485cbbb671c2b120369edc9c80eae8ccc3a825e13776171b7cf752e776bab42
    • Transparency log index: 145049821
    • Transparency log integration time:

File details

Details for the file tf_shell-0.1.9-cp310-cp310-manylinux_2_35_x86_64.whl.

File metadata

File hashes

Hashes for tf_shell-0.1.9-cp310-cp310-manylinux_2_35_x86_64.whl
Algorithm Hash digest
SHA256 1b60f7f552a1903a41127715207f3b8e2fdf1bf078328367fc16fa354d1386bd
MD5 21ceeae6b727c990d8a1c87b084535aa
BLAKE2b-256 16337c5ed1d34bf5c82d007c76273207da1a622cc1eb28dc715f09cbf8d95d93

See more details on using hashes here.

Provenance

The following attestation bundles were made for tf_shell-0.1.9-cp310-cp310-manylinux_2_35_x86_64.whl:

Publisher: GitHub
  • Repository: google/tf-shell
  • Workflow: wheel.yaml
Attestations:
  • Statement type: https://in-toto.io/Statement/v1
    • Predicate type: https://docs.pypi.org/attestations/publish/v1
    • Subject name: tf_shell-0.1.9-cp310-cp310-manylinux_2_35_x86_64.whl
    • Subject digest: 1b60f7f552a1903a41127715207f3b8e2fdf1bf078328367fc16fa354d1386bd
    • Transparency log index: 145049820
    • Transparency log integration time:

File details

Details for the file tf_shell-0.1.9-cp39-cp39-manylinux_2_35_x86_64.whl.

File metadata

File hashes

Hashes for tf_shell-0.1.9-cp39-cp39-manylinux_2_35_x86_64.whl
Algorithm Hash digest
SHA256 1db1f773768e52fefbc0b30cfe0c487c2be18f8224bc29b16e824dc8a580e0aa
MD5 6bf823db5d55f4d1ed1465bbf49a98f9
BLAKE2b-256 25e27b1cc9820495c4c44d6034deba2bce56cd82ca34bfc870bbad586698cd98

See more details on using hashes here.

Provenance

The following attestation bundles were made for tf_shell-0.1.9-cp39-cp39-manylinux_2_35_x86_64.whl:

Publisher: GitHub
  • Repository: google/tf-shell
  • Workflow: wheel.yaml
Attestations:
  • Statement type: https://in-toto.io/Statement/v1
    • Predicate type: https://docs.pypi.org/attestations/publish/v1
    • Subject name: tf_shell-0.1.9-cp39-cp39-manylinux_2_35_x86_64.whl
    • Subject digest: 1db1f773768e52fefbc0b30cfe0c487c2be18f8224bc29b16e824dc8a580e0aa
    • Transparency log index: 145049822
    • Transparency log integration time:

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