- CpuTi(CpuTiModel *model, simgrid::s4u::Host *host, xbt_dynar_t speedPeak,
- tmgr_trace_t speedTrace, int core,
- 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);
- void updateRemainingAmount(double now);
+ CpuTi(CpuTiModel* model, s4u::Host* host, const std::vector<double>& speed_per_pstate, int core);
+ CpuTi(const CpuTi&) = delete;
+ CpuTi& operator&(const CpuTi&) = delete;
+ ~CpuTi() override;
+
+ void set_speed_profile(profile::Profile* profile) override;
+
+ void apply_event(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;
+ CpuAction* 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 */