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

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

?? spsm.cc

?? sparselib庫
?? CC
?? 第 1 頁 / 共 3 頁
字號:
/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*//*             ********   ***                                 SparseLib++    *//*          *******  **  ***       ***      ***                              *//*           *****      ***     ******** ********                            *//*            *****    ***     ******** ********              R. Pozo        *//*       **  *******  ***   **   ***      ***                 K. Remington   *//*        ********   ********                                 A. Lumsdaine   *//*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*//*                                                                           *//*                                                                           *//*                     SparseLib++ : Sparse Matrix Library                   *//*                                                                           *//*               National Institute of Standards and Technology              *//*                        University of Notre Dame                           *//*              Authors: R. Pozo, K. Remington, A. Lumsdaine                 *//*                                                                           *//*                                 NOTICE                                    *//*                                                                           *//* Permission to use, copy, modify, and distribute this software and         *//* its documentation for any purpose and without fee is hereby granted       *//* provided that the above notice appear in all copies and supporting        *//* documentation.                                                            *//*                                                                           *//* Neither the Institutions (National Institute of Standards and Technology, *//* University of Notre Dame) nor the Authors make any representations about  *//* the suitability of this software for any purpose.  This software is       *//* provided ``as is'' without expressed or implied warranty.                 *//*                                                                           *//*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*//* * Home Grown Sparse BLAS * * These are just a subset of the functions described in SPARKER * Working Note #3. * * Would be great if these could be templated some day * */#include <stdlib.h>#include <iostream>#include "spblas.h"#define _SpMatVal(_a,_lda,_row,_col) ((_a)[(_lda)*(_col)+(_row)])/* * int &m   Number of rows in matrix c * * int &n   Number of columns in matrix c * * int &k   Number of rows in matrix b * * Assume diagonal elements are in proper place * * unitd = 1    D = I * unitd = 2    left (row scaling) * unitd = 3    right (column scaling) */static voidCopyRectangularArray_double(int m, int n,             const double *b, int ldb, double *c, int ldc){  int i, l;  if (b == c)    return;  if (n == 1)    for (i = 0; i < m; i++)      c[i] = b[i];  else    for (l = 0; l < n; l++)      for (i = 0; i < m; i++)    _SpMatVal(c, ldc, i, l) = _SpMatVal(b, ldb, i, l);}static voidCopyRectangularArray_float(int m, int n,             const float *b, int ldb, float *c, int ldc){  int i, l;  if (b == c)    return;  if (n == 1)    for (i = 0; i < m; i++)      c[i] = b[i];  else    for (l = 0; l < n; l++)      for (i = 0; i < m; i++)    _SpMatVal(c, ldc, i, l) = _SpMatVal(b, ldb, i, l);}static voidCompCol_LowerUnitSolve_double(int m, int n, int unitd, const double *dv,       double alpha, const double *val, const int *indx, const int *pntr,      const double *b, int ldb, double *c, int ldc){  int i, j, l;  double z;  // To make the compiler happy  if (dv)    ;  if (unitd != 1) {    std::cerr << "unitd != 1 not implemented" << "\n";    exit(1);  }  if (alpha == 0.0)    return;  CopyRectangularArray_double(m, n, b, ldb, &c[pntr[0]-1], ldc);  c -= 1;  val -= pntr[0];  indx -= pntr[0];  if (alpha == 1.0) {    if (n == 1)      for (i = 0; i < m; i++) {    z = c[i+pntr[0]];    for (j = pntr[i]; j < pntr[i+1]; j++)      c[indx[j]] -= z * val[j];      }    else      for (l = 0; l < n; l++)    for (i = 0; i < m; i++) {      z = _SpMatVal(c, ldc, i+pntr[0], l);      for (j = pntr[i]; j < pntr[i+1]; j++)        _SpMatVal(c, ldc, indx[j], l) -= z * val[j];    }  } else {    if (n == 1)      for (i = 0; i < m; i++) {    z = alpha * c[i+pntr[0]];    for (j = pntr[i]; j < pntr[i+1]; j++)      c[indx[j]] -= z * val[j];      }    else      for (l = 0; l < n; l++)    for (i = 0; i < m; i++) {      z = alpha * _SpMatVal(c, ldc, i+pntr[0], l);      for (j = pntr[i]; j < pntr[i+1]; j++)        _SpMatVal(c, ldc, indx[j], l) -= z * val[j];    }  }}static voidCompCol_LowerUnitSolve_float(int m, int n, int unitd, const float *dv,     float alpha, const float *val, const int *indx, const int *pntr,    const float *b, int ldb, float *c, int ldc){  int i, j, l;  float z;  // To make the compiler happy  if (dv)    ;  if (unitd != 1) {    std::cerr << "unitd != 1 not implemented" << "\n";    exit(1);  }  if (alpha == 0.0)    return;  CopyRectangularArray_float(m, n, b, ldb, &c[pntr[0]-1], ldc);  c -= 1;  val -= pntr[0];  indx -= pntr[0];  if (alpha == 1.0) {    if (n == 1)      for (i = 0; i < m; i++) {    z = c[i+pntr[0]];    for (j = pntr[i]; j < pntr[i+1]; j++)      c[indx[j]] -= z * val[j];      }    else      for (l = 0; l < n; l++)    for (i = 0; i < m; i++) {      z = _SpMatVal(c, ldc, i+pntr[0], l);      for (j = pntr[i]; j < pntr[i+1]; j++)        _SpMatVal(c, ldc, indx[j], l) -= z * val[j];    }  } else {    if (n == 1)      for (i = 0; i < m; i++) {    z = alpha * c[i+pntr[0]];    for (j = pntr[i]; j < pntr[i+1]; j++)      c[indx[j]] -= z * val[j];      }    else      for (l = 0; l < n; l++)    for (i = 0; i < m; i++) {      z = alpha * _SpMatVal(c, ldc, i+pntr[0], l);      for (j = pntr[i]; j < pntr[i+1]; j++)        _SpMatVal(c, ldc, indx[j], l) -= z * val[j];    }  }}static voidCompCol_LowerDiagSolve_double(int m, int n, int unitd, const double *dv, double alpha,               const double *val, const int *indx, const int *pntr,               const double *b, int ldb, double *c, int ldc){  int i, j, l;  double z;  // To make the compiler happy  if (dv)    ;  if (unitd != 1) {    std::cerr << "unitd != 1 not implemented" << "\n";    exit(1);  }  if (alpha == 0.0)    return;  CopyRectangularArray_double(m, n, b, ldb, &c[pntr[0]-1], ldc);  c -= 1;  val -= pntr[0];  indx -= pntr[0];  if (alpha == 1.0) {    if (n == 1)      for (i = 0; i < m; i++) {    z = c[i+pntr[0]] / val[pntr[i]];    c[i+pntr[0]] = z;    for (j = pntr[i] + 1; j < pntr[i+1]; j++)      c[indx[j]] -= z * val[j];      }    else      for (l = 0; l < n; l++)    for (i = 0; i < m; i++) {      z = _SpMatVal(c, ldc, i+pntr[0], l) / val[pntr[i]];      _SpMatVal(c, ldc, i+pntr[0], l) = z;      for (j = pntr[i] + 1; j < pntr[i+1]; j++)        _SpMatVal(c, ldc, indx[j], l) -= z * val[j];    }  } else {    if (n == 1)      for (i = 0; i < m; i++) {    z = alpha * c[i+pntr[0]] / val[pntr[i]];    c[i+pntr[0]] = z;    for (j = pntr[i] + 1; j < pntr[i+1]; j++)      c[indx[j]] -= z * val[j];      }    else      for (l = 0; l < n; l++)    for (i = 0; i < m; i++) {      z = alpha * _SpMatVal(c, ldc, i+pntr[0], l) / val[pntr[i]];      _SpMatVal(c, ldc, i, l) = z;      for (j = pntr[i] + 1; j < pntr[i+1]; j++)        _SpMatVal(c, ldc, indx[j], l) -= z * val[j];    }  }}static voidCompCol_LowerDiagSolve_float(int m, int n, int unitd, const float *dv,                 float alpha,               const float *val, const int *indx, const int *pntr,               const float *b, int ldb, float *c, int ldc){  int i, j, l;  float z;  // To make the compiler happy  if (dv)    ;  if (unitd != 1) {    std::cerr << "unitd != 1 not implemented" << "\n";    exit(1);  }  if (alpha == 0.0)    return;  CopyRectangularArray_float(m, n, b, ldb, &c[pntr[0]-1], ldc);  c -= 1;  val -= pntr[0];  indx -= pntr[0];  if (alpha == 1.0) {    if (n == 1)      for (i = 0; i < m; i++) {    z = c[i+pntr[0]] / val[pntr[i]];    c[i+pntr[0]] = z;    for (j = pntr[i] + 1; j < pntr[i+1]; j++)      c[indx[j]] -= z * val[j];      }    else      for (l = 0; l < n; l++)    for (i = 0; i < m; i++) {      z = _SpMatVal(c, ldc, i+pntr[0], l) / val[pntr[i]];      _SpMatVal(c, ldc, i+pntr[0], l) = z;      for (j = pntr[i] + 1; j < pntr[i+1]; j++)        _SpMatVal(c, ldc, indx[j], l) -= z * val[j];    }  } else {    if (n == 1)      for (i = 0; i < m; i++) {    z = alpha * c[i+pntr[0]] / val[pntr[i]];    c[i+pntr[0]] = z;    for (j = pntr[i] + 1; j < pntr[i+1]; j++)      c[indx[j]] -= z * val[j];      }    else      for (l = 0; l < n; l++)    for (i = 0; i < m; i++) {      z = alpha * _SpMatVal(c, ldc, i+pntr[0], l) / val[pntr[i]];      _SpMatVal(c, ldc, i, l) = z;      for (j = pntr[i] + 1; j < pntr[i+1]; j++)        _SpMatVal(c, ldc, indx[j], l) -= z * val[j];    }  }}static voidCompCol_UpperUnitSolve_double(int m, int n, int unitd, const double *dv,                 double alpha,               const double *val, const int *indx, const int *pntr,               const double *b, int ldb, double *c, int ldc){  int i, j, l;  double z;  // To make the compiler happy  if (dv)    ;  if (unitd != 1) {    std::cerr << "unitd != 1 not implemented" << "\n";    exit(1);  }  if (alpha == 0.0)    return;  CopyRectangularArray_double(m, n, b, ldb, &c[pntr[0]-1], ldc);  c -= 1;  val -= pntr[0];    indx -= pntr[0];  if (alpha == 1.0) {    if (n == 1)      for (i = m - 1; i >= 0; i--) {    z = c[i+pntr[0]];    for (j = pntr[i]; j < pntr[i+1]; j++)      c[indx[j]] -= z * val[j];      }    else      for (l = 0; l < n; l++)    for (i = m - 1; i >= 0; i--) {      z = _SpMatVal(c, ldc, i+pntr[0], l);      for (j = pntr[i]; j < pntr[i+1]; j++)        _SpMatVal(c, ldc, indx[j], l) -= z * val[j];    }  } else {    if (n == 1)      for (i = m - 1; i >= 0; i--) {    z = alpha * c[i+pntr[0]];    for (j = pntr[i]; j < pntr[i+1]; j++)      c[indx[j]] -= z * val[j];      }    else      for (l = 0; l < n; l++)    for (i = m - 1; i >= 0; i--) {      z = alpha * _SpMatVal(c, ldc, i+pntr[0], l);      for (j = pntr[i]; j < pntr[i+1]; j++)        _SpMatVal(c, ldc, indx[j], l) -= z * val[j];    }  }}static voidCompCol_UpperUnitSolve_float(int m, int n, int unitd, const float *dv,                 float alpha,               const float *val, const int *indx, const int *pntr,               const float *b, int ldb, float *c, int ldc){  int i, j, l;  float z;  // To make the compiler happy  if (dv)    ;  if (unitd != 1) {    std::cerr << "unitd != 1 not implemented" << "\n";    exit(1);  }  if (alpha == 0.0)    return;  CopyRectangularArray_float(m, n, b, ldb, &c[pntr[0]-1], ldc);  c -= 1;  val -= pntr[0];    indx -= pntr[0];  if (alpha == 1.0) {    if (n == 1)      for (i = m - 1; i >= 0; i--) {    z = c[i+pntr[0]];    for (j = pntr[i]; j < pntr[i+1]; j++)      c[indx[j]] -= z * val[j];      }    else      for (l = 0; l < n; l++)    for (i = m - 1; i >= 0; i--) {      z = _SpMatVal(c, ldc, i+pntr[0], l);      for (j = pntr[i]; j < pntr[i+1]; j++)        _SpMatVal(c, ldc, indx[j], l) -= z * val[j];    }  } else {    if (n == 1)      for (i = m - 1; i >= 0; i--) {    z = alpha * c[i+pntr[0]];    for (j = pntr[i]; j < pntr[i+1]; j++)      c[indx[j]] -= z * val[j];      }    else      for (l = 0; l < n; l++)    for (i = m - 1; i >= 0; i--) {      z = alpha * _SpMatVal(c, ldc, i+pntr[0], l);      for (j = pntr[i]; j < pntr[i+1]; j++)        _SpMatVal(c, ldc, indx[j], l) -= z * val[j];    }  }}static voidCompCol_UpperDiagSolve_double(int m, int n, int unitd, const double *dv,             double alpha,               const double *val, const int *indx, const int *pntr,               const double *b, int ldb, double *c, int ldc){  int i, j, l;  double z;  // To make the compiler happy  if (dv)    ;  if (unitd != 1) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩一区二区免费电影| 亚洲一线二线三线久久久| 亚洲品质自拍视频| 精品一区二区免费看| 色噜噜狠狠色综合中国| 久久久久久久国产精品影院| 亚洲电影在线免费观看| av电影在线观看一区| www精品美女久久久tv| 天天操天天干天天综合网| 99精品一区二区三区| 国产色91在线| 狠狠色综合播放一区二区| 欧美日韩国产免费一区二区| 亚洲免费在线看| 成人免费视频免费观看| 久久精品免视看| 精品一区二区影视| 91精品国产91热久久久做人人| 樱花影视一区二区| 97se亚洲国产综合在线| 国产精品色噜噜| 成人午夜精品在线| 国产欧美日韩在线观看| 国产精品正在播放| 久久先锋影音av鲁色资源| 久久精品噜噜噜成人av农村| 日韩欧美一区中文| 青青草97国产精品免费观看无弹窗版| 欧美三级电影在线观看| 亚洲国产你懂的| 欧美日韩亚洲综合在线| 午夜精品久久久| 欧美日韩国产影片| 免费一区二区视频| 欧美成人一区二区| 国产一区二区免费在线| 久久久av毛片精品| 成人黄色a**站在线观看| 中文字幕欧美激情一区| 99精品国产91久久久久久| ㊣最新国产の精品bt伙计久久| 99视频在线精品| 一区二区三区在线免费播放| 欧美三级日本三级少妇99| 午夜久久福利影院| 欧美大片在线观看| 国产成人综合精品三级| 亚洲欧美自拍偷拍色图| 91久久一区二区| 五月天丁香久久| 精品国产乱码久久久久久闺蜜| 国产精品一区免费视频| 亚洲同性同志一二三专区| 欧美三级资源在线| 九九热在线视频观看这里只有精品| 精品国产乱子伦一区| 成人av电影观看| 亚洲免费在线视频| 日韩欧美资源站| 99久久国产综合精品女不卡| 亚洲国产毛片aaaaa无费看| 日韩欧美www| 91小视频在线| 日韩电影在线一区| 日本一区二区三区高清不卡 | 久久丁香综合五月国产三级网站| 久久综合中文字幕| 91免费看片在线观看| 免费观看成人av| 日韩美女视频19| 日韩女优制服丝袜电影| 一本大道av一区二区在线播放| 日韩国产在线观看| 成人免费在线视频观看| 欧美一级免费观看| 91色视频在线| 黑人精品欧美一区二区蜜桃 | 色8久久精品久久久久久蜜| 另类小说图片综合网| 亚洲免费看黄网站| 亚洲精品一区二区三区香蕉| 91福利在线免费观看| 成人一级视频在线观看| 奇米影视一区二区三区小说| 亚洲精品亚洲人成人网| ww久久中文字幕| 91精品国产欧美一区二区18 | 成人精品在线视频观看| 麻豆精品新av中文字幕| 亚洲午夜精品一区二区三区他趣| 久久久久99精品国产片| 欧美一区永久视频免费观看| 色综合色狠狠综合色| 国产寡妇亲子伦一区二区| 青草av.久久免费一区| 亚洲精品网站在线观看| 中文字幕第一区二区| 精品99999| 欧美电影免费观看高清完整版在 | 成人国产精品视频| 激情五月播播久久久精品| 日本成人在线不卡视频| 亚洲一级在线观看| 一级做a爱片久久| 一区二区三区不卡视频 | 欧美国产一区二区在线观看| 精品国产91乱码一区二区三区 | 91久久精品网| 在线一区二区三区| 91久久免费观看| 在线精品视频一区二区| 日本久久一区二区三区| 色爱区综合激月婷婷| 日本乱人伦一区| 欧美视频一区在线观看| 欧美日韩另类国产亚洲欧美一级| 欧美亚洲愉拍一区二区| 欧美性大战久久久久久久蜜臀| 在线观看一区不卡| 欧美日韩在线播放三区| 欧美顶级少妇做爰| 日韩美女一区二区三区四区| 精品国产区一区| 亚洲国产精品av| 有坂深雪av一区二区精品| 亚洲一级二级三级| 免费观看91视频大全| 欧美精品一区二| 在线视频一区二区三区| 欧美日韩高清一区二区| 日韩免费高清av| 精品少妇一区二区三区在线播放| 久久婷婷国产综合国色天香| 国产精品午夜春色av| 一区二区不卡在线播放| 美女视频黄免费的久久| 成人激情电影免费在线观看| 色女孩综合影院| 日韩午夜在线观看| 国产精品久久午夜| 婷婷综合久久一区二区三区| 狠狠色伊人亚洲综合成人| www.日本不卡| 欧美疯狂性受xxxxx喷水图片| 91精品国产综合久久香蕉麻豆| 欧美精品一区二区三区在线播放| 国产精品久久久久影院亚瑟| 亚洲一区二区三区在线| 国产在线播精品第三| 91蜜桃传媒精品久久久一区二区| 69堂成人精品免费视频| 国产精品婷婷午夜在线观看| 石原莉奈在线亚洲三区| 国模套图日韩精品一区二区| 91国偷自产一区二区三区观看 | 中文一区二区完整视频在线观看| 亚洲另类中文字| 狠狠色狠狠色综合系列| 欧美性xxxxxxxx| 久久精品欧美日韩精品| 亚洲图片欧美综合| 国产suv精品一区二区6| 欧美一区二区三区在线看| 1024成人网色www| 精品一区二区影视| 欧美色精品在线视频| 欧美高清在线精品一区| 日韩av电影天堂| 91污片在线观看| 久久精品夜色噜噜亚洲aⅴ| 偷拍一区二区三区| 色婷婷综合久久久中文一区二区| 久久先锋影音av鲁色资源网| 日韩福利电影在线观看| 欧美在线视频你懂得| 国产精品久久久久毛片软件| 激情文学综合插| 欧美高清视频不卡网| 亚洲伦在线观看| 成人av在线资源网| 国产日本亚洲高清| 国产在线视频一区二区| 日韩欧美成人激情| 琪琪久久久久日韩精品| 欧美精品一二三四| 亚洲综合在线五月| 色婷婷综合久久久| 亚洲精品视频在线| 97se亚洲国产综合自在线不卡 | 久久嫩草精品久久久精品| 日本不卡的三区四区五区| 欧美日韩一级二级| 亚洲成年人网站在线观看| 欧美色图在线观看| 亚洲主播在线观看| 欧美日韩不卡一区| 日韩精品福利网| 精品日产卡一卡二卡麻豆| 久久精品噜噜噜成人av农村|