Hi @nvar. I’ve only just now realized that I never replied to this post… Although it might no longer be relevant to you, it might be to others, so let me quickly comment here:
Having a mechanism in monitors that allows you to calculate some “reduction” of multiple values (most importantly sum/average, but something like min/max might be useful as well sometimes), is something that we have discussed for a long time (see e.g. Code generation syntax for reductions? · Issue #180 · brian-team/brian2 · GitHub), but unfortunately we never got around implementing anything. The good news, though, is that we have a general mechanism to combine information from several neurons which can be applied here: Synapses
. While this looks a bit odd, it is also quite powerful (e.g. you can easily calculate the average membrane potential for several sub populations by setting up the connections accordingly). Here’s the general idea:
group = NeuronGroup(..., 'dv/dt = ...', ...)
# Dummy group to store the average membrane potential at every time step
vm_container = NeuronGroup(1, 'average_vm : volt')
# Synapses averaging the membrane potential of all neurons
vm_averager = Synapses(group, average_vm, 'average_vm_post = v_pre/N_pre : volt (summed)')
vm_averager.connect()
# Monitor recording the average membrane potential
vm_mon = StateMonitor(vm_container, 'average_vm', record=0)