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

Non-contiguous subgroups #1229

Open
wants to merge 68 commits into
base: master
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
68 commits
Select commit Hold shift + click to select a range
604e633
WIP: First steps to generalize subgroups to be non-contiguous
mstimberg Feb 21, 2020
d67ca90
Update SpikeMonitor for non-contiguous subgroups
mstimberg Feb 24, 2020
eeff84b
Sort indices before their use in Subgroup
mstimberg Feb 25, 2020
97659da
Fix logic error in Cython/C++ SpikeMonitor code
mstimberg Feb 25, 2020
4672adf
Make PopulationRateMonitor work with non-contiguous subgroups
mstimberg Feb 25, 2020
4c677f0
Add subgroups test for StateMonitor
mstimberg Feb 26, 2020
db2dcd5
Fix subgroups of SpatialNeuron
mstimberg Feb 26, 2020
aa9237d
Forbid using non-contiguous subgroups in Synapses
mstimberg Feb 26, 2020
db3ddf4
Enable string expressions for subgroups
mstimberg Feb 26, 2020
f0a34d1
Make string expressions for subgroups/indexing work in standalone
mstimberg Feb 27, 2020
5acd917
Fix string indexing with references to external constants
mstimberg Feb 28, 2020
33f537e
Make doctest compatible with Windows output for 32bit ints
mstimberg Sep 14, 2020
b477583
Do not allow unsorted indices in subgroups
mstimberg Sep 14, 2020
0cfe648
Merge branch 'master' into non_contiguous_subgroup
mstimberg Jan 4, 2021
e48f89b
Merge branch 'master' into non_contiguous_subgroup
mstimberg Feb 22, 2021
92aff0b
Merge branch 'master' into non_contiguous_subgroup
mstimberg Apr 21, 2021
cdb5427
Fix a remaining case of a deprecated numpy scalar
mstimberg Apr 21, 2021
35bf32f
Merge remote-tracking branch 'origin/master' into non_contiguous_subg…
mstimberg Feb 8, 2022
3032909
Merge branch 'master' into non_contiguous_subgroup
mstimberg Feb 9, 2022
3177307
Merge remote-tracking branch 'origin/master' into non_contiguous_subg…
mstimberg Apr 29, 2022
89430b9
minor optimization for non-contiguous subgroups
mstimberg May 2, 2022
269d9e0
make PoissonGroup work with non-contiguous subgroups
mstimberg May 2, 2022
73cd6d9
make SpikeMonitor generated code deterministic
mstimberg May 2, 2022
d0abc65
Check for illegal subgroup indices in consistent way
mstimberg May 2, 2022
afd5324
Merge branch 'non_contiguous_subgroup' of github.com:brian-team/brian…
mstimberg May 2, 2022
20e0efb
revert run_tests script to original version
mstimberg May 2, 2022
3ae9e1a
Add/update tests for subgroups
mstimberg May 2, 2022
fd2933d
Merge branch 'master' into non_contiguous_subgroup
mstimberg Jun 8, 2022
c57e129
Merge branch 'master' into non_contiguous_subgroup
mstimberg Oct 19, 2022
d8707aa
Update documentation for non-contiguous subgroups
mstimberg Nov 10, 2022
7e495bb
Some more basic tests for incorrect subgroup creation
mstimberg Nov 10, 2022
ec0fe52
Merge branch 'master' into non_contiguous_subgroup
mstimberg Nov 10, 2022
aaacc26
Fix exception type in subgroup tests
mstimberg Nov 14, 2022
22629b8
Test+doc for non-contiguous indices in SpatialNeuron
mstimberg Nov 14, 2022
209d239
Merge branch 'master' into non_contiguous_subgroup
mstimberg Nov 22, 2022
65ec4c3
Remove deprecated usage of np.bool
mstimberg Nov 22, 2022
82e3ffc
Fragile but basic working version of SynapticSubgroup
mstimberg Mar 23, 2023
6f84542
Merge branch 'master' into non_contiguous_subgroup
mstimberg Mar 24, 2023
5509437
Remove unnecessary imports
mstimberg Mar 24, 2023
fe861b7
Add tests for synaptic subgroups
mstimberg Mar 24, 2023
73d214f
Support array indexing for multi-synaptic indices
mstimberg Mar 24, 2023
e51b0ae
Refactor `Group.Indexing` for better readability
mstimberg Mar 29, 2023
6ceba16
Add new tests for synaptic subgroups
mstimberg Mar 29, 2023
dbbb741
Small refactoring for synaptic indexing
mstimberg Mar 30, 2023
2ff3cb1
Fix a test
mstimberg Mar 31, 2023
fe0add7
Write sizes of dynamic arrays to disk after run in standalone mode
mstimberg Mar 31, 2023
eaf1efa
Simplify RateMonitor template for non-contiguous subgroup
mstimberg Apr 7, 2023
3759bf7
Minor reformatting in test
mstimberg Apr 7, 2023
2c4787b
Fail for out-of-range 1d array indices in Synapses
mstimberg Apr 19, 2023
53ae0d8
Handle scalar synaptic indices correctly
mstimberg Apr 20, 2023
6d27f53
Raise errors for boolean indices of incorrect shape
mstimberg Apr 20, 2023
adc17ec
Handle IndexErrors correctly for synapses as well
mstimberg Apr 20, 2023
fed868e
Install coveralls with pip everywhere
mstimberg Apr 20, 2023
d163840
Merge branch 'master' into non_contiguous_subgroup
mstimberg Jun 15, 2023
a7f6cbe
Fix incorrect merge
mstimberg Jun 15, 2023
1c050b2
Merge remote-tracking branch 'origin/master' into non_contiguous_subg…
mstimberg Oct 6, 2023
a7cd7f3
Do not force float64 in TimedArray
mstimberg Oct 26, 2023
437e3fe
Invalidate caches on each run
mstimberg Oct 26, 2023
de0ee35
Merge remote-tracking branch 'origin/master' into non_contiguous_subg…
mstimberg Oct 26, 2023
b476451
Fix cache invalidation
mstimberg Oct 30, 2023
285dffb
Correctly the return type of TimedArray functions in generated code
mstimberg Oct 30, 2023
4cb865b
WIP: Allow non-contiguous subgroups for synapses
mstimberg Nov 2, 2023
bb7ddb9
Allow non-contiguous subgroups for synapses
mstimberg Nov 14, 2023
ce5bb3b
Non-contiguous subgroups for synapses: summed variables
mstimberg Nov 14, 2023
16e2ffc
Test summed variable error for overlapping subgroups
mstimberg Nov 16, 2023
3097569
Merge branch 'master' into non_contiguous_subgroup
mstimberg Sep 13, 2024
f1ea1b5
minor fixes
mstimberg Sep 13, 2024
c21ec60
Re-add write sizes of dynamic arrays to disk
mstimberg Sep 13, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Do not allow unsorted indices in subgroups
Instead of raising a warning
  • Loading branch information
