婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 使用numpy實現topk函數操作(并排序)

使用numpy實現topk函數操作(并排序)

熱門標簽:江西省地圖標注 沈陽外呼系統呼叫系統 外呼系統哪些好辦 沈陽人工外呼系統價格 如何申請400電話費用 武漢外呼系統平臺 富錦商家地圖標注 沈陽防封電銷卡品牌 池州外呼調研線路

np.argpartition 難以解決topK

topK是常用的一個功能,在python中,numpy等計算庫使用了豐富的底層優化,對于矩陣計算的效率遠高于python的for-loop實現。因此,我們希望盡量用一些numpy函數的組合實現topK。

pytorch 庫提供了topk函數,可以將高維數組沿某一維度(該維度共N項),選出最大(最小)的K項并排序。返回排序結果和index信息。奇怪的是,更輕量級的numpy庫并沒有直接提供 topK 函數。numpy只提供了argpartition 和 partition,可以將最大(最小)的K項排到前K位。以argpartition為例,最小的3項排到了前3位:

>>> x = np.array([3, 5, 6, 4, 2, 7, 1])
>>> x[np.argpartition(x, 3)]
array([2, 1, 3, 4, 5, 7, 6])

注意,argpartition實現的是 partial sorting,如上例,前3項和其余項被分開,但是兩部分各自都是不排序的!而我們可能更想要topK的幾項排好序(其余項則不作要求)。因此,下面提供一種基于argpartition的topK方法。

一個naive方法

最簡單的方法自然是全排序,然后取前K項。缺點在于,要把topK之外的數據也進行排序,當K N時較為浪費時間,復雜度為O ( n log ⁡ n ) O(n \log n)O(nlogn):

def naive_arg_topK(matrix, K, axis=0):
    """
    perform topK based on np.argsort
    :param matrix: to be sorted
    :param K: select and sort the top K items
    :param axis: dimension to be sorted.
    :return:
    """
    full_sort = np.argsort(matrix, axis=axis)
    return full_sort.take(np.arange(K), axis=axis)

# Example
>>> dists = np.random.permutation(np.arange(30)).reshape(6, 5)
array([[17, 28,  1, 24, 23,  8],
       [ 9, 21,  3, 22,  4,  5],
       [19, 12, 26, 11, 13, 27],
       [10, 15, 18, 14,  7, 16],
       [ 0, 25, 29,  2,  6, 20]])
>>> naive_arg_topK(dists, 2, axis=0)
array([[4, 2, 0, 4, 1, 1],
       [1, 3, 1, 2, 4, 0]])
>>> naive_arg_topK(dists, 2, axis=1)
array([[2, 5],
       [2, 4],
       [3, 1],
       [4, 0],
       [0, 3]])

基于partition的方法

對于 np.argpartition 函數,復雜度可能下降到 O ( n log ⁡ K ) O(n \log K)O(nlogK),很多情況下,K N,此時naive方法有優化的空間。

以下方法首先選出 topK 項,然后僅對前topK項進行排序(matrix僅限2d-array)。

def partition_arg_topK(matrix, K, axis=0):
    """
    perform topK based on np.argpartition
    :param matrix: to be sorted
    :param K: select and sort the top K items
    :param axis: 0 or 1. dimension to be sorted.
    :return:
    """
    a_part = np.argpartition(matrix, K, axis=axis)
    if axis == 0:
        row_index = np.arange(matrix.shape[1 - axis])
        a_sec_argsort_K = np.argsort(matrix[a_part[0:K, :], row_index], axis=axis)
        return a_part[0:K, :][a_sec_argsort_K, row_index]
    else:
        column_index = np.arange(matrix.shape[1 - axis])[:, None]
        a_sec_argsort_K = np.argsort(matrix[column_index, a_part[:, 0:K]], axis=axis)
        return a_part[:, 0:K][column_index, a_sec_argsort_K]

# Example
>>> dists = np.random.permutation(np.arange(30)).reshape(6, 5)
array([[17, 28,  1, 24, 23,  8],
       [ 9, 21,  3, 22,  4,  5],
       [19, 12, 26, 11, 13, 27],
       [10, 15, 18, 14,  7, 16],
       [ 0, 25, 29,  2,  6, 20]])
>>> partition_arg_topK(dists, 2, axis=0)
array([[4, 2, 0, 4, 1, 1],
       [1, 3, 1, 2, 4, 0]])
