Portál AbcLinuxu, 8. května 2025 22:48

Dotaz: Fortran - rozdilny beh programu v debug a optimalizovanem modu

masomlejn avatar 25.3.2009 14:14 masomlejn | skóre: 16
Fortran - rozdilny beh programu v debug a optimalizovanem modu
Přečteno: 236×
Odpovědět | Admin

Zdravím,
tento dotaz je primárně směřován na ženy/muže orientující se v problematice programovaní  a kompilace ve fortranu ale ani ostatní se nemusí cítit odstrčeni.

Popis problému:
Program na řešení soustavy parabolických PDE (trubkový reaktor s axiální disperzí), napsaný ve fortran90 (z důvodu dynamické alokace polí) a FORTRAN77 (rutiny na řešeni PDE), byl zkompilován Intel Fortran Compiler For Linux verze 10.1 20080312. Pokud je program zkompilován v debug modu (s parametry -g -debug all) běží vše v pořádku, resp. je dosažen smysluplný výsledek*. Pokud ale je použita při kompilaci optimalizace (-O2 a výše) solver DDASPK, který má za úkol numerické řešení prostorových derivací, se ukončí z důvodu neschopnosti vypočíst YPRIME (první derivace funkce y - definované uživatelem).

Nejde zde ani tak o problém fyzikální (věřím že fyzikální podstata problému je naprogramována správně), ale spíše programátorský. Jak může obecně optimalizace zdrojového kódu kompilátorem ovlivnit numerickou stabilitu výpočtu? Dočetl jsem se, že během optimalizace dochází k vektorizaci vybraných smyček-cyklů není zde podstata výše uvedeného problému? Setkali jste se už někdy s rozdílným chováním programu zkompilovaného v debug modu a optimalizovaného (jedno v jakém programovacím jazyku)?

Dík za Vaše zamyšlení nad problémem,
Milan

* Smysluplným výsledkem je myšlen ten, který splňuje zadání úlohy a poskytuje reálné (fyzikální) hodnoty, jako třeba kladné absolutní teploty, respektuje zákon zachování hybnosti, hmoty a energie.

Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

masomlejn avatar 25.3.2009 14:32 masomlejn | skóre: 16
Rozbalit Rozbalit vše Re: Fortran - rozdilny beh programu v debug a optimalizovanem modu
Odpovědět | | Sbalit | Link | Blokovat | Admin

HA! Tak formulace problému zde nafóru mi pomohla najít vhodnou formu dotazu pro google!:

computation result differs with Optimize/Debug versions

A výsledky se začaly hrnout. Třeba hned jeden z prvních odkazů:

http://www.flounder.com/debug_release.htm

se zdá být nanejvýš relevantní.

masomlejn avatar 25.3.2009 15:37 masomlejn | skóre: 16
Rozbalit Rozbalit vše Re: Fortran - rozdilny beh programu v debug a optimalizovanem modu
Odpovědět | | Sbalit | Link | Blokovat | Admin

No budu pokračovat v samomluvě. Našel jsem to co je nejspíše příčinou mého problému. Níže uvedený odkaz obsahuje sice obecnou přednášku, ale na stránce 7 je přesně popsáno, co způsobuje "horlivá" optimalizace za bordel.

www.cs.berkeley.edu/~wkahan/Mind1ess.pdf

 

 

 

25.3.2009 17:51 l4m4
Rozbalit Rozbalit vše Re: Fortran - rozdilny beh programu v debug a optimalizovanem modu
To nevysvětluje nic, pokud jsi explicitně nezapnul nebezpečné optimalizace, což by -O2 dělat nemělo. Jinak musí kompilátor produkovat kód, který odpovídá IEEE, a pokud to nedělá, je to bug. Nezbývá než vypisovat mezvýsledky, dokud se nedopracuješ k tomu, kde se výpočty začnou lišit -- a je-li kód správně, stěžovat si. Taky tam ale můžeš mít kód s nedefinovanou sémantikou, používat neinicializované hodnoty a pod...
masomlejn avatar 25.3.2009 19:17 masomlejn | skóre: 16
Rozbalit Rozbalit vše Re: Fortran - rozdilny beh programu v debug a optimalizovanem modu

Dík za napad s paralelním výpisem z neoptimalizovaného  a optimalizovaného programu a sledovat kde dochází ke změně. Jinak optimalizace začne produkovat jiné výsledky když použiju -O2. Když přidám -fltconsitency tak problém zmizí.

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.