IA039 Měření času, profilování a měření výkonu Měření času výpočtu ■ Optimalizace není možní bez znalosti, co optimalizovat ■ Potřebujeme znát údaje o běhu programu ■ Čas výpočtu celého programu: příkazy time a timex ■ Čas výpočtu částí programů: profilování ■ Srovnání systémů: benchmarking IA039 2 Jaro 2008 Příkaz time ■ User time ■ Čas procesoru strávený uživatelskými procesy ■ System time ■ Čas procesoru strávený obsluhou funkcí jádra ■ Elapsed time ■ Celkový čas výpočtu CPU time = user time + system time IA039 3 Jaro 2008 Příkaz time - další údaje ■ Dostupné pro time v prostředí C shellu ■ Sdílený pamětový prostor ■ Privátní (unshared) pamětový prostor ■ Počet block input operací ■ Počet block output operací ■ Počet page faultů ■ Počet swapů IA039 4 Jaro 2008 Příkaz timex (System V) ■ Údaje o čase ■ real, user a system time ■ Další údaje ■ Mean memory size ■ Kcore-minutes ■ Přenesené bloky a znaky ■ Využívá sar accounting IA039 5 Příklady - time time netscape http://www.pgroup.com/ppro_cc_desc.html 7.3u 3.1s 1:31 11% 0+0k 272+36io 125pf+0w IA039 6 Jaro 2008 Příklady - timex timex -opkmt netscape http://www.pgroup.com/ppro_cc_desc.html real 2:33.61 user 9.20 sys 3.50 START AFT: Mon May 4 10:21:19 1998 END BEFOR: Mon May 4 10:23:53 1998 COMMAND START END REAL NAME USER TTYNAME TIME TIME (SECS) netstat ludek pts/5 10:21:26 10:21:27 1.26 netscape ludek pts/5 10:21:19 10:23:52 153.60 CPU (SECS) CHARS BLOCKS MEAN KCORE SYS USER TRNSFD READ SIZE(K) MIN 0.09 0.85 577536 32 104.34 1.63 3.40 8.34 7045120 486 1144.37 223.91 CHARS TRNSFD = 7622656 BLOCKS READ =518 IA039 7 Jaro 2008 Profiling ■ Snaha získat informace o částech programu ■ Doba strávená v'jednotlivých blocích ■ Doba strávená jednotlivými příkazy ■ Počet opakování bloků/příkazů ■ Primární pozornost zaměřena na procedury ■ Profil: graf ■ Osa X: jednotlivé procedury ■ Osa Y: Doba výpočtu IA039 8 Typy profilů ■ Ostrý profil ■ Píky odpovídají dominujícícm procedurám ■ Numerické aplikace, technické výpočty s maticemi atd. ■ „Snadno" optimalizovatelné ■ Plochý profil ■ Program tráví čas rovnoměrně ve všech procedurách ■ Zpravidla databáze, informační systémy, systémové programy ■ Obtížně optimalizovatelné ■ Amdahlovo pravidlo platí i zde IA039 9 Jaro 2008 Profilery ■ Nástroje pro tvorbu profilů ■ Samozřejmě možné i „ručně" ■ Procedurově orientované ■ prof ■ gprof ■ Blokově (řádkově) orientované ■ pixie ■ tcov ■ Iprof IA039 10 Jaro 2008 Použití profilerů ■ Dvě fáze: ■ Instrumentovany běh programu (s nebo bez opětného překladu) ■ Vlastní zpráva o výsledcích (report) ■ Přístup ke zdrojovému kódu ■ Znalost struktury programu IA039 11 Jaro 2008 Procedurově orientované profilery ■ Typický představitel: prof ■ Instrumentace ■ Nový překlad programu ■ Zpravidla dostupný přes přepínač překladače -p ■ Výpočet ■ Instrumentovaný program vytváří záznam o výpočtu ■ Soubor mon.out ■ Vytvoření zprávy ■ Vlastní běh programu prof IA039 12 Jaro 2008 prof - další informace ■ Okročilé procesory a operační systémy nepotřebují zvláštní překlad ■ Např. SGI IRIX 6.x (procesory MIPS R1X000) ■ Instrumentace za běhu - SpeedShop * Program spouštěn příkazem ssrun -exptype * Výpočet generuje SOUbor .. * exptype definuje typ profilu IA039 13 Jaro 2008 SpeedShop - typy profilů usertime - uživatelský čas [f]pcsamp[x] - vzorkování ideal (pixie) - blokový profiler fpe - pohyblivá řádová čárka prof_hwc - hardwarové čitače f gLhwc, [f]cy_hwc, [f]ic_hwc, [f]isc_hwc, [f]dc_hwc, [f]dsc_hwc, [f]tlb_hwc, [f]gfp_hwc IA039 14 Jaro 2008 gprof ■ Poskytuje call graf ■ Kdo koho volá ■ Počty volání procedur ■ Kumulované časy výpočtu větví IA039 15 Jaro 2008 Přesnost měření ■ Měření času ■ Absolutní čas vstupu aVystupu procedury * Vnořené procedury * Krátké procedury ■ Sběr hodnoty čitače instrukcí v pravidelných intervalech * Přesnost výsledku závislá na vzorkování (sampling interval) IA039 16 Jaro 2008 Blokově orientované profilery ■ Poskytují informace o průchodech základními bloky ■ tcov a I prof ■ Počet průchodů každým příkazem (řádkem) ■ pixie ■ Počet cyklů procesorů strávený v každém příkazu IA039 17 Jaro 2008 static void foo(), bar(), baz(); mainO { int 1; for (1=0; 1 <1000; 1++) { if ( 1 == 2*(l/2) ) foo(); bar(); baz(); } } IA039 Príklad 13 void foo() 14 { int j; 15 for (j=0; j<200; j++); 16 } 17 void bar() 18 { int j; 19 for (j=0; j<200; j++); 20 } 21 void baz() 22 { int j; 23 for (j=0; j<300; j++); 24 } 18 Jaro 2008 SpeedShop - usertime usertime: index °/0Samples self descendents total name [1] 100.0°/. 0.00 0.03 1 main [2] 100.0°/. 0.03 0.00 1 bar IA039 19 Jaro 2008 SpeedShop - pcsamp: samples time(°/o) cum time(Z) procedure 2 0.02s( 50.0) 1 0.01s( 25.0) 1 0.01s( 25.0) 0.02s( 50.0) foo 0.03s( 75.0) bar 0.04s(100.0) baz fpcsamp samples 18 12 12 time(Z) cum time(%) procedure 0.02s( 41.9) 0.02s( 41.9) baz O.OlsC 27.9) 0.03s( 69.8) bar 0.01s( 27.9) 0.04s( 97.7) foo IA039 20 vzorkování Jaro 2008 SpeedShop ideal: cycles (°/o) cum % sees instrns 3918000(49.63) 49.63 0.03 2111000 2618000(33.16) 82.80 0.02 1411000 1309000(16.58) 99.38 0.01 705500 47024( 0.60) 99.98 0.00 25017 - blokový přístup alls procedure 1000 baz 1000 bar 500 foo 1 main IA039 21 SpeedShop - blokový prístup II ideal -h: cycles (%) cum % times line procedure 3907858(49.50%) 49.50% 300000 23 baz 2607858(33.04%) 82.54% 200000 19 bar 1303930(16.52%) 99.06% 100000 15 foo 14000( 0.18%) 99.24% 1000 6 main 13009( 0.16%) 99.40% 1000 5 main 8000 ( 0.10%) 99.50% 1000 9 main 8000 ( 0.10%) 99.60% 1000 8 main 7000 ( 0.09%) 99.69% 1000 24 baz 7000 ( 0.09%) 99.78% 1000 20 bar 4000 ( 0.05%) 99.83% 500 7 main 3500 ( 0.04%) 99.88% 500 16 foo 3142 ( 0.04%) 99.92% 1000 18 bar 3142( 0.04%) 99.96% 1000 22 baz 1570 ( 0.02%) 99.98% 500 14 foo IA039 22 Jaro 2008 for (1=0; 1 <1000; 1++) { if ( 1 == 2*(1/2) ) foo(); bar(); baz(); void foo() 500 -> for (j=0; j<200; j++); void bar() 1000 -> for (j=0; j<200; j++); void baz() 1000 -> for (j=0; i<300; i++); 1 -> 1000 -> 500 -> 1000 -> tcov 23 Jaro 2008 tcov - pokračování Top 10 Blocks Line Count 6 1000 8 1000 19 1000 23 1000 7 500 15 500 5 1 7 Basic blocks in this file 7 Basic blocks executed 100.00 Percent of the file executed 5001 Total basic block executions 714.43 Average executions per basic block IA039 24 Zjištování výkonu - benchmarking ■ Snaha o porovnání systémů ■ Hardware i software společně ■ Neexistuje žádné „zázračné" řešení ■ Základní přístupy ■ Průmyslové („profesionální") benchmarky * Porovnatelnost, nezávislost na výrobcích ■ „Privátní" benchmarky * Konkrétní (specifické) požadavky IA039 25 Mysteriózní MIPS a MFLOPS ■ Srovnání na základě počtu instrukcích vykonaných za sekundu ■ MIPS - milion celočíselných instrukcí za sekundu ■ MFLOPS - milion operací s pohyblivou řádovou čárkou za sekundu ■ Problémy ■ Jaké instrukce? ■ V jaké posloupnosti? ■ Umělé, nevypovídající IA039 26 Jaro 2008 Celočíslené benchmarky ■ VAX MIPS ■ Dhrystones IA039 27 Jaro 2008 Benchmarky s pohyblivou řádovou čárkou ■ Whetstone (umělý mix, skalární) ■ Linpack (daxpy, vektorizace) ■ 100*100 ■ 1000*1000 IA039 28 Jaro 2008 SPEC benchmarks ■ Nezávislá organizace ■ Standard Performace Evaluation Corporation ■ Standardizované benchmarky pro různé architektury ■ Vychází z tzv. kernel kódů ■ Celý nebo část existujícího programu ■ Dostupné ve zdrojovém kódů * Je možno „doladit" IA039 29 Jaro 2008 SPEC skupiny ■ Open Systems Group (OSG) ■ High Performance Group (HPG ■ Graphics Performance Characterization Group (GPC) IA039 30 Jaro 2008 SPEC OSG podskupiny ■ CPU ■ SPECmarks a CPU benchmarks ■ JAVA ■ JVM98, JBB2005, Java client a server benchmarky ■ MAIL ■ SPECmail2001 - SFS ■ Systémy souborů (SFS97) ■ WEB ■ WEB99, WEB99 SSL, WEB2005 IA039 31 Jaro 2008 CPU2000 ■ Aktuální CPU benchmark ■ Dělení ■ CINT2000 - celočíselné výpočty ■ CFP2000 - výpočty s pohyblivou řádovou čárkou IA039 32 Jaro 2008 CINT2000 Jednotlivé součásti 164.gzip Compression 175.vpr FPGA Circuit Placement and Routing 176.gcc C Programming Language Compiler 181.mcf Combinatorial Optimization 186.crafty Game Playing: Chess 197.parser Word Processing 252.eon Computer Visualization 253.perlbmk PERL Programming Language 254.gap Group Theory, Interpreter 255.vortex Object-oriented Database 256.bzip2 Compression 300.twolf Place and Route Simulator IA039 33 Jaro 2008 CFP2000 Jednotlivé součásti 168.wupwise 171.swim 172.mgrid 173.applu 177.mesa 178.galgel 179.art 183.equake 187.facerec 188.ammp 189.lucas 191.fma3d 200.sixtrack 301.apsi Physics / Quantum Chromodynamics Shallow Water Modeling Multi-grid Solver: 3D Potential Field Parabolic / Elliptic Partial Differential Equations 3-D Graphics Library Computational Fluid Dynamics Image Recognition / Neural Networks Seismic Wave Propagation Simulation Image Processing: Face Recognition Computational Chemistry Number Theory / Primality Testing Finite-element Crash Simulation High Energy Nuclear Physics Accelerator Design Meteorology: Pollutant Distribution IA039 34 Jaro 2008 Transakční benchmarky ■ Výkon databází ■ TPC-A * Testuje interakci s ATM (6 požadavků za minutu) * 1 TPS znamená, že 10 ATM současně vydá požadavek a výsledek dostane do 2 s (s 90% účinností) ■ TPC-B * Jako TPC-A, ale testuje se přímo, ne přes (pomalou) sít ■ ■ TPC-C * Komplexní, transakce jsou objednávky, platby, dotazy s jistým procentem záměrných chyb vyžadujících automatickou korekci IA039 35 Jaro 2008 aY ■ netperf ■ iperf ■ End to end měření IA039 vé benchmarky 36 Jaro 2008 Vlastní benchmarky ■ Sepcifické (konkrétní) požadavky ■ Důležité parametry: ■ Co testovat ■ Jak dlouho testovat ■ Požadavky na velikost paměti ■ Typy benchmarků ■ Jednoduchý proud (opakování) ■ Propustnost (benchmark stone wall) IA039 37 Jaro 2008 Kontroly ■ Nezbytná součást používání benchmarku ■ Měříme opravdu to, co chceme? ■ Možné příčiny obvlivnění ■ Použitá optimalizace ■ Velikost paměti ■ Přítomnost jinéých procesů ■ Co je třeba explicitně kontrolovat ■ CPU čas a čas nástěných hodin ■ Výsledky! ■ Srovnání se „známým" standardem IA039 38 Jaro 2008