mirror of
https://github.com/ml-explore/mlx.git
synced 2025-09-01 12:49:44 +08:00
Ensure small sort doesn't use indices if not argsort
This commit is contained in:
@@ -45,7 +45,9 @@ struct ThreadSort {
|
||||
for (short j = i & 1; j < N_PER_THREAD - 1; j += 2) {
|
||||
if (op(vals[j + 1], vals[j])) {
|
||||
thread_swap(vals[j + 1], vals[j]);
|
||||
thread_swap(idxs[j + 1], idxs[j]);
|
||||
if (ARG_SORT) {
|
||||
thread_swap(idxs[j + 1], idxs[j]);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -111,7 +113,9 @@ struct BlockMergeSort {
|
||||
bool pred = (b_idx < B_sz) && (a_idx >= A_sz || op(b, a));
|
||||
|
||||
vals[i] = pred ? b : a;
|
||||
idxs[i] = pred ? Bs_idx[b_idx] : As_idx[a_idx];
|
||||
if (ARG_SORT) {
|
||||
idxs[i] = pred ? Bs_idx[b_idx] : As_idx[a_idx];
|
||||
}
|
||||
|
||||
b_idx += short(pred);
|
||||
a_idx += short(!pred);
|
||||
|
Reference in New Issue
Block a user