校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 使用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函數操作(并排序)的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    日韩精品欧美成人高清一区二区| 日韩欧美在线1卡| 国产亚洲欧美中文| 美女视频网站黄色亚洲| 欧美另类videos死尸| 亚洲欧美另类综合偷拍| 成人性色生活片免费看爆迷你毛片| 欧美sm极限捆绑bd| 麻豆精品蜜桃视频网站| 欧美一区二区私人影院日本| 日韩精品电影在线| 7777精品伊人久久久大香线蕉| 日韩电影免费一区| 一本色道久久综合亚洲aⅴ蜜桃| 国产日韩av一区二区| 人人超碰91尤物精品国产| 欧美嫩在线观看| 日韩不卡一区二区三区| 日韩视频不卡中文| 国产一区二区在线观看视频| 国产无一区二区| 丰满少妇在线播放bd日韩电影| 亚洲国产高清不卡| 99这里都是精品| 亚洲免费观看高清完整| 在线欧美小视频| 亚洲成人第一页| 欧美一区二区福利在线| 加勒比av一区二区| 亚洲国产精品精华液ab| 91视视频在线直接观看在线看网页在线看 | 欧美日韩在线一区二区| 视频一区二区三区在线| 欧美一区二区三区视频在线观看| 91论坛在线播放| 中文字幕在线免费不卡| 国产又黄又大久久| 久久午夜电影网| 老司机免费视频一区二区三区| 欧美日韩一二三区| 亚洲女女做受ⅹxx高潮| 欧美电影免费提供在线观看| 免费成人在线视频观看| 成人av先锋影音| 欧美精品777| 亚洲综合图片区| 91老司机福利 在线| 国产亚洲一区字幕| 国产91丝袜在线播放| 精品国产乱码久久久久久免费| 一区二区激情小说| 欧美无砖专区一中文字| 亚洲一区二区三区美女| 91视频一区二区| 中文一区在线播放| 在线精品亚洲一区二区不卡| 欧美在线三级电影| 国产精品欧美综合在线| 久久99精品国产.久久久久久 | 亚洲人成网站精品片在线观看| 国产欧美视频一区二区| 日本不卡123| 国产精品每日更新在线播放网址 | 久久久不卡网国产精品一区| 色婷婷香蕉在线一区二区| 久久精品国产精品亚洲精品| 夜夜嗨av一区二区三区| 欧美激情艳妇裸体舞| 在线不卡免费欧美| 国产一区二区三区美女| 中文字幕一区在线观看| 亚洲精品在线免费播放| 欧美日韩国产区一| 91看片淫黄大片一级| 国产成人精品一区二区三区网站观看| 一区二区三区高清在线| 欧美激情在线一区二区| 欧美成人vr18sexvr| 99久久99久久精品国产片果冻 | 一区二区三区产品免费精品久久75| 日韩免费性生活视频播放| 国产精品123区| 久久精品国内一区二区三区| 五月婷婷激情综合| 亚洲免费观看高清完整| 亚洲视频电影在线| 中文在线一区二区| 91麻豆精品国产91久久久使用方法| 国产一区二区在线影院| 亚欧色一区w666天堂| 亚洲午夜日本在线观看| 亚洲日本丝袜连裤袜办公室| 国产精品久久久久久亚洲毛片| 欧美精品一区视频| 欧美精品一区二区久久久| 88在线观看91蜜桃国自产| 一本到不卡精品视频在线观看 | 国产精品美日韩| 日韩精品一区二区三区四区视频 | 欧美成人高清电影在线| 在线成人免费观看| 欧洲一区在线电影| 在线精品视频小说1| 欧美日韩一区不卡| 欧美日韩一区二区三区不卡| 欧美日韩免费不卡视频一区二区三区| 91久久精品一区二区三| 91丨九色porny丨蝌蚪| 91蝌蚪porny九色| 色综合久久综合| 欧美日韩中字一区| 欧美高清性hdvideosex| 日韩午夜激情电影| 欧美丝袜丝交足nylons图片| 欧美日韩亚洲不卡| 91精品国产美女浴室洗澡无遮挡| 日韩亚洲欧美一区| 久久久久久9999| 国产精品免费观看视频| 亚洲精品视频在线观看免费| 亚洲国产精品久久不卡毛片| 日韩精品一二区| 国产一区二区三区国产| 成人免费观看av| 91丨九色丨黑人外教| 欧美区一区二区三区| 欧美精品一区二区三区一线天视频| 久久久影视传媒| 亚洲国产视频一区二区| xnxx国产精品| 日韩欧美一级在线播放| 中文字幕一区二区三区不卡在线| 亚洲国产日产av| 99视频国产精品| 欧美大尺度电影在线| 亚洲综合一二区| www.亚洲人| 国产亚洲欧美日韩日本| 天堂蜜桃91精品| 99re亚洲国产精品| 国产女同互慰高潮91漫画| 青青草97国产精品免费观看| 99国产精品国产精品久久| 久久久久久久久免费| 青草av.久久免费一区| 色天天综合色天天久久| 中文字幕av免费专区久久| 美女mm1313爽爽久久久蜜臀| 欧美日韩在线播| 中文字幕日韩精品一区 | 91精品国产麻豆国产自产在线| 综合电影一区二区三区| 国产成人小视频| 久久天天做天天爱综合色| 免费的成人av| 91精品免费观看| 性久久久久久久久| 91高清视频在线| 亚洲精品欧美专区| 成人国产在线观看| 亚洲国产精品精华液2区45| 狠狠色2019综合网| 久久先锋影音av鲁色资源| 久久成人久久鬼色| 日韩免费一区二区三区在线播放| 日韩中文字幕不卡| 91精品国产手机| 蜜桃av一区二区在线观看| 欧美日韩日日摸| 日本视频一区二区| 日韩欧美中文字幕精品| 日韩av在线免费观看不卡| 日韩色在线观看| 久久av资源网| 亚洲精品一区二区三区香蕉| 精品亚洲porn| 国产精品私人影院| 91在线高清观看| 亚洲一区中文日韩| 91精品婷婷国产综合久久竹菊| 日本强好片久久久久久aaa| 制服丝袜激情欧洲亚洲| 久久99精品国产.久久久久久| 久久久蜜桃精品| 91社区在线播放| 亚洲无人区一区| 日韩一级黄色大片| 国产成a人无v码亚洲福利| 中文字幕日本不卡| 欧美日韩国产小视频在线观看| 石原莉奈在线亚洲二区| 久久欧美一区二区| 97精品国产97久久久久久久久久久久| 一区二区三区不卡视频在线观看| 欧美日韩精品专区| 国产精品一区二区你懂的| 亚洲私人影院在线观看| 欧美日韩一级二级三级| 国产精品一级黄| 综合久久一区二区三区|