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

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

?? mvvtp.h

?? sparselib庫
?? H
字號:
/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*//*                                                                           *//*                                                                           *//*                   MV++ Numerical Matrix/Vector C++ Library                *//*                             MV++ Version 1.5                              *//*                                                                           *//*                                  R. Pozo                                  *//*               National Institute of Standards and Technology              *//*                                                                           *//*                                  NOTICE                                   *//*                                                                           *//* Permission to use, copy, modify, and distribute this software and         *//* its documentation for any purpose and without fee is hereby granted       *//* provided that this permission notice appear in all copies and             *//* supporting documentation.                                                 *//*                                                                           *//* Neither the Institution (National Institute of Standards and Technology)  *//* nor the author makes any representations about the suitability of this    *//* software for any purpose.  This software is provided ``as is''without     *//* expressed or implied warranty.                                            *//*                                                                           *//*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/////      mvvtp.h     Basic templated vector class//#ifndef _MV_VECTOR_TPL_H_#define _MV_VECTOR_TPL_H_    #include <stdlib.h>#ifdef MV_VECTOR_BOUNDS_CHECK#   include <assert.h>#endif#include "mvvind.h"#include "mvvrf.h"template <class TYPE>class MV_Vector{                                                                          protected:                                                                      TYPE *p_;            int dim_;           int ref_;  // 0 or 1; does this own its own memory space?    public:                                                                    /*::::::::::::::::::::::::::*/                                         /* Constructors/Destructors */                                         /*::::::::::::::::::::::::::*/                                                                                                            MV_Vector();                                 MV_Vector( int);                                 MV_Vector( int, const TYPE&);                                              MV_Vector(TYPE*,  int);         MV_Vector(const TYPE*,  int);               // reference of an exisiting data structure    //    MV_Vector(TYPE*,  int, MV_Vector_::ref_type i);     MV_Vector(const MV_Vector<TYPE>&);     ~MV_Vector();                                                                                                             /*::::::::::::::::::::::::::::::::*/                                   /*  Indices and access operations */                                   /*::::::::::::::::::::::::::::::::*/                                                                                                      inline            TYPE&     operator()( int i)                  {#                   ifdef MV_VECTOR_BOUNDS_CHECK                    assert(i < dim_);#                   endif                    return p_[i];                  }    inline  const  TYPE&    operator()( int i) const                   {#                   ifdef MV_VECTOR_BOUNDS_CHECK                    assert(i < dim_);#                   endif                    return p_[i];                  }    inline        TYPE&     operator[]( int i)                  {#                   ifdef MV_VECTOR_BOUNDS_CHECK                    assert(i < dim_);#                   endif                    return p_[i];                  }    inline      const  TYPE&    operator[]( int i) const                   {#                   ifdef MV_VECTOR_BOUNDS_CHECK                    assert(i < dim_);#                   endif                    return p_[i];                  }    inline MV_Vector<TYPE> operator()(const MV_VecIndex &I) ;    inline MV_Vector<TYPE> operator()(void);    inline const MV_Vector<TYPE> operator()(void) const;    inline const MV_Vector<TYPE> operator()(const MV_VecIndex &I) const;    inline  int             size() const { return dim_;}    inline int                      ref() const { return  ref_;}    inline int                      null() const {return dim_== 0;}            //            // Create a new *uninitalized* vector of size N            MV_Vector<TYPE> & newsize( int );                                                                               /*::::::::::::::*/                                                     /*  Assignment  */                                                     /*::::::::::::::*/                                                                                                                                MV_Vector<TYPE> & operator=(const MV_Vector<TYPE>&);            MV_Vector<TYPE> & operator=(const TYPE&);};                                                                         template <class TYPE>MV_Vector<TYPE>::MV_Vector()  : p_(0), dim_(0) , ref_(0){};template <class TYPE>MV_Vector<TYPE>::MV_Vector( int n) : p_(new TYPE[n]), dim_(n),             ref_(0){    if (p_ == NULL)    {        cerr << "Error: NULL pointer in MV_Vector(int) constructor " << endl;        cerr << "       Most likely out of memory... " << endl;        exit(1);    }}template <class TYPE>MV_Vector<TYPE>::MV_Vector( int n, const TYPE& v) :         p_(new TYPE[n]), dim_(n), ref_(0){    if (p_ == NULL)    {        cerr << "Error: NULL pointer in MV_Vector(int) constructor " << endl;        cerr << "       Most likely out of memory... " << endl;        exit(1);    }    for (int i=0; i<n; i++)        p_[i] = v;}// operators and member functions//template <class TYPE>MV_Vector<TYPE>& MV_Vector<TYPE>::operator=(const TYPE & m) {#ifdef TRACE_VEC    cout << "> MV_Vector<TYPE>::operator=(const TYPE & m)  " << endl;#endif    // unroll loops to depth of length 4    int N = size();    int Nminus4 = N-4;    int i;    for (i=0; i<Nminus4; )    {        p_[i++] = m;        p_[i++] = m;        p_[i++] = m;        p_[i++] = m;    }    for (; i<N; p_[i++] = m);   // finish off last piece...#ifdef TRACE_VEC    cout << "< MV_Vector<TYPE>::operator=(const TYPE & m)  " << endl;#endif    return *this;}template <class TYPE>MV_Vector<TYPE>& MV_Vector<TYPE>::newsize( int n){#ifdef TRACE_VEC    cout << "> MV_Vector<TYPE>::newsize( int n) " << endl;#endif    if (ref_ )                  // is this structure just a pointer?    {        {            cerr << "MV_Vector::newsize can't operator on references.\n";            exit(1);        }    }    else    if (dim_ != n )                     // only delete and new if    {                                   // the size of memory is really        if (p_) delete [] p_;           // changing, otherwise just        p_ = new TYPE[n];               // copy in place.        if (p_ == NULL)        {            cerr << "Error : NULL pointer in operator= " << endl;            exit(1);        }        dim_ = n;    }#ifdef TRACE_VEC    cout << "< MV_Vector<TYPE>::newsize( int n) " << endl;#endif    return *this;}    template <class TYPE>MV_Vector<TYPE>& MV_Vector<TYPE>::operator=(const MV_Vector<TYPE> & m) {    int N = m.dim_;    int i;    if (ref_ )                  // is this structure just a pointer?    {        if (dim_ != m.dim_)     // check conformance,        {            cerr << "MV_VectorRef::operator=  non-conformant assignment.\n";            exit(1);        }        // handle overlapping matrix references        if ((m.p_ + m.dim_) >= p_)        {            // overlap case, copy backwards to avoid overwriting results            for (i= N-1; i>=0; i--)                p_[i] = m.p_[i];        }        else        {            for (i=0; i<N; i++)                p_[i] = m.p_[i];        }                    }    else    {        newsize(N);        // no need to test for overlap, since this region is new        for (i =0; i< N; i++)       // careful not to use bcopy()            p_[i] = m.p_[i];                // here, but TYPE::operator= TYPE.    }    return *this;   }template <class TYPE>MV_Vector<TYPE>::MV_Vector(const MV_Vector<TYPE> & m) : p_(new TYPE[m.dim_]),     dim_(m.dim_) , ref_(0){    if (p_ == NULL)    {        cerr << "Error:  Null pointer in MV_Vector(const MV_Vector&); " << endl;        exit(1);    }    int N = m.dim_;    for (int i=0; i<N; i++)        p_[i] = m.p_[i];}// note that ref() is initalized with i rather than 1.// this is so compilers will not generate a warning that i was// not used in the construction.  (MV_Vector::ref_type is an enum that// can *only* have the value of 1.//template <class TYPE>MV_Vector<TYPE>::MV_Vector(TYPE* d,  int n, MV_Vector_::ref_type i) :         p_(d), dim_(n) , ref_(i) {}template <class TYPE>MV_Vector<TYPE>::MV_Vector(TYPE* d,  int n) : p_(new TYPE[n]),       dim_(n) , ref_(0){    if (p_ == NULL)    {        cerr << "Error: Null pointer in MV_Vector(TYPE*, int) " << endl;        exit(1);    }    for (int i=0; i<n; i++)        p_[i] = d[i];}template <class TYPE>MV_Vector<TYPE>::MV_Vector(const TYPE* d,  int n) : p_(new TYPE[n]),       dim_(n) , ref_(0){    if (p_ == NULL)    {        cerr << "Error: Null pointer in MV_Vector(TYPE*, int) " << endl;        exit(1);    }    for (int i=0; i<n; i++)        p_[i] = d[i];}template <class TYPE>MV_Vector<TYPE> MV_Vector<TYPE>::operator()(void){    return MV_Vector<TYPE>(p_, dim_, MV_Vector_::ref);}template <class TYPE>const MV_Vector<TYPE> MV_Vector<TYPE>::operator()(void) const{    return MV_Vector<TYPE>(p_, dim_, MV_Vector_::ref);}template <class TYPE>MV_Vector<TYPE> MV_Vector<TYPE>::operator()(const MV_VecIndex &I) {    // default parameters    if (I.all())        return MV_Vector<TYPE>(p_, dim_, MV_Vector_::ref);    else    {    // check that index is not out of bounds    //        if ( I.end() >= dim_)        {            cerr << "MV_VecIndex: (" << I.start() << ":" << I.end() <<                 ") too big for matrix (0:" << dim_ - 1 << ") " << endl;            exit(1);        }        return MV_Vector<TYPE>(p_+ I.start(), I.end() - I.start() + 1,            MV_Vector_::ref);    }}template <class TYPE>const MV_Vector<TYPE> MV_Vector<TYPE>::operator()(const MV_VecIndex &I) const{    // check that index is not out of bounds    //    if ( I.end() >= dim_)    {        cerr << "MV_VecIndex: (" << I.start() << ":" << I.end() <<                 ") too big for matrix (0:" << dim_ - 1 << ") " << endl;        exit(1);    }    return MV_Vector<TYPE>(p_+ I.start(), I.end() - I.start() + 1,            MV_Vector_::ref);}template <class TYPE>MV_Vector<TYPE>::~MV_Vector(){        if (p_ && !ref_ ) delete [] p_;}template <class TYPE>class FMV_Vector : public MV_Vector<TYPE>{                                                                          public:                                                                    FMV_Vector( int n) : MV_Vector<TYPE>(n) {}        FMV_Vector<TYPE>& operator=(const FMV_Vector<TYPE>& m);        FMV_Vector<TYPE>& operator=(const TYPE& m);};template <class TYPE>FMV_Vector<TYPE>& FMV_Vector<TYPE>::operator=( const FMV_Vector<TYPE>& m){#ifdef TRACE_VEC    cout << "> FMV_Vector<TYPE>::operator=( const FMV_Vector<TYPE>& m)" << endl;#endif    int N = m.dim_;    if (ref_ )                  // is this structure just a pointer?    {        if (dim_ != m.dim_)     // check conformance,        {            cerr << "MV_VectorRef::operator=  non-conformant assignment.\n";            exit(1);        }    }    else if ( dim_ != m.dim_ )      // resize only if necessary        newsize(N);    memmove(p_, m.p_, N * sizeof(TYPE));#ifdef TRACE_VEC    cout << "< FMV_Vector<TYPE>::operator=( const FMV_Vector<TYPE>& m)" << endl;#endif    return *this;   }template <class TYPE>FMV_Vector<TYPE>& FMV_Vector<TYPE>::operator=(const TYPE & m) {#ifdef TRACE_VEC    cout << "> FMV_Vector<TYPE>::operator=(const TYPE & m)  " << endl;#endif    // unroll loops to depth of length 4    int N = size();    int Nminus4 = N-4;    int i;    for (i=0; i<Nminus4; )    {        p_[i++] = m;        p_[i++] = m;        p_[i++] = m;        p_[i++] = m;    }    for (; i<N; p_[i++] = m);   // finish off last piece...#ifdef TRACE_VEC    cout << "< FMV_Vector<TYPE>::operator=(const TYPE & m)  " << endl;#endif    return *this;}#include "mvblas.h"#endif // _MV_VECTOR_TPL_H_

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品一区久久久久| 欧美一区二区三区人| 欧美精品丝袜中出| 国产欧美一区二区在线观看| 亚洲精品免费一二三区| 国产在线精品国自产拍免费| 欧美午夜精品一区| 国产精品久久久久久久蜜臀| 青青草原综合久久大伊人精品优势| 成人激情电影免费在线观看| 精品国产乱码久久久久久1区2区 | 一区二区三区日韩欧美| 国内一区二区在线| 欧美一区二区黄色| 亚洲一二三级电影| 色婷婷av一区二区三区大白胸| 久久久精品2019中文字幕之3| 免费成人av资源网| 欧美麻豆精品久久久久久| 亚洲欧美日韩国产成人精品影院| 国产精品资源在线| 精品国产乱码久久久久久1区2区| 日本成人在线电影网| 欧美视频在线播放| 亚洲欧美日韩在线播放| www.欧美日韩国产在线| 国产日产欧美精品一区二区三区| 美腿丝袜亚洲三区| 日韩欧美色电影| 日韩精品亚洲专区| 538在线一区二区精品国产| 亚洲电影第三页| 欧美亚洲图片小说| 亚洲国产成人91porn| 欧美亚洲国产怡红院影院| 亚洲精品免费在线观看| 在线看国产一区| 午夜精品久久久久久| 欧美精品久久天天躁| 肉丝袜脚交视频一区二区| 在线播放亚洲一区| 日本亚洲欧美天堂免费| 欧美一级国产精品| 久久黄色级2电影| 久久久久久日产精品| 国产成人午夜精品影院观看视频| 亚洲国产精品成人综合色在线婷婷| 国产激情视频一区二区三区欧美| 亚洲国产精品黑人久久久| 一本到三区不卡视频| 一级日本不卡的影视| 欧美精品色综合| 久久精品国产免费看久久精品| 久久久久久9999| 成人免费高清视频在线观看| 怡红院av一区二区三区| 正在播放一区二区| 国产一区不卡在线| 亚洲欧美日韩在线不卡| 欧美一区二区三区啪啪| 国内精品久久久久影院薰衣草| 欧美激情综合五月色丁香小说| 91在线观看成人| 亚洲成a人片综合在线| 日韩精品中文字幕一区| 97精品视频在线观看自产线路二| 亚洲国产另类精品专区| 日韩精品在线一区| 99精品欧美一区| 麻豆极品一区二区三区| 国产精品美女久久久久久2018| 欧美性猛交xxxx黑人交| 捆绑紧缚一区二区三区视频| 国产精品免费视频观看| 欧美午夜一区二区三区免费大片| 狠狠色综合日日| 亚洲自拍与偷拍| 国产丝袜美腿一区二区三区| 91久久一区二区| 国产精品一二二区| 亚洲成人一区二区在线观看| 久久久久88色偷偷免费| 欧美精品高清视频| 99精品视频在线观看免费| 六月丁香婷婷色狠狠久久| 一区二区三区在线免费视频 | 国产网红主播福利一区二区| 欧美午夜电影在线播放| av动漫一区二区| 久久99国产精品免费| 亚洲综合久久久| 中文字幕一区二区三区四区不卡| 欧美电影免费观看完整版| 欧美亚男人的天堂| 99精品黄色片免费大全| 国产乱色国产精品免费视频| 天天色天天操综合| 亚洲一区影音先锋| 成人免费视频在线观看| 国产天堂亚洲国产碰碰| 2022国产精品视频| 538在线一区二区精品国产| 在线中文字幕一区| 91麻豆免费视频| 99精品视频中文字幕| 国产成人午夜视频| 国产成人午夜精品5599 | 亚洲国产成人91porn| 亚洲特级片在线| 国产精品网站在线| 国产三级三级三级精品8ⅰ区| 日韩亚洲欧美在线| 正在播放一区二区| 欧美一区二区三区成人| 欧美日韩美女一区二区| 欧美午夜寂寞影院| 欧美嫩在线观看| 欧美久久久久久蜜桃| 91精品中文字幕一区二区三区| 欧美三级日韩三级| 欧美精品一级二级| 日韩欧美在线影院| 欧美精品一区二区三区在线播放| 日韩欧美资源站| 精品国产a毛片| 日本一区二区成人| 亚洲精品久久7777| 日日摸夜夜添夜夜添精品视频| 亚洲va欧美va国产va天堂影院| 午夜精品aaa| 久久99精品国产.久久久久 | gogogo免费视频观看亚洲一| www.日韩大片| 欧美在线观看一二区| 欧美性受xxxx| 日韩精品在线一区二区| 国产日韩欧美不卡| 中文字幕一区免费在线观看| 亚洲影视在线播放| 久久国产生活片100| 国产高清不卡二三区| 99久久精品国产一区| 欧美日韩中文精品| 欧美mv和日韩mv的网站| 国产精品妹子av| 五月天精品一区二区三区| 国产一区二区剧情av在线| 成人av在线资源| 欧美精品日韩一本| 国产精品女主播av| 亚洲gay无套男同| 国产伦精品一区二区三区免费迷 | 91污在线观看| 欧美精品v国产精品v日韩精品| 欧美大片一区二区三区| 国产精品久久久久影院色老大| 亚洲国产精品久久人人爱| 国产在线精品视频| 在线观看91视频| 337p日本欧洲亚洲大胆精品| 1区2区3区国产精品| 日本中文字幕一区二区视频| hitomi一区二区三区精品| 日韩免费福利电影在线观看| 中文字幕一区在线| 美国毛片一区二区三区| 91视频一区二区三区| 日韩免费一区二区三区在线播放| 国产精品视频看| 久久电影国产免费久久电影| 在线亚洲高清视频| 国产日产精品一区| 日韩精品福利网| 色综合久久88色综合天天6| 久久久久久久综合| 琪琪一区二区三区| 色综合天天综合给合国产| 久久久久久久国产精品影院| 肉肉av福利一精品导航| 色综合久久精品| 中文字幕精品一区二区三区精品 | 欧美一级专区免费大片| 一区二区三区高清| 99久久久免费精品国产一区二区| 日韩丝袜美女视频| 天堂av在线一区| 在线亚洲一区二区| 亚洲视频1区2区| 懂色av一区二区在线播放| 精品国产区一区| 日韩成人免费电影| 欧美日韩国产小视频| 一区二区在线观看不卡| 99久久伊人网影院| 欧美国产日韩精品免费观看| 国产精品一区二区不卡| 久久久精品影视| 国产一区二区三区观看| 亚洲另类在线一区| 成人app软件下载大全免费|