Skip to content

Tensorflow implementation of the `intelligent synapse' model from [Zenke et al., (2017)] and application to the Permuted MNIST benchmark.

Notifications You must be signed in to change notification settings

spiglerg/TF_ContinualLearningViaSynapticIntelligence

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 
 
 

Repository files navigation

TF_ContinualLearningViaSynapticIntelligence

TensorFlow implementation of the `intelligent synapse' model from [Zenke et al., (2017)] and application to the Permuted MNIST benchmark.

This project re-implements the model by Zenke, Poole and Ganguli (2017) in TensorFlow and tests it on the Permuted MNIST benchmark. The Permuted MNIST is a sequence of classification tasks in which the pixels of the input images are swapped with a random permutation specific to each task.

As part of the project, source is provided to visualize the learning trajectory in weights space in a bidimensional dummy case.

The implementation can be compared against normal Stochastic Gradient Descent by disabling the auxiliary weights-protection loss (`param_c=0') in each source file.

Results

Performance for Synaptic Intelligence (left) is still at 93% after training on 10 Permuted MNIST tasks. On the contrary, standard Stochastic Gradient Descent is around 76%. The final accuracy is lower than that reported in the main paper. This is due to our use of a smaller network and its lack of dropout. Both modifications are easy to make and achieve significantly improved performance. Also note that different optimizers may be used instead of SGD. However, in that case, the code should be modified to compute the weights changes at each step explicitly (the code is available on request but it is not in this repository yet). alt tag

Trajectory in weights space while optimizing two Tasks in sequence, Task 1 first (left) followed by Task 2 (center). The contour plots outline the error surface for each task, together with their joint one (average of the two) in the right panel. alt tag

The model by Zenke et al. (2017) effectively manages to mitigate the problem, converging near the correct multi-task minimum. alt tag

References.

Zenke, F., Poole, B., & Ganguli, S. (2017). Improved multitask learning through synaptic intelligence. arXiv preprint https://arxiv.org/abs/1703.04200

About

Tensorflow implementation of the `intelligent synapse' model from [Zenke et al., (2017)] and application to the Permuted MNIST benchmark.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages