64 assert (
etat != ETATNONDEF) ;
73 "Scalar::raccord : The mapping does not belong to the class Map_af !"
78 assert (mapping->get_mg()->get_type_r(1) == FIN) ;
79 assert (mapping->get_mg()->get_type_r(0) == RARE) ;
84 va.set_etat_cf_qcq() ;
85 va.c_cf->t[0]->annule_hard() ;
88 int nz = mapping->get_mg()->get_nzone() ;
89 int nbrer_kernel = mapping->get_mg()->get_nr(0) ;
90 int nbrer_shell = mapping->get_mg()->get_nr(1) ;
92 int nbret_kernel = mapping->get_mg()->get_nt(0) ;
93 int nbret_shell = mapping->get_mg()->get_nt(1) ;
95 int nbrep_kernel = mapping->get_mg()->get_np(0) ;
96 int nbrep_shell = mapping->get_mg()->get_np(1) ;
98 double alpha_kernel = mapping->
get_alpha()[0] ;
99 double alpha_shell = mapping->
get_alpha()[1] ;
101 int base_r, m_quant, l_quant ;
103 for (
int k=0 ; k<nbrep_kernel+1 ; k++)
104 for (
int j=0 ; j<nbret_kernel ; j++)
105 if (nullite_plm(j, nbret_kernel, k,nbrep_kernel,
va.base) == 1)
106 if (nullite_plm(j, nbret_shell, k, nbrep_shell,
va.base) == 1)
109 donne_lm(nz, 0, j, k,
va.base, m_quant, l_quant, base_r) ;
114 Tbl facteur (nbrer_kernel) ;
116 for (
int i=0 ; i<nbrer_shell ; i++)
118 facteur.
set(i) = (*
va.c_cf)(1, k, j, i) ;
120 Tbl sec_membre (sec_membre_raccord (facteur, cont, alpha_shell)) ;
123 systeme = matrice_raccord_pair (cont, alpha_kernel) ;
125 systeme = matrice_raccord_impair (cont, alpha_kernel) ;
128 Tbl regulier (nbrer_kernel) ;
131 for (
int i=0 ; i<cont ; i++)
132 va.c_cf->set(0, k, j, i) = soluce(i) ;
135 regulier = regularise (soluce, nbrer_kernel,
R_CHEBP) ;
137 regulier = regularise (soluce, nbrer_kernel,
R_CHEBI) ;
139 for (
int i=0 ; i<nbrer_kernel ; i++)
140 va.c_cf->set(0, k, j, i) = regulier(i) ;