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


C++ Polynomial::copy方法代码示例

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


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

示例1: reduceStep

bool SimpleReductor::reduceStep (Polynomial& r, const Polynomial& p) {
   Polynomial t;
   r.copy(p);
   Monomial lm = r.lm();
   int i, i0 = -1;
   for (i = 0; i < g.size(); ++i) {
      Monomial m = g[i].lm();
      if (MP.divides(lm, m)) {
         t.mul(g[i], MP.div(lm, m));
         Cf f;
         Ring::neg(f, r.lc());
         r.add(t, t.lc(), f);
         return true;
      }
   }
   return false;
}
开发者ID:Qnan,项目名称:mkmsc,代码行数:17,代码来源:tnirps_reduction.cpp

示例2: test_polynomials

  void Tester::test_polynomials()
  {
    Polynomial ZERO = Polynomial::ZERO();
    cout << ZERO << endl;

    Polynomial p = ZERO.copy();
    
    p.addTrailingTerm(3);
    p.addTrailingTerm(-5);
    p.addTrailingTerm(10);
    p.addTrailingTerm(-3);

    Polynomial p2 = ZERO;//ZERO.copy();//new Polynomial();
    p2.addTrailingTerm(3);
    p2.addTrailingTerm(1);
    //    p2 -> addTrailingTerm(10);

    cout << "a:   " << p  << endl;
    cout << "b:   " << p2 << endl;
    
    Polynomial p12 = p + p2;
    cout << "a+b: " << p12 << endl;

    Polynomial sub = p - p2;
    cout << "a-b: " << sub << endl;

    Polynomial scale = p *.5;
    cout << "a*.5: " << scale << endl;

    Polynomial mult = p*p2;
    cout << "a*b: " << mult << endl;

    // Division and Remainder.
    Polynomial div = p/p2;
    cout << "a/b: " << p/p2  << endl;
    //    cout << "a%b: " << p%p2 << endl;

    // WARNING: Memory Explosion if not handled with care.
    
    std::vector<double> roots;

    /*
    p -> computeRealRoots(roots,
			  -1000, 1000,
			  .000001);
    */

    Polynomial p3 = ZERO;
    // This polynomial has roots 1, 2, 3, 4, 5. They are all found accuratly.
    
    p3.addTrailingTerm(1);
    p3.addTrailingTerm(-15);
    p3.addTrailingTerm(85);
    p3.addTrailingTerm(-225);
    p3.addTrailingTerm(274);
    p3.addTrailingTerm(-120);
    

    // This polynomial has roots:
    // -1.32, 1.32, 4.56, 4.58, 4.6.
    // Thus far we only find -1.32, 1.32, and 4.53658.
    // We don't find the close last 3 values accuratly.
    /*
    p3.addTrailingTerm(1);
    p3.addTrailingTerm(-13.74);
    p3.addTrailingTerm(61.1864);
    p3.addTrailingTerm(-72.1295);
    p3.addTrailingTerm(-109.647);
    p3.addTrailingTerm(167.393);
    */

    std::cout << "Quintic Polynomial: " << p3 << std::endl;
    
    p3.computeRealRoots(roots,
			-1000, 1000,
			.0000001);

    for(auto iter = roots.begin(); iter != roots.end(); ++iter)
    {
      cout << "Root: " << *iter << " -> " << p3.eval(*iter)<< endl;
    }

    Polynomial x, y, z;

    x.addTrailingTerm(1);
    x.addTrailingTerm(1);

    y.addTrailingTerm(2);
    y.addTrailingTerm(2);

    z.addTrailingTerm(3);
    z.addTrailingTerm(3);

    PolynomialVector3D vec(x, y, z);

    cout << "vec - vec = " << vec - vec << endl;
    cout << "vec + vec = " << vec + vec << endl;
    
    cout << vec << endl;
    vec = dot(vec, vec);
//.........这里部分代码省略.........
开发者ID:Bryce-Summers,项目名称:GeometricSurfaceCurves,代码行数:101,代码来源:testing.cpp


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