KADATH
ope_partial.cpp
1 /*
2  Copyright 2017 Philippe Grandclement
3 
4  This file is part of Kadath.
5 
6  Kadath is free software: you can redistribute it and/or modify
7  it under the terms of the GNU General Public License as published by
8  the Free Software Foundation, either version 3 of the License, or
9  (at your option) any later version.
10 
11  Kadath is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  GNU General Public License for more details.
15 
16  You should have received a copy of the GNU General Public License
17  along with Kadath. If not, see <http://www.gnu.org/licenses/>.
18 */
19 
20 #include "ope_eq.hpp"
21 #include "tensor.hpp"
22 namespace Kadath {
23 Ope_partial::Ope_partial (const System_of_eqs* zesys, char ind, Ope_eq* target) : Ope_eq(zesys, target->get_dom(), 1), ind_der(ind) {
24  parts[0] = target ;
25 }
26 
28 }
29 
31  Term_eq target (parts[0]->action()) ;
32  // Check it is a tensor
33  if (target.type_data != TERM_T) {
34  cerr << "Ope_partial only defined with respect for a tensor" << endl ;
35  abort() ;
36  }
37 
38  return (partial (target, ind_der)) ;
39 }}
Abstract class that describes the various operators that can appear in the equations.
Definition: ope_eq.hpp:32
MMPtr_array< Ope_eq > parts
Pointers of the various parts of the current operator.
Definition: ope_eq.hpp:38
char ind_der
name of the index
Definition: ope_eq.hpp:834
Ope_partial(const System_of_eqs *syst, char name, Ope_eq *so)
Constructor.
Definition: ope_partial.cpp:23
Term_eq action() const override
Computes the action of the current Ope_eq using its various parts.
Definition: ope_partial.cpp:30
~Ope_partial() override
Destructor.
Definition: ope_partial.cpp:27
Class used to describe and solve a system of equations.
This class is intended to describe the manage objects appearing in the equations.
Definition: term_eq.hpp:62
const int type_data
Flag describing the type of data :
Definition: term_eq.hpp:75