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

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

?? methods.cc

?? A C++ class library for scientific computing
?? CC
字號:
#ifndef BZ_ARRAYMETHODS_CC#define BZ_ARRAYMETHODS_CC#ifndef BZ_ARRAY_H #error <blitz/array/methods.cc> must be included via <blitz/array.h>#endifBZ_NAMESPACE(blitz)template<typename P_numtype, int N_rank> template<typename T_expr>Array<P_numtype,N_rank>::Array(_bz_ArrayExpr<T_expr> expr){    // Determine extent of the array expression    TinyVector<int,N_rank> lbound, extent, ordering;    TinyVector<bool,N_rank> ascendingFlag;    TinyVector<bool,N_rank> in_ordering;    in_ordering = false;    int j = 0;    for (int i=0; i < N_rank; ++i)    {        lbound(i) = expr.lbound(i);        int ubound = expr.ubound(i);        extent(i) = ubound - lbound(i) + 1;        int orderingj = expr.ordering(i);        if (orderingj != INT_MIN && orderingj < N_rank &&            !in_ordering( orderingj )) { // unique value in ordering array            in_ordering( orderingj ) = true;            ordering(j++) = orderingj;        }        int ascending = expr.ascending(i);        ascendingFlag(i) = (ascending == 1);#ifdef BZ_DEBUG        if ((lbound(i) == INT_MIN) || (ubound == INT_MAX)           || (ordering(i) == INT_MIN) || (ascending == INT_MIN))        {          BZPRECHECK(0,           "Attempted to construct an array from an expression " << endl           << "which does not have a shape.  To use this constructor, "           << endl            << "the expression must contain at least one array operand.");          return;        }#endif    }    // It is possible that ordering is not a permutation of 0,...,N_rank-1.    // In that case j will be less than N_rank. We fill in ordering with the    // usused values in decreasing order.    for (int i = N_rank-1; j < N_rank; ++j) {        while (in_ordering(i))          --i;        ordering(j) = i--;    }    Array<T_numtype,N_rank> A(lbound,extent,        GeneralArrayStorage<N_rank>(ordering,ascendingFlag));    A = expr;    reference(A);}template<typename P_numtype, int N_rank>Array<P_numtype,N_rank>::Array(const TinyVector<int, N_rank>& lbounds,    const TinyVector<int, N_rank>& extent,    const GeneralArrayStorage<N_rank>& storage)    : storage_(storage){    length_ = extent;    storage_.setBase(lbounds);    setupStorage(N_rank - 1);}/* * This routine takes the storage information for the array * (ascendingFlag_[], base_[], and ordering_[]) and the size * of the array (length_[]) and computes the stride vector * (stride_[]) and the zero offset (see explanation in array.h). */template<typename P_numtype, int N_rank>_bz_inline2 void Array<P_numtype, N_rank>::computeStrides(){    if (N_rank > 1)    {      int stride = 1;      // This flag simplifies the code in the loop, encouraging      // compile-time computation of strides through constant folding.      bool allAscending = storage_.allRanksStoredAscending();      // BZ_OLD_FOR_SCOPING      int n;      for (n=0; n < N_rank; ++n)      {          int strideSign = +1;          // If this rank is stored in descending order, then the stride          // will be negative.          if (!allAscending)          {            if (!isRankStoredAscending(ordering(n)))                strideSign = -1;          }          // The stride for this rank is the product of the lengths of          // the ranks minor to it.          stride_[ordering(n)] = stride * strideSign;          stride *= length_[ordering(n)];      }    }    else {        // Specialization for N_rank == 1        // This simpler calculation makes it easier for the compiler        // to propagate stride values.        if (isRankStoredAscending(0))            stride_[0] = 1;        else            stride_[0] = -1;    }    calculateZeroOffset();}template<typename P_numtype, int N_rank>void Array<P_numtype, N_rank>::calculateZeroOffset(){    // Calculate the offset of (0,0,...,0)    zeroOffset_ = 0;    // zeroOffset_ = - sum(where(ascendingFlag_, stride_ * base_,    //     (length_ - 1 + base_) * stride_))    for (int n=0; n < N_rank; ++n)    {        if (!isRankStoredAscending(n))            zeroOffset_ -= (length_[n] - 1 + base(n)) * stride_[n];        else            zeroOffset_ -= stride_[n] * base(n);    }}template<typename P_numtype, int N_rank>bool Array<P_numtype, N_rank>::isStorageContiguous() const{    // The storage is contiguous if for the set    // { | stride[i] * extent[i] | }, i = 0..N_rank-1,    // there is only one value which is not in the set    // of strides; and if there is one stride which is 1.    // This algorithm is quadratic in the rank.  It is hard    // to imagine this being a serious problem.    int numStridesMissing = 0;    bool haveUnitStride = false;    for (int i=0; i < N_rank; ++i)    {        int stride = BZ_MATHFN_SCOPE(abs)(stride_[i]);        if (stride == 1)            haveUnitStride = true;        int vi = stride * length_[i];        int j = 0;        for (j=0; j < N_rank; ++j)            if (BZ_MATHFN_SCOPE(abs)(stride_[j]) == vi)                break;        if (j == N_rank)        {            ++numStridesMissing;            if (numStridesMissing == 2)                return false;        }    }    return haveUnitStride;}template<typename P_numtype, int N_rank>void Array<P_numtype, N_rank>::dumpStructureInformation(ostream& os) const{    os << "Dump of Array<" << BZ_DEBUG_TEMPLATE_AS_STRING_LITERAL(P_numtype)        << ", " << N_rank << ">:" << endl       << "ordering_      = " << storage_.ordering() << endl       << "ascendingFlag_ = " << storage_.ascendingFlag() << endl       << "base_          = " << storage_.base() << endl       << "length_        = " << length_ << endl       << "stride_        = " << stride_ << endl       << "zeroOffset_    = " << zeroOffset_ << endl       << "numElements()  = " << numElements() << endl       << "isStorageContiguous() = " << isStorageContiguous() << endl;}/* * Make this array a view of another array's data. */template<typename P_numtype, int N_rank>void Array<P_numtype, N_rank>::reference(const Array<P_numtype, N_rank>& array){    storage_ = array.storage_;    length_ = array.length_;    stride_ = array.stride_;    zeroOffset_ = array.zeroOffset_;    MemoryBlockReference<P_numtype>::changeBlock(array.noConst());}/* * Modify the Array storage.  Array must be unallocated. */template<typename P_numtype, int N_rank>void Array<P_numtype, N_rank>::setStorage(GeneralArrayStorage<N_rank> x){#ifdef BZ_DEBUG    if (size() != 0) {        BZPRECHECK(0,"Cannot modify storage format of an Array that has already been allocated!" << endl);        return;    }#endif    storage_ = x;    return;}/* * This method is called to allocate memory for a new array.   */template<typename P_numtype, int N_rank>_bz_inline2 void Array<P_numtype, N_rank>::setupStorage(int lastRankInitialized){    TAU_TYPE_STRING(p1, "Array<T,N>::setupStorage() [T="        + CT(P_numtype) + ",N=" + CT(N_rank) + "]");    TAU_PROFILE(" ", p1, TAU_BLITZ);    /*     * If the length of some of the ranks was unspecified, fill these     * in using the last specified value.     *     * e.g. Array<int,3> A(40) results in a 40x40x40 array.     */    for (int i=lastRankInitialized + 1; i < N_rank; ++i)    {        storage_.setBase(i, storage_.base(lastRankInitialized));        length_[i] = length_[lastRankInitialized];    }    // Compute strides    computeStrides();    // Allocate a block of memory    int numElem = numElements();    if (numElem==0)        MemoryBlockReference<P_numtype>::changeToNullBlock();    else        MemoryBlockReference<P_numtype>::newBlock(numElem);    // Adjust the base of the array to account for non-zero base    // indices and reversals    data_ += zeroOffset_;}template<typename P_numtype, int N_rank>Array<P_numtype, N_rank> Array<P_numtype, N_rank>::copy() const{    if (numElements())    {        Array<T_numtype, N_rank> z(length_, storage_);        z = *this;        return z;    }    else {        // Null array-- don't bother allocating an empty block.        return *this;    }}template<typename P_numtype, int N_rank>void Array<P_numtype, N_rank>::makeUnique(){    if (numReferences() > 1)    {        T_array tmp = copy();        reference(tmp);    }}template<typename P_numtype, int N_rank>Array<P_numtype, N_rank> Array<P_numtype, N_rank>::transpose(int r0, int r1,     int r2, int r3, int r4, int r5, int r6, int r7, int r8, int r9, int r10){    T_array B(*this);    B.transposeSelf(r0,r1,r2,r3,r4,r5,r6,r7,r8,r9,r10);    return B;}template<typename P_numtype, int N_rank>void Array<P_numtype, N_rank>::transposeSelf(int r0, int r1, int r2, int r3,    int r4, int r5, int r6, int r7, int r8, int r9, int r10){    BZPRECHECK(r0+r1+r2+r3+r4+r5+r6+r7+r8+r9+r10 == N_rank * (N_rank-1) / 2,        "Invalid array transpose() arguments." << endl        << "Arguments must be a permutation of the numerals (0,...,"        << (N_rank - 1) << ")");    // Create a temporary reference copy of this array    Array<T_numtype, N_rank> x(*this);    // Now reorder the dimensions using the supplied permutation    doTranspose(0, r0, x);    doTranspose(1, r1, x);    doTranspose(2, r2, x);    doTranspose(3, r3, x);    doTranspose(4, r4, x);    doTranspose(5, r5, x);    doTranspose(6, r6, x);    doTranspose(7, r7, x);    doTranspose(8, r8, x);    doTranspose(9, r9, x);    doTranspose(10, r10, x);}template<typename P_numtype, int N_rank>void Array<P_numtype, N_rank>::doTranspose(int destRank, int sourceRank,    Array<T_numtype, N_rank>& array){    // BZ_NEEDS_WORK: precondition check    if (destRank >= N_rank)        return;    length_[destRank] = array.length_[sourceRank];    stride_[destRank] = array.stride_[sourceRank];    storage_.setAscendingFlag(destRank,         array.isRankStoredAscending(sourceRank));    storage_.setBase(destRank, array.base(sourceRank));    // BZ_NEEDS_WORK: Handling the storage ordering is currently O(N^2)    // but it can be done fairly easily in linear time by constructing    // the appropriate permutation.    // Find sourceRank in array.storage_.ordering_    int i=0;    for (; i < N_rank; ++i)        if (array.storage_.ordering(i) == sourceRank)            break;    storage_.setOrdering(i, destRank);}template<typename P_numtype, int N_rank>void Array<P_numtype, N_rank>::reverseSelf(int rank){    BZPRECONDITION(rank < N_rank);    storage_.setAscendingFlag(rank, !isRankStoredAscending(rank));    int adjustment = stride_[rank] * (lbound(rank) + ubound(rank));    zeroOffset_ += adjustment;    data_ += adjustment;    stride_[rank] *= -1;}template<typename P_numtype, int N_rank>Array<P_numtype, N_rank> Array<P_numtype,N_rank>::reverse(int rank){    T_array B(*this);    B.reverseSelf(rank);    return B;}template<typename P_numtype, int N_rank> template<typename P_numtype2>Array<P_numtype2,N_rank> Array<P_numtype,N_rank>::extractComponent(P_numtype2,     int componentNumber, int numComponents) const{    BZPRECONDITION((componentNumber >= 0)         && (componentNumber < numComponents));    TinyVector<int,N_rank> stride2;    for (int i=0; i < N_rank; ++i)      stride2(i) = stride_(i) * numComponents;    const P_numtype2* dataFirst2 =         ((const P_numtype2*)dataFirst()) + componentNumber;    return Array<P_numtype2,N_rank>(const_cast<P_numtype2*>(dataFirst2),         length_, stride2, storage_);}/*  * These routines reindex the current array to use a new base vector. * The first reindexes the array, the second just returns a reindex view * of the current array, leaving the current array unmodified. * (Contributed by Derrick Bass) */template<typename P_numtype, int N_rank>_bz_inline2 void Array<P_numtype, N_rank>::reindexSelf(const     TinyVector<int, N_rank>& newBase) {    int delta = 0;    for (int i=0; i < N_rank; ++i)      delta += (base(i) - newBase(i)) * stride_(i);    data_ += delta;    // WAS: dot(base() - newBase, stride_);    storage_.setBase(newBase);    calculateZeroOffset();}template<typename P_numtype, int N_rank>_bz_inline2 Array<P_numtype, N_rank> Array<P_numtype, N_rank>::reindex(const TinyVector<int, N_rank>& newBase) {    T_array B(*this);    B.reindexSelf(newBase);    return B;}BZ_NAMESPACE_END#endif // BZ_ARRAY_CC

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品一品二品| 精品视频在线视频| 欧美丝袜第三区| 国产女主播视频一区二区| 婷婷久久综合九色综合伊人色| 国产精品亚洲专一区二区三区 | 精品国产sm最大网站免费看| 国产精品白丝在线| 久久超碰97人人做人人爱| 91成人在线观看喷潮| 中文字幕av免费专区久久| 九九久久精品视频| 欧美精品在线观看播放| 亚洲一区二区视频在线观看| 99久久国产免费看| 国产欧美在线观看一区| 韩国成人福利片在线播放| 欧美电影在哪看比较好| 亚洲成人一区在线| 欧美三级视频在线| 亚洲综合色网站| 97久久精品人人做人人爽50路| 久久夜色精品国产噜噜av| 免费三级欧美电影| 欧美一区二区三区色| 亚洲电影在线免费观看| 欧美视频精品在线观看| 亚洲三级免费观看| 色婷婷亚洲精品| 亚洲精品免费播放| 91网上在线视频| 亚洲另类春色校园小说| 91免费视频网址| 一区二区三区在线观看欧美| 91麻豆国产福利在线观看| 国产精品久久久久一区| 91丨九色丨蝌蚪富婆spa| 亚洲女性喷水在线观看一区| 成人99免费视频| 亚洲乱码国产乱码精品精的特点| 99久久精品免费看国产| 亚洲精品高清在线观看| 欧美日韩激情在线| 奇米色777欧美一区二区| 26uuu国产电影一区二区| 国产麻豆精品一区二区| 国产精品久久久久精k8| 色中色一区二区| 日本一道高清亚洲日美韩| 精品国产麻豆免费人成网站| 国产精品一二三在| 亚洲品质自拍视频| 欧美精品 日韩| 美女性感视频久久| 国产精品乱码妇女bbbb| 欧美性猛交一区二区三区精品| 日韩精品成人一区二区三区| 亚洲精品一区二区三区四区高清| 成人高清视频在线观看| 亚洲一区二区三区四区的 | 婷婷国产v国产偷v亚洲高清| 欧美电视剧免费全集观看| 处破女av一区二区| 日本亚洲欧美天堂免费| 国产精品你懂的在线欣赏| 欧美三级电影一区| 国产成人8x视频一区二区| 一区二区三区鲁丝不卡| 久久影院视频免费| 99精品久久只有精品| 日韩福利视频导航| 欧美国产综合一区二区| 在线不卡欧美精品一区二区三区| 国产精品亚洲第一区在线暖暖韩国| 亚洲欧洲制服丝袜| 久久久777精品电影网影网| 欧美日韩精品一区二区天天拍小说 | 久久精品夜色噜噜亚洲aⅴ| 91久久线看在观草草青青| 老司机午夜精品| 亚洲最大成人综合| 一区在线观看免费| 精品国产乱码久久久久久1区2区| 91欧美一区二区| 国产露脸91国语对白| 日韩精品国产精品| 亚洲国产成人porn| 中文字幕在线不卡国产视频| 日韩视频在线永久播放| 91精品91久久久中77777| 国产99久久久国产精品免费看| 亚洲成av人在线观看| 亚洲日本在线视频观看| 久久精品在线观看| 精品99久久久久久| 日韩午夜激情视频| 欧美精品在线一区二区三区| 97久久精品人人爽人人爽蜜臀| 国产真实乱对白精彩久久| 琪琪久久久久日韩精品| 日韩电影在线一区| 亚洲 欧美综合在线网络| 一区二区三区高清不卡| 亚洲女与黑人做爰| 亚洲免费大片在线观看| 成人免费在线播放视频| 国产精品理论片在线观看| 国产精品三级视频| 欧美国产激情二区三区| 国产精品免费视频网站| 国产欧美精品一区二区三区四区 | 4438x亚洲最大成人网| 在线观看免费亚洲| 欧美午夜电影网| 欧美日本精品一区二区三区| 欧美视频在线一区二区三区| 欧美私人免费视频| 9191久久久久久久久久久| 欧美剧情片在线观看| 欧美日韩国产在线观看| 3d成人h动漫网站入口| 欧美一卡2卡三卡4卡5免费| 91麻豆精品国产| 精品国产一区二区国模嫣然| 久久久www成人免费毛片麻豆| 国产丝袜欧美中文另类| 国产精品久久久久一区二区三区 | 老司机免费视频一区二区三区| 日本美女视频一区二区| 激情av综合网| av资源网一区| 欧美日韩美女一区二区| 91麻豆精品国产综合久久久久久| 日韩精品一区二区三区蜜臀| 久久综合九色综合97婷婷女人| 中文字幕av免费专区久久| 亚洲视频资源在线| 午夜欧美电影在线观看| 久久国产乱子精品免费女| 成人黄色综合网站| 在线亚洲免费视频| 日韩欧美亚洲国产另类| 国产精品视频一二三区 | 精品在线观看免费| 成人精品高清在线| 欧美性感一类影片在线播放| 欧美一区二区三区在线观看| 国产精品成人一区二区艾草| 亚洲午夜精品网| 国产老女人精品毛片久久| 欧美在线免费观看亚洲| 精品国产免费一区二区三区香蕉| 成人欧美一区二区三区白人| 免费成人av资源网| 色香蕉成人二区免费| 精品国产乱码久久久久久蜜臀 | 日欧美一区二区| 成人av资源在线| 欧美成人精品3d动漫h| 亚洲最大成人网4388xx| 高清不卡一二三区| 欧美一区二区三区免费观看视频 | 色老汉一区二区三区| 欧美变态tickling挠脚心| 一区二区三区欧美在线观看| 国模冰冰炮一区二区| 欧美日韩在线播放三区四区| 久久精品视频一区二区三区| 亚欧色一区w666天堂| 99国产精品国产精品毛片| 精品99999| 日本不卡不码高清免费观看| 色香色香欲天天天影视综合网| 久久久午夜精品| 免费看欧美美女黄的网站| 欧美日韩一区不卡| 亚洲欧美激情插| 99久久精品国产麻豆演员表| 国产日韩欧美精品在线| 激情综合网天天干| 欧美福利视频导航| 亚洲一区中文在线| 99re这里只有精品6| 国产日韩欧美一区二区三区综合 | 色诱视频网站一区| 中文字幕一区二区三| 成人一区二区三区| 久久久一区二区三区| 久久aⅴ国产欧美74aaa| 精品国产亚洲在线| 激情综合色综合久久| 欧美videossexotv100| 日本不卡视频一二三区| 宅男噜噜噜66一区二区66| 日韩av网站在线观看| 欧美一卡2卡三卡4卡5免费| 秋霞电影一区二区| 日韩三级伦理片妻子的秘密按摩| 日韩电影一二三区| 欧美一区二区在线播放|