model

package
v0.6.1 Latest Latest
Warning

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

Go to latest
Published: Oct 12, 2023 License: Apache-2.0 Imports: 13 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var (
	EstimatorSidecarSocket = "/tmp/estimator.sock"
)

Functions

func CreateContainerPowerEstimatorModel added in v0.5.4

func CreateContainerPowerEstimatorModel(containerFeatureNames, systemMetaDataFeatureNames, systemMetaDataFeatureValues []string)

func CreateNodeComponentPoweEstimatorModel added in v0.5.4

func CreateNodeComponentPoweEstimatorModel(nodeFeatureNames, systemMetaDataFeatureNames, systemMetaDataFeatureValues []string)

CreateNodeComponentPoweEstimatorModel only create a new power model estimater if node components power metrics are not available

func CreateNodePlatformPoweEstimatorModel added in v0.5.4

func CreateNodePlatformPoweEstimatorModel(nodeFeatureNames, systemMetaDataFeatureNames, systemMetaDataFeatureValues []string)

CreateNodeComponentPoweEstimatorModel only create a new power model estimater if node platform power metrics are not available

func CreatePowerEstimatorModels added in v0.5.4

func CreatePowerEstimatorModels(containerFeatureNames, systemMetaDataFeatureNames, systemMetaDataFeatureValues []string)

CreatePowerEstimatorModels checks validity of power model and set estimate functions

func CreatePowerModelConfig added in v0.5.4

func CreatePowerModelConfig(powerSourceTarget string) *types.ModelConfig

CreatePowerModelConfig loads the power model configurations from the ConfigMap, including the Model type, name, filter, URL to download data, and model output type. The powerSourceTarget parameter acts as a prefix, which can have values like NODE_TOTAL, NODE_COMPONENTS, CONTAINER_COMPONENTS, etc. The complete variable name is created by combining the prefix with the specific attribute. For example, if the model name (which the key is MODEL) is under NODE_TOTAL, it will be called NODE_TOTAL_MODEL.

func CreateProcessPowerEstimatorModel added in v0.5.4

func CreateProcessPowerEstimatorModel(processFeatureNames, systemMetaDataFeatureNames, systemMetaDataFeatureValues []string)

func GetNodeComponentPowers

func GetNodeComponentPowers(nodeMetrics *collector_metric.NodeMetrics, isIdlePower bool) (nodeComponentsEnergy map[int]source.NodeComponentsEnergy)

GetNodeComponentPowers returns estimated RAPL power for the node

func GetNodePlatformPower added in v0.5.4

func GetNodePlatformPower(nodeMetrics *collector_metric.NodeMetrics, isIdlePower bool) (platformEnergy map[string]float64)

GetNodePlatformPower returns a single estimated value of node total power

func IsNodeComponentPowerModelEnabled

func IsNodeComponentPowerModelEnabled() bool

IsNodeComponentPowerModelEnabled returns if the estimator has been enabled or not

func IsNodePlatformPowerModelEnabled

func IsNodePlatformPowerModelEnabled() bool

IsNodePlatformPowerModelEnabled returns if the estimator has been enabled or not

func UpdateContainerEnergy

func UpdateContainerEnergy(containersMetrics map[string]*collector_metric.ContainerMetrics, nodeMetrics *collector_metric.NodeMetrics)

UpdateContainerEnergy resets the power model samples, add new samples to the power models, then estimates the idle and dynamic energy

func UpdateNodeComponentEnergy added in v0.5.4

func UpdateNodeComponentEnergy(nodeMetrics *collector_metric.NodeMetrics)

UpdateNodeComponentIdleEnergy sets the power model samples, get absolute powers, and set gauge value for each component energy

func UpdateNodeComponentIdleEnergy added in v0.6.1

func UpdateNodeComponentIdleEnergy(nodeMetrics *collector_metric.NodeMetrics)

UpdateNodeComponentIdleEnergy sets the power model samples to zeros, get idle powers, and set gauge value for each component idle energy

