Selon un vieille lame sobre predictive commoning
on peut dire que
for(int i=0; i < n; i++)
f[i]= a[i]*exp(i+1)+a[i+1]*exp(i+2);
est équivalent à
double p0=a[0]*exp(1);
int i;
for (i=0; i < n-n%2; i+=2)
{
double p1=a[i+1]*exp(i+2);
f[i] = p0+p1;
p0=a[i+2]*exp(i+3);
f[i+1] = p1+p0;
}
for (; i < n; i++)
f[i] = a[i]*exp(i+1)+a[i+1]*exp(i+2);
sauf que le second code est plus optimisé ( Point de repère ).
J'ai testé gcc
avec le niveau d'optimisation le plus élevé -O3
et pourtant je ne vois pas gcc
en effectuant cette optimisation.
(Encore pire ces deux exemples A y B )
Comment puis-je forcer gcc
pour effectuer une telle optimisation ?