Aller au contenu

Mathc initiation/Fichiers h : c50fa

Un livre de Wikilivres.


Installer ce fichier dans votre répertoire de travail.

x_cylkrz.h
/* --------------------------------- */
/* save as x_cylkrz.h                */
/* --------------------------------- */
double cylindrical_k_dkdrdz(
double (*P_f)(double r, double k, double z),

double (*Pk0)(double r, double z),
double (*Pk1)(double r, double z),
   int   nk,

double r,

double z
)
{
double k = 0;

   int i = 0;
double m = 0.;
double M = 0.;

 for(i = 0; i <= nk; i++)
 {
       if(i ==0 || i== nk){m = 1.;}
  else if(fmod(i,2) == 0 ){m = 2.;}
  else                    {m = 4.;}
  
  k = ((*Pk0)(r,z)) + i*(((*Pk1)(r,z))-((*Pk0)(r,z)))/nk;
  
  M += m * (*P_f)( r, k, z) * r;
 }

  return( ((((*Pk1)(r,z)) -((*Pk0)(r,z)))*M) / (3*nk) );
}
/* --------------------------------- */
double cylindrical_r_dkdrdz(
double (*P_f)(double r, double k, double z),
   
double (*Pk0)(double r, double z),
double (*Pk1)(double r, double z),
   int   nk,

double (*Pr0)(double z),
double (*Pr1)(double z),
   int   nr,

double z
)
{
   int i = 0;
double m = 0.;
double M = 0.;

 for(i = 0; i <= nr; i++)
 {
       if(i ==0 || i== nr){m = 1.;}
  else if(fmod(i,2) ==  0){m = 2.;}
  else                    {m = 4.;}

  M += m * cylindrical_k_dkdrdz( 
                             (*P_f),                           
                             (*Pk0),(*Pk1),nk,                                
                           (((*Pr0)(z))+i*(((*Pr1)(z))-((*Pr0)(z)))/nr),
                                z);
 }

 return( ((((*Pr1)(z)) -((*Pr0)(z)))*M) / (3*nr) );
}
/* --------------------------------- */
double cylindrical_dkdrdz(
double (*P_f)(double r, double k, double z),
   
double (*Pk0)(double r, double z),
double (*Pk1)(double r, double z),
   int   nk,
   
double (*Pr0)(double r),
double (*Pr1)(double r),
   int   nr,

double z0,
double z1,
   int nz
)
{
   int i = 0;
double m = 0.;
double M = 0.;

 for(i = 0; i <= nz; i++)
 {
       if(i ==0 || i== nz){m = 1.;}
  else if(fmod(i,2) ==  0){m = 2.;}
  else                    {m = 4.;}

  M += m * cylindrical_r_dkdrdz(
                             (*P_f),                               
                             (*Pk0),(*Pk1),nk,                             
                             (*Pr0),(*Pr1),nr,  
                             (z0+i*(z1-z0)/nz));
 }

  return( ((z1 -z0)*M) / (3*nz) );
}
/* --------------------------------- */
/* --------------------------------- */