func UpdateNodePlatformEnergy added in v0.5.4

func UpdateNodePlatformEnergy(nodeMetrics *collector_metric.NodeMetrics)

UpdateNodePlatformEnergy sets the power model samples, get absolute powers, and set platform energy

func UpdateNodePlatformIdleEnergy added in v0.6.1

func UpdateNodePlatformIdleEnergy(nodeMetrics *collector_metric.NodeMetrics)

UpdateNodePlatformIdleEnergy sets the power model samples to zeros, get idle powers, and set platform energy

func UpdateProcessEnergy

func UpdateProcessEnergy(processMetrics map[uint64]*collector_metric.ProcessMetrics, nodeMetrics *collector_metric.NodeMetrics)

UpdateProcessEnergy resets the power model samples, add new samples to the power models, then estimates the idle and dynamic energy

func UpdateVMEnergy added in v0.6.1

func UpdateVMEnergy(vmMetrics map[uint64]*collector_metric.VMMetrics, processMetrics map[uint64]*collector_metric.ProcessMetrics)

UpdateVMEnergy matches the VM metrics with the process metrics already computed

Types

type PowerMoldelInterface added in v0.5.4

type PowerMoldelInterface interface {
	// AddContainerFeatureValues adds the new x as a point for trainning or prediction. Where x are explanatory variable (or the independent variable).
	// x values are added to a sliding window with circular list for dynamic data flow
	AddContainerFeatureValues(x []float64)
	// AddNodeFeatureValues adds the new x as a point for trainning or prediction. Where x are explanatory variable (or the independent variable).
	AddNodeFeatureValues(x []float64)
	// AddDesiredOutValue adds the new y as a point for trainning. Where y the response variable (or the dependent variable).
	AddDesiredOutValue(y float64)
	// ResetSampleIdx set the sample sliding window index, setting to 0 to overwrite the old samples with new ones for trainning or prediction.
	ResetSampleIdx()
	// Train triggers the regressiong fit after adding data points to create a new power model
	Train() error
	// IsEnabled returns true if the power model was trained and is active
	IsEnabled() bool
	// GetModelType returns if the model is Ratio, LinearRegressor or EstimatorSidecar
	GetModelType() types.ModelType
	// GetContainerFeatureNamesList returns the list of container features that the model was configured to use
	GetContainerFeatureNamesList() []string
	// GetNodeFeatureNamesList returns the list of node features that the model was configured to use
	GetNodeFeatureNamesList() []string
	// GetPlatformPower returns the total Platform Power in Watts associated to each process/container/pod
	// If isIdlePower is true, return the idle power, otherwise return the dynamic or absolute power depending on the model.
	GetPlatformPower(isIdlePower bool) ([]float64, error)
	// GetComponentsPower returns RAPL components Power in Watts associated to each each process/container/pod
	// If isIdlePower is true, return the idle power, otherwise return the dynamic or absolute power depending on the model.
	GetComponentsPower(isIdlePower bool) ([]source.NodeComponentsEnergy, error)
	// GetComponentsPower returns GPU Power in Watts associated to each each process/container/pod
	// If isIdlePower is true, return the idle power, otherwise return the dynamic or absolute power depending on the model.
	GetGPUPower(isIdlePower bool) ([]float64, error)
}

PowerMoldelInterface defines the power model sckeleton

var (
	ContainerPlatformPowerModel  PowerMoldelInterface
	ContainerComponentPowerModel PowerMoldelInterface
)
var (
	ProcessPlatformPowerModel  PowerMoldelInterface
	ProcessComponentPowerModel PowerMoldelInterface
)
var (
	// the absulute power model includes both the absolute and idle power consumption
	NodeComponentPowerModel PowerMoldelInterface
)
var (
	NodePlatformPowerModel PowerMoldelInterface
)

Directories

Path Synopsis
estimator

Jump to

Keyboard shortcuts

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