An open API service indexing awesome lists of open source software.

https://github.com/tf-encrypted/tf-big

Arbitrary precision integers in TensorFlow
https://github.com/tf-encrypted/tf-big

cryptography machine-learning tensorflow

Last synced: 12 months ago
JSON representation

Arbitrary precision integers in TensorFlow

Awesome Lists containing this project

README

          

# TF Big

TF Big adds big number support to TensorFlow, allowing computations to be performed on arbitrary precision integers. Internally these are represented as variant tensors of [GMP](https://gmplib.org/) values, and exposed in Python through the `tf_big.Tensor` wrapper for convenience. For importing and exporting, numbers are typically expressed as strings.

[![PyPI](https://img.shields.io/pypi/v/tf-big.svg)](https://pypi.org/project/tf-big/) [![CircleCI Badge](https://circleci.com/gh/tf-encrypted/tf-big/tree/master.svg?style=svg)](https://circleci.com/gh/tf-encrypted/tf-big/tree/master)

## Usage

```python
import tensorflow as tf
import tf_big

# load large values as strings
x = tf_big.constant([["100000000000000000000", "200000000000000000000"]])

# load ordinary TensorFlow tensors
y = tf_big.import_tensor(tf.constant([[3, 4]]))

# perform computation as usual
z = x * y

# export result back into a TensorFlow tensor
tf_res = tf_big.export_tensor(z)
print(tf_res)
```

## Installation

Python 3 packages are available from [PyPI](https://pypi.org/project/tf-big/):

```
pip install tf-big
```

See below for further instructions for setting up a development environment.

## Development

### Requirements

We recommend using [Miniconda](https://docs.conda.io/en/latest/miniconda.html) or [Anaconda](https://www.anaconda.com/distribution/) to set up and use a Python 3.5 or 3.6 environment for all instructions below:

```
conda create -n tfbig-dev python=3.6
source activate tfbig-dev
```

#### Ubuntu

The only requirement for Ubuntu is to have [docker installed](https://docs.docker.com/install/linux/docker-ce/ubuntu/). This is the recommended way to [build custom operations for TensorFlow](https://github.com/tensorflow/custom-op). We provide a custom development container for TF Big with all dependencies already installed.

#### macOS

Setting up a development environment on macOS is a little more involved since we cannot use a docker container. We need four things:

- Python (>= 3.5)
- [Bazel](https://www.bazel.build/) (>= 0.15.0)
- [GMP](https://gmplib.org/) (>= 6.1.2)
- [TensorFlow](https://www.tensorflow.org/) (see setup.py for version requirements for your TF Big version)

Using [Homebrew](https://brew.sh/) we first make sure that both [Bazel](https://docs.bazel.build/versions/master/install-os-x.html#install-with-installer-mac-os-x) and GMP are installed. We recommend using a Bazel version earlier than 1.0.0, e.g.:

```
brew tap bazelbuild/tap
brew extract bazel bazelbuild/tap --version 0.26.1
brew install gmp
brew install mmv
```

The remaining PyPI packages can then be installed using:

```
pip install -r requirements-dev.txt
```

### Testing

#### Ubuntu

Run the tests on Ubuntu by running the `make test` command inside of a docker container. Right now, the docker container doesn't exist on docker hub yet so we must first build it:

```
docker build -t tf-encrypted/tf-big:build .
```

Then we can run `make test`:

```
sudo docker run -it \
-v `pwd`:/opt/my-project -w /opt/my-project \
tf-encrypted/tf-big:0.1.0 /bin/bash -c "make test"
```

#### macOS

Once the development environment is set up we can simply run:

```
make test
```

This will install TensorFlow if not previously installed and build and run the tests.

### Building pip package

Just run:

```
make build && make bundle
```

For linux, doing it inside the tensorflow/tensorflow:custom-op container is recommended. Note that [CircleCI](#circle-ci) is currently used to build the official pip packages.

## Circle CI

We use [Circle CI](https://circleci.com/gh/tf-encrypted/workflows/tf-big) for integration testing and deployment of TF Big.

### Releasing

1. update version number in setup.py and push to master; this will build and tests wheels
2. iterate 1. until happy with the release, having potentially tested the wheel manually
3. when happy, tag a commit with semver label and push; this will build, test, and deploy wheels