25char op_dsdx_C[] =
"$Header: /cvsroot/Lorene/C++/Source/Non_class_members/Operators/op_dsdx.C,v 1.8 2014/10/13 08:53:25 j_novak Exp $" ;
95void _dsdx_pas_prevu(Tbl* ,
int & b) {
96 cout <<
"dsdx pas prevu..." << endl ;
97 cout <<
" base: " << b << endl ;
103void _dsdx_r_cheb(Tbl *tb,
int & )
107 if (tb->get_etat() == ETATZERO) {
112 assert(tb->get_etat() == ETATQCQ) ;
115 int nr = (tb->dim).dim[0] ;
116 int nt = (tb->dim).dim[1] ;
117 int np = (tb->dim).dim[2] ;
121 double* xo =
new double[(tb->dim).taille] ;
124 for (
int i=0; i<(tb->dim).taille; i++) {
133 int borne_phi = np + 1 ;
134 if (np == 1) borne_phi = 1 ;
136 for (
int k=0 ; k< borne_phi ; k++)
143 for (
int j=0 ; j<nt ; j++) {
148 som = 2*(nr-1) * xci[nr-1] ;
150 for (
int i = nr-4 ; i >= 0 ; i -= 2 ) {
151 som += 2*(i+1) * xci[i+1] ;
154 som = 2*(nr-2) * xci[nr-2] ;
156 for (
int i = nr-5 ; i >= 0 ; i -= 2 ) {
157 som += 2*(i+1) * xci[i+1] ;
177void _dsdx_r_chebu(Tbl *tb,
int & )
181 if (tb->get_etat() == ETATZERO) {
186 assert(tb->get_etat() == ETATQCQ) ;
189 int nr = (tb->dim).dim[0] ;
190 int nt = (tb->dim).dim[1] ;
191 int np = (tb->dim).dim[2] ;
195 double* xo =
new double[(tb->dim).taille] ;
198 for (
int i=0; i<(tb->dim).taille; i++) {
207 int borne_phi = np + 1 ;
208 if (np == 1) borne_phi = 1 ;
210 for (
int k=0 ; k< borne_phi ; k++)
219 for (
int j=0 ; j<nt ; j++) {
224 som = 2*(nr-1) * xci[nr-1] ;
226 for (
int i = nr-4 ; i >= 0 ; i -= 2 ) {
227 som += 2*(i+1) * xci[i+1] ;
230 som = 2*(nr-2) * xci[nr-2] ;
232 for (
int i = nr-5 ; i >= 0 ; i -= 2 ) {
233 som += 2*(i+1) * xci[i+1] ;
253void _dsdx_r_chebp(Tbl *tb,
int & b)
257 if (tb->get_etat() == ETATZERO) {
258 int base_t = b &
MSQ_T ;
259 int base_p = b &
MSQ_P ;
260 b = base_p | base_t |
R_CHEBI ;
265 assert(tb->get_etat() == ETATQCQ) ;
268 int nr = (tb->dim).dim[0] ;
269 int nt = (tb->dim).dim[1] ;
270 int np = (tb->dim).dim[2] ;
274 double* xo =
new double[(tb->dim).taille] ;
277 for (
int i=0; i<(tb->dim).taille; i++) {
286 int borne_phi = np + 1 ;
287 if (np == 1) borne_phi = 1 ;
289 for (
int k=0 ; k< borne_phi ; k++)
300 for (
int j=0 ; j<nt ; j++) {
305 som = 4*(nr-1) * xci[nr-1] ;
307 for (
int i = nr-3 ; i >= 0 ; i-- ) {
308 som += 4*(i+1) * xci[i+1] ;
323 int base_t = b &
MSQ_T ;
324 int base_p = b &
MSQ_P ;
325 b = base_p | base_t |
R_CHEBI ;
330void _dsdx_r_chebi(Tbl *tb,
int & b)
334 if (tb->get_etat() == ETATZERO) {
335 int base_t = b &
MSQ_T ;
336 int base_p = b &
MSQ_P ;
337 b = base_p | base_t |
R_CHEBP ;
342 assert(tb->get_etat() == ETATQCQ) ;
345 int nr = (tb->dim).dim[0] ;
346 int nt = (tb->dim).dim[1] ;
347 int np = (tb->dim).dim[2] ;
351 double* xo =
new double[(tb->dim).taille] ;
354 for (
int i=0; i<(tb->dim).taille; i++) {
363 int borne_phi = np + 1 ;
364 if (np == 1) borne_phi = 1 ;
366 for (
int k=0 ; k< borne_phi ; k++)
374 for (
int j=0 ; j<nt ; j++) {
379 som = 2*(2*nr-3) * xci[nr-2] ;
381 for (
int i = nr-3 ; i >= 0 ; i-- ) {
382 som += 2*(2*i+1) * xci[i] ;
398 int base_t = b &
MSQ_T ;
399 int base_p = b &
MSQ_P ;
400 b = base_p | base_t |
R_CHEBP ;
405void _dsdx_r_chebpim_p(Tbl *tb,
int & b)
409 if (tb->get_etat() == ETATZERO) {
410 int base_t = b &
MSQ_T ;
411 int base_p = b &
MSQ_P ;
417 int nr = (tb->dim).dim[0] ;
418 int nt = (tb->dim).dim[1] ;
419 int np = (tb->dim).dim[2] ;
423 double* xo =
new double[(tb->dim).taille] ;
426 for (
int i=0; i<(tb->dim).taille; i++) {
439 for (
int k=0 ; k<np+1 ; k += 4) {
440 auxiliaire = (k==np) ? 1 : 2 ;
441 for (
int kmod=0 ; kmod<auxiliaire ; kmod++) {
446 if ((k==0) && (kmod == 1)) {
453 for (
int j=0 ; j<nt ; j++) {
458 som = 4*(nr-1) * xci[nr-1] ;
460 for (
int i = nr-3 ; i >= 0 ; i-- ) {
461 som += 4*(i+1) * xci[i+1] ;
476 for (
int k=2 ; k<np+1 ; k += 4) {
477 auxiliaire = (k==np) ? 1 : 2 ;
478 for (
int kmod=0 ; kmod<auxiliaire ; kmod++) {
479 for (
int j=0 ; j<nt ; j++) {
484 som = 2*(2*nr-3) * xci[nr-2] ;
486 for (
int i = nr-3 ; i >= 0 ; i-- ) {
487 som += 2*(2*i+1) * xci[i] ;
506 int base_t = b &
MSQ_T ;
507 int base_p = b &
MSQ_P ;
513void _dsdx_r_chebpim_i(Tbl *tb,
int & b)
517 if (tb->get_etat() == ETATZERO) {
518 int base_t = b &
MSQ_T ;
519 int base_p = b &
MSQ_P ;
525 assert(tb->get_etat() == ETATQCQ) ;
529 int nr = (tb->dim).dim[0] ;
530 int nt = (tb->dim).dim[1] ;
531 int np = (tb->dim).dim[2] ;
535 double* xo =
new double[(tb->dim).taille] ;
538 for (
int i=0; i<(tb->dim).taille; i++) {
551 for (
int k=0 ; k<np+1 ; k += 4) {
552 auxiliaire = (k==np) ? 1 : 2 ;
553 for (
int kmod=0 ; kmod<auxiliaire ; kmod++) {
558 if ((k==0) && (kmod == 1)) {
565 for (
int j=0 ; j<nt ; j++) {
570 som = 2*(2*nr-3) * xci[nr-2] ;
572 for (
int i = nr-3 ; i >= 0 ; i-- ) {
573 som += 2*(2*i+1) * xci[i] ;
589 for (
int k=2 ; k<np+1 ; k += 4) {
590 auxiliaire = (k==np) ? 1 : 2 ;
591 for (
int kmod=0 ; kmod<auxiliaire ; kmod++) {
592 for (
int j=0 ; j<nt ; j++) {
597 som = 4*(nr-1) * xci[nr-1] ;
599 for (
int i = nr-3 ; i >= 0 ; i-- ) {
600 som += 4*(i+1) * xci[i+1] ;
618 int base_t = b &
MSQ_T ;
619 int base_p = b &
MSQ_P ;
625void _dsdx_r_chebpi_p(Tbl *tb,
int & b)
629 if (tb->get_etat() == ETATZERO) {
630 int base_t = b &
MSQ_T ;
631 int base_p = b &
MSQ_P ;
637 assert(tb->get_etat() == ETATQCQ) ;
640 int nr = (tb->dim).dim[0] ;
641 int nt = (tb->dim).dim[1] ;
642 int np = (tb->dim).dim[2] ;
646 double* xo =
new double[(tb->dim).taille] ;
649 for (
int i=0; i<(tb->dim).taille; i++) {
658 int borne_phi = np + 1 ;
659 if (np == 1) borne_phi = 1 ;
661 for (
int k=0 ; k< borne_phi ; k++)
672 for (
int j=0 ; j<nt ; j++) {
678 som = 4*(nr-1) * xci[nr-1] ;
680 for (
int i = nr-3 ; i >= 0 ; i-- ) {
681 som += 4*(i+1) * xci[i+1] ;
686 som = 2*(2*nr-3) * xci[nr-2] ;
688 for (
int i = nr-3 ; i >= 0 ; i-- ) {
689 som += 2*(2*i+1) * xci[i] ;
705 int base_t = b &
MSQ_T ;
706 int base_p = b &
MSQ_P ;
712void _dsdx_r_chebpi_i(Tbl *tb,
int & b)
716 if (tb->get_etat() == ETATZERO) {
717 int base_t = b &
MSQ_T ;
718 int base_p = b &
MSQ_P ;
724 assert(tb->get_etat() == ETATQCQ) ;
727 int nr = (tb->dim).dim[0] ;
728 int nt = (tb->dim).dim[1] ;
729 int np = (tb->dim).dim[2] ;
733 double* xo =
new double[(tb->dim).taille] ;
736 for (
int i=0; i<(tb->dim).taille; i++) {
745 int borne_phi = np + 1 ;
746 if (np == 1) borne_phi = 1 ;
748 for (
int k=0 ; k< borne_phi ; k++)
756 for (
int j=0 ; j<nt ; j++) {
762 som = 4*(nr-1) * xci[nr-1] ;
764 for (
int i = nr-3 ; i >= 0 ; i-- ) {
765 som += 4*(i+1) * xci[i+1] ;
770 som = 2*(2*nr-3) * xci[nr-2] ;
772 for (
int i = nr-3 ; i >= 0 ; i-- ) {
773 som += 2*(2*i+1) * xci[i] ;
789 int base_t = b &
MSQ_T ;
790 int base_p = b &
MSQ_P ;
797void _dsdx_r_leg(Tbl *tb,
int & )
801 if (tb->get_etat() == ETATZERO) {
806 assert(tb->get_etat() == ETATQCQ) ;
809 int nr = (tb->dim).dim[0] ;
810 int nt = (tb->dim).dim[1] ;
811 int np = (tb->dim).dim[2] ;
815 double* xo =
new double[(tb->dim).taille] ;
818 for (
int i=0; i<(tb->dim).taille; i++) {
827 int borne_phi = np + 1 ;
828 if (np == 1) borne_phi = 1 ;
830 for (
int k=0 ; k< borne_phi ; k++)
837 for (
int j=0 ; j<nt ; j++) {
843 xco[nr-2] = double(2*nr-3)*som ;
844 for (
int i = nr-4 ; i >= 0 ; i -= 2 ) {
846 xco[i] = double(2*i+1)*som ;
849 if (nr > 2) xco[nr-3] = double(2*nr-5)*som ;
850 for (
int i = nr-5 ; i >= 0 ; i -= 2 ) {
852 xco[i] = double(2*i+1) * som ;
870void _dsdx_r_legp(Tbl *tb,
int & b)
874 if (tb->get_etat() == ETATZERO) {
875 int base_t = b &
MSQ_T ;
876 int base_p = b &
MSQ_P ;
877 b = base_p | base_t |
R_LEGI ;
882 assert(tb->get_etat() == ETATQCQ) ;
885 int nr = (tb->dim).dim[0] ;
886 int nt = (tb->dim).dim[1] ;
887 int np = (tb->dim).dim[2] ;
891 double* xo =
new double[(tb->dim).taille] ;
894 for (
int i=0; i<(tb->dim).taille; i++) {
903 int borne_phi = np + 1 ;
904 if (np == 1) borne_phi = 1 ;
906 for (
int k=0 ; k< borne_phi ; k++)
917 for (
int j=0 ; j<nt ; j++) {
923 if (nr > 1) xco[nr-2] = double(4*nr-5) * som ;
924 for (
int i = nr-3 ; i >= 0 ; i-- ) {
926 xco[i] = double(4*i+3) * som ;
940 int base_t = b &
MSQ_T ;
941 int base_p = b &
MSQ_P ;
942 b = base_p | base_t |
R_LEGI ;
947void _dsdx_r_legi(Tbl *tb,
int & b)
951 if (tb->get_etat() == ETATZERO) {
952 int base_t = b &
MSQ_T ;
953 int base_p = b &
MSQ_P ;
954 b = base_p | base_t |
R_LEGP ;
959 assert(tb->get_etat() == ETATQCQ) ;
962 int nr = (tb->dim).dim[0] ;
963 int nt = (tb->dim).dim[1] ;
964 int np = (tb->dim).dim[2] ;
968 double* xo =
new double[(tb->dim).taille] ;
971 for (
int i=0; i<(tb->dim).taille; i++) {
980 int borne_phi = np + 1 ;
981 if (np == 1) borne_phi = 1 ;
983 for (
int k=0 ; k< borne_phi ; k++)
991 for (
int j=0 ; j<nt ; j++) {
997 if (nr > 1) xco[nr-2] = double(4*nr - 7) * som ;
998 for (
int i = nr-3 ; i >= 0 ; i-- ) {
1000 xco[i] = double(4*i+1) * som ;
1014 int base_t = b &
MSQ_T ;
1015 int base_p = b &
MSQ_P ;
1016 b = base_p | base_t |
R_LEGP ;
1021void _dsdx_r_jaco02(Tbl *tb,
int & )
1025 if (tb->get_etat() == ETATZERO) {
1030 assert(tb->get_etat() == ETATQCQ) ;
1033 int nr = (tb->dim).dim[0] ;
1034 int nt = (tb->dim).dim[1] ;
1035 int np = (tb->dim).dim[2] ;
1039 double* xo =
new double[(tb->dim).taille] ;
1042 for (
int i=0; i<(tb->dim).taille; i++) {
1047 double* xi = tb->t ;
1051 int borne_phi = np + 1 ;
1052 if (np == 1) borne_phi = 1 ;
1054 for (
int k=0 ; k< borne_phi ; k++)
1061 for (
int j=0 ; j<nt ; j++) {
1066 for (
int i = 0 ; i < nr-1 ; i++ ) {
1069 for (
int m = i+1 ; m < nr ; m++ ) {
1070 int signe = ((m-i)%2 == 0 ? 1 : -1) ;
1071 som += (1-signe*(i+1)*(i+2)/double((m+1)*(m+2)))* xci[m] ;
1073 xco[i] = (i+1.5)*som ;
#define R_LEGP
base de Legendre paire (rare) seulement
#define R_LEGI
base de Legendre impaire (rare) seulement
#define R_CHEBI
base de Cheb. impaire (rare) seulement
#define R_CHEBPIM_I
Cheb. pair-impair suivant m, impair pour m=0.
#define R_CHEBPI_I
Cheb. pair-impair suivant l impair pour l=0.
#define R_CHEBPIM_P
Cheb. pair-impair suivant m, pair pour m=0.
#define MSQ_T
Extraction de l'info sur Theta.
#define R_CHEBP
base de Cheb. paire (rare) seulement
#define MSQ_P
Extraction de l'info sur Phi.
#define R_CHEBPI_P
Cheb. pair-impair suivant l pair pour l=0.