Documentation ¶
Index ¶
- Constants
- Variables
- func ScopeName(mode EvalModes, time Times) string
- type Context
- func (ctx *Context) ClosestPat(layNm, unitVar string, pats *etable.Table, colnm, namecol string) (int, float32, string)
- func (ctx *Context) ItemFloat(mode EvalModes, time Times, itemNm string) float64
- func (ctx *Context) ItemFloatScope(scope ScopeKey, itemNm string) float64
- func (ctx *Context) ItemString(mode EvalModes, time Times, itemNm string) string
- func (ctx *Context) ItemStringScope(scope ScopeKey, itemNm string) string
- func (ctx *Context) LastNRows(mode EvalModes, time Times, n int) *etable.IdxView
- func (ctx *Context) LastNRowsScope(sk ScopeKey, n int) *etable.IdxView
- func (ctx *Context) Layer(layNm string) emer.Layer
- func (ctx *Context) SetAgg(mode EvalModes, time Times, ag agg.Aggs) float64
- func (ctx *Context) SetAggItem(mode EvalModes, time Times, itemNm string, ag agg.Aggs) float64
- func (ctx *Context) SetAggItemScope(scope ScopeKey, itemNm string, ag agg.Aggs) float64
- func (ctx *Context) SetAggScope(scope ScopeKey, ag agg.Aggs) float64
- func (ctx *Context) SetFloat32(val float32)
- func (ctx *Context) SetFloat64(val float64)
- func (ctx *Context) SetInt(val int)
- func (ctx *Context) SetLayerTensor(layNm, unitVar string) *etensor.Float32
- func (ctx *Context) SetStatFloat(name string)
- func (ctx *Context) SetStatInt(name string)
- func (ctx *Context) SetStatString(name string)
- func (ctx *Context) SetString(val string)
- func (ctx *Context) SetTable(sk ScopeKey, lt *LogTable, row int)
- func (ctx *Context) SetTensor(val etensor.Tensor)
- type DefaultBool
- type EvalModes
- type Item
- func (item *Item) CompileScopes()
- func (item *Item) HasMode(mode EvalModes) bool
- func (item *Item) HasTime(time Times) bool
- func (item *Item) SetEachScopeKey()
- func (item *Item) SetWriteFunc(mode EvalModes, time Times, theFunc WriteFunc)
- func (item *Item) SetWriteFuncAll(theFunc WriteFunc)
- func (item *Item) SetWriteFuncOver(modes []EvalModes, times []Times, theFunc WriteFunc)
- func (item *Item) WriteFunc(mode, time string) (WriteFunc, bool)
- type LogTable
- type Logs
- func (lg *Logs) AddItem(item *Item)
- func (lg *Logs) CloseLogFiles()
- func (lg *Logs) CompileAllScopes()
- func (lg *Logs) CreateTables() error
- func (lg *Logs) IdxView(mode EvalModes, time Times) *etable.IdxView
- func (lg *Logs) IdxViewScope(sk ScopeKey) *etable.IdxView
- func (lg *Logs) ItemBindAllScopes(item *Item)
- func (lg *Logs) Log(mode EvalModes, time Times) *etable.Table
- func (lg *Logs) LogRow(mode EvalModes, time Times, row int) *etable.Table
- func (lg *Logs) LogRowScope(sk ScopeKey, row int) *etable.Table
- func (lg *Logs) LogScope(sk ScopeKey) *etable.Table
- func (lg *Logs) MiscTable(name string) *etable.Table
- func (lg *Logs) NamedIdxView(mode EvalModes, time Times, name string) (*etable.IdxView, bool)
- func (lg *Logs) NamedIdxViewScope(sk ScopeKey, name string) (*etable.IdxView, bool)
- func (lg *Logs) NewTable(mode, time string) *etable.Table
- func (lg *Logs) NoPlot(mode EvalModes, time Times)
- func (lg *Logs) NoPlotScope(sk ScopeKey)
- func (lg *Logs) ProcessItems()
- func (lg *Logs) ResetLog(mode EvalModes, time Times)
- func (lg *Logs) SetContext(stats *estats.Stats, net emer.Network)
- func (lg *Logs) SetLogFile(mode EvalModes, time Times, fnm string)
- func (lg *Logs) SetMeta(mode EvalModes, time Times, key, val string)
- func (lg *Logs) SetMetaScope(sk ScopeKey, key, val string)
- func (lg *Logs) Table(mode EvalModes, time Times) *etable.Table
- func (lg *Logs) TableDetails(mode EvalModes, time Times) *LogTable
- func (lg *Logs) TableDetailsScope(sk ScopeKey) *LogTable
- func (lg *Logs) TableScope(sk ScopeKey) *etable.Table
- func (lg *Logs) WriteItems(sk ScopeKey, row int)
- func (lg *Logs) WriteLastRowToFile(lt *LogTable)
- type ScopeKey
- func (sk *ScopeKey) FromScope(mode EvalModes, time Times)
- func (sk *ScopeKey) FromScopeStr(mode, time string)
- func (sk *ScopeKey) FromScopes(modes []EvalModes, times []Times)
- func (sk *ScopeKey) FromScopesMap(modes, times map[string]bool)
- func (sk *ScopeKey) FromScopesStr(modes, times []string)
- func (sk *ScopeKey) ModeAndTime() (mode EvalModes, time Times)
- func (sk *ScopeKey) ModesAndTimes() (modes, times []string)
- func (sk *ScopeKey) ModesAndTimesMap() (modes, times map[string]bool)
- type Times
- type WriteFunc
- type WriteMap
Constants ¶
const LogPrec = 4
LogPrec is precision for saving float values in logs
Variables ¶
var ( ScopeKeySeparator = "&" // between mode and time ScopeKeyList = "|" // between multiple modes, times )
Like "Train|Test&Epoch|Trial"
var KiT_EvalModes = kit.Enums.AddEnum(EvalModesN, kit.NotBitFlag, nil)
var KiT_Times = kit.Enums.AddEnum(TimesN, kit.NotBitFlag, nil)
var LogDir = ""
LogDir is a directory that is prefixed for saving log files
Functions ¶
Types ¶
type Context ¶
type Context struct { Logs *Logs `desc:"pointer to the Logs object with all log data"` Stats *estats.Stats `desc:"pointer to stats"` Net emer.Network `desc:"network"` Item *Item `desc:"current log Item"` Scope ScopeKey `desc:"current scope key"` Mode EvalModes `desc:"current scope eval mode (if standard)"` Time Times `desc:"current scope timescale (if standard)"` LogTable *LogTable `desc:"LogTable with extra data for the table"` Table *etable.Table `desc:"current table to record value to"` Row int `desc:"current row in table to write to"` }
Context provides the context for logging Write functions. SetContext must be called on Logs to set the Stats and Net values Provides various convenience functions for setting log values and other commonly-used operations.
func (*Context) ClosestPat ¶
func (ctx *Context) ClosestPat(layNm, unitVar string, pats *etable.Table, colnm, namecol string) (int, float32, string)
ClosestPat finds the closest pattern in given column of given pats table to given layer activation pattern using given variable. Returns the row number, correlation value, and value of a column named namecol for that row if non-empty. Column must be etensor.Float32
func (*Context) ItemFloat ¶
ItemFloat returns a float64 value of the last row of given item name in log for given mode, time
func (*Context) ItemFloatScope ¶
ItemFloatScope returns a float64 value of the last row of given item name in log for given scope.
func (*Context) ItemString ¶
ItemString returns a string value of the last row of given item name in log for given mode, time
func (*Context) ItemStringScope ¶
ItemStringScope returns a string value of the last row of given item name in log for given scope.
func (*Context) LastNRows ¶
LastNRows returns an IdxView onto table for given scope with the last n rows of the table (only valid rows, if less than n). This index view is available later with the "LastNRows" name via NamedIdxView functions.
func (*Context) LastNRowsScope ¶
LastNRowsScope returns an IdxView onto table for given scope with the last n rows of the table (only valid rows, if less than n). This index view is available later with the "LastNRows" name via NamedIdxView functions.
func (*Context) Layer ¶
Layer returns layer by name as the emer.Layer interface -- you may then need to convert to a concrete type depending.
func (*Context) SetAgg ¶
SetAgg sets an aggregated scalar value computed from given eval mode and time scale with same Item name, to current item, row. returns aggregated value
func (*Context) SetAggItem ¶
SetAggItem sets an aggregated scalar value computed from given eval mode and time scale with given Item name, to current item, row. returns aggregated value
func (*Context) SetAggItemScope ¶
SetAggItemScope sets an aggregated scalar value computed from another scope (ScopeKey) with given Item name, to current item, row. returns aggregated value
func (*Context) SetAggScope ¶
SetAggScope sets an aggregated scalar value computed from another scope (ScopeKey) with same Item name, to current item, row returns aggregated value
func (*Context) SetFloat32 ¶
SetFloat32 sets a float32 to current table, item, row
func (*Context) SetFloat64 ¶
SetFloat64 sets a float64 to current table, item, row
func (*Context) SetLayerTensor ¶
SetLayerTensor sets tensor of Unit values on a layer for given variable
func (*Context) SetStatFloat ¶
SetStatFloat sets a Stats Float of given name to current table, item, row
func (*Context) SetStatInt ¶
SetStatInt sets a Stats int of given name to current table, item, row
func (*Context) SetStatString ¶
SetStatString sets a Stats string of given name to current table, item, row
type DefaultBool ¶
type DefaultBool int64
const ( DUnknown DefaultBool = iota DTrue DFalse )
func (*DefaultBool) ToBool ¶
func (db *DefaultBool) ToBool() bool
type EvalModes ¶
type EvalModes int32
EvalModes the mode enum
const ( NoEvalMode EvalModes = iota // AllModes indicates that the log should occur over all modes present in other items. AllModes // Train is this a training mode for the env Train // Test is this a test mode for the env Test // Validate is this a validation mode for the env Validate // Analyze when analyzing the representations and behavior of the network Analyze EvalModesN )
The evaluation modes
func (*EvalModes) FromString ¶
func (EvalModes) MarshalJSON ¶
func (*EvalModes) UnmarshalJSON ¶
type Item ¶
type Item struct { Name string `desc:"name of column -- must be unique for a table"` Type etensor.Type `desc:"data type, using etensor types which are isomorphic with arrow.Type"` CellShape []int `` /* 168-byte string literal not displayed */ DimNames []string `desc:"names of the dimensions within the CellShape -- 'Row' will be added to outer dimension"` Write WriteMap `` /* 263-byte string literal not displayed */ Plot DefaultBool `desc:"Whether or not to plot it"` Range minmax.F64 `desc:"The minimum and maximum values, for plotting"` FixMin DefaultBool `desc:"Whether to fix the minimum in the display"` FixMax DefaultBool `desc:"Whether to fix the maximum in the display"` // following are updated in final Process step Modes map[string]bool `desc:"map of eval modes that this item has a Write function for"` Times map[string]bool `desc:"map of times that this item has a Write function for"` }
Item describes one item to be logged -- has all the info for this item, across all scopes where it is relevant.
func (*Item) CompileScopes ¶
func (item *Item) CompileScopes()
CompileScopes compiles maps of modes and times where this item appears. Based on the final updated Write map
func (*Item) SetEachScopeKey ¶
func (item *Item) SetEachScopeKey()
SetEachScopeKey updates the Write map so that it only contains entries for a unique Mode,Time pair, where multiple modes and times may have originally been specified.
func (*Item) SetWriteFunc ¶
SetWriteFunc sets Write function for one mode, time
func (*Item) SetWriteFuncAll ¶
SetWriteFuncAll sets the Write function for all existing Modes and Times Can be used to replace a Write func after the fact.
func (*Item) SetWriteFuncOver ¶
SetWriteFuncOver sets the Write function over range of modes and times
type LogTable ¶
type LogTable struct { Table *etable.Table `desc:"Actual data stored."` Meta map[string]string `desc:"arbitrary meta-data for each table, e.g., hints for plotting: Plot = false to not plot, XAxisCol, LegendCol"` IdxView *etable.IdxView `view:"-" desc:"Index View of the table -- automatically updated when a new row of data is logged to the table."` NamedViews map[string]*etable.IdxView `` /* 196-byte string literal not displayed */ File *os.File `view:"-" desc:"File to store the log into."` WroteHeaders bool `view:"-" desc:"true if headers for File have already been written"` }
LogTable contains all the data for one log table
func NewLogTable ¶
NewLogTable returns a new LogTable entry for given table, initializing values
func (*LogTable) GetIdxView ¶
GetIdxView returns the index view for the whole table. It is reset to nil after log row is written, and if nil then it is initialized to reflect current rows.
func (*LogTable) NamedIdxView ¶
NamedIdxView returns a named Index View of the table, and true if this index view was newly created to show entire table (else false). This is used for additional data aggregation, filtering etc. It is reset to nil after log row is written, and if nil then it is initialized to reflect current rows as a starting point (returning true). Thus, the bool return value can be used for re-using cached indexes.
func (*LogTable) ResetIdxViews ¶
func (lt *LogTable) ResetIdxViews()
ResetIdxViews resets all IdxViews -- after log row is written
type Logs ¶
type Logs struct { Tables map[ScopeKey]*LogTable `desc:"Tables storing log data, auto-generated from Items."` MiscTables map[string]*etable.Table `desc:"holds additional tables not computed from items -- e.g., aggregation results, intermediate computations, etc"` Items []*Item `` /* 167-byte string literal not displayed */ Context Context `` /* 171-byte string literal not displayed */ Modes map[string]bool `view:"-" desc:"All the eval modes that appear in any of the items of this log."` Times map[string]bool `view:"-" desc:"All the timescales that appear in any of the items of this log."` ItemIdxMap map[string]int `view:"-" desc:"map of item indexes by name, for rapid access to items if they need to be modified after adding."` TableOrder []ScopeKey `view:"-" desc:"sorted order of table scopes"` }
Logs contains all logging state and API for doing logging. do AddItem to add any number of items, at different eval mode, time scopes. Each Item has its own Write functions, at each scope as neeeded. Then call CreateTables to generate log Tables from those items. Call Log with a scope to add a new row of data to the log and ResetLog to reset the log to empty.
func (*Logs) AddItem ¶
AddItem adds an item to the list. The items are stored in the order they are added, and this order is used for calling the item Write functions, so you can rely on that ordering for any sequential dependencies across items (e.g., in using intermediate computed values). Note: item names must be unique -- use different scopes for Write functions where needed.
func (*Logs) CloseLogFiles ¶
func (lg *Logs) CloseLogFiles()
CloseLogFiles closes all open log files
func (*Logs) CompileAllScopes ¶
func (lg *Logs) CompileAllScopes()
CompileAllScopes gathers all the modes and times used across all items
func (*Logs) CreateTables ¶
CreateTables creates the log tables based on all the specified log items It first calls ProcessItems to instantiate specific scopes.
func (*Logs) IdxView ¶
IdxView returns the Index View of a log table for a given mode, time This is used for data aggregation functions over the entire table. It should not be altered (don't Filter!) and always shows the whole table. See NamedIdxView for custom index views.
func (*Logs) IdxViewScope ¶
IdxViewScope returns the Index View of a log table for given ScopeKey This is used for data aggregation functions over the entire table. This view should not be altered and always shows the whole table. See NamedIdxView for custom index views.
func (*Logs) ItemBindAllScopes ¶
ItemBindAllScopes translates the AllModes or AllTimes scopes into a concrete list of actual Modes and Times used across all items
func (*Logs) Log ¶
Log performs logging for given mode, time. Adds a new row and Writes all the items. and saves data to file if open.
func (*Logs) LogRow ¶
LogRow performs logging for given mode, time, at given row. Saves data to file if open.
func (*Logs) LogRowScope ¶
LogRowScope performs logging for given ScopeKey, at given row. Saves data to file if open.
func (*Logs) LogScope ¶
LogScope performs logging for given ScopeKey Adds a new row and Writes all the items. and saves data to file if open.
func (*Logs) MiscTable ¶
MiscTable gets a miscellaneous table that is not specified or typically expected
func (*Logs) NamedIdxView ¶
NamedIdxView returns a named Index View of a log table for a given mode, time. This is used for additional data aggregation, filtering etc. When accessing the first time during writing a new row of the log, it automatically shows a view of the entire table and returns true for 2nd arg. You can then filter, sort, etc as needed. Subsequent calls within same row Write will return the last filtered view, and false for 2nd arg -- can then just reuse view.
func (*Logs) NamedIdxViewScope ¶
NamedIdxView returns a named Index View of a log table for a given mode, time. This is used for additional data aggregation, filtering etc. When accessing the first time during writing a new row of the log, it automatically shows a view of the entire table and returns true for 2nd arg. You can then filter, sort, etc as needed. Subsequent calls within same row Write will return the last filtered view, and false for 2nd arg -- can then just reuse view.
func (*Logs) NoPlot ¶
NoPlot sets meta data to not plot for given scope mode, time. Typically all combinations of mode and time end up being generated, so you have to turn off plotting of cases not used.
func (*Logs) NoPlotScope ¶
NoPlotScope sets meta data to not plot for given scope mode, time. Typically all combinations of mode and time end up being generated, so you have to turn off plotting of cases not used.
func (*Logs) ProcessItems ¶
func (lg *Logs) ProcessItems()
ProcessItems is called in CreateTables, after all items have been added. It instantiates All scopes, and compiles multi-list scopes into single mode, item pairs
func (*Logs) ResetLog ¶
ResetLog resets the log for given mode, time, at given row. by setting number of rows = 0
func (*Logs) SetContext ¶
SetContext sets the Context for logging Write functions to give general access to the stats and network
func (*Logs) SetLogFile ¶
SetLogFile sets the log filename for given scope
func (*Logs) SetMetaScope ¶
SetMetaScope sets table meta data for given scope
func (*Logs) TableDetails ¶
TableDetails returns the LogTable record of associated info for given table
func (*Logs) TableDetailsScope ¶
TableDetailsScope returns the LogTable record of associated info for given table
func (*Logs) TableScope ¶
TableScope returns the table for given ScopeKey
func (*Logs) WriteItems ¶
WriteItems calls all item Write functions within given scope providing the relevant Context for the function. Items are processed in the order added, to enable sequential dependencies to be used.
func (*Logs) WriteLastRowToFile ¶
WriteLastRowToFile writes the last row of table to file, if File != nil
type ScopeKey ¶
type ScopeKey string
ScopeKey the associated string representation of a scope or scopes. They include one or more EvalModes and one or more Times. It is fully extensible with arbitrary mode and time strings -- the enums are a convenience for standard cases. Ultimately a single mode, time pair is used concretely, but the All* cases and lists of multiple can be used as a convenience to specify ranges
func ScopesMap ¶
ScopesMap generates a scope key from maps of modes and times (warning: ordering is random!)
func SortScopes ¶
SortScopes sorts a list of concrete mode, time scopes according to the EvalModes and Times enum ordering
func (*ScopeKey) FromScopeStr ¶
FromScopeStr create an associated scope from given mode and time as strings
func (*ScopeKey) FromScopes ¶
FromScopes creates an associated scope merging the modes and times that are specified If you modify this, also modify ModesAndTimes, below.
func (*ScopeKey) FromScopesMap ¶
FromScopesMap creates an associated scope key merging the modes and times that are specified by map of strings.
func (*ScopeKey) FromScopesStr ¶
FromScopesStr creates an associated scope merging the modes and times that are specified as strings If you modify this, also modify ModesAndTimes, below.
func (*ScopeKey) ModeAndTime ¶
ModeAndTime returns the singular mode and time as enums from a concrete scope key having one of each (No* cases if not standard)
func (*ScopeKey) ModesAndTimes ¶
ModesAndTimes returns the mode(s) and time(s) as strings from the current key value. This must be the inverse of FromScopesStr
func (*ScopeKey) ModesAndTimesMap ¶
ModesAndTimesMap returns maps of modes and times as strings parsed from the current scopekey
type Times ¶
type Times int32
Times the enum
const ( // NoTime represents a non-initialized value NoTime Times = iota // AllTimes indicates that the log should occur over all times present in other items. AllTimes // Cycle is the finest time scale -- typically 1 msec -- a single activation update. Cycle // FastSpike is typically 10 cycles = 10 msec (100hz) = the fastest spiking time // generally observed in the brain. This can be useful for visualizing updates // at a granularity in between Cycle and GammaCycle. FastSpike // GammaCycle is typically 25 cycles = 25 msec (40hz) GammaCycle // Phase is either Minus or Plus phase, where plus phase is bursting / outcome // that drives positive learning relative to prediction in minus phase. Phase // BetaCycle is typically 50 cycles = 50 msec (20 hz) = one beta-frequency cycle. // Gating in the basal ganglia and associated updating in prefrontal cortex // occurs at this frequency. BetaCycle // AlphaCycle is typically 100 cycles = 100 msec (10 hz) = one alpha-frequency cycle. AlphaCycle // ThetaCycle is typically 200 cycles = 200 msec (5 hz) = two alpha-frequency cycles. // This is the modal duration of a saccade, the update frequency of medial temporal lobe // episodic memory, and the minimal predictive learning cycle (perceive an Alpha 1, predict on 2). ThetaCycle // Event is the smallest unit of naturalistic experience that coheres unto itself // (e.g., something that could be described in a sentence). // Typically this is on the time scale of a few seconds: e.g., reaching for // something, catching a ball. Event // Trial is one unit of behavior in an experiment -- it is typically environmentally // defined instead of endogenously defined in terms of basic brain rhythms. // In the minimal case it could be one ThetaCycle, but could be multiple, and // could encompass multiple Events (e.g., one event is fixation, next is stimulus, // last is response) Trial // Tick is one step in a sequence -- often it is useful to have Trial count // up throughout the entire Epoch but also include a Tick to count trials // within a Sequence Tick // Sequence is a sequential group of Trials (not always needed). Sequence // Condition is a collection of Blocks that share the same set of parameters. // This is intermediate between Block and Run levels. Condition // Block is a collection of Trials, Sequences or Events, often used in experiments // when conditions are varied across blocks. Block // Epoch is used in two different contexts. In machine learning, it represents a // collection of Trials, Sequences or Events that constitute a "representative sample" // of the environment. In the simplest case, it is the entire collection of Trials // used for training. In electrophysiology, it is a timing window used for organizing // the analysis of electrode data. Epoch // Run is a complete run of a model / subject, from training to testing, etc. // Often multiple runs are done in an Expt to obtain statistics over initial // random weights etc. Run // Expt is an entire experiment -- multiple Runs through a given protocol / set of // parameters. Expt // Scene is a sequence of events that constitutes the next larger-scale coherent unit // of naturalistic experience corresponding e.g., to a scene in a movie. // Typically consists of events that all take place in one location over // e.g., a minute or so. This could be a paragraph or a page or so in a book. Scene // Episode is a sequence of scenes that constitutes the next larger-scale unit // of naturalistic experience e.g., going to the grocery store or eating at a // restaurant, attending a wedding or other "event". // This could be a chapter in a book. Episode TimesN )
A list of predefined time scales at which logging can occur