Documentation ¶
Index ¶
- func AUC(posPrediction, negPrediction []float32) float32
- func Accuracy(posPrediction, negPrediction []float32) float32
- func LoadLibFMFile(path string) (features [][]int32, values [][]float32, targets base.Array[float32], ...)
- func MarshalIndex(w io.Writer, index UnifiedIndex) error
- func MarshalModel(w io.Writer, m FactorizationMachine) error
- func Precision(posPrediction, negPrediction []float32) float32
- func Recall(posPrediction, _ []float32) float32
- type BaseFactorizationMachine
- type Dataset
- type FM
- func (fm *FM) Bytes() int
- func (fm *FM) Clear()
- func (fm *FM) Complexity() int
- func (fm *FM) Fit(trainSet, testSet *Dataset, config *FitConfig) Score
- func (fm *FM) GetParamsGrid(withSize bool) model.ParamsGrid
- func (fm *FM) Init(trainSet *Dataset)
- func (fm *FM) InternalPredict(features []int32, values []float32) float32
- func (fm *FM) Invalid() bool
- func (fm *FM) Marshal(w io.Writer) error
- func (fm *FM) Predict(userId, itemId string, userLabels, itemLabels []string) float32
- func (fm *FM) SetParams(params model.Params)
- func (fm *FM) Unmarshal(r io.Reader) error
- type FMTask
- type FactorizationMachine
- type FitConfig
- type ModelSearcher
- type ParamsSearchResult
- type Score
- type SnapshotManger
- type UnifiedDirectIndex
- func (unified *UnifiedDirectIndex) Bytes() int
- func (unified *UnifiedDirectIndex) CountContextLabels() int32
- func (unified *UnifiedDirectIndex) CountItemLabels() int32
- func (unified *UnifiedDirectIndex) CountItems() int32
- func (unified *UnifiedDirectIndex) CountUserLabels() int32
- func (unified *UnifiedDirectIndex) CountUsers() int32
- func (unified *UnifiedDirectIndex) EncodeContextLabel(label string) int32
- func (unified *UnifiedDirectIndex) EncodeItem(itemId string) int32
- func (unified *UnifiedDirectIndex) EncodeItemLabel(itemLabel string) int32
- func (unified *UnifiedDirectIndex) EncodeUser(userId string) int32
- func (unified *UnifiedDirectIndex) EncodeUserLabel(userLabel string) int32
- func (unified *UnifiedDirectIndex) GetContextLabels() []string
- func (unified *UnifiedDirectIndex) GetItemLabels() []string
- func (unified *UnifiedDirectIndex) GetItems() []string
- func (unified *UnifiedDirectIndex) GetUserLabels() []string
- func (unified *UnifiedDirectIndex) GetUsers() []string
- func (unified *UnifiedDirectIndex) Len() int32
- func (unified *UnifiedDirectIndex) Marshal(w io.Writer) error
- func (unified *UnifiedDirectIndex) Unmarshal(r io.Reader) error
- type UnifiedIndex
- type UnifiedMapIndex
- func (unified *UnifiedMapIndex) Bytes() int
- func (unified *UnifiedMapIndex) CountContextLabels() int32
- func (unified *UnifiedMapIndex) CountItemLabels() int32
- func (unified *UnifiedMapIndex) CountItems() int32
- func (unified *UnifiedMapIndex) CountUserLabels() int32
- func (unified *UnifiedMapIndex) CountUsers() int32
- func (unified *UnifiedMapIndex) EncodeContextLabel(label string) int32
- func (unified *UnifiedMapIndex) EncodeItem(itemId string) int32
- func (unified *UnifiedMapIndex) EncodeItemLabel(itemLabel string) int32
- func (unified *UnifiedMapIndex) EncodeUser(userId string) int32
- func (unified *UnifiedMapIndex) EncodeUserLabel(userLabel string) int32
- func (unified *UnifiedMapIndex) GetContextLabels() []string
- func (unified *UnifiedMapIndex) GetItemLabels() []string
- func (unified *UnifiedMapIndex) GetItems() []string
- func (unified *UnifiedMapIndex) GetUserLabels() []string
- func (unified *UnifiedMapIndex) GetUsers() []string
- func (unified *UnifiedMapIndex) Len() int32
- func (unified *UnifiedMapIndex) Marshal(w io.Writer) error
- func (unified *UnifiedMapIndex) Unmarshal(r io.Reader) error
- type UnifiedMapIndexBuilder
- func (builder *UnifiedMapIndexBuilder) AddCtxLabel(ctxLabel string)
- func (builder *UnifiedMapIndexBuilder) AddItem(itemId string)
- func (builder *UnifiedMapIndexBuilder) AddItemLabel(itemLabel string)
- func (builder *UnifiedMapIndexBuilder) AddUser(userId string)
- func (builder *UnifiedMapIndexBuilder) AddUserLabel(userLabel string)
- func (builder *UnifiedMapIndexBuilder) Build() UnifiedIndex
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func LoadLibFMFile ¶
func LoadLibFMFile(path string) (features [][]int32, values [][]float32, targets base.Array[float32], maxLabel int32, err error)
LoadLibFMFile loads libFM format file.
func MarshalIndex ¶ added in v0.2.7
func MarshalIndex(w io.Writer, index UnifiedIndex) error
MarshalIndex marshal index into byte stream.
func MarshalModel ¶ added in v0.2.7
func MarshalModel(w io.Writer, m FactorizationMachine) error
Types ¶
type BaseFactorizationMachine ¶
type BaseFactorizationMachine struct { model.BaseModel Index UnifiedIndex }
func (*BaseFactorizationMachine) Init ¶
func (b *BaseFactorizationMachine) Init(trainSet *Dataset)
type Dataset ¶
type Dataset struct { Index UnifiedIndex UserFeatures [][]int32 // features of users ItemFeatures [][]int32 // features of items Users base.Array[int32] Items base.Array[int32] CtxFeatures [][]int32 CtxValues [][]float32 NormValues base.Array[float32] Target base.Array[float32] PositiveCount int NegativeCount int }
Dataset for click-through-rate models.
func LoadDataFromBuiltIn ¶
LoadDataFromBuiltIn loads built-in dataset.
type FM ¶
type FM struct { BaseFactorizationMachine // Model parameters V [][]float32 W []float32 B float32 MinTarget float32 MaxTarget float32 Task FMTask // contains filtered or unexported fields }
func (*FM) Complexity ¶ added in v0.4.5
func (*FM) GetParamsGrid ¶
func (fm *FM) GetParamsGrid(withSize bool) model.ParamsGrid
func (*FM) InternalPredict ¶
type FactorizationMachine ¶
type FactorizationMachine interface { model.Model Predict(userId, itemId string, userLabels, itemLabels []string) float32 InternalPredict(x []int32, values []float32) float32 Fit(trainSet *Dataset, testSet *Dataset, config *FitConfig) Score Marshal(w io.Writer) error Bytes() int Complexity() int }
func UnmarshalModel ¶ added in v0.2.7
func UnmarshalModel(r io.Reader) (FactorizationMachine, error)
type FitConfig ¶
type FitConfig struct { *task.JobsAllocator Verbose int Task *task.Task }
func NewFitConfig ¶
func NewFitConfig() *FitConfig
func (*FitConfig) LoadDefaultIfNil ¶
func (*FitConfig) SetJobsAllocator ¶ added in v0.4.6
func (config *FitConfig) SetJobsAllocator(allocator *task.JobsAllocator) *FitConfig
func (*FitConfig) SetVerbose ¶ added in v0.2.5
type ModelSearcher ¶
type ModelSearcher struct {
// contains filtered or unexported fields
}
ModelSearcher is a thread-safe click model searcher.
func NewModelSearcher ¶
func NewModelSearcher(nEpoch, nTrials int, searchSize bool) *ModelSearcher
NewModelSearcher creates a thread-safe personal ranking model searcher.
func (*ModelSearcher) Complexity ¶ added in v0.4.5
func (searcher *ModelSearcher) Complexity() int
func (*ModelSearcher) Fit ¶
func (searcher *ModelSearcher) Fit(trainSet, valSet *Dataset, t *task.Task, j *task.JobsAllocator) error
func (*ModelSearcher) GetBestModel ¶
func (searcher *ModelSearcher) GetBestModel() (FactorizationMachine, Score)
GetBestModel returns the best click model with its score.
type ParamsSearchResult ¶
type ParamsSearchResult struct { BestScore Score BestModel FactorizationMachine BestParams model.Params BestIndex int Scores []Score Params []model.Params }
ParamsSearchResult contains the return of grid search.
func GridSearchCV ¶
func GridSearchCV(estimator FactorizationMachine, trainSet *Dataset, testSet *Dataset, paramGrid model.ParamsGrid, _ int64, fitConfig *FitConfig) ParamsSearchResult
GridSearchCV finds the best parameters for a model.
func RandomSearchCV ¶
func RandomSearchCV(estimator FactorizationMachine, trainSet *Dataset, testSet *Dataset, paramGrid model.ParamsGrid, numTrials int, seed int64, fitConfig *FitConfig) ParamsSearchResult
RandomSearchCV searches hyper-parameters by random.
type Score ¶
type Score struct { Task FMTask RMSE float32 Precision float32 Recall float32 Accuracy float32 AUC float32 }
func EvaluateClassification ¶
func EvaluateClassification(estimator FactorizationMachine, testSet *Dataset) Score
EvaluateClassification evaluates factorization machines in classification task.
func EvaluateRegression ¶
func EvaluateRegression(estimator FactorizationMachine, testSet *Dataset) Score
EvaluateRegression evaluates factorization machines in regression task.
func (Score) BetterThan ¶
type SnapshotManger ¶
type SnapshotManger struct { BestWeights []interface{} BestScore Score }
SnapshotManger manages the best snapshot.
func (*SnapshotManger) AddSnapshot ¶
func (sm *SnapshotManger) AddSnapshot(score Score, weights ...interface{})
AddSnapshot adds a copied snapshot.
type UnifiedDirectIndex ¶
type UnifiedDirectIndex struct {
N int32
}
UnifiedDirectIndex maps string to integer in literal.
func (*UnifiedDirectIndex) Bytes ¶ added in v0.4.3
func (unified *UnifiedDirectIndex) Bytes() int
func (*UnifiedDirectIndex) CountContextLabels ¶
func (unified *UnifiedDirectIndex) CountContextLabels() int32
CountContextLabels should be used by unit testing only.
func (*UnifiedDirectIndex) CountItemLabels ¶
func (unified *UnifiedDirectIndex) CountItemLabels() int32
CountItemLabels should be used by unit testing only.
func (*UnifiedDirectIndex) CountItems ¶
func (unified *UnifiedDirectIndex) CountItems() int32
CountItems should be used by unit testing only.
func (*UnifiedDirectIndex) CountUserLabels ¶
func (unified *UnifiedDirectIndex) CountUserLabels() int32
CountUserLabels should be used by unit testing only.
func (*UnifiedDirectIndex) CountUsers ¶
func (unified *UnifiedDirectIndex) CountUsers() int32
CountUsers should be used by unit testing only.
func (*UnifiedDirectIndex) EncodeContextLabel ¶
func (unified *UnifiedDirectIndex) EncodeContextLabel(label string) int32
EncodeContextLabel should be used by unit testing only.
func (*UnifiedDirectIndex) EncodeItem ¶
func (unified *UnifiedDirectIndex) EncodeItem(itemId string) int32
EncodeItem should be used by unit testing only.
func (*UnifiedDirectIndex) EncodeItemLabel ¶
func (unified *UnifiedDirectIndex) EncodeItemLabel(itemLabel string) int32
EncodeItemLabel should be used by unit testing only.
func (*UnifiedDirectIndex) EncodeUser ¶
func (unified *UnifiedDirectIndex) EncodeUser(userId string) int32
EncodeUser should be used by unit testing only.
func (*UnifiedDirectIndex) EncodeUserLabel ¶
func (unified *UnifiedDirectIndex) EncodeUserLabel(userLabel string) int32
EncodeUserLabel should be used by unit testing only.
func (*UnifiedDirectIndex) GetContextLabels ¶
func (unified *UnifiedDirectIndex) GetContextLabels() []string
GetContextLabels should be used by unit testing only.
func (*UnifiedDirectIndex) GetItemLabels ¶
func (unified *UnifiedDirectIndex) GetItemLabels() []string
GetItemLabels should be used by unit testing only.
func (*UnifiedDirectIndex) GetItems ¶
func (unified *UnifiedDirectIndex) GetItems() []string
GetItems should be used by unit testing only.
func (*UnifiedDirectIndex) GetUserLabels ¶
func (unified *UnifiedDirectIndex) GetUserLabels() []string
GetUserLabels should be used by unit testing only.
func (*UnifiedDirectIndex) GetUsers ¶
func (unified *UnifiedDirectIndex) GetUsers() []string
GetUsers should be used by unit testing only.
func (*UnifiedDirectIndex) Len ¶
func (unified *UnifiedDirectIndex) Len() int32
Len should be used by unit testing only.
type UnifiedIndex ¶
type UnifiedIndex interface { Len() int32 Bytes() int EncodeUser(userId string) int32 EncodeItem(itemId string) int32 EncodeUserLabel(userLabel string) int32 EncodeItemLabel(itemLabel string) int32 EncodeContextLabel(ctxLabel string) int32 GetUsers() []string GetItems() []string GetUserLabels() []string GetItemLabels() []string GetContextLabels() []string CountUsers() int32 CountItems() int32 CountUserLabels() int32 CountItemLabels() int32 CountContextLabels() int32 Marshal(w io.Writer) error Unmarshal(r io.Reader) error }
UnifiedIndex maps users, items and labels into a unified encoding space.
func NewUnifiedDirectIndex ¶
func NewUnifiedDirectIndex(n int32) UnifiedIndex
NewUnifiedDirectIndex creates a UnifiedDirectIndex.
func UnmarshalIndex ¶ added in v0.2.7
func UnmarshalIndex(r io.Reader) (UnifiedIndex, error)
UnmarshalIndex unmarshal index from byte stream.
type UnifiedMapIndex ¶
type UnifiedMapIndex struct { UserIndex base.Index ItemIndex base.Index UserLabelIndex base.Index ItemLabelIndex base.Index CtxLabelIndex base.Index }
UnifiedMapIndex is the id -> index mapper for factorization machines. The division of id is: | user | item | user label | item label | context label |
func (*UnifiedMapIndex) Bytes ¶ added in v0.4.3
func (unified *UnifiedMapIndex) Bytes() int
func (*UnifiedMapIndex) CountContextLabels ¶
func (unified *UnifiedMapIndex) CountContextLabels() int32
CountContextLabels returns the number of context labels.
func (*UnifiedMapIndex) CountItemLabels ¶
func (unified *UnifiedMapIndex) CountItemLabels() int32
CountItemLabels returns the number of item labels.
func (*UnifiedMapIndex) CountItems ¶
func (unified *UnifiedMapIndex) CountItems() int32
CountItems returns the number of items.
func (*UnifiedMapIndex) CountUserLabels ¶
func (unified *UnifiedMapIndex) CountUserLabels() int32
CountUserLabels returns the number of user labels.
func (*UnifiedMapIndex) CountUsers ¶
func (unified *UnifiedMapIndex) CountUsers() int32
CountUsers returns the number of users.
func (*UnifiedMapIndex) EncodeContextLabel ¶
func (unified *UnifiedMapIndex) EncodeContextLabel(label string) int32
EncodeContextLabel converts a context label to a integer in the encoding space.
func (*UnifiedMapIndex) EncodeItem ¶
func (unified *UnifiedMapIndex) EncodeItem(itemId string) int32
EncodeItem converts a item id to a integer in the encoding space.
func (*UnifiedMapIndex) EncodeItemLabel ¶
func (unified *UnifiedMapIndex) EncodeItemLabel(itemLabel string) int32
EncodeItemLabel converts a item label to a integer in the encoding space.
func (*UnifiedMapIndex) EncodeUser ¶
func (unified *UnifiedMapIndex) EncodeUser(userId string) int32
EncodeUser converts a user id to a integer in the encoding space.
func (*UnifiedMapIndex) EncodeUserLabel ¶
func (unified *UnifiedMapIndex) EncodeUserLabel(userLabel string) int32
EncodeUserLabel converts a user label to a integer in the encoding space.
func (*UnifiedMapIndex) GetContextLabels ¶
func (unified *UnifiedMapIndex) GetContextLabels() []string
GetContextLabels returns all context labels.
func (*UnifiedMapIndex) GetItemLabels ¶
func (unified *UnifiedMapIndex) GetItemLabels() []string
GetItemLabels returns all item labels.
func (*UnifiedMapIndex) GetItems ¶
func (unified *UnifiedMapIndex) GetItems() []string
GetItems returns all items.
func (*UnifiedMapIndex) GetUserLabels ¶
func (unified *UnifiedMapIndex) GetUserLabels() []string
GetUserLabels returns all user labels.
func (*UnifiedMapIndex) GetUsers ¶
func (unified *UnifiedMapIndex) GetUsers() []string
GetUsers returns all users.
func (*UnifiedMapIndex) Len ¶
func (unified *UnifiedMapIndex) Len() int32
Len returns the size of unified index.
type UnifiedMapIndexBuilder ¶
type UnifiedMapIndexBuilder struct { UserIndex base.Index ItemIndex base.Index UserLabelIndex base.Index ItemLabelIndex base.Index CtxLabelIndex base.Index }
UnifiedMapIndexBuilder is the builder for UnifiedMapIndex.
func NewUnifiedMapIndexBuilder ¶
func NewUnifiedMapIndexBuilder() *UnifiedMapIndexBuilder
NewUnifiedMapIndexBuilder creates a UnifiedMapIndexBuilder.
func (*UnifiedMapIndexBuilder) AddCtxLabel ¶
func (builder *UnifiedMapIndexBuilder) AddCtxLabel(ctxLabel string)
AddCtxLabel adds a context label the unified index.
func (*UnifiedMapIndexBuilder) AddItem ¶
func (builder *UnifiedMapIndexBuilder) AddItem(itemId string)
AddItem adds a item into the unified index.
func (*UnifiedMapIndexBuilder) AddItemLabel ¶
func (builder *UnifiedMapIndexBuilder) AddItemLabel(itemLabel string)
AddItemLabel adds a item label into the unified index.
func (*UnifiedMapIndexBuilder) AddUser ¶
func (builder *UnifiedMapIndexBuilder) AddUser(userId string)
AddUser adds a user into the unified index.
func (*UnifiedMapIndexBuilder) AddUserLabel ¶
func (builder *UnifiedMapIndexBuilder) AddUserLabel(userLabel string)
AddUserLabel adds a user label into the unified index.
func (*UnifiedMapIndexBuilder) Build ¶
func (builder *UnifiedMapIndexBuilder) Build() UnifiedIndex
Build UnifiedMapIndex from UnifiedMapIndexBuilder.