Question de c/c++

Top Page

Reply to this message
Author: Patrick Dupre
Date:  
To: guilde
Subject: Question de c/c++
Bonsoir,

Une question que m'echappe totalement.
Peut-etre pour Edgar !

Dans la routine suivante tout se passe bien SAUF que j'ai des fuites memoire que je
parviens pas a controller.

Cette function est appelee par une function d'integration de GSL.
La function call_ode_BAP_2 appelle une stucture de numerical recipes III pour
resoudre un systeme d'equations.
Tout se passe "normalement" si je fais
param_doublet.Rabi_0 = 1e-8 ; // par exemple.
Mais si j'affecte la variable, le calcule est correct (mais pas si je fais = 1e-8 evidemment).
Si j'interprete correctement ce que je vois, a partir du moment ou
j'affecte une variable qui va etre utilisee par cal_ode_BAP_2, il y a une duplication a chaque appel de
la memoire de calcul et cela diverge rapidement.
Si la variable est une constante, soit il n'y a pas d'allocationb intempestive, soit
la desallocation se fait correctement.

Lorsque j'ai une fuite
valgrind me signale

==83464== 6,291,648 (192 direct, 6,291,456 indirect) bytes in 6 blocks are definitely lost in loss record 47 of 47
==83464==    at 0x4843866: malloc (vg_replace_malloc.c:446)
==83464==    by 0x4C9119A: call_ode_BAP_2 (in /home/pdupre/mylib/libODE_BAP_2.so.1.0)
==83464==    by 0x4C915B7: ode_BAP_impact_2 (in /home/pdupre/mylib/libODE_BAP_2.so.1.0)
==83464==    by 0x4A31973: gsl_integration_cquad (cquad.c:236)
==83464==    by 0x42CA23: Impact_integration_ode_BAP_2 (in /home/pdupre/Spectroscopy/Dressed/Density_Matrix/Density_matrix)
==83464==    by 0x403B93: main (in /home/pdupre/Spectroscopy/Dressed/Density_Matrix/Density_matrix)


LEAK SUMMARY:
==83464==    definitely lost: 576 bytes in 18 blocks
==83464==    indirectly lost: 18,087,936 bytes in 69 blocks
==83464==      possibly lost: 786,432 bytes in 3 blocks
==83464==    still reachable: 2,489,432 bytes in 47 blocks
==83464==         suppressed: 0 bytes in 0 blocks
==83464== 
==83464== ERROR SUMMARY: 5 errors from 5 contexts (suppressed: 0 from 0)


Je ne vois pas comment forcer la desallocation qui devrait etre automatique.
On dirait que c'est param_doublet qui n'est pas libere (mais c'est etrange)
Est-ce qu'il y a un outil qui pourrait me le confirmer ?



double ode_BAP_impact_2 (const double impact, const cont_impact_struct *const param_int) {

BAP_struct_I param_doublet ;
memmove (&param_doublet, param_int -> param, sizeof (BAP_struct_I)) ;
const double tmp = param_int -> Rabi_0 * exp (-sqr (impact / param_int -> waist)) ;
param_doublet.Rabi_0 = tmp ; // param_int -> Rabi_0 * exp (-sqr (impact / param_int -> waist)) ;

const Thr_level_rho_struct Rho = call_ode_BAP_2 (&param_doublet, param_int -> tolerance) ;

.....
Les 3 lignes suivantes n'ont pas d'importance.
const double fact_mult = exp (-sqr (impact / param_int -> waist)) ;
if (param_int -> type_out == '4') return Rho.rho_01r * fact_mult ;
if (param_int -> type_out == '5') return Rho.rho_01i * fact_mult ;
}

===========================================================================
 Patrick DUPRÉ                                 | | email: pdupre@???
===========================================================================