- 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);
-
- bool isUsed() override;
- CpuAction *execution_start(double size) override;
- CpuAction *sleep(double duration) override;
- double getAvailableSpeed() override;
-
- void modified(bool modified);
+ CpuTi(s4u::Host* host, const std::vector<double>& speed_per_pstate);
+ CpuTi(const CpuTi&) = delete;
+ CpuTi& operator&(const CpuTi&) = delete;
+ ~CpuTi() override;
+
+ CpuImpl* 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() const override;
+ CpuAction* execution_start(double size, double user_bound) override;
+ CpuAction* execution_start(double, int, double) 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 */