59 #include "param_elliptic.h" 69 Mtbl_cf elliptic_solver_only_zec (
const Param_elliptic& ope_var,
const Mtbl_cf& source,
double val) {
73 assert (source.get_mg()->get_type_r(nz-1) == UNSURR) ;
85 Mtbl_cf solution_part(source.get_mg(), source.base) ;
86 Mtbl_cf solution_hom_un(source.get_mg(), source.base) ;
87 Mtbl_cf solution_hom_deux(source.get_mg(), source.base) ;
88 Mtbl_cf resultat(source.get_mg(), source.base) ;
90 solution_part.annule_hard() ;
91 solution_hom_un.annule_hard() ;
92 solution_hom_deux.annule_hard() ;
93 resultat.annule_hard() ;
97 for (
int l=0 ; l<nz-1 ; l++) {
98 nt = source.get_mg()->get_nt(l) ;
99 np = source.get_mg()->get_np(l) ;
100 for (
int k=0 ; k<np+1 ; k++)
101 for (
int j=0 ; j<nt ; j++)
104 int conte = conte_start ;
108 nr = source.get_mg()->get_nr(zone) ;
109 nt = source.get_mg()->get_nt(zone) ;
110 np = source.get_mg()->get_np(zone) ;
112 for (
int k=0 ; k<np+1 ; k++)
113 for (
int j=0 ; j<nt ; j++) {
115 if (ope_var.operateurs[conte] != 0x0) {
118 sol_hom =
new Tbl(ope_var.operateurs[conte]->get_solh()) ;
123 for (
int i=0 ; i<nr ; i++)
124 so->set(i) = source(zone, k, j, i) ;
126 sol_part =
new Tbl(ope_var.operateurs[conte]->get_solp(*so)) ;
129 for (
int i=0 ; i<nr ; i++) {
130 solution_part.set(zone, k, j, i) = (*sol_part)(i) ;
131 if (sol_hom->get_ndim()==1)
132 solution_hom_un.set(zone, k, j, i) = (*sol_hom)(i) ;
135 solution_hom_un.set(zone, k, j, i) = (*sol_hom)(0,i) ;
136 solution_hom_deux.set(zone, k, j, i) = (*sol_hom)(1,i) ;
156 int start = conte_start ;
157 for (
int k=0 ; k<1 ; k++)
158 for (
int j=0 ; j<1 ; j++) {
159 if (ope_var.operateurs[start] != 0x0) {
163 double facteur = ((val-ope_var.F_minus(nz-1, k, j))/
164 ope_var.G_minus(nz-1) -
165 ope_var.operateurs[start]->val_sp_minus()) /
166 ope_var.operateurs[start]->val_sh_one_minus() ;
169 nr = source.get_mg()->get_nr(nz-1) ;
170 for (
int i=0 ; i<nr ; i++)
171 resultat.set(nz-1,k,j,i) = solution_part(nz-1,k,j,i) +
172 facteur*solution_hom_un(nz-1,k,j,i) ;
const Mg3d * get_mg() const
Returns the Mg3d on which the Mtbl_cf is defined.
int get_nzone() const
Returns the number of domains.