00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029 char cmp_asymptot_C[] = "$Header: /cvsroot/Lorene/C++/Source/Cmp/cmp_asymptot.C,v 1.3 2002/10/16 14:36:34 j_novak Exp $" ;
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054
00055
00056
00057
00058
00059 #include <math.h>
00060
00061
00062 #include "cmp.h"
00063
00064 Valeur** Cmp::asymptot(int n0, const int flag) const {
00065
00066 assert(n0 >= 0) ;
00067 const Mg3d& mg = *(mp->get_mg()) ;
00068 int nz = mg.get_nzone() ;
00069 int nzm1 = nz-1 ;
00070 assert(mg.get_type_r(nzm1) == UNSURR) ;
00071 int np = mg.get_np(nzm1) ;
00072 int nt = mg.get_nt(nzm1) ;
00073 int nr = mg.get_nr(nzm1) ;
00074 int nrm1 = nr-1 ;
00075
00076 Valeur** vu = new Valeur*[n0+1] ;
00077 for (int h=0; h<=n0; h++) {
00078 vu[h] = new Valeur(mg.get_angu()) ;
00079 }
00080
00081 Cmp uu = *this ;
00082
00083 int precis = 2 ;
00084
00085
00086
00087 for (int h=0; h<dzpuis; h++) {
00088
00089 vu[h]->set_etat_zero() ;
00090
00091 }
00092
00093
00094
00095 for (int h=dzpuis; h<=n0; h++) {
00096
00097
00098
00099 vu[h]->set_etat_c_qcq() ;
00100 vu[h]->c->set_etat_qcq() ;
00101 for (int l=0; l<nzm1; l++) {
00102 vu[h]->c->t[l]->set_etat_zero() ;
00103 }
00104 vu[h]->c->t[nzm1]->set_etat_qcq() ;
00105
00106 for (int k=0; k<np; k++) {
00107 for (int j=0; j<nt; j++) {
00108 vu[h]->set(nzm1, k, j, 0) = uu(nzm1, k, j, nrm1) ;
00109 }
00110 }
00111
00112 vu[h]->set_base( uu.va.base ) ;
00113
00114
00115
00116 if (flag != 0) {
00117 cout << "Term in 1/r^" << h << endl ;
00118 cout << "-------------" << endl ;
00119
00120 double ndec = 0 ;
00121 double vmin = (*vu[h])(nzm1, 0, 0, 0) ;
00122 double vmax = vmin ;
00123
00124 cout << " Values at the point (phi_k, theta_j) : " << endl ;
00125 cout.precision(precis) ;
00126 cout.setf(ios::showpoint) ;
00127 for (int k=0; k<np; k++) {
00128 cout << " k=" << k << " : " ;
00129 for (int j=0; j<nt; j++) {
00130 double xx = (*vu[h])(nzm1, k, j, 0) ;
00131 cout << " " << setw(precis) << xx ;
00132 ndec += fabs(xx) ;
00133 vmin = ( xx < vmin ) ? xx : vmin ;
00134 vmax = ( xx > vmax ) ? xx : vmax ;
00135 }
00136 cout << endl;
00137 }
00138 ndec /= np*nt ;
00139 cout << "Minimum value on S^2 : " << vmin << endl ;
00140 cout << "Maximum value on S^2 : " << vmax << endl ;
00141 cout << "L^1 norm on S^2 : " << ndec << endl ;
00142 }
00143
00144
00145 for (int k=0; k<np; k++) {
00146 for (int j=0; j<nt; j++) {
00147 double v_inf = (*vu[h])(nzm1, k, j, 0) ;
00148 for (int i=0; i<nr; i++) {
00149 uu.set(nzm1, k, j, i) -= v_inf ;
00150 }
00151 }
00152 }
00153
00154
00155
00156
00157 uu.mult_r_zec() ;
00158
00159 }
00160
00161 return vu ;
00162
00163 }