86 void dirichlet_binaire (
const Cmp& source_un,
const Cmp& source_deux,
87 const Valeur& boundary_un,
const Valeur& boundary_deux,
88 Cmp& sol_un, Cmp& sol_deux,
int num_front,
92 assert (source_un.get_mp() == sol_un.get_mp()) ;
93 assert (source_deux.get_mp() == sol_deux.get_mp()) ;
95 Valeur limite_un (boundary_un.get_mg()) ;
96 Valeur limite_deux (boundary_deux.get_mg()) ;
98 Cmp sol_un_old (sol_un.get_mp()) ;
99 Cmp sol_deux_old (sol_deux.get_mp()) ;
101 Mtbl xa_mtbl_un (source_un.get_mp()->xa) ;
102 Mtbl ya_mtbl_un (source_un.get_mp()->ya) ;
103 Mtbl za_mtbl_un (source_un.get_mp()->za) ;
104 Mtbl xa_mtbl_deux (source_deux.get_mp()->xa) ;
105 Mtbl ya_mtbl_deux (source_deux.get_mp()->ya) ;
106 Mtbl za_mtbl_deux (source_deux.get_mp()->za) ;
108 double xabs, yabs, zabs ;
109 double air, theta, phi ;
112 int nbrep_un = boundary_un.get_mg()->get_np(num_front) ;
113 int nbret_un = boundary_un.get_mg()->get_nt(num_front) ;
114 int nbrep_deux = boundary_deux.get_mg()->get_np(num_front) ;
115 int nbret_deux = boundary_deux.get_mg()->get_nt(num_front) ;
117 int nz_un = boundary_un.get_mg()->get_nzone() ;
118 int nz_deux = boundary_deux.get_mg()->get_nzone() ;
122 for (
int k=0 ; k<nbrep_un ; k++)
123 for (
int j=0 ; j<nbret_un ; j++)
124 limite_un.set(num_front, k, j, 0) =
125 sol_un.va.val_point_jk(num_front+1, -1, j, k) ;
126 limite_un.set_base (boundary_un.base) ;
129 for (
int k=0 ; k<nbrep_deux ; k++)
130 for (
int j=0 ; j<nbret_deux ; j++)
131 limite_deux.set(num_front, k, j, 0) =
132 sol_deux.va.val_point_jk(num_front+1, -1, j, k) ;
133 limite_deux.set_base (boundary_deux.base) ;
141 sol_un_old = sol_un ;
142 sol_deux_old = sol_deux ;
144 sol_un = source_un.poisson_dirichlet(limite_un, num_front) ;
145 sol_deux = source_deux.poisson_dirichlet(limite_deux, num_front) ;
147 xa_mtbl_deux = source_deux.get_mp()->xa ;
148 ya_mtbl_deux = source_deux.get_mp()->ya ;
149 za_mtbl_deux = source_deux.get_mp()->za ;
152 for (
int k=0 ; k<nbrep_deux ; k++)
153 for (
int j=0 ; j<nbret_deux ; j++) {
154 xabs = xa_mtbl_deux (num_front+1, k, j, 0) ;
155 yabs = ya_mtbl_deux (num_front+1, k, j, 0) ;
156 zabs = za_mtbl_deux (num_front+1, k, j, 0) ;
158 source_un.get_mp()->convert_absolute
159 (xabs, yabs, zabs, air, theta, phi) ;
160 valeur = sol_un.val_point(air, theta, phi) ;
162 limite_deux.set(num_front, k, j, 0) =
163 boundary_deux(num_front, k, j, 0) - valeur ;
166 xa_mtbl_un = source_un.get_mp()->xa ;
167 ya_mtbl_un = source_un.get_mp()->ya ;
168 za_mtbl_un = source_un.get_mp()->za ;
170 for (
int k=0 ; k<nbrep_un ; k++)
171 for (
int j=0 ; j<nbret_un ; j++) {
172 xabs = xa_mtbl_un (num_front+1, k, j, 0) ;
173 yabs = ya_mtbl_un (num_front+1, k, j, 0) ;
174 zabs = za_mtbl_un (num_front+1, k, j, 0) ;
176 source_deux.get_mp()->convert_absolute
177 (xabs, yabs, zabs, air, theta, phi) ;
178 valeur = sol_deux.val_point(air, theta, phi) ;
180 limite_un.set(num_front, k, j, 0) =
181 boundary_un(num_front, k, j, 0) - valeur ;
185 Tbl diff_un (
diffrelmax(sol_un, sol_un_old)) ;
186 for (
int i=num_front+1 ; i<nz_un ; i++)
187 if (diff_un(i) > erreur)
188 erreur = diff_un(i) ;
190 Tbl diff_deux (
diffrelmax(sol_deux, sol_deux_old)) ;
191 for (
int i=num_front+1 ; i<nz_deux ; i++)
192 if (diff_deux(i) > erreur)
193 erreur = diff_deux(i) ;
195 cout <<
"Pas " << conte <<
" : Difference " << erreur << endl ;
198 if (erreur < precision)
205 void dirichlet_binaire (
const Cmp& source_un,
const Cmp& source_deux,
206 double bound_un,
double bound_deux,
207 Cmp& sol_un, Cmp& sol_deux,
int num_front,
210 Valeur boundary_un (source_un.get_mp()->get_mg()->get_angu()) ;
212 boundary_un.annule_hard() ;
214 boundary_un = bound_un ;
215 boundary_un.std_base_scal() ;
217 Valeur boundary_deux (source_deux.get_mp()->get_mg()->get_angu()) ;
219 boundary_deux.annule_hard() ;
221 boundary_deux = bound_deux ;
222 boundary_deux.std_base_scal() ;
224 dirichlet_binaire (source_un, source_deux, boundary_un, boundary_deux,
225 sol_un, sol_deux, num_front, precision) ;
230 void dirichlet_binaire (
const Scalar& source_un,
const Scalar& source_deux,
231 const Valeur& boundary_un,
const Valeur& boundary_deux,
232 Scalar& sol_un, Scalar& sol_deux,
int num_front,
236 assert (source_un.get_mp() == sol_un.get_mp()) ;
237 assert (source_deux.get_mp() == sol_deux.get_mp()) ;
239 Valeur limite_un (boundary_un.get_mg()) ;
240 Valeur limite_deux (boundary_deux.get_mg()) ;
242 Scalar sol_un_old (sol_un.get_mp()) ;
243 Scalar sol_deux_old (sol_deux.get_mp()) ;
245 Mtbl xa_mtbl_un (source_un.get_mp().xa) ;
246 Mtbl ya_mtbl_un (source_un.get_mp().ya) ;
247 Mtbl za_mtbl_un (source_un.get_mp().za) ;
248 Mtbl xa_mtbl_deux (source_deux.get_mp().xa) ;
249 Mtbl ya_mtbl_deux (source_deux.get_mp().ya) ;
250 Mtbl za_mtbl_deux (source_deux.get_mp().za) ;
252 double xabs, yabs, zabs ;
253 double air, theta, phi ;
256 int nbrep_un = boundary_un.get_mg()->get_np(num_front) ;
257 int nbret_un = boundary_un.get_mg()->get_nt(num_front) ;
258 int nbrep_deux = boundary_deux.get_mg()->get_np(num_front) ;
259 int nbret_deux = boundary_deux.get_mg()->get_nt(num_front) ;
261 int nz_un = boundary_un.get_mg()->get_nzone() ;
262 int nz_deux = boundary_deux.get_mg()->get_nzone() ;
266 for (
int k=0 ; k<nbrep_un ; k++)
267 for (
int j=0 ; j<nbret_un ; j++)
268 limite_un.set(num_front, k, j, 0) =
269 sol_un.get_spectral_va().val_point_jk(num_front+1, -1, j, k) ;
270 limite_un.set_base (boundary_un.base) ;
273 for (
int k=0 ; k<nbrep_deux ; k++)
274 for (
int j=0 ; j<nbret_deux ; j++)
275 limite_deux.set(num_front, k, j, 0) =
276 sol_deux.get_spectral_va().val_point_jk(num_front+1, -1, j, k) ;
277 limite_deux.set_base (boundary_deux.base) ;
285 sol_un_old = sol_un ;
286 sol_deux_old = sol_deux ;
288 sol_un = source_un.poisson_dirichlet(limite_un, num_front) ;
289 sol_deux = source_deux.poisson_dirichlet(limite_deux, num_front) ;
291 xa_mtbl_deux = source_deux.get_mp().xa ;
292 ya_mtbl_deux = source_deux.get_mp().ya ;
293 za_mtbl_deux = source_deux.get_mp().za ;
296 for (
int k=0 ; k<nbrep_deux ; k++)
297 for (
int j=0 ; j<nbret_deux ; j++) {
298 xabs = xa_mtbl_deux (num_front+1, k, j, 0) ;
299 yabs = ya_mtbl_deux (num_front+1, k, j, 0) ;
300 zabs = za_mtbl_deux (num_front+1, k, j, 0) ;
302 source_un.get_mp().convert_absolute
303 (xabs, yabs, zabs, air, theta, phi) ;
304 valeur = sol_un.val_point(air, theta, phi) ;
306 limite_deux.set(num_front, k, j, 0) =
307 boundary_deux(num_front, k, j, 0) - valeur ;
310 xa_mtbl_un = source_un.get_mp().xa ;
311 ya_mtbl_un = source_un.get_mp().ya ;
312 za_mtbl_un = source_un.get_mp().za ;
314 for (
int k=0 ; k<nbrep_un ; k++)
315 for (
int j=0 ; j<nbret_un ; j++) {
316 xabs = xa_mtbl_un (num_front+1, k, j, 0) ;
317 yabs = ya_mtbl_un (num_front+1, k, j, 0) ;
318 zabs = za_mtbl_un (num_front+1, k, j, 0) ;
320 source_deux.get_mp().convert_absolute
321 (xabs, yabs, zabs, air, theta, phi) ;
322 valeur = sol_deux.val_point(air, theta, phi) ;
324 limite_un.set(num_front, k, j, 0) =
325 boundary_un(num_front, k, j, 0) - valeur ;
330 Tbl diff_un (
diffrelmax(sol_un, sol_un_old)) ;
331 for (
int i=num_front+1 ; i<nz_un ; i++)
332 if (diff_un(i) > erreur)
333 erreur = diff_un(i) ;
335 Tbl diff_deux (
diffrelmax(sol_deux, sol_deux_old)) ;
336 for (
int i=num_front+1 ; i<nz_deux ; i++)
337 if (diff_deux(i) > erreur)
338 erreur = diff_deux(i) ;
340 cout <<
"Pas " << conte <<
" : Difference " << erreur << endl ;
343 if (erreur < precision)
353 void neumann_binaire (
const Cmp& source_un,
const Cmp& source_deux,
354 const Valeur& boundary_un,
const Valeur& boundary_deux,
355 Cmp& sol_un, Cmp& sol_deux,
int num_front,
359 assert (source_un.get_mp() == sol_un.get_mp()) ;
360 assert (source_deux.get_mp() == sol_deux.get_mp()) ;
363 double orient_un = source_un.get_mp()->get_rot_phi() ;
364 assert ((orient_un==0) || (orient_un==M_PI)) ;
365 double orient_deux = source_deux.get_mp()->get_rot_phi() ;
366 assert ((orient_deux==0) || (orient_deux==M_PI)) ;
367 int same_orient = (orient_un==orient_deux) ? 1 : -1 ;
369 Valeur limite_un (boundary_un.get_mg()) ;
370 Valeur limite_deux (boundary_deux.get_mg()) ;
372 Cmp sol_un_old (sol_un.get_mp()) ;
373 Cmp sol_deux_old (sol_deux.get_mp()) ;
375 Mtbl xa_mtbl_un (source_un.get_mp()->xa) ;
376 Mtbl ya_mtbl_un (source_un.get_mp()->ya) ;
377 Mtbl za_mtbl_un (source_un.get_mp()->za) ;
379 Mtbl cost_mtbl_un (source_un.get_mp()->cost) ;
380 Mtbl sint_mtbl_un (source_un.get_mp()->sint) ;
381 Mtbl cosp_mtbl_un (source_un.get_mp()->cosp) ;
382 Mtbl sinp_mtbl_un (source_un.get_mp()->sinp) ;
385 Mtbl xa_mtbl_deux (source_deux.get_mp()->xa) ;
386 Mtbl ya_mtbl_deux (source_deux.get_mp()->ya) ;
387 Mtbl za_mtbl_deux (source_deux.get_mp()->za) ;
389 Mtbl cost_mtbl_deux (source_deux.get_mp()->cost) ;
390 Mtbl sint_mtbl_deux (source_deux.get_mp()->sint) ;
391 Mtbl cosp_mtbl_deux (source_deux.get_mp()->cosp) ;
392 Mtbl sinp_mtbl_deux (source_deux.get_mp()->sinp) ;
394 double xabs, yabs, zabs ;
395 double air, theta, phi ;
398 int nbrep_un = boundary_un.get_mg()->get_np(num_front) ;
399 int nbret_un = boundary_un.get_mg()->get_nt(num_front) ;
400 int nbrep_deux = boundary_deux.get_mg()->get_np(num_front) ;
401 int nbret_deux = boundary_deux.get_mg()->get_nt(num_front) ;
403 int nz_un = boundary_un.get_mg()->get_nzone() ;
404 int nz_deux = boundary_deux.get_mg()->get_nzone() ;
409 Cmp der_un (sol_un.dsdr()) ;
410 Cmp der_deux (sol_deux.dsdr()) ;
412 for (
int k=0 ; k<nbrep_un ; k++)
413 for (
int j=0 ; j<nbret_un ; j++)
414 limite_un.set(num_front, k, j, 0) =
415 der_un.va.val_point_jk(num_front+1, -1, j, k) ;
416 limite_un.set_base (boundary_un.base) ;
418 for (
int k=0 ; k<nbrep_deux ; k++)
419 for (
int j=0 ; j<nbret_deux ; j++)
420 limite_deux.set(num_front, k, j, 0) =
421 der_deux.va.val_point_jk(num_front+1, -1, j, k) ;
422 limite_deux.set_base (boundary_deux.base) ;
429 sol_un_old = sol_un ;
430 sol_deux_old = sol_deux ;
432 sol_un = source_un.poisson_neumann(limite_un, num_front) ;
433 sol_deux = source_deux.poisson_neumann(limite_deux, num_front) ;
436 Tenseur copie_un (sol_un) ;
437 Tenseur grad_sol_un (copie_un.gradient()) ;
438 grad_sol_un.dec2_dzpuis() ;
439 grad_sol_un.set(0) = grad_sol_un(0)*same_orient ;
440 grad_sol_un.set(1) = grad_sol_un(1)*same_orient ;
442 for (
int k=0 ; k<nbrep_deux ; k++)
443 for (
int j=0 ; j<nbret_deux ; j++) {
444 xabs = xa_mtbl_deux (num_front+1, k, j, 0) ;
445 yabs = ya_mtbl_deux (num_front+1, k, j, 0) ;
446 zabs = za_mtbl_deux (num_front+1, k, j, 0) ;
448 source_un.get_mp()->convert_absolute
449 (xabs, yabs, zabs, air, theta, phi) ;
451 valeur = sint_mtbl_deux (num_front+1, k, j, 0) * (
452 cosp_mtbl_deux(num_front+1, k, j, 0)*grad_sol_un(0).val_point(air, theta, phi)+
453 sinp_mtbl_deux(num_front+1, k, j, 0)*grad_sol_un(1).val_point(air, theta, phi))+
454 cost_mtbl_deux(num_front+1, k, j, 0)*grad_sol_un(2).val_point(air, theta, phi);
456 limite_deux.set(num_front, k, j, 0) =
457 boundary_deux(num_front, k, j, 0) - valeur ;
460 Tenseur copie_deux (sol_deux) ;
461 Tenseur grad_sol_deux (copie_deux.gradient()) ;
462 grad_sol_deux.dec2_dzpuis() ;
463 grad_sol_deux.set(0) = grad_sol_deux(0)*same_orient ;
464 grad_sol_deux.set(1) = grad_sol_deux(1)*same_orient ;
466 for (
int k=0 ; k<nbrep_un ; k++)
467 for (
int j=0 ; j<nbret_un ; j++) {
468 xabs = xa_mtbl_un (num_front+1, k, j, 0) ;
469 yabs = ya_mtbl_un (num_front+1, k, j, 0) ;
470 zabs = za_mtbl_un (num_front+1, k, j, 0) ;
472 source_deux.get_mp()->convert_absolute
473 (xabs, yabs, zabs, air, theta, phi) ;
475 valeur = sint_mtbl_un (num_front+1, k, j, 0) * (
476 cosp_mtbl_un(num_front+1, k, j, 0)*grad_sol_deux(0).val_point(air, theta, phi)+
477 sinp_mtbl_un(num_front+1, k, j, 0)*grad_sol_deux(1).val_point(air, theta, phi))+
478 cost_mtbl_un(num_front+1, k, j, 0)*grad_sol_deux(2).val_point(air, theta, phi);
480 limite_un.set(num_front, k, j, 0) =
481 boundary_un(num_front, k, j, 0) - valeur ;
485 Tbl diff_un (
diffrelmax(sol_un, sol_un_old)) ;
486 for (
int i=num_front+1 ; i<nz_un ; i++)
487 if (diff_un(i) > erreur)
488 erreur = diff_un(i) ;
490 Tbl diff_deux (
diffrelmax(sol_deux, sol_deux_old)) ;
491 for (
int i=num_front+1 ; i<nz_deux ; i++)
492 if (diff_deux(i) > erreur)
493 erreur = diff_deux(i) ;
495 cout <<
"Pas " << conte <<
" : Difference " << erreur << endl ;
498 if (erreur < precision)
504 void neumann_binaire (
const Cmp& source_un,
const Cmp& source_deux,
505 double bound_un,
double bound_deux,
506 Cmp& sol_un, Cmp& sol_deux,
int num_front,
509 Valeur boundary_un (source_un.get_mp()->get_mg()->get_angu()) ;
511 boundary_un.annule_hard () ;
513 boundary_un = bound_un ;
514 boundary_un.std_base_scal() ;
516 Valeur boundary_deux (source_deux.get_mp()->get_mg()->get_angu()) ;
518 boundary_deux.annule_hard() ;
520 boundary_deux = bound_deux ;
521 boundary_deux.std_base_scal() ;
523 neumann_binaire (source_un, source_deux, boundary_un, boundary_deux,
524 sol_un, sol_deux, num_front, precision) ;
526 void neumann_binaire (
const Scalar& source_un,
const Scalar& source_deux,
527 const Valeur& boundary_un,
const Valeur& boundary_deux,
528 Scalar& sol_un, Scalar& sol_deux,
int num_front,
532 assert (source_un.get_mp() == sol_un.get_mp()) ;
533 assert (source_deux.get_mp() == sol_deux.get_mp()) ;
536 double orient_un = source_un.get_mp().get_rot_phi() ;
537 assert ((orient_un==0) || (orient_un==M_PI)) ;
538 double orient_deux = source_deux.get_mp().get_rot_phi() ;
539 assert ((orient_deux==0) || (orient_deux==M_PI)) ;
540 int same_orient = (orient_un==orient_deux) ? 1 : -1 ;
542 Valeur limite_un (boundary_un.get_mg()) ;
543 Valeur limite_deux (boundary_deux.get_mg()) ;
545 Scalar sol_un_old (sol_un.get_mp()) ;
546 Scalar sol_deux_old (sol_deux.get_mp()) ;
548 Mtbl xa_mtbl_un (source_un.get_mp().xa) ;
549 Mtbl ya_mtbl_un (source_un.get_mp().ya) ;
550 Mtbl za_mtbl_un (source_un.get_mp().za) ;
552 Mtbl cost_mtbl_un (source_un.get_mp().cost) ;
553 Mtbl sint_mtbl_un (source_un.get_mp().sint) ;
554 Mtbl cosp_mtbl_un (source_un.get_mp().cosp) ;
555 Mtbl sinp_mtbl_un (source_un.get_mp().sinp) ;
557 Mtbl xa_mtbl_deux (source_deux.get_mp().xa) ;
558 Mtbl ya_mtbl_deux (source_deux.get_mp().ya) ;
559 Mtbl za_mtbl_deux (source_deux.get_mp().za) ;
561 Mtbl cost_mtbl_deux (source_deux.get_mp().cost) ;
562 Mtbl sint_mtbl_deux (source_deux.get_mp().sint) ;
563 Mtbl cosp_mtbl_deux (source_deux.get_mp().cosp) ;
564 Mtbl sinp_mtbl_deux (source_deux.get_mp().sinp) ;
566 double xabs, yabs, zabs ;
567 double air, theta, phi ;
570 const Metric_flat& ff_un (source_un.get_mp().flat_met_cart()) ;
571 const Metric_flat& ff_deux (source_deux.get_mp().flat_met_cart()) ;
573 int nbrep_un = boundary_un.get_mg()->get_np(num_front) ;
574 int nbret_un = boundary_un.get_mg()->get_nt(num_front) ;
575 int nbrep_deux = boundary_deux.get_mg()->get_np(num_front) ;
576 int nbret_deux = boundary_deux.get_mg()->get_nt(num_front) ;
578 int nz_un = boundary_un.get_mg()->get_nzone() ;
579 int nz_deux = boundary_deux.get_mg()->get_nzone() ;
584 Scalar der_un (sol_un.dsdr()) ;
585 Scalar der_deux (sol_deux.dsdr()) ;
587 for (
int k=0 ; k<nbrep_un ; k++)
588 for (
int j=0 ; j<nbret_un ; j++)
589 limite_un.set(num_front, k, j, 0) =
590 der_un.get_spectral_va().val_point_jk(num_front+1, -1, j, k) ;
591 limite_un.set_base (boundary_un.base) ;
593 for (
int k=0 ; k<nbrep_deux ; k++)
594 for (
int j=0 ; j<nbret_deux ; j++)
595 limite_deux.set(num_front, k, j, 0) =
596 der_deux.get_spectral_va().val_point_jk(num_front+1, -1, j, k) ;
597 limite_deux.set_base (boundary_deux.base) ;
604 sol_un_old = sol_un ;
605 sol_deux_old = sol_deux ;
607 sol_un = source_un.poisson_neumann(limite_un, num_front) ;
608 sol_deux = source_deux.poisson_neumann(limite_deux, num_front) ;
611 Scalar copie_un (sol_un) ;
612 Vector grad_sol_un (copie_un.derive_cov(ff_un)) ;
613 grad_sol_un.dec_dzpuis(2) ;
614 grad_sol_un.set(1) = grad_sol_un(1)*same_orient ;
615 grad_sol_un.set(2) = grad_sol_un(2)*same_orient ;
618 for (
int k=0 ; k<nbrep_deux ; k++)
619 for (
int j=0 ; j<nbret_deux ; j++) {
620 xabs = xa_mtbl_deux (num_front+1, k, j, 0) ;
621 yabs = ya_mtbl_deux (num_front+1, k, j, 0) ;
622 zabs = za_mtbl_deux (num_front+1, k, j, 0) ;
624 source_un.get_mp().convert_absolute
625 (xabs, yabs, zabs, air, theta, phi) ;
627 valeur = sint_mtbl_deux (num_front+1, k, j, 0) * (
628 cosp_mtbl_deux(num_front+1, k, j, 0)*grad_sol_un(1).val_point(air, theta, phi)+
629 sinp_mtbl_deux(num_front+1, k, j, 0)*grad_sol_un(2).val_point(air, theta, phi))+
630 cost_mtbl_deux(num_front+1, k, j, 0)*grad_sol_un(3).val_point(air, theta, phi);
632 limite_deux.set(num_front, k, j, 0) =
633 boundary_deux(num_front, k, j, 0) - valeur ;
636 Scalar copie_deux (sol_deux) ;
637 Vector grad_sol_deux (copie_deux.derive_cov(ff_deux)) ;
638 grad_sol_deux.dec_dzpuis(2) ;
639 grad_sol_deux.set(1) = grad_sol_deux(1)*same_orient ;
640 grad_sol_deux.set(2) = grad_sol_deux(2)*same_orient ;
642 for (
int k=0 ; k<nbrep_un ; k++)
643 for (
int j=0 ; j<nbret_un ; j++) {
644 xabs = xa_mtbl_un (num_front+1, k, j, 0) ;
645 yabs = ya_mtbl_un (num_front+1, k, j, 0) ;
646 zabs = za_mtbl_un (num_front+1, k, j, 0) ;
648 source_deux.get_mp().convert_absolute
649 (xabs, yabs, zabs, air, theta, phi) ;
651 valeur = sint_mtbl_un (num_front+1, k, j, 0) * (
652 cosp_mtbl_un(num_front+1, k, j, 0)*grad_sol_deux(1).val_point(air, theta, phi)+
653 sinp_mtbl_un(num_front+1, k, j, 0)*grad_sol_deux(2).val_point(air, theta, phi))+
654 cost_mtbl_un(num_front+1, k, j, 0)*grad_sol_deux(3).val_point(air, theta, phi);
658 limite_un.set(num_front, k, j, 0) =
659 boundary_un(num_front, k, j, 0) - valeur ;
663 Tbl diff_un (
diffrelmax(sol_un, sol_un_old)) ;
664 for (
int i=num_front+1 ; i<nz_un ; i++)
665 if (diff_un(i) > erreur)
666 erreur = diff_un(i) ;
668 Tbl diff_deux (
diffrelmax(sol_deux, sol_deux_old)) ;
669 for (
int i=num_front+1 ; i<nz_deux ; i++)
670 if (diff_deux(i) > erreur)
671 erreur = diff_deux(i) ;
673 cout <<
"Pas " << conte <<
" : Difference " << erreur << endl ;
676 Scalar source1 (source_un) ;
677 Scalar solution1 (sol_un) ;
682 if (erreur < precision)
Tbl diffrelmax(const Cmp &a, const Cmp &b)
Relative difference between two Cmp (max version).