- CpuTi() {};
- CpuTi(CpuTiModelPtr model, const char *name, xbt_dynar_t powerPeak,
- int pstate, 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();
- CpuActionPtr execute(double size);
- CpuTiActionPtr _execute(double size);
- CpuActionPtr sleep(double duration);
- double getAvailableSpeed();
-
- xbt_dynar_t getWattsRangeList() {};
- double getCurrentWattsValue(double cpu_load) {};
- void updateEnergy(double cpu_load) {};
-
- double getCurrentPowerPeak() {};
- double getPowerPeakAt(int pstate_index) {};
- int getNbPstates() {};
- void setPowerPeakAt(int pstate_index) {};
- double getConsumedEnergy() {};
-
- CpuTiTgmrPtr p_availTrace; /*< Structure with data needed to integrate trace file */
- tmgr_trace_event_t p_stateEvent; /*< trace file with states events (ON or OFF) */
- tmgr_trace_event_t p_powerEvent; /*< trace file with availability events */
- xbt_swag_t p_actionSet; /*< set with all actions running on cpu */
- s_xbt_swag_hookup_t p_modifiedCpuHookup; /*< hookup to swag that indicates 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 */
-
- int m_pstate; /*< Current pstate (index in the power_peak_list)*/
- double current_frequency;
-
- void updateRemainingAmount(double now);
+ CpuTi(CpuTiModel* model, simgrid::s4u::Host* host, std::vector<double>* speed_per_pstate, int core);
+ CpuTi(const CpuTi&) = delete;
+ CpuTi& operator&(const CpuTi&) = delete;
+ ~CpuTi() override;
+
+ void set_speed_profile(kernel::profile::Profile* profile) override;
+
+ void apply_event(kernel::profile::Event* event, double value) override;
+ void update_actions_finish_time(double now);
+ void update_remaining_amount(double now);
+
+ bool is_used() override;
+ CpuAction *execution_start(double size) override;
+ kernel::resource::Action* execution_start(double, int) override
+ {
+ THROW_UNIMPLEMENTED;
+ return nullptr;
+ }
+ CpuAction *sleep(double duration) override;
+ double get_speed_ratio() override;
+
+ void set_modified(bool modified);
+
+ CpuTiTmgr* speed_integrated_trace_ = nullptr; /*< Structure with data needed to integrate trace file */
+ ActionTiList action_set_; /*< set with all actions running on cpu */
+ double sum_priority_ = 0; /*< the sum of actions' priority that are running on cpu */
+ double last_update_ = 0; /*< last update of actions' remaining amount done */
+
+ boost::intrusive::list_member_hook<> cpu_ti_hook;