Mathc initiation/Fichiers h : c50fa
Apparence
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) );
}
/* --------------------------------- */
/* --------------------------------- */