Documentation ¶
Overview ¶
Package fsfffb provides Fast and Slow feedforward (FF) and feedback (FB) inhibition (FFFB) based on incoming spikes (FF) and outgoing spikes (FB).
This produces a robust, graded k-Winners-Take-All dynamic of sparse distributed representations having approximately k out of N neurons active at any time, where k is typically 10-20 percent of N.
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Inhib ¶
type Inhib struct { FFsRaw float32 `desc:"all feedforward incoming spikes into neurons in this pool -- raw aggregation"` FBsRaw float32 `desc:"all feedback outgoing spikes generated from neurons in this pool -- raw aggregation"` GeExtRaw float32 `desc:"all extra GeExt conductances added to neurons"` FFs float32 `desc:"all feedforward incoming spikes into neurons in this pool, normalized by pool size"` FBs float32 `desc:"all feedback outgoing spikes generated from neurons in this pool, normalized by pool size"` GeExts float32 `desc:"all extra GeExt conductances added to neurons, normalized by pool size"` FSi float32 `desc:"fast spiking PV+ fast integration of FFs feedforward spikes"` SSi float32 `desc:"slow spiking SST+ integration of FBs feedback spikes"` SSf float32 `desc:"slow spiking facilitation factor"` FSGi float32 `desc:"overall fast-spiking inhibitory conductance"` SSGi float32 `desc:"overall slow-spiking inhibitory conductance"` Gi float32 `desc:"overall inhibitory conductance = FSGi + SSGi"` GiOrig float32 `desc:"original value of the inhibition (before pool or other effects)"` LayGi float32 `` /* 127-byte string literal not displayed */ }
Inhib contains state values for computed FFFB inhibition
func (*Inhib) GiFmFSSS ¶ added in v1.6.1
GiFmFSSS returns the sum of FSGi and SSGi as overall inhibition
func (*Inhib) InitRaw ¶
func (fi *Inhib) InitRaw()
InitRaw clears raw spike counters -- done every cycle prior to accumulating
func (*Inhib) LayerMax ¶
LayerMax updates given pool-level inhib values from given layer-level with resulting value being the Max of either
func (*Inhib) PoolMax ¶
PoolMax updates given layer-level inhib values from given pool-level with resulting value being the Max of either
func (*Inhib) SaveOrig ¶
func (fi *Inhib) SaveOrig()
SaveOrig saves the current Gi values as original values
func (*Inhib) SpikesFmRaw ¶
SpikesFmRaw updates spike values from raw, dividing by given number in pool
type Params ¶
type Params struct { On bool `desc:"enable this level of inhibition"` Gi float32 `` /* 236-byte string literal not displayed */ FB float32 `viewif:"On" min:"0" def:"0.5" desc:"amount of FB spikes included in FF for driving FS"` FSTau float32 `` /* 188-byte string literal not displayed */ SS float32 `` /* 152-byte string literal not displayed */ SSfTau float32 `` /* 284-byte string literal not displayed */ SSiTau float32 `` /* 215-byte string literal not displayed */ FS0 float32 `` /* 145-byte string literal not displayed */ FSDt float32 `inactive:"+" view:"-" json:"-" xml:"-" desc:"rate = 1 / tau"` SSfDt float32 `inactive:"+" view:"-" json:"-" xml:"-" desc:"rate = 1 / tau"` SSiDt float32 `inactive:"+" view:"-" json:"-" xml:"-" desc:"rate = 1 / tau"` }
Params parameterizes feedforward (FF) and feedback (FB) inhibition (FFFB) based on incoming spikes (FF) and outgoing spikes (FB) across Fast (PV+) and Slow (SST+) timescales. FF -> PV -> FS fast spikes, FB -> SST -> SS slow spikes (slow to get going)
func (*Params) Inhib ¶
Inhib is full inhibition computation for given inhib state which has aggregated FFs and FBs spiking values