[Rd] gfortran optimization problems
    Dave Roberts 
    droberts at montana.edu
       
    Sat Oct 25 00:53:39 CEST 2008
    
    
  
Colleagues,
I have a routine in package labdsv that calls a FORTRAN subroutine. 
Recently, I was informed that it sometimes gives different results on a 
PC and Mac, and that the PC version is clearly wrong.  I tested it on 
linux (because I don't have a PC), and I get the same (incorrect) 
behavior as the PC.
Simply by inserting debug WRITE statements in the FORTRAN I would get 
different, and correct, results, so I assumed it was an optimization 
error.
So,
1) R CMD SHLIB duleg.f    does not work, and produces bogus code
however,
2) gfortran -c alt_duleg.f
    gcc -O -std=gnu99 -shared -L/usr/local/lib -o alt_duleg.so
         alt_duleg.o -lgfortran -lm -lgcc_s
does work (note the -O low optimization).  Otherwise the gcc command is 
identical to the one produced by R CMD SHLIB.
Has anyone else seen this?  Is there a simple way to have my package 
enforce no optimization so others don't struggle with this?  As far as I 
know the same code worked under g77.
Thanks, Dave Roberts
-- 
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
David W. Roberts                                     office 406-994-4548
Professor and Head                                      FAX 406-994-3190
Department of Ecology                         email droberts at montana.edu
Montana State University
Bozeman, MT 59717-3460
    
    
More information about the R-devel
mailing list