fffb

package
v1.6.5 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 19, 2022 License: BSD-3-Clause Imports: 1 Imported by: 0

README

FFFB Inhibition

FFFB is the feedforward (FF) and feedback (FB) inhibition mechanism, originally developed for the Leabra model. It 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.

  • FF is a simple linear function of the average netinput (Ge) coming into neurons in a layer / pool. It is critical to have a FF0 offset for the zero-point for FF inhibition. Note that by giving FF access to the netinput, it implicitly has access to the strength of synaptic weights in a layer, which makes it automatically more robust over the course of learning.

  • FB must be integrated over time to avoid oscillations, but is otherwise also a weighted proportion of average activity in a layer.

Documentation

Overview

Package fffb provides feedforward (FF) and feedback (FB) inhibition (FFFB) based on average (or maximum) excitatory Ge (FF) and activation (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 Bg added in v1.2.33

type Bg struct {
	On  bool    `desc:"enable adaptive layer inhibition gain as stored in layer GiCur value"`
	Gi  float32 `` /* 173-byte string literal not displayed */
	Tau float32 `` /* 175-byte string literal not displayed */

	Dt float32 `inactive:"+" view:"-" json:"-" xml:"-" desc:"rate = 1 / tau"`
}

Bg has parameters for a slower, low level of background inhibition based on main FFFB computed inhibition.

func (*Bg) Defaults added in v1.2.33

func (bg *Bg) Defaults()

func (*Bg) GiBg added in v1.2.33

func (bg *Bg) GiBg(gibg *float32, gi float32)

GiBg updates the gi background value from Gi FFFB computed value

func (*Bg) Update added in v1.2.33

func (bg *Bg) Update()

type Inhib

type Inhib struct {
	FFi    float32         `desc:"computed feedforward inhibition"`
	FBi    float32         `desc:"computed feedback inhibition (total)"`
	Gi     float32         `` /* 170-byte string literal not displayed */
	GiOrig float32         `desc:"original value of the inhibition (before pool or other effects)"`
	LayGi  float32         `` /* 127-byte string literal not displayed */
	Ge     minmax.AvgMax32 `desc:"average and max Ge excitatory conductance values, which drive FF inhibition"`
	Act    minmax.AvgMax32 `desc:"average and max Act activation values, which drive FB inhibition"`
}

Inhib contains state values for computed FFFB inhibition

func (*Inhib) Decay

func (fi *Inhib) Decay(decay float32)

Decay reduces inhibition values by given decay proportion

func (*Inhib) Init

func (fi *Inhib) Init()

func (*Inhib) Zero

func (fi *Inhib) Zero()

Zero clears inhibition but does not affect Ge, Act averages

type Inhibs

type Inhibs []Inhib

Inhibs is a slice of Inhib records

type Params

type Params struct {
	On       bool    `desc:"enable this level of inhibition"`
	Gi       float32 `` /* 238-byte string literal not displayed */
	FF       float32 `` /* 310-byte string literal not displayed */
	FB       float32 `` /* 253-byte string literal not displayed */
	FBTau    float32 `` /* 477-byte string literal not displayed */
	MaxVsAvg float32 `` /* 749-byte string literal not displayed */
	FF0      float32 `` /* 380-byte string literal not displayed */
	FFEx     float32 `` /* 277-byte string literal not displayed */
	FFEx0    float32 `viewif:"On" def:"0.15" desc:"point of average Ge at which extra inhibition based on feedforward level starts"`

	FBDt float32 `inactive:"+" view:"-" json:"-" xml:"-" desc:"rate = 1 / tau"`
}

Params parameterizes feedforward (FF) and feedback (FB) inhibition (FFFB) based on average (or maximum) Ge (FF) and activation (FB)

func (*Params) Defaults

func (fb *Params) Defaults()

func (*Params) FBInhib

func (fb *Params) FBInhib(avgAct float32) float32

FBInhib computes feedback inhibition value as function of average activation

func (*Params) FBUpdt

func (fb *Params) FBUpdt(fbi *float32, newFbi float32)

FBUpdt updates feedback inhibition using time-integration rate constant

func (*Params) FFInhib

func (fb *Params) FFInhib(avgGe, maxGe float32) float32

FFInhib returns the feedforward inhibition value based on average and max excitatory conductance within relevant scope

func (*Params) Inhib

func (fb *Params) Inhib(inh *Inhib, gimult float32)

Inhib is full inhibition computation for given inhib state, which must have the Ge and Act values updated to reflect the current Avg and Max of those values in relevant inhibitory pool.

func (*Params) Update

func (fb *Params) Update()

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL