亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? stpmv.cu

?? Nividia提供的CUDA的BLAS庫源碼
?? CU
字號:
/* * Copyright 1993-2008 NVIDIA Corporation.  All rights reserved. * * NOTICE TO USER:    * * This source code is subject to NVIDIA ownership rights under U.S. and * international Copyright laws.   * * This software and the information contained herein is being provided  * under the terms and conditions of a Source Code License Agreement.      * * NVIDIA MAKES NO REPRESENTATION ABOUT THE SUITABILITY OF THIS SOURCE * CODE FOR ANY PURPOSE.  IT IS PROVIDED "AS IS" WITHOUT EXPRESS OR  * IMPLIED WARRANTY OF ANY KIND.  NVIDIA DISCLAIMS ALL WARRANTIES WITH * REGARD TO THIS SOURCE CODE, INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE. * IN NO EVENT SHALL NVIDIA BE LIABLE FOR ANY SPECIAL, INDIRECT, INCIDENTAL, * OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS * OF USE, DATA OR PROFITS,  WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE * OR OTHER TORTIOUS ACTION,  ARISING OUT OF OR IN CONNECTION WITH THE USE * OR PERFORMANCE OF THIS SOURCE CODE.   * * U.S. Government End Users.   This source code is a "commercial item" as  * that term is defined at  48 C.F.R. 2.101 (OCT 1995), consisting  of * "commercial computer  software"  and "commercial computer software  * documentation" as such terms are  used in 48 C.F.R. 12.212 (SEPT 1995) * and is provided to the U.S. Government only as a commercial end item. * Consistent with 48 C.F.R.12.212 and 48 C.F.R. 227.7202-1 through * 227.7202-4 (JUNE 1995), all U.S. Government End Users acquire the  * source code with only those rights set forth herein. *//* This file contains the implementation of the BLAS-2 function stpmv */#include <stdlib.h>#include <assert.h>#include <string.h>#include <stdio.h>#include <limits.h>#include <ctype.h>#include <math.h>#include "cublas.h"   /* CUBLAS public header file  */#include "cublasP.h"  /* CUBLAS private header file */__global__ void stpmv_main_up_tr (struct cublasStpmvParams parms);__global__ void stpmv_main_lo_tr (struct cublasStpmvParams parms);__global__ void stpmv_main_up_nt (struct cublasStpmvParams parms);__global__ void stpmv_main_lo_nt (struct cublasStpmvParams parms);/* * void  * cublasStpmv (char uplo, char trans, char diag, int n, const float *AP,  *              float *x, int incx); * * performs one of the matrix-vector operations x = op(A) * x, where op(A) = A, * or op(A) = transpose(A). x is an n element single precision vector, and A  * is an n x n, unit or non-unit, upper or lower triangular matrix composed  * of single precision elements. * * Input * ----- * uplo   specifies whether the matrix A is an upper or lower triangular *        matrix. If uplo == 'U' or 'u', then A is an upper triangular matrix. *        If uplo == 'L' or 'l', then A is a lower triangular matrix. * trans  specifies op(A). If transa == 'N' or 'n', op(A) = A. If trans == 'T', *        't', 'C', or 'c', op(A) = transpose(A) * diag   specifies whether or not matrix A is unit triangular. If diag == 'U' *        or 'u', A is assumed to be unit triangular. If diag == 'N' or 'n', A  *        is not assumed to be unit triangular. * n      specifies the number of rows and columns of the matrix A. n must be  *        at least zero. In the current implementation n must not exceed 4070. * AP     single precision array with at least ((n * (n + 1)) / 2) elements. If *        uplo == 'U' or 'u', the array AP contains the upper triangular part  *        of the symmetric matrix A, packed sequentially, column by column;  *        that is, if i <= j, then A[i,j] is stored in AP[i+(j*(j+1)/2)]. If  *        uplo == 'L' or 'L', the array AP contains the lower triangular part  *        of the symmetric matrix A, packed sequentially, column by column;  *        that is, if i >= j, then A[i,j] is stored in AP[i+((2*n-j+1)*j)/2]. * x      single precision array of length at least (1 + (n - 1) * abs(incx)). *        On entry, x contains the source vector. On exit, x is overwritten  *        with the result vector. * incx   specifies the storage spacing for elements of x. incx must not be  *        zero. * * Output * ------ * x      updated according to x = op(A) * x, * * Reference: http://www.netlib.org/blas/stpmv.f * * Error status for this function can be retrieved via cublasGetError(). * * Error Status * ------------ * CUBLAS_STATUS_NOT_INITIALIZED  if CUBLAS library has not been initialized * CUBLAS_STATUS_INVALID_VALUE    if incx == 0, n < 0, or n > 4070 * CUBLAS_STATUS_EXECUTION_FAILED if function failed to launch on GPU */__host__ void CUBLASAPI cublasStpmv (char uplo, char trans, char diag, int n,                                      const float *AP, float *x, int incx){    struct cublasContext *ctx = CUBLAS_GET_CTX();    struct cublasStpmvParams params;    cudaError_t cudaStat;    int info = 0;    if (!cublasInitialized (ctx)) {        cublasSetError (ctx, CUBLAS_STATUS_NOT_INITIALIZED);        return;    }    /* check other inputs */    if ((toupper (uplo) != 'U') &&        (toupper (uplo) != 'L')) {        info = 1;    }    else if ((toupper (trans) != 'N') &&              (toupper (trans) != 'T') &&              (toupper (trans) != 'C')) {        info = 2;    }     else if ((toupper (diag) != 'U') &&             (toupper (diag) != 'N')) {        info = 3;    }    else if ((n < 0) && (n > CUBLAS_STPMV_MAX_DIM)) {        info = 4;    }    else if (incx == 0) {        info = 7;    }    if (info) {        cublasXerbla ("STPMV ", info);        cublasSetError (ctx, CUBLAS_STATUS_INVALID_VALUE);        return;    }    /* early out if nothing to do */    if (n == 0) {        return;    }    memset (&params, 0, sizeof(params));    params.n = n;    params.AP = AP;    params.x = x;    params.incx = incx;    params.trans = ((toupper(trans) == 'T') || (toupper(trans) == 'C'));    params.unit = (toupper(diag) == 'U');    params.up = (toupper(uplo) == 'U');    cudaStat = cudaGetLastError(); /* clear error status */    if (params.trans) {        if (params.up) {            stpmv_main_up_tr<<<CUBLAS_STPMV_CTAS,CUBLAS_STPMV_THREAD_COUNT>>>(params);        } else {            stpmv_main_lo_tr<<<CUBLAS_STPMV_CTAS,CUBLAS_STPMV_THREAD_COUNT>>>(params);        }    } else {        if (params.up) {            stpmv_main_up_nt<<<CUBLAS_STPMV_CTAS,CUBLAS_STPMV_THREAD_COUNT>>>(params);        } else {            stpmv_main_lo_nt<<<CUBLAS_STPMV_CTAS,CUBLAS_STPMV_THREAD_COUNT>>>(params);        }    }    cudaStat = cudaGetLastError(); /* check for launch error */    if (cudaStat != cudaSuccess) {        cublasSetError (ctx, CUBLAS_STATUS_EXECUTION_FAILED);    }}/* column-major ordering */#define IDXX(i)             (startx + ((i) * parms.incx))#define XINC                (CUBLAS_STPMV_THREAD_COUNT)__shared__ float xx[CUBLAS_STPMV_MAX_DIM];  /* cached portion of vector x */__global__ void stpmv_main_up_tr (struct cublasStpmvParams parms) {#undef  UP#undef  TRANS#define TRANS 1#define UP    1#include "stpmv.h"}__global__ void stpmv_main_lo_tr (struct cublasStpmvParams parms) {#undef  UP#undef  TRANS#define TRANS 1#define UP    0#include "stpmv.h"}__global__ void stpmv_main_up_nt (struct cublasStpmvParams parms) {#undef  UP#undef  TRANS#define TRANS 0#define UP    1#include "stpmv.h"}__global__ void stpmv_main_lo_nt (struct cublasStpmvParams parms) {#undef  UP#undef  TRANS#define TRANS 0#define UP    0#include "stpmv.h"}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区三区综合| 91视视频在线观看入口直接观看www | 日韩精品欧美成人高清一区二区| 蜜臀久久99精品久久久久宅男 | 亚洲图片你懂的| 蜜臀av亚洲一区中文字幕| 国产成人精品一区二区三区四区| 欧美日本国产视频| 亚洲色图色小说| 成人午夜激情影院| 精品国产凹凸成av人导航| 五月天丁香久久| 91成人网在线| 亚洲三级在线播放| 99久久免费视频.com| 国产精品系列在线| 国产成人午夜99999| 精品福利一二区| 国内外成人在线视频| 欧美一区二区三区男人的天堂| 亚洲少妇最新在线视频| 成人午夜视频免费看| 欧美国产日韩a欧美在线观看 | 开心九九激情九九欧美日韩精美视频电影| 91性感美女视频| 国产精品久久久久久久久免费桃花| 欧美在线999| 国产精品久久久久久久第一福利| 国产在线不卡一区| 欧美不卡一二三| 久久97超碰国产精品超碰| 欧美videofree性高清杂交| 蜜臀精品久久久久久蜜臀| 欧美一级理论片| 裸体在线国模精品偷拍| 日韩免费一区二区三区在线播放| 麻豆精品国产91久久久久久| 日韩欧美色综合| 国内精品第一页| 国产精品久久久久永久免费观看| 成人美女视频在线观看| 亚洲欧美综合另类在线卡通| 91麻豆免费观看| 亚洲一区二区三区四区在线免费观看 | 香蕉加勒比综合久久 | 色香色香欲天天天影视综合网| 国产精品污www在线观看| av在线不卡免费看| 伊人性伊人情综合网| 欧美久久久久久蜜桃| 首页国产欧美久久| 久久综合九色综合97_久久久| 国产美女娇喘av呻吟久久 | 久久网这里都是精品| 成人中文字幕在线| 亚洲女同一区二区| 777久久久精品| 国产91对白在线观看九色| ...av二区三区久久精品| 国产精品短视频| 精品在线一区二区三区| 91亚洲精品久久久蜜桃| 99国产精品99久久久久久| 99久久精品免费看国产| 大胆亚洲人体视频| 欧美色图免费看| 一区二区三区在线不卡| 色综合久久六月婷婷中文字幕| 综合亚洲深深色噜噜狠狠网站| 99久久综合色| 日韩精品综合一本久道在线视频| 亚洲成人动漫一区| 国产精品一区在线观看乱码| 亚洲欧美日韩国产手机在线 | 国产精品色噜噜| 欧美日韩一区二区三区视频| 国内成人精品2018免费看| 成人高清在线视频| 欧美一二三区在线| 精品久久久久久久一区二区蜜臀| 国产综合色产在线精品| 一区二区三区精品视频| 精品美女一区二区三区| 色999日韩国产欧美一区二区| 美女精品自拍一二三四| 亚洲精品大片www| 国产婷婷精品av在线| 在线成人av影院| 色香蕉成人二区免费| 国产成人精品免费网站| 日本在线播放一区二区三区| 有码一区二区三区| 91免费观看在线| 亚洲一级二级在线| 欧美大尺度电影在线| 亚洲午夜精品在线| 欧美日韩国产首页在线观看| 日本欧美在线看| 欧美日韩成人综合天天影院| 精品美女在线播放| 国产成人自拍网| 蜜桃视频一区二区三区 | 亚洲精品视频在线观看免费| 91福利视频久久久久| 亚洲国产精品av| 色婷婷av一区二区三区软件| 国产在线麻豆精品观看| 久久久91精品国产一区二区精品| 欧亚洲嫩模精品一区三区| 国产精品系列在线播放| 国产精品77777| 国产福利精品一区| 国产精品综合二区| 国产福利一区在线| 成人a区在线观看| 色婷婷综合中文久久一本| 99久久婷婷国产综合精品电影| 国产成人午夜高潮毛片| 99免费精品在线| 91免费国产视频网站| 不卡av在线免费观看| 欧美性色黄大片| 日韩欧美国产不卡| 国产精品久久久久一区二区三区 | 日本韩国精品一区二区在线观看| 91免费国产在线| 欧美日韩1234| 本田岬高潮一区二区三区| 99久久久免费精品国产一区二区 | caoporm超碰国产精品| 99re在线视频这里只有精品| 日韩视频一区二区三区在线播放 | 7777精品伊人久久久大香线蕉的 | 亚洲天堂久久久久久久| 亚洲国产精品一区二区尤物区| 日日夜夜精品视频天天综合网| 日本欧美一区二区三区| 色欧美乱欧美15图片| 久久人人爽爽爽人久久久| 亚洲欧洲制服丝袜| 精品在线播放免费| 色婷婷激情一区二区三区| 精品国内二区三区| 亚洲国产精品欧美一二99| 国产精品中文字幕欧美| 丁香婷婷深情五月亚洲| 国产成人精品一区二区三区四区 | 一区二区三区视频在线看| 国产精品一区一区三区| 日韩精品一区二区三区视频在线观看| 亚洲欧洲精品一区二区精品久久久 | 亚洲国产精品精华液2区45| 中文字幕在线一区免费| 免费高清视频精品| 国产欧美综合在线观看第十页| 色又黄又爽网站www久久| 亚洲成人第一页| 国产午夜精品美女毛片视频| 欧美在线看片a免费观看| 国产在线精品一区在线观看麻豆| 日本韩国一区二区三区视频| 亚洲自拍偷拍欧美| 国产精品水嫩水嫩| 91精品在线麻豆| 色哟哟日韩精品| 国产a久久麻豆| 激情另类小说区图片区视频区| 久久久久亚洲蜜桃| 成人黄色av网站在线| 欧美亚洲自拍偷拍| 国产suv精品一区二区6| 亚洲国产一区二区三区 | 日韩视频在线一区二区| 91在线视频18| 国产一区二区三区最好精华液| 伊人性伊人情综合网| 久久久欧美精品sm网站| 欧美精三区欧美精三区| 91尤物视频在线观看| 丁香婷婷综合网| 国产麻豆精品在线观看| 亚洲va中文字幕| 最新成人av在线| 久久久蜜桃精品| 精品国一区二区三区| 欧美日韩久久久| 欧美绝品在线观看成人午夜影视| 成人av网站在线观看免费| 国产一区二区三区美女| 成人黄色片在线观看| 蜜臀av一区二区三区| 激情久久五月天| 91国内精品野花午夜精品 | 亚洲色图视频网站| 蜜臀久久久久久久| 成人av综合一区| 欧美xfplay| 亚洲午夜国产一区99re久久| 国产成人综合网站| 7777精品伊人久久久大香线蕉超级流畅|