Skip to content

Latest commit

 

History

History
76 lines (36 loc) · 2.14 KB

README.md

File metadata and controls

76 lines (36 loc) · 2.14 KB

Code for NeurIPS 2020 paper: Neural Execution Engines: Learning to Execute Subroutines

Authors: Yujun Yan, Kevin Swersky, Danai Koutra, Parthasarathy Ranganathan, Milad Hashemi

Link to the paper: https://arxiv.org/abs/2006.08084

This folder only contains code to run NEE. For the baseline transformer model, it can be obtained from https://github.com/tensorflow/docs/blob/master/site/en/tutorials/text/transformer.ipynb

Software requirement:

This code was tested with Python 3.7.4, numpy 1.17.1 and tensorflow 2.0.0-rc0

Usage:

Please run the following commands in the folder run_exp

To see different options:

python run_experiment.py -h

General use:

python run_experiment.py -T [task_name] -R [reload_file_path] -H [number of holdout]

task_name options:

"add": addition task

"addhold": addition task with holdout

"mul": multiplication task

"merge": merge sort task

"sel": selection sort task

"predist": train Dijkstra's shortest path with graph traces

"premst": train Prim's minimum spanning tree with graph traces

"dist": evaluate Dijkstra's shortest path

"mst": evaluate Prim's minimum spanning tree

To note: run "dist" or "mst" require 2 file paths

To run graph algorithms, we need to first train it using:

Dijkstra: python run_experiment.py -T predist

Prim: python run_experiment.py -T premst

Then do the evaluation:

Using selection sort and test on various graphs:

Prim: python run_experiment.py -T mst -R Shortest_path_05_03_00_52 Shortest_path_05_03_00_52

Dijkstra: python run_experiment.py -T dist -R Shortest_path_05_03_00_52 Shortest_path_05_03_00_52

Using ER traces to train and test on various graphs:

Prim: python run_experiment.py -T mst -R premst_09_03_48_55 premst_09_03_48_55

Dijkstra: python run_experiment.py -T dist -R Shortest_path_05_03_00_52 predist_06_19_22_32

Embedding visualizations:

The embeddings (one for each bit) are stored in the folder of current execution. First transform the emb.npy into emb.mat and then change the directory path in the corresponding m file.

Since codes to run different task share similarities, I will mainly comment on run_sel_sort.py file for your reference.