当前位置: 首页>>代码示例>>C++>>正文


C++ polynomial::size方法代码示例

本文整理汇总了C++中polynomial::size方法的典型用法代码示例。如果您正苦于以下问题:C++ polynomial::size方法的具体用法?C++ polynomial::size怎么用?C++ polynomial::size使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在polynomial的用法示例。


在下文中一共展示了polynomial::size方法的8个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: size

 polynomial operator+(const polynomial<T>& o) const
 {
   int len;
   const polynomial<T> *p;
   size() >= o.size() ? (p=this, len=size()) : (p=&o, len=o.size());
   polynomial<T> out(len);
   std::transform(vals->data(),vals->data()+std::min(size(),o.size()),o.vals->data(),out.vals->data(),[](T a, T b){return a+b;});
   if (size() != o.size()) std::copy_n(&p->element(std::min(size(),o.size())),abs(size()-o.size()),&out(std::min(size(),o.size())));
   return out;
 }
开发者ID:andyras,项目名称:SplitOp,代码行数:10,代码来源:polynomial.hpp

示例2: derivative

 friend polynomial derivative(polynomial const& p) {
  int s = p.size();
  if(s == 0) return {};

  polynomial res;
  res.coeffs.resize(s-1);
  for(int n = 0; n < s-1; ++n)
   res.coeffs(n) = p.coeffs(n+1) * CoeffType(n+1);
  return res;
 }
开发者ID:krivenko,项目名称:som,代码行数:10,代码来源:polynomial.hpp

示例3: antiderivative

 friend polynomial antiderivative(polynomial const& p) {
  int s = p.size();
  if(s == 0) return {};

  polynomial res;
  res.coeffs.resize(s+1);
  res.coeffs(0) = CoeffType{};
  for(int n = 1; n < s+1; ++n)
   res.coeffs(n) = p.coeffs(n-1) / CoeffType(n);
  return res;
 }
开发者ID:krivenko,项目名称:som,代码行数:11,代码来源:polynomial.hpp

示例4: divide

 void divide(const polynomial &b)
 {
     int m=b.size(),res[1110];
     for (int i=n;i>=m;i--)
     {
         int t=a[i]/b[m];
         for (int j=i;j>=i-m;j--)
             a[j]-=b[j-i+m]*t;
         res[i-m]=t;
     }
     n-=m;
     for (int i=0;i<=n;i++)
         a[i]=res[i];
 }
开发者ID:liuq901,项目名称:code,代码行数:14,代码来源:hd_4447.cpp

示例5: fr_kernels

void fr_kernels(int i, const polynomial& P, const monomial& d, monomial& bk, polynomial& bcok, int& bv)
{
    for (int j = i; j < literal_size(); ++j)
    {
        int times = 0;
        for (int k = 0; k < P.size(); ++k)
        {
            if (P[k].getpow(j) != 0)
            {
                ++times;
            }
        }
        if (times > 1)
        {
            monomial Lj(j);
            polynomial Ft = P / Lj;
            monomial C = Ft.gcd();
            bool cflag = true;
            for (int k = 0; k < C.size(); ++k)
            {
                if (C.lit(k) < j)
                {
                    cflag = false;
                    break;
                }
            }
            if (cflag)
            {
                polynomial FI = Ft / C;//kernel
                monomial DI = d * C * Lj;//co-kernel
                int v = fr_value(DI, FI);
                if (v > bv)
                {
                    bv = v;
                    bk = DI;
                    bcok = FI;
                }
                fr_kernels(j, FI, DI, bk, bcok, bv);
            }
        }
    }
}
开发者ID:zxrlha,项目名称:wpo,代码行数:42,代码来源:kernel.cpp

示例6: fr_value

//The fr_kernels part are part of initial fastrun stategy
//Now they are deprecated, but we still keep these code in case.
int fr_value(const monomial& bk, const polynomial& bcok)
{
    return (bcok.size() - 1) * bk.multiplication_number();
}
开发者ID:zxrlha,项目名称:wpo,代码行数:6,代码来源:kernel.cpp

示例7: kernels

void kernels(int i, const polynomial& P, const monomial& d, vector<pair<monomial, polynomial>>& kernelmap)
{
    //we use bitset for sj1 as we need fast lookup
    //while for sj2 we need iteration therefore we use set
    std::set<int> sj2;
    //brackets here for early release sj1, to reduce memory cost, as in recursive calling we may waste lots of memory
    {
        boost::dynamic_bitset<uint64_t> sj1(literal_size());//default value should be 0, i.e. false
        for (int mi = 0; mi < P.size(); ++mi)
        {
            for (int ti = 0; ti < P[mi].size(); ++ti)
            {
                int tmp = P[mi].lit(ti);
                if (tmp < i) { continue; }
                if (sj1[tmp] == 0)
                {
                    sj1[tmp] = 1;
                }
                else
                {
                    sj2.insert(tmp);
                }
            }
        }
    }
    for (auto j : sj2)
    {
        monomial Lj(j);
        polynomial Ft = P / Lj;
        monomial C = Ft.gcd();
        //optimization for this common case
        if (C == monomial())
        {
            monomial DI = d * Lj;//co-kernel
            kernelmap.push_back(make_pair(DI, Ft));
            kernels(j, Ft, DI, kernelmap);
            continue;
        }
        bool cflag = true;
        for (int k = 0; k < C.size(); ++k)
        {
            if (C.lit(k) < j)
            {
                cflag = false;
                break;
            }
        }
        if (cflag)
        {
            polynomial FI = Ft / C;//kernel
            monomial DI = d * C * Lj;//co-kernel
            //special for if FI=1+...
            /*
            if (FI.contain(monomial()))
            {
                for (int l = 0; l < C.size(); ++l)
                {
                    polynomial NFI = FI * monomial(C.lit(l));
                    monomial NDI = DI;
                    NDI /= monomial(C.lit(l));
                    std::cout<<NDI<<" "<<NFI<<std::endl;
                    kernelmap.push_back(make_pair(NDI, NFI));
                    kernels(j, NFI, NDI, kernelmap);
                }
            }
            */
            kernelmap.push_back(make_pair(DI, FI));
            kernels(j, FI, DI, kernelmap);
        }
    }
}
开发者ID:zxrlha,项目名称:wpo,代码行数:71,代码来源:kernel.cpp

示例8: polynomial

 polynomial(const polynomial& o) : vals(std::make_shared<std::vector<T>>(o.size()))
 {
   std::copy_n(o.vals->data(), size(), vals->data());
 }
开发者ID:andyras,项目名称:SplitOp,代码行数:4,代码来源:polynomial.hpp


注:本文中的polynomial::size方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。