- CpuTi() {};
- CpuTi(CpuTiModelPtr model, const char *name, double powerPeak,
- double powerScale, tmgr_trace_t powerTrace, int core,
- e_surf_resource_state_t stateInitial, tmgr_trace_t stateTrace,
- xbt_dict_t properties) ;
- ~CpuTi() {};
-
- void updateState(tmgr_trace_event_t event_type, double value, double date);
- void updateActionFinishDate(double now);
- bool isUsed();
- void printCpuTiModel();
- CpuTiModelPtr getModel();
- CpuActionPtr execute(double size);
- CpuActionPtr sleep(double duration);
- double getAvailableSpeed();
-
- CpuTiTgmrPtr p_availTrace; /*< Structure with data needed to integrate trace file */
- e_surf_resource_state_t p_stateCurrent; /*< CPU current state (ON or OFF) */
- tmgr_trace_event_t p_stateEvent; /*< trace file with states events (ON or OFF) */
- tmgr_trace_event_t p_powerEvent; /*< trace file with availabitly events */
- xbt_swag_t p_actionSet; /*< set with all actions running on cpu */
- s_xbt_swag_hookup_t p_modifiedCpuHookup; /*< hookup to swag that indicacates whether share resources must be recalculated or not */
- double m_sumPriority; /*< the sum of actions' priority that are running on cpu */
- double m_lastUpdate; /*< last update of actions' remaining amount done */
+ CpuTi(CpuTiModel *model, simgrid::s4u::Host *host, xbt_dynar_t speedPeak,
+ int pstate, double speedScale, tmgr_trace_t speedTrace, int core,
+ int initiallyOn, tmgr_trace_t stateTrace) ;
+ ~CpuTi();
+
+ void set_speed_trace(tmgr_trace_t trace) override;
+
+ void apply_event(tmgr_trace_iterator_t event, double value) override;
+ void updateActionsFinishTime(double now);