欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > 使用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位。以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函數操作(并排序)的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    99re66热这里只有精品3直播| 欧美在线不卡一区| 欧美不卡激情三级在线观看| 亚洲成人一区在线| 亚洲av无一区二区三区久久| 欧美综合天天夜夜久久| 亚洲欧美日韩国产综合在线| 99精品欧美一区二区三区综合在线| 国产精品夜夜夜爽阿娇| 国产农村妇女精品| 大美女一区二区三区| 全网免费在线播放视频入口| ...xxx性欧美| av影片在线播放| 51精品视频一区二区三区| 午夜精品一区二区三区三上悠亚| 俄罗斯黄色录像| 337p亚洲精品色噜噜狠狠| 三级久久三级久久| 中文字幕在线看高清电影| 久久综合一区二区| 国产老女人精品毛片久久| 久久久久久久久久97| 国产精品日韩精品欧美在线| www.日韩在线| 欧美视频在线播放| 肉色丝袜一区二区| 欧洲美一区二区三区亚洲| 国产亚洲一区二区三区| 粉嫩av一区二区三区| 色综合久久久久久久久| 亚洲午夜激情网页| 国产成人无码一区二区在线观看 | 久久91精品国产91久久小草| a资源在线观看| 国产精品美女久久久久av爽李琼| 9人人澡人人爽人人精品| 欧美私模裸体表演在线观看| 视频精品一区二区| 亚洲性猛交xxxx乱大交| 国产精品久久久久永久免费观看 | 亚洲乱码精品一二三四区日韩在线| 91免费国产视频网站| 91精品国产综合久久蜜臀| 欧美日韩你懂得| 喷白浆一区二区| 熟女av一区二区| 亚洲一区二区三区四区的| 四虎永久免费在线观看| 亚洲欧洲成人精品av97| 久久免费精品国产| 国产天堂亚洲国产碰碰| 91论坛在线播放| 欧美精品一区视频| 99在线热播精品免费| 日韩精品专区在线| 成人动漫一区二区| 日韩三级免费观看| 成年人国产精品| 欧美成人一区二区三区在线观看| 国产凹凸在线观看一区二区| 欧美日韩国产一级| 国产精品一区二区在线播放| 精品视频一区三区九区| 国产麻豆午夜三级精品| 欧美日韩免费观看一区三区| 国产一区二区三区精品视频| 欧美日韩久久久久久| 国产精品一区在线观看你懂的| 精品视频色一区| 国产馆精品极品| 91精品国产aⅴ一区二区| 国产a视频精品免费观看| 91精品久久久久久久99蜜桃 | 亚洲av成人精品一区二区三区| 国产亚洲午夜高清国产拍精品| 无码人妻少妇色欲av一区二区| 久久久久久免费毛片精品| 亚洲欧美日韩中文字幕在线观看| 久久精品亚洲国产奇米99| 超碰caoprom| 亚洲色图欧美在线| 精品在线观看一区| 美女视频黄a大片欧美| 欧美视频一区在线观看| 成人免费视频caoporn| 精品福利一区二区三区| 午夜男人的天堂| 亚洲欧美一区二区三区国产精品| 阿v天堂2014| 三级在线观看一区二区| 91搞黄在线观看| 国产mv日韩mv欧美| 久久久久亚洲蜜桃| ass精品国模裸体欣赏pics| 亚洲午夜日本在线观看| 日本青青草视频| 国产成人免费网站| 久久久电影一区二区三区| 亚洲国产精品成人综合久久久| 九九精品视频免费| 久久激五月天综合精品| 欧美一级生活片| 日本精品一二三区| 一区二区三区久久| 色8久久精品久久久久久蜜| 国产.欧美.日韩| 国产天堂亚洲国产碰碰| 熟女少妇内射日韩亚洲| 奇米888四色在线精品| 欧美一区二区黄| 亚洲图片综合网| 亚洲一二三区视频在线观看| 在线免费观看一区| 美女100%无挡| 国产乱人伦偷精品视频不卡| 精品久久一区二区| 中文字幕伦理片| 丝袜亚洲另类丝袜在线| 久久精品在线免费观看| 99re成人精品视频| 综合激情成人伊人| 五月婷婷一区二区| 不卡的av电影| 亚洲欧美日韩一区二区| 国产精品国产高清国产| 成人av在线影院| 最新国产成人在线观看| 一本久久a久久精品亚洲| 成人aa视频在线观看| 亚洲视频一区在线观看| 日本黄色一区二区| 91蜜桃在线免费视频| 洋洋成人永久网站入口| 欧美日本韩国一区二区三区视频| 国产精品熟妇一区二区三区四区 | 亚洲熟妇无码av| 麻豆91在线播放免费| 久久婷婷国产综合国色天香| 9.1片黄在线观看| 丰满少妇在线播放bd日韩电影| 中文字幕一区二| 欧美视频一区二区三区四区 | 国产精品系列在线| 国产精品三级视频| 一本一道波多野结衣一区二区| 日本一级免费视频| 日韩网站在线播放| 人妻丰满熟妇aⅴ无码| 在线观看一区二区三区视频| 久久99久久久久| 亚洲一区 欧美| 成人一区二区三区中文字幕| 亚洲不卡的av| 亚洲6080在线| 国产蜜臀97一区二区三区| 国产精品白丝喷水在线观看| 久久久久亚洲av无码麻豆| 午夜久久久影院| 中文字幕第一页久久| 色八戒一区二区三区| 亚洲午夜久久久久久久久红桃 | 欧美狂猛xxxxx乱大交3| www.色综合.com| 久久精品国产久精国产| 在线观看一区二区视频| 亚洲一区二区三区黄色| 久久精品国产一区二区| 中文字幕日本不卡| 欧美日本一区二区三区四区| 91网站免费入口| 成人高清视频在线观看| 亚洲mv在线观看| 国产性色一区二区| 欧美性猛交xxxx乱大交退制版| 中文字幕日韩三级片| 国产成人在线视频网站| 亚洲第一二三四区| 国产欧美视频一区二区| 欧美日韩国产精品成人| 毛片久久久久久| 久久久久国产免费| 国产精品1区2区3区| 亚洲成人手机在线| 亚洲国产精品精华液2区45| 欧美日韩国产精品成人| 91制片厂在线| 国产老熟女伦老熟妇露脸| 丁香天五香天堂综合| 日韩精品三区四区| 中文字幕在线播放不卡一区| 欧美一区二区网站| 色综合天天狠狠| 三年中国中文观看免费播放| 人妻精油按摩bd高清中文字幕| 国产一区二区在线看| 婷婷夜色潮精品综合在线| 国产精品不卡一区二区三区| 欧美mv日韩mv亚洲| 欧美日韩三级在线|