1
0
Fork 0
mirror of https://github.com/tensorflow/haskell.git synced 2024-11-16 16:09:43 +01:00
tensorflow-haskell/README.md
Judah Jacobson 54eddcc6bd Add instructions for building on Mac OS X. (#8)
* Add instructions for building on Mac OS X.
* Include /usr/local/lib directly in stack.yaml.
2016-10-26 11:13:42 -07:00

1.7 KiB

The tensorflow-haskell package provides Haskell bindings to TensorFlow.

This is not an official Google product.

Instructions

Build with Docker on Linux

As an expedient we use docker for building. Once you have docker working, the following commands will compile and run the tests.

git clone --recursive https://github.com/tensorflow/haskell.git tensorflow-haskell
cd tensorflow-haskell
IMAGE_NAME=tensorflow/haskell:v0
docker build -t $IMAGE_NAME docker
# TODO: move the setup step to the docker script.
stack --docker --docker-image=$IMAGE_NAME setup
stack --docker --docker-image=$IMAGE_NAME test

There is also a demo application:

cd tensorflow-mnist
stack --docker --docker-image=$IMAGE_NAME build --exec Main

Build on Mac OS X

The following instructions were verified with Mac OS X El Capitan.

  • Install dependencies via Homebrew:

      brew install swig
      brew install bazel
    
  • Build the TensorFlow library and install it on your machine:

      cd third_party/tensorflow
      ./configure  # Choose the defaults when prompted
      bazel build -c opt tensorflow:libtensorflow_c.so
      install bazel-bin/tensorflow/libtensorflow_c.so /usr/local/lib
      cd ../..
    
  • Run stack:

      stack test
    

Note: you may need to upgrade your version of Clang if you get an error like the following:

tensorflow/core/ops/ctc_ops.cc:60:7: error: return type 'tensorflow::Status' must match previous return type 'const ::tensorflow::Status' when lambda expression has unspecified explicit return type
    return Status::OK();

In that case you can just upgrade XCode and then run gcc --version to get the new version of the compiler.