mstimberg committed Sep 14, 2020
commit b47758395a52547f808f70fe1a5bfca35cd5f503
7 changes: 2 additions & 5 deletions brian2/groups/subgroup.py
Original file line number Diff line number Diff line change
@@ -56,7 +56,7 @@ def to_start_stop_or_index(item, group, level=0):
(3, 6, None)
>>> to_start_stop_or_index([3, 5, 7], group) # doctest: +ELLIPSIS
(None, None, array([3, 5, 7]...))
>>> to_start_stop_or_index([-1, -2, -3], group)
>>> to_start_stop_or_index([-3, -2, -1], group)
(7, 10, None)
'''
start = stop = None
@@ -66,10 +66,7 @@ def to_start_stop_or_index(item, group, level=0):
indices = np.array([indices])

if not np.all(indices[:-1] <= indices[1:]):
logger.warn('The indices provided to create the subgroup were '
'not sorted. They will be sorted before use.',
name_suffix='unsorted_subgroup_indices')
indices.sort()
raise TypeError('Subgroups can only be created from ordered indices.')
if not len(indices) > 0:
raise IndexError('Cannot create an empty subgroup')

8 changes: 2 additions & 6 deletions brian2/tests/test_monitor.py
Original file line number Diff line number Diff line change
@@ -133,9 +133,8 @@ def test_spike_monitor_subgroups():
spikes_2 = SpikeMonitor(G[2:4])
spikes_3 = SpikeMonitor(G[4:])
spikes_indexed = SpikeMonitor(G[::2])
with catch_logs() as l:
spikes_indexed_unsorted = SpikeMonitor(G[[4, 0, 2]]) # This should not make a difference
assert len(l) == 1 and l[0][1].endswith('.unsorted_subgroup_indices')
with pytest.raises(TypeError):
SpikeMonitor(G[[4, 0, 2]]) # unsorted
run(defaultclock.dt)
# Spikes
assert_allclose(spikes_all.i, [0, 4, 5])
@@ -148,15 +147,12 @@ def test_spike_monitor_subgroups():
assert_allclose(spikes_3.t, [0, 0] * ms)
assert_allclose(spikes_indexed.i, [0, 2])
assert_allclose(spikes_indexed.t, [0, 0]*ms)
assert_allclose(spikes_indexed_unsorted.i, [0, 2])
assert_allclose(spikes_indexed_unsorted.t, [0, 0]*ms)
# Spike count
assert_allclose(spikes_all.count, [1, 0, 0, 0, 1, 1])
assert_allclose(spikes_1.count, [1, 0])
assert_allclose(spikes_2.count, [0, 0])
assert_allclose(spikes_3.count, [1, 1])
assert_allclose(spikes_indexed.count, [1, 0, 1])
assert_allclose(spikes_indexed_unsorted.count, [1, 0, 1])


def test_spike_monitor_bug_824():
3 changes: 1 addition & 2 deletions brian2/tests/test_subgroup.py
Original file line number Diff line number Diff line change
@@ -683,7 +683,7 @@ def test_spike_monitor():
@pytest.mark.codegen_independent
@pytest.mark.parametrize('item', [slice(10, None), slice(3, 2),
[9, 10], [10, 11], [2.5, 3.5, 4.5],
[5, 5, 5], []])
[5, 5, 5], [], [5, 4, 3]])
def test_wrong_indexing(item):
G = NeuronGroup(10, 'v:1')
with pytest.raises((TypeError, IndexError)):
@@ -696,7 +696,6 @@ def test_wrong_indexing(item):
(3, np.array([3])),
([3, 4, 5], np.array([3, 4, 5])),
([3, 5, 7], np.array([3, 5, 7])),
([7, 5, 3], np.array([3, 5, 7])),
([3, -1], np.array([3, 9]))])
def test_alternative_indexing(item, expected):
G = NeuronGroup(10, 'v : integer')