Intel OneAPI MKL + Visual Studio 2019 C配置

利用VS2019+MKL加速矩陣運(yùn)算。

軟件版本

Intel OneAP 2022.0.2
Visual Studio 2019 Community

工程配置

  • 新建空工程


    image.png
  • 打開OneAPI選項(xiàng)


    image.png
  • 加入代碼(官方示例)
#include <stdio.h>
#include <time.h>
#include <stdlib.h>
#include "mkl.h"

void print_arr(int N, char* name, double* array);
void init_arr(int N, double* a);
void Dgemm_multiply(double* a, double* b, double* c, int N);

int main(int argc, char* argv[])
{
    clock_t start, stop;
    int i, j;
    int N;
    double* a;
    double* b;
    double* c;
    if (argc < 2)
    {
        printf("Enter matrix size N=");
        //please enter small number first to ensure that the 
        //multiplication is correct! and then you may enter 
        //a "reasonably" large number say like 500 or even 1000
        scanf("%d", &N);
    }
    else
    {
        N = atoi(argv[1]);
    }

    a = (double*)malloc(sizeof(double) * N * N);
    b = (double*)malloc(sizeof(double) * N * N);
    c = (double*)malloc(sizeof(double) * N * N);

    init_arr(N, a);
    init_arr(N, b);

    //DGEMM Multiply
    //reallocate to force cash to be flushed
    a = (double*)malloc(sizeof(double) * N * N);
    b = (double*)malloc(sizeof(double) * N * N);
    c = (double*)malloc(sizeof(double) * N * N);
    init_arr(N, a);
    init_arr(N, b);

    start = clock();
    //for(i=0;i<1000;i++)
    Dgemm_multiply(a, b, c, N);
    stop = clock();

    printf("Dgemm_multiply(). Elapsed time = %g seconds\n",
        ((double)(stop - start)) / CLOCKS_PER_SEC);
    //print simple test case of data to be sure multiplication is correct
    if (N < 7) {
        print_arr(N, "a", a);
        print_arr(N, "b", b);
        print_arr(N, "c", c);
    }

    free(a);
    free(b);
    free(c);

    return 0;
}


//DGEMM way. The PREFERED way, especially for large matrices
void Dgemm_multiply(double* a, double* b, double* c, int N)
{

    double alpha = 1.0, beta = 0.;
    int incx = 1;
    int incy = N;
    cblas_dgemm(CblasRowMajor, CblasNoTrans, CblasNoTrans, N, N, N, alpha, b, N, a, N, beta, c, N);
}

//initialize array with random data
void init_arr(int N, double* a)
{
    int i, j;
    for (i = 0; i < N; i++) {
        for (j = 0; j < N; j++) {
            a[i * N + j] = (i + j + 1) % 10; //keep all entries less than 10. pleasing to the eye!
        }
    }
}

//print array to std out
void print_arr(int N, char* name, double* array)
{
    int i, j;
    printf("\n%s\n", name);
    for (i = 0; i < N; i++) {
        for (j = 0; j < N; j++) {
            printf("%g\t", array[N * i + j]);
        }
        printf("\n");
    }
}

運(yùn)行和調(diào)試

  • 偶然出現(xiàn)的奇怪問題合搅,在設(shè)置OneAPI方式為Sequential的時(shí)候燃逻,程序一直可以運(yùn)行旁涤,但是OneAPI設(shè)置為Parallel后,輸入的N只能是小于15(多次實(shí)測),不然就會(huì)報(bào)錯(cuò)!


    Parallel N=14

    Parallel N=15

    錯(cuò)誤
  • 解決方法窘俺,在debug出來的exe文件夾下放入libiomp5md.dll


點(diǎn)亮“在看”
歡迎關(guān)注、收藏复凳、轉(zhuǎn)載哈!
最有意思的GNSS NEWS…不定期更新…

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末瘤泪,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子育八,更是在濱河造成了極大的恐慌对途,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,490評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件髓棋,死亡現(xiàn)場離奇詭異实檀,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)按声,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評論 3 395
  • 文/潘曉璐 我一進(jìn)店門膳犹,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人儒喊,你說我怎么就攤上這事”液牵” “怎么了怀愧?”我有些...
    開封第一講書人閱讀 165,830評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長余赢。 經(jīng)常有香客問我芯义,道長,這世上最難降的妖魔是什么妻柒? 我笑而不...
    開封第一講書人閱讀 58,957評論 1 295
  • 正文 為了忘掉前任扛拨,我火速辦了婚禮,結(jié)果婚禮上举塔,老公的妹妹穿的比我還像新娘绑警。我一直安慰自己求泰,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,974評論 6 393
  • 文/花漫 我一把揭開白布计盒。 她就那樣靜靜地躺著渴频,像睡著了一般。 火紅的嫁衣襯著肌膚如雪北启。 梳的紋絲不亂的頭發(fā)上卜朗,一...
    開封第一講書人閱讀 51,754評論 1 307
  • 那天,我揣著相機(jī)與錄音咕村,去河邊找鬼场钉。 笑死,一個(gè)胖子當(dāng)著我的面吹牛懈涛,可吹牛的內(nèi)容都是我干的逛万。 我是一名探鬼主播,決...
    沈念sama閱讀 40,464評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼肩钠,長吁一口氣:“原來是場噩夢啊……” “哼泣港!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起价匠,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤当纱,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后踩窖,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體坡氯,經(jīng)...
    沈念sama閱讀 45,847評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,995評論 3 338
  • 正文 我和宋清朗相戀三年洋腮,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了箫柳。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,137評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡啥供,死狀恐怖悯恍,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情伙狐,我是刑警寧澤涮毫,帶...
    沈念sama閱讀 35,819評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站贷屎,受9級特大地震影響罢防,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜唉侄,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,482評論 3 331
  • 文/蒙蒙 一咒吐、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦恬叹、人聲如沸候生。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,023評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽陶舞。三九已至,卻和暖如春绪励,著一層夾襖步出監(jiān)牢的瞬間肿孵,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,149評論 1 272
  • 我被黑心中介騙來泰國打工疏魏, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留停做,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,409評論 3 373
  • 正文 我出身青樓大莫,卻偏偏與公主長得像蛉腌,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子只厘,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,086評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 聽師兄說IT++庫可以用來做ICA烙丛,google找了半天資料才裝好,為了后來的同學(xué)們少走彎路羔味,把安裝過程記錄下來河咽。...
    Yuu_CX閱讀 1,726評論 0 0
  • 軟件測試用例 1.測試用例的概念和作用 1.1.引言 對一個(gè)測試工程師來說,測試用例的設(shè)計(jì)編寫是一項(xiàng)必須掌握的能力...
    ae1c0a8ab70d閱讀 810評論 0 0
  • 一 測試用例(Test Case) 測試用例(Test Case)是指對一項(xiàng)特定的軟件產(chǎn)品進(jìn)行測試任務(wù)的描述,體現(xiàn)...
    IT_Bears閱讀 1,110評論 0 0
  • GW1NR-9 開發(fā)板手冊 1.概述非常感謝選擇SZFPGA GW1NR-9開發(fā)板赋元。 GW1NR-9 開發(fā)板特性:...
    lichenllin閱讀 479評論 0 1
  • 1.測試用例的概念和作用 1.1.引言 對一個(gè)測試工程師來說,測試用例的設(shè)計(jì)編寫是一項(xiàng)必須掌握的能力忘蟹,但有效的設(shè)計(jì)...
    Anwfly閱讀 1,009評論 0 2