You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
tf-encrypted is a Python library built on top of [TensorFlow](https://www.tensorflow.org) for researchers and practitioners to experiment with privacy-preserving machine learning. It provides an interface similar to that of TensorFlow, and aims at making the technology readily available without first becoming an expert in machine learning, cryptography, distributed systems, and high performance computing.
5
+
TF Encrypted is a Python library built on top of [TensorFlow](https://www.tensorflow.org) for researchers and practitioners to experiment with privacy-preserving machine learning. It provides an interface similar to that of TensorFlow, and aims at making the technology readily available without first becoming an expert in machine learning, cryptography, distributed systems, and high performance computing.
6
6
7
7
In particular, the library focuses on:
8
8
@@ -18,7 +18,7 @@ The project has benefitted enormously from the efforts of several contributors f
18
18
19
19
# Installation
20
20
21
-
tf-encrypted is available as a package on [PyPI](https://pypi.org/project/tf-encrypted/) supporting Python 3.5+ and TensorFlow 1.12.0+ which can be installed using:
21
+
TF Encrypted is available as a package on [PyPI](https://pypi.org/project/tf-encrypted/) supporting Python 3.5+ and TensorFlow 1.12.0+ which can be installed using:
22
22
23
23
```bash
24
24
pip3 install tf-encrypted
@@ -32,17 +32,17 @@ cd tf-encrypted
32
32
pip3 install -e .
33
33
```
34
34
35
-
This latter is useful on platforms for which the pip package has not yet been compiled but is also needed for [development](./.github/CONTRIBUTING.md). Note that this will get you a working basic installation, yet [a few more steps](./INSTALL.md) are required to match the performance and security of the version shipped in the pip package.
35
+
This latter is useful on platforms for which the pip package has not yet been compiled but is also needed for [development](./.github/CONTRIBUTING.md). Note that this will get you a working basic installation, yet a few more steps are required to match the performance and security of the version shipped in the pip package, see [INSTALL.md](./docs/INSTALL.md).
36
36
37
37
## Custom build of TensorFlow
38
38
39
-
While tf-encrypted will work with the official release of [TensorFlow](https://pypi.org/project/tensorflow/) (version 1.12+), some features currently depend on improvements that have not yet been shipped. In particular, to get speed improvements by using int64 tensors instead of int100 tensors you currently need a custom build of TensorFlow.
39
+
While TF Encrypted will work with the official release of [TensorFlow](https://pypi.org/project/tensorflow/) (version 1.12+), some features currently depend on improvements that have not yet been shipped. In particular, to get speed improvements by using int64 tensors instead of int100 tensors you currently need a custom build of TensorFlow.
40
40
41
-
Such builds are available for [macOS](https://storage.googleapis.com/dropoutlabs-tensorflow-builds/tensorflow-1.12.0-cp35-cp35m-macosx_10_7_x86_64.whl) and [Linux](https://storage.googleapis.com/dropoutlabs-tensorflow-builds/tensorflow-1.12.0-cp35-cp35m-linux_x86_64.whl) as a temporary solution until the next official release of TensorFlow is out (version 1.13), but no guarantees are made about them and they should be treated as pre-alpha. See more in the [installation instructions](./INSTALL.md#custom-tensorflow).
41
+
Such builds are available for [macOS](https://storage.googleapis.com/dropoutlabs-tensorflow-builds/tensorflow-1.12.0-cp35-cp35m-macosx_10_7_x86_64.whl) and [Linux](https://storage.googleapis.com/dropoutlabs-tensorflow-builds/tensorflow-1.12.0-cp35-cp35m-linux_x86_64.whl) as a temporary solution until the next official release of TensorFlow is out (version 1.13), but no guarantees are made about them and they should be treated as pre-alpha. See more in the [installation instructions](./docs/INSTALL.md#custom-tensorflow).
42
42
43
43
# Usage
44
44
45
-
The following is an example of simple matmul on encrypted data using tf-encrypted:
45
+
The following is an example of simple matmul on encrypted data using TF Encrypted:
46
46
47
47
```python
48
48
import tensorflow as tf
@@ -81,7 +81,7 @@ The following texts provide further in-depth presentations of the project:
81
81
82
82
# Project Status
83
83
84
-
tf-encrypted is experimental software not currently intended for use in production environments. The focus is on building the underlying primitives and techniques, with some practical security issues post-poned for a later stage. However, care is taken to ensure that none of these represent fundamental issues that cannot be fixed as needed.
84
+
TF Encrypted is experimental software not currently intended for use in production environments. The focus is on building the underlying primitives and techniques, with some practical security issues postponed for a later stage. However, care is taken to ensure that none of these represent fundamental issues that cannot be fixed as needed.
Copy file name to clipboardexpand all lines: docs/CONTRIBUTING.md
+5-4
Original file line number
Diff line number
Diff line change
@@ -1,26 +1,26 @@
1
1
# Contribution Guide
2
2
3
-
The goal of `tf-encrypted` is to make it easy for researchers and practitioners to experiment with various tricks and techniques for privacy-preserving machine learning. As such, contributions are more than welcome and we're always looking for use cases, feature ideas, cryptographic protocols, or machine learning optimizations!
3
+
The goal of TF Encrypted is to make it easy for researchers and practitioners to experiment with various tricks and techniques for privacy-preserving machine learning. As such, contributions are more than welcome and we're always looking for use cases, feature ideas, cryptographic protocols, or machine learning optimizations!
4
4
5
5
This document helps you get started on:
6
6
7
7
-[Submitting a pull request](#submitting-a-pull-request)
8
8
-[Writing documentation](#writing-documentation)
9
9
-[Reporting a bug](#reporting-a-bug)
10
10
11
-
Please visit the [installation instructions](/INSTALL.md) for help on setting up for development.
11
+
Please visit the [installation instructions](./INSTALL.md) for help on setting up for development.
12
12
13
13
# Submitting a Pull Request
14
14
15
-
To contribute, [fork](https://help.github.com/articles/fork-a-repo/)`tf-encrypted`, commit your changes, and [open a pull request](https://help.github.com/articles/using-pull-requests/).
15
+
To contribute, [fork](https://help.github.com/articles/fork-a-repo/)TF Encrypted, commit your changes, and [open a pull request](https://help.github.com/articles/using-pull-requests/).
16
16
17
17
While you may be asked to make changes to your submission during the review process, we will work with you on this and suggest changes. Consider giving us [push rights to your branch](https://help.github.com/articles/allowing-changes-to-a-pull-request-branch-created-from-a-fork/) so we can potentially also help via commits.
18
18
19
19
## Commit history and merging
20
20
21
21
For the sake of transparency our key rule is to keep a logical and intelligible commit history, meaning anyone stepping through the commits on either the `master` branch or as part of a review should be able to easily follow the changes made and their potential implications.
22
22
23
-
To this end we ask all contributors to sanitise pull requests before submitting them as our preferred way of merging pull requests is rebasing.
23
+
To this end we ask all contributors to sanitize pull requests before submitting them as our preferred way of merging pull requests is rebasing.
24
24
25
25
Some guidelines:
26
26
@@ -73,6 +73,7 @@ make docs
73
73
command which will
74
74
subsequently output the html version of our docs to your `build` folder. You
75
75
can view the docs after their built using your browser by running
Copy file name to clipboardexpand all lines: docs/INSTALL.md
+5-5
Original file line number
Diff line number
Diff line change
@@ -1,6 +1,6 @@
1
1
# Installation
2
2
3
-
The most convenient way of installing tf-encrypted is via [the official pip package](https://pypi.org/project/tf-encrypted/):
3
+
The most convenient way of installing TF Encrypted is via [the official pip package](https://pypi.org/project/tf-encrypted/):
4
4
5
5
```
6
6
pip3 install tf-encrypted
@@ -44,7 +44,7 @@ We address both below but stress that they can be skipped for initial experiment
44
44
45
45
# Custom Ops
46
46
47
-
Certains operations, such as secure randomness generation, rely on C++ extensions of TensorFlow known as [custom ops](https://www.tensorflow.org/guide/extend/op). These come precompiled with the [tf-encrypted pip package](https://pypi.org/project/tf-encrypted/) but need to be manually compiled when installing from source code as done above.
47
+
Certains operations, such as secure randomness generation, rely on C++ extensions of TensorFlow known as [custom ops](https://www.tensorflow.org/guide/extend/op). These come precompiled with the [pip package](https://pypi.org/project/tf-encrypted/) but need to be manually compiled when installing from source code as done above.
48
48
49
49
On macOS this is straight forward once libtool and automake are installed (see the [detailed instructions](#complete-instructions)):
50
50
@@ -100,7 +100,7 @@ after making sure flake8 is installed:
100
100
101
101
# Custom TensorFlow
102
102
103
-
While tf-encrypted will work with the official release of [TensorFlow](https://pypi.org/project/tensorflow/) (version 1.12+), some features currently depend on improvements that have not yet been shipped. In particular, to get speed improvements from using int64 instead of int100 tensors you currently need a custom build of TensorFlow.
103
+
While TF Encrypted will work with the official release of [TensorFlow](https://pypi.org/project/tensorflow/) (version 1.12+), some features currently depend on improvements that have not yet been shipped. In particular, to get speed improvements from using int64 instead of int100 tensors you currently need a custom build of TensorFlow.
104
104
105
105
We provide such builds as a temporary solution until the next official release of TensorFlow is out (version 1.13), but no guarantees are made about them and they should be treated as experimental:
106
106
@@ -115,7 +115,7 @@ In both cases should you end up with a wheel file that you can install using pip
115
115
(venv) ./ $ pip install tensorflow-1.13.0-XXX.whl
116
116
```
117
117
118
-
tf-encrypted auto-detects which features are available so no further actions are needed.
118
+
TF Encrypted auto-detects which features are available so no further actions are needed.
119
119
120
120
# Complete Instructions
121
121
@@ -213,7 +213,7 @@ We finally close the repository:
213
213
./ $ cd tf-encrypted
214
214
```
215
215
216
-
install tf-encrypted outside a virtual environment and without dependencies:
216
+
install TF Encrypted outside a virtual environment and without dependencies:
@@ -69,7 +69,7 @@ Two servers and a crypto producer are doing the actual computation on encrypted
69
69
## Private Predictions
70
70
### a. Locally
71
71
72
-
With tf-encrypted, you can very easily make private predictions with a pre-trained model saved as a [protobuf](https://www.tensorflow.org/extend/tool_developers/) file.
72
+
With TF Encrypted, you can very easily make private predictions with a pre-trained model saved as a [protobuf](https://www.tensorflow.org/extend/tool_developers/) file.
73
73
74
74
1. In the [`examples/`](./examples/) folder run the following line of code in your terminal to train a convolution network on MNIST dataset, then save the model as a protobuf file :
Copy file name to clipboardexpand all lines: docs/source/index.rst
+2-2
Original file line number
Diff line number
Diff line change
@@ -3,10 +3,10 @@
3
3
You can adapt this file completely to your liking, but it should at least
4
4
contain the root `toctree` directive.
5
5
6
-
tf-encrypted
6
+
TF Encrypted
7
7
========================================
8
8
9
-
tf-encrypted is a Python library built on top of TensorFlow_ for researchers and practitioners to experiment with privacy-preserving machine learning. It provides an interface similar to that of TensorFlow, and aims at making the technology readily available without first becoming an expert in machine learning, cryptography, distributed systems, and high performance computing.
9
+
TF Encrypted is a Python library built on top of TensorFlow_ for researchers and practitioners to experiment with privacy-preserving machine learning. It provides an interface similar to that of TensorFlow, and aims at making the technology readily available without first becoming an expert in machine learning, cryptography, distributed systems, and high performance computing.
0 commit comments