mirror of https://github.com/milvus-io/milvus.git
commit
4825f0724a
|
@ -57,6 +57,7 @@ Please mark all change in change log and use the issue from GitHub
|
||||||
- \#1577 Row count incorrect if delete vectors then create index
|
- \#1577 Row count incorrect if delete vectors then create index
|
||||||
- \#1580 Old segment folder not removed after merge/compact if create_index is called before adding data
|
- \#1580 Old segment folder not removed after merge/compact if create_index is called before adding data
|
||||||
- \#1590 Server down caused by failure to write file during concurrent mixed operations
|
- \#1590 Server down caused by failure to write file during concurrent mixed operations
|
||||||
|
- \#1598 Server down during mixed operations
|
||||||
- \#1601 External link bug in HTTP doc
|
- \#1601 External link bug in HTTP doc
|
||||||
|
|
||||||
## Feature
|
## Feature
|
||||||
|
|
|
@ -9,7 +9,10 @@
|
||||||
// is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
|
// is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
|
||||||
// or implied. See the License for the specific language governing permissions and limitations under the License.
|
// or implied. See the License for the specific language governing permissions and limitations under the License.
|
||||||
|
|
||||||
|
#include "scheduler/task/SearchTask.h"
|
||||||
|
|
||||||
#include <fiu-local.h>
|
#include <fiu-local.h>
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
@ -21,7 +24,6 @@
|
||||||
#include "metrics/Metrics.h"
|
#include "metrics/Metrics.h"
|
||||||
#include "scheduler/SchedInst.h"
|
#include "scheduler/SchedInst.h"
|
||||||
#include "scheduler/job/SearchJob.h"
|
#include "scheduler/job/SearchJob.h"
|
||||||
#include "scheduler/task/SearchTask.h"
|
|
||||||
#include "segment/SegmentReader.h"
|
#include "segment/SegmentReader.h"
|
||||||
#include "utils/Log.h"
|
#include "utils/Log.h"
|
||||||
#include "utils/TimeRecorder.h"
|
#include "utils/TimeRecorder.h"
|
||||||
|
@ -264,13 +266,16 @@ XSearchTask::Execute() {
|
||||||
|
|
||||||
// step 3: pick up topk result
|
// step 3: pick up topk result
|
||||||
auto spec_k = file_->row_count_ < topk ? file_->row_count_ : topk;
|
auto spec_k = file_->row_count_ < topk ? file_->row_count_ : topk;
|
||||||
if (search_job->GetResultIds().front() == -1 && search_job->GetResultIds().size() > spec_k) {
|
|
||||||
// initialized results set
|
|
||||||
search_job->GetResultIds().resize(spec_k);
|
|
||||||
search_job->GetResultDistances().resize(spec_k);
|
|
||||||
}
|
|
||||||
{
|
{
|
||||||
std::unique_lock<std::mutex> lock(search_job->mutex());
|
std::unique_lock<std::mutex> lock(search_job->mutex());
|
||||||
|
|
||||||
|
if (search_job->GetResultIds().front() == -1 && search_job->GetResultIds().size() > spec_k) {
|
||||||
|
// initialized results set
|
||||||
|
search_job->GetResultIds().resize(spec_k);
|
||||||
|
search_job->GetResultDistances().resize(spec_k);
|
||||||
|
}
|
||||||
|
|
||||||
XSearchTask::MergeTopkToResultSet(output_ids, output_distance, spec_k, nq, topk, ascending_reduce,
|
XSearchTask::MergeTopkToResultSet(output_ids, output_distance, spec_k, nq, topk, ascending_reduce,
|
||||||
search_job->GetResultIds(), search_job->GetResultDistances());
|
search_job->GetResultIds(), search_job->GetResultDistances());
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue