OPAL (Object Oriented Parallel Accelerator Library) 2022.1
OPAL
DifferentialOperatorTwo.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2018, Martin Duy Tat
3 * All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are met:
6 * 1. Redistributions of source code must retain the above copyright notice,
7 * this list of conditions and the following disclaimer.
8 * 2. Redistributions in binary form must reproduce the above copyright notice,
9 * this list of conditions and the following disclaimer in the documentation
10 * and/or other materials provided with the distribution.
11 * 3. Neither the name of STFC nor the names of its contributors may be used to
12 * endorse or promote products derived from this software without specific
13 * prior written permission.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
16 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
19 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
20 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
21 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
22 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
23 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
24 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
25 * POSSIBILITY OF SUCH DAMAGE.
26 */
27
28#ifndef DIFFERENTIAL_OPERATOR_TWO_H
29#define DIFFERENTIAL_OPERATOR_TWO_H
30
48#include <vector>
49#include "PolynomialSum.h"
50#include "TwoPolynomial.h"
51
52namespace polynomial {
53
55public:
63 DifferentialOperatorTwo(const std::size_t &xDerivatives,
64 const std::size_t &sDerivatives);
71 const DifferentialOperatorTwo &doperator);
75 void resizeX(const std::size_t &xDerivatives);
79 void resizeS(const std::size_t &sDerivatives);
81 void differentiateX();
83 void differentiateS();
87 void multiplyPolynomial(const TwoPolynomial &poly);
93 void setPolynomial(const TwoPolynomial &poly,
94 const std::size_t &x,
95 const std::size_t &s);
97 void printOperator() const;
101 void addOperator(const DifferentialOperatorTwo &doperator);
103 std::size_t getXDerivatives() const;
105 std::size_t getSDerivatives() const;
113 bool isPolynomialZero(const std::size_t &x,
114 const std::size_t &s,
115 const std::size_t &term) const;
119 void truncate(const std::size_t &truncateOrder);
127 double evaluatePolynomial(const double &x,
128 const double &s,
129 const std::size_t &xDerivative,
130 const std::size_t &sDerivative,
131 const std::vector<double> &dSvalues) const;
139 std::size_t numberOfTerms(const std::size_t &xDerivatives,
140 const std::size_t &sDerivatives) const;
149 std::vector<std::size_t> getdSFactors(const std::size_t &xDerivatives,
150 const std::size_t &sDerivatives,
151 const std::size_t &p) const;
155 void sortTerms();
156private:
157 std::vector<std::vector<PolynomialSum>> polynomials_m;
158 std::size_t xDerivatives_m;
159 std::size_t sDerivatives_m;
160};
161
162inline
164 return xDerivatives_m;
165}
166inline
168 return sDerivatives_m;
169}
170
171}
172
173#endif
void setPolynomial(const TwoPolynomial &poly, const std::size_t &x, const std::size_t &s)
DifferentialOperatorTwo & operator=(const DifferentialOperatorTwo &doperator)
bool isPolynomialZero(const std::size_t &x, const std::size_t &s, const std::size_t &term) const
void multiplyPolynomial(const TwoPolynomial &poly)
double evaluatePolynomial(const double &x, const double &s, const std::size_t &xDerivative, const std::size_t &sDerivative, const std::vector< double > &dSvalues) const
void resizeX(const std::size_t &xDerivatives)
void truncate(const std::size_t &truncateOrder)
std::size_t numberOfTerms(const std::size_t &xDerivatives, const std::size_t &sDerivatives) const
std::vector< std::vector< PolynomialSum > > polynomials_m
std::vector< std::size_t > getdSFactors(const std::size_t &xDerivatives, const std::size_t &sDerivatives, const std::size_t &p) const
void addOperator(const DifferentialOperatorTwo &doperator)
void resizeS(const std::size_t &sDerivatives)