| CARVIEW |
mathflow: Dependently typed tensorflow modeler
Flags
Automatic Flags
| Name | Description | Default |
|---|---|---|
| usepython | Use Python for test | Disabled |
Use -f <flag> to enable a flag, or -f -<flag> to disable that flag. More info
Downloads
- mathflow-0.1.0.0.tar.gz [browse] (Cabal source package)
- Package description (as included in the package)
Maintainer's Corner
For package maintainers and hackage trustees
Candidates
- No Candidates
| Versions [RSS] | 0.1.0.0 |
|---|---|
| Dependencies | base (>=4.7 && <5), process, singletons, template-haskell [details] |
| License | BSD-3-Clause |
| Copyright | 2017 Junji Hashimoto |
| Author | Junji Hashimoto |
| Maintainer | junji.hashimoto@gmail.com |
| Uploaded | by junjihashimoto at 2017-08-08T01:36:13Z |
| Category | Math |
| Home page | https://github.com/junjihashimoto/mathflow#readme |
| Source repo | head: git clone https://github.com/junjihashimoto/mathflow |
| Distributions | |
| Reverse Dependencies | 1 direct, 0 indirect [details] |
| Downloads | 914 total (3 in the last 30 days) |
| Rating | (no votes yet) [estimated by Bayesian average] |
| Your Rating |
|
| Status | Docs available [build log] Last success reported on 2017-08-08 [all 1 reports] |
Readme for mathflow-0.1.0.0
[back to package description]mathflow(Dependently typed tensorflow modeler)
This package provides a model of tensor-operations. The model is independent from tensorflow-binding of python and haskell, though this package generates python-code. tensor's dimensions and constraints are described by dependent types. The tensor-operations are based on tensorflow-api. Currently the model can be translated into python-code. To write this package, I refer to this neural network document and singletons.
Install
Install tensorflow of python and this package.
> sudo apt install python3 python3-pip
> pip3 install -U pip
> pip3 install tensorflow
> git clone git@github.com:junjihashimoto/mathflow.git
> cd mathflow
> stack install
Usage
About model
Model has a type of Tensor (dimensions:[Nat]) value-type output-type.
dimensionsare tensor-dimensions.value-typeis a value type like Integer or Float of tensorflow-data-types.output-typeis a type of code which this package generates. PyString-type is used for generating python-code.
This package makes tensorflow-graph from the mode. The model's endpoint is always a tensor-type.
At first write graph by using arithmetic operators like (+,-,,/), % (which is matrix multiply) and tensorflow-functions. Mathflow.{TF,TF.NN,TF.Train} packages define Tensorflow-functions.
A example is below.
testMatMul :: Tensor '[2,1] Int PyString
testMatMul =
let n1 = (Tensor "tf.constant([[2],[3]])") :: Tensor '[2,1] Int PyString
n2 = (Tensor "tf.constant([[2,0],[0,1]])") :: Tensor '[2,2] Int PyString
y = (n2 %* n1) :: Tensor '[2,1] Int PyString
in y
Create model and run it
Write tensorflow-model.
testMatMul :: Tensor '[2,1] Int PyString
testMatMul =
let n1 = (Tensor "tf.constant([[2],[3]])") :: Tensor '[2,1] Int PyString
n2 = (Tensor "tf.constant([[2,0],[0,1]])") :: Tensor '[2,2] Int PyString
y = n2 %* n1 :: Tensor '[2,1] Int PyString
in y
Run the model. This run function generates python-code and excecute the code by python.
main = do
(retcode,stdout,stderr) <- run testMatMul
print stdout
