MS-368 Implement cost.cpp

Former-commit-id: 554f06b109662bb381bb06aa73ddab956fb8c47c
pull/191/head
wxyu 2019-08-16 17:51:05 +08:00
parent 484f255f5e
commit 2ea773b930
4 changed files with 33 additions and 6 deletions

View File

@ -22,6 +22,7 @@ Please mark all change in change log and use the ticket from JIRA.
- MS-364 - Modify tasktableitem in tasktable
- MS-365 - Use tasktableitemptr instead in event
- MS-366 - Implement TaskTable
- MS-368 - Implement cost.cpp
## New Feature
- MS-343 - Implement ResourceMgr

View File

@ -12,22 +12,40 @@ namespace milvus {
namespace engine {
std::vector<uint64_t>
PickToMove(const TaskTable &task_table, const CacheMgr &cache_mgr, uint64_t limit) {
PickToMove(TaskTable &task_table, const CacheMgr &cache_mgr, uint64_t limit) {
std::vector<uint64_t> indexes;
for (uint64_t i = 0, count = 0; i < task_table.Size() && count < limit; ++i) {
if (task_table[i]->state == TaskTableItemState::LOADED) {
indexes.push_back(i);
++count;
}
}
return indexes;
}
std::vector<uint64_t>
PickToLoad(const TaskTable &task_table, uint64_t limit) {
PickToLoad(TaskTable &task_table, uint64_t limit) {
std::vector<uint64_t> indexes;
for (uint64_t i = 0, count = 0; i < task_table.Size() && count < limit; ++i) {
if (task_table[i]->state == TaskTableItemState::START) {
indexes.push_back(i);
++count;
}
}
return indexes;
}
std::vector<uint64_t>
PickToExecute(const TaskTable &task_table, uint64_t limit) {
PickToExecute(TaskTable &task_table, uint64_t limit) {
std::vector<uint64_t> indexes;
for (uint64_t i = 0, count = 0; i < task_table.Size() && count < limit; ++i) {
if (task_table[i]->state == TaskTableItemState::LOADED) {
indexes.push_back(i);
++count;
}
}
return indexes;
}

View File

@ -23,7 +23,7 @@ namespace engine {
* call from scheduler;
*/
std::vector<uint64_t>
PickToMove(const TaskTable &task_table, const CacheMgr &cache_mgr, uint64_t limit);
PickToMove(TaskTable &task_table, const CacheMgr &cache_mgr, uint64_t limit);
/*
@ -32,7 +32,7 @@ PickToMove(const TaskTable &task_table, const CacheMgr &cache_mgr, uint64_t limi
* I DONT SURE NEED THIS;
*/
std::vector<uint64_t>
PickToLoad(const TaskTable &task_table, uint64_t limit);
PickToLoad(TaskTable &task_table, uint64_t limit);
/*
* select task to execute;
@ -40,7 +40,7 @@ PickToLoad(const TaskTable &task_table, uint64_t limit);
* I DONT SURE NEED THIS;
*/
std::vector<uint64_t>
PickToExecute(const TaskTable &task_table, uint64_t limit);
PickToExecute(TaskTable &task_table, uint64_t limit);
}

View File

@ -90,6 +90,14 @@ public:
Size() {
return table_.size();
}
public:
TaskTableItemPtr &
operator[](uint64_t index) {
return table_[index];
}
std::deque<TaskTableItemPtr>::iterator begin() { return table_.begin(); }
std::deque<TaskTableItemPtr>::iterator end() { return table_.end(); }
public: