- CpuTi(CpuTiModelPtr model, string 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() {};
- virtual double getSpeed (double load);
- virtual double getAvailableSpeed ();
- void printCpuTiModel();
- CpuTiModelPtr getModel();
-
- double m_powerPeak; /*< CPU power peak */
- double m_powerScale; /*< Percentage of CPU disponible */
- surf_cpu_ti_tgmr_t m_availTrace; /*< Structure with data needed to integrate trace file */
- e_surf_resource_state_t m_stateCurrent; /*< CPU current state (ON or OFF) */
- tmgr_trace_event_t m_stateEvent; /*< trace file with states events (ON or OFF) */
- tmgr_trace_event_t m_powerEvent; /*< trace file with availabitly events */
- std::vector<CpuTiActionPtr> m_actionSet; /*< set with all actions running on cpu */
- s_xbt_swag_hookup_t m_modifiedCpuHookup; /*< hookup to swag that indicacates whether share resources must be recalculated or not */
+ 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);
+
+ void updateState(tmgr_trace_iterator_t event_type, double value) override;
+ void updateActionsFinishTime(double now);
+ void updateRemainingAmount(double now);
+
+ bool isUsed() override;
+ CpuAction *execution_start(double size) override;
+ CpuAction *sleep(double duration) override;
+ double getAvailableSpeed() override;
+
+ void modified(bool modified);
+
+ CpuTiTgmr *p_availTrace; /*< Structure with data needed to integrate trace file */
+ ActionTiList *p_actionSet; /*< set with all actions running on cpu */