>>> partition_arg_topK(dists, 2, axis=1)
array([[2, 5],
       [2, 4],
       [3, 1],
       [4, 0],
       [0, 3]])

大數據量測試

對shape(5000, 100000)的矩陣進行topK排序,測試時間為:

K partition(s) naive(s)
10 8.884 22.604
100 9.012 22.458
1000 8.904 22.506
5000 11.305 22.844

補充:python堆排序實現TOPK問題

# 構建小頂堆跳轉def sift(li, low, higt):
    tmp = li[low]
    i = low
    j = 2 * i + 1
    while j = higt:  # 情況2:i已經是最后一層
        if j + 1 = higt and li[j + 1]  li[j]:  # 右孩子存在并且小于左孩子
            j += 1
        if tmp > li[j]:
            li[i] = li[j]
            i = j
            j = 2 * i + 1
        else:
            break  # 情況1:j位置比tmp小
    li[i] = tmp


def top_k(li, k):
    heap = li[0:k]
    # 建堆
    for i in range(k // 2 - 1, -1, -1):
        sift(heap, i, k - 1)
    for i in range(k, len(li)):
        if li[i] > heap[0]:
            heap[0] = li[i]
            sift(heap, 0, k - 1)
    # 挨個輸出
    for i in range(k - 1, -1, -1):
        heap[0], heap[i] = heap[i], heap[0]
        sift(heap, 0, i - 1)
    return heap


li = [0, 8, 6, 2, 4, 9, 1, 4, 6]
print(top_k(li, 3))

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • Python堆排序原理與實現方法詳解
  • Python實現堆排序的方法詳解
  • python 的topk算法實例
  • python 實現堆排序算法代碼

標簽:阿里 潛江 通遼 黑龍江 銅川 常德 株洲 呂梁

巨人網絡通訊聲明:本文標題《使用numpy實現topk函數操作(并排序)》,本文關鍵詞  使用,numpy,實現,topk,函數,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《使用numpy實現topk函數操作(并排序)》相關的同類信息!
  • 本頁收集關于使用numpy實現topk函數操作(并排序)的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    高清成人免费视频| 亚洲乱码日产精品bd| 4hu四虎永久在线影院成人| 精品捆绑美女sm三区| 中文字幕一区二区三区四区| 亚洲成人免费看| 国产酒店精品激情| 911国产精品| 午夜av电影一区| 国产一区二区伦理片| 欧美久久久久久久久| 欧美国产禁国产网站cc| 免费成人美女在线观看| 精品在线一区二区三区| 欧美在线观看视频一区二区 | 欧美三级中文字| 久久久久久一级片| 美女性感视频久久| 91精品久久久久久久91蜜桃 | 欧美日本高清视频在线观看| 国产精品美女视频| 国产一区二区三区免费播放| 91精品国产欧美一区二区成人| 中文字幕制服丝袜一区二区三区| 国产精品99久久不卡二区| 91免费小视频| 亚洲欧洲成人自拍| 成人性生交大片免费看中文| 欧美日韩国产精品自在自线| 亚洲精品中文字幕在线观看| 91网上在线视频| 国产亚洲一区二区三区四区 | 中文字幕一区在线| 国产成人精品亚洲日本在线桃色| 91精品国产综合久久久久| 国产成都精品91一区二区三| 久久婷婷国产综合国色天香| 久久综合国产精品| 捆绑调教美女网站视频一区| 91精品国产综合久久香蕉的特点| 欧美日韩亚洲另类| 亚洲国产精品久久一线不卡| 国产成人免费9x9x人网站视频| 麻豆精品视频在线观看视频| 欧美日韩国产大片| 久久综合久久综合久久| 久久精品视频免费| 国产精品久久三区| 日本一二三四高清不卡| 蜜臀精品一区二区三区在线观看| 色婷婷综合久久久久中文一区二区| 免费成人在线视频观看| 在线观看欧美精品| 精品国产乱码久久| 亚洲欧美韩国综合色| 国产成人免费视频一区| 欧美大片顶级少妇| 亚洲一区二区三区四区五区中文| 亚洲激情男女视频| 精品国产91洋老外米糕| 奇米888四色在线精品| 国产欧美一区二区三区在线老狼| 麻豆精品一区二区三区| 亚洲bt欧美bt精品777| 亚洲国产精品高清| 粉嫩嫩av羞羞动漫久久久| 欧美二区三区的天堂| 欧美日韩成人激情| 中国av一区二区三区| 亚洲一区二区在线免费看| 三级精品在线观看| 欧美精品视频www在线观看| 国产日韩影视精品| 欧美哺乳videos| 日韩免费性生活视频播放| 欧美精品一卡二卡| 日韩亚洲欧美高清| 91成人在线免费观看| 在线免费观看视频一区| 成人在线综合网站| 日韩欧美区一区二| 亚洲综合男人的天堂| 成人va在线观看| 日韩高清国产一区在线| 一区二区高清在线| 麻豆中文一区二区| 亚洲午夜在线视频| 视频一区二区三区中文字幕| 亚洲少妇最新在线视频| 欧美一级日韩不卡播放免费| 国产日韩精品视频一区| 欧美激情资源网| 亚洲免费视频中文字幕| 51精品久久久久久久蜜臀| 日韩精品一区二区三区视频| 国产亲近乱来精品视频| 久久精品亚洲精品国产欧美kt∨| 国产日韩精品一区二区浪潮av| 欧美激情一区三区| 亚洲欧美福利一区二区| 精品久久免费看| 亚洲va欧美va人人爽午夜| 色拍拍在线精品视频8848| 欧美一级视频精品观看| 国产女主播在线一区二区| 一级特黄大欧美久久久| 韩国毛片一区二区三区| 一本到一区二区三区| 中文字幕欧美一| 精品一区二区三区在线播放| 欧美激情一区二区三区不卡| 在线欧美小视频| 国产一区高清在线| 亚洲综合区在线| 亚洲国产精品成人综合| 欧美日韩国产色站一区二区三区| 久久99热99| 亚洲福利一区二区三区| 最新国产精品久久精品| 欧美xxxx老人做受| 欧美另类videos死尸| 高清在线不卡av| 国产一区二区不卡老阿姨| 国产情人综合久久777777| 中文字幕av一区二区三区| 粉嫩aⅴ一区二区三区四区| 91亚洲男人天堂| 国产午夜精品一区二区三区视频| 亚洲最新在线观看| 国产不卡免费视频| 欧美videofree性高清杂交| 一区二区三区四区视频精品免费| 国产乱对白刺激视频不卡| 色老头久久综合| 久久噜噜亚洲综合| 免费观看在线综合| 色婷婷久久久久swag精品 | 欧美一区二区三区日韩视频| 国产精品欧美经典| 五月激情六月综合| 一本大道久久a久久综合婷婷| 精品国产伦一区二区三区观看体验| 有码一区二区三区| 国产高清在线精品| 欧美日韩综合一区| 亚洲妇熟xx妇色黄| av欧美精品.com| 一区视频在线播放| 成人一区二区三区中文字幕| 国产亚洲精品资源在线26u| 国产毛片精品一区| 国产午夜精品美女毛片视频| 狠狠色丁香久久婷婷综| 久久久久亚洲综合| 成+人+亚洲+综合天堂| 国产精品卡一卡二| 成人性生交大片免费看视频在线| 国产精品免费视频网站| 成人av在线一区二区三区| 中文字幕永久在线不卡| 色综合网色综合| 亚洲国产成人高清精品| 91精品久久久久久久99蜜桃| 国内精品久久久久影院一蜜桃| 久久午夜国产精品| 成人av资源站| 午夜一区二区三区视频| 91精品婷婷国产综合久久性色| 久久精品免费看| 国产欧美一二三区| 91麻豆国产香蕉久久精品| 日日夜夜精品视频天天综合网| 亚洲精品在线免费播放| youjizz久久| 午夜视频久久久久久| 久久五月婷婷丁香社区| 91久久精品一区二区| 老司机精品视频导航| 亚洲日本一区二区三区| 日韩欧美国产三级| 91丝袜美腿高跟国产极品老师| 日韩精品视频网| 国产精品卡一卡二| 日韩色视频在线观看| 972aa.com艺术欧美| 琪琪久久久久日韩精品| 久久色中文字幕| 色综合天天狠狠| 久久99精品一区二区三区三区| 成人免费在线视频| 欧美大片在线观看一区二区| av在线播放成人| 麻豆精品在线观看| 亚洲综合色成人| 国产欧美一区二区精品秋霞影院| 欧美日韩dvd在线观看| 99re视频精品| 国产精品18久久久久久久久久久久 | 精品精品国产高清a毛片牛牛| 99精品1区2区|