Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Improve error message for chip -> chip learning #208

Closed
arvoelke opened this issue Mar 28, 2019 · 0 comments
Closed

Improve error message for chip -> chip learning #208

arvoelke opened this issue Mar 28, 2019 · 0 comments
Assignees

Comments

@arvoelke
Copy link
Contributor

import nengo
import nengo_loihi

with nengo.Network() as model:
    nengo_loihi.add_params(model)
    
    a = nengo.Ensemble(100, 1)
    b = nengo.Ensemble(100, 1)
    model.config[b].on_chip = True
    
    nengo.Connection(a, b, learning_rule_type=nengo.PES())

with nengo_loihi.Simulator(model) as sim:
    pass
~/CTN/nengo-loihi/nengo_loihi/splitter.py in split(net, precompute, node_neurons, node_tau, remove_passthrough)
    132 
    133     # --- Step 2: place simple connections
--> 134     place_internetwork_connections(networks, conns)
    135 
    136     # --- Step 3: split complex connections

~/CTN/nengo-loihi/nengo_loihi/splitter.py in place_internetwork_connections(networks, conns)
    234         if pre_loc == post_loc:
    235             if pre_loc == "chip":
--> 236                 assert conn.learning_rule_type is None
    237             networks.move(conn, pre_loc)
    238 

AssertionError: 
@arvoelke arvoelke self-assigned this Mar 28, 2019
arvoelke added a commit that referenced this issue Mar 29, 2019
hunse pushed a commit that referenced this issue Apr 3, 2019
Most of the work done by the splitter is now done in the builder.
This should give more clarity and control over the mapping between
pre-build and post-build objects. The `SplitterDirective` class
takes on the organizational tasks of the old `Splitter`, giving
directives to the builder about what should be on- or off-chip.

Also:
- Add unit tests for splitter refactoring.
- Raise `BuildError` if learning objects are on_chip. Fixes #208
  and #209.
- Pass no decoder cache to sub-models. Decoder cache wasn't working
  due to lack of context manager which is normally constructed by
  the top-level network build. Fixes #207.
- Various improvements to passthrough removal, including not removing
  useful passthrough nodes.
  Outstanding issues include: #210, #212, #213
- Handle sliced probes. Closes #205.
- Check that splitter handles sliced probes. Closes #206.
- Test that splitter does not mutate network. Closes #211.
hunse pushed a commit that referenced this issue Apr 3, 2019
Most of the work done by the splitter is now done in the builder.
This should give more clarity and control over the mapping between
pre-build and post-build objects. The `SplitterDirective` class
takes on the organizational tasks of the old `Splitter`, giving
directives to the builder about what should be on- or off-chip.

Also:
- Add unit tests for splitter refactoring.
- Raise `BuildError` if learning objects are on_chip. Fixes #208
  and #209.
- Pass no decoder cache to sub-models. Decoder cache wasn't working
  due to lack of context manager which is normally constructed by
  the top-level network build. Fixes #207.
- Various improvements to passthrough removal, including not removing
  useful passthrough nodes.
  Outstanding issues include: #210, #212, #213
- Handle sliced probes. Closes #205.
- Check that splitter handles sliced probes. Closes #206.
- Test that splitter does not mutate network. Closes #211.
hunse pushed a commit that referenced this issue Apr 9, 2019
Most of the work done by the splitter is now done in the builder.
This should give more clarity and control over the mapping between
pre-build and post-build objects. The `SplitterDirective` class
takes on the organizational tasks of the old `Splitter`, giving
directives to the builder about what should be on- or off-chip.

Also:
- Add unit tests for splitter refactoring.
- Raise `BuildError` if learning objects are on_chip or learning and
  `precompute` are combined. Fixes #208 and #209.
- Pass no decoder cache to sub-models. Decoder cache wasn't working
  due to lack of context manager which is normally constructed by
  the top-level network build. Fixes #207.
- Handle sliced probes. Closes #205.
- Check that splitter handles sliced probes. Closes #206.
- Test that splitter does not mutate network. Closes #211.
- Simulation is now identical whether precompute is True or False,
  on both emulator and chip. The tolerance for test_precompute is
  now zero.
tbekolay pushed a commit that referenced this issue Apr 15, 2019
Most of the work done by the splitter is now done in the builder.
This should give more clarity and control over the mapping between
pre-build and post-build objects. The `SplitterDirective` class
takes on the organizational tasks of the old `Splitter`, giving
directives to the builder about what should be on- or off-chip.

Also:
- Add unit tests for splitter refactoring.
- Raise `BuildError` if learning objects are on_chip or learning and
  `precompute` are combined. Fixes #208 and #209.
- Pass no decoder cache to sub-models. Decoder cache wasn't working
  due to lack of context manager which is normally constructed by
  the top-level network build. Fixes #207.
- Handle sliced probes. Closes #205.
- Check that splitter handles sliced probes. Closes #206.
- Test that splitter does not mutate network. Closes #211.
- Simulation is now identical whether precompute is True or False,
  on both emulator and chip. The tolerance for test_precompute is
  now zero.
tbekolay pushed a commit that referenced this issue Apr 15, 2019
tbekolay pushed a commit that referenced this issue Apr 15, 2019
tbekolay pushed a commit that referenced this issue Apr 15, 2019
tbekolay pushed a commit that referenced this issue Apr 15, 2019
tbekolay pushed a commit that referenced this issue Apr 23, 2019
tbekolay pushed a commit that referenced this issue Apr 23, 2019
arvoelke added a commit that referenced this issue Apr 23, 2019
tbekolay pushed a commit that referenced this issue Apr 24, 2019
tbekolay pushed a commit that referenced this issue Apr 24, 2019
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Development

No branches or pull requests

1 participant