Portál AbcLinuxu, 30. dubna 2025 17:25
Prochazi se velike pole 1.4M s tuple prvky nad kterymi jsou provadene operace odecitani a testovani hodnoty. Meri se cas, za jak dlouho se danne pole projde cele.No, pole, ikdyby ten seznam nakonec byl pole, tak v něm budou stejně jen odkazy na nějaké ty tuple a ty už móžó bét rozházené po paměti divně, no ni? Zdá se mi, že totok závisí dosti na implementaci pythóna, tož těžko věřit, že to něco měřit. Ale musím dodat, že pythonu vůbec nerozumím. A docela by mě zajímalo třeba, jestli interpret vůbec někdy třeba počítá dummy (což vypadá jako lokální proměnná ne, která se nikde nepoužívá) nebo místo toho udělá jen "continue" (jako né že by to mělo vliv na výslednej ča, kvůli tomu sa neptám).
0.764378070831 real 0m15.569s user 0m15.365s sys 0m0.196s model name : Intel(R) Xeon(R) CPU E5335 @ 2.00GHz
1.11453294754 real 0m20.534s user 0m20.241s sys 0m0.256sIntel Xeon 3050 (2.13 GHz, 2x 1 MB cache)
0.810898065567 real 0m14.930s user 0m14.753s sys 0m0.168sIntel Pentium 4 HT (2.4 GHz, 512 kB cache)
1.60360789299 real 0m30.278s user 0m29.958s sys 0m0.188s... vsechno na Gentoo
Core 2 Duo T7300 2.0 GHz
0.79435300827 real 0m14.214s user 0m13.957s sys 0m0.144s
Celeron 220 1.2 GHz
1.42196798325 real 0m26.569s user 0m26.226s sys 0m0.296s
Oboje OpenSUSE 10.3 64-bit. Ten Celer příjemně překvapil.
Ještě doplním PC ve škole:
Pentium 4 2.8 HT, 512 KiB cache, Fedora 7 32 bit, Python 2.5
1.72318410873 real 0m30.870s user 0m30.446s sys 0m0.420s
$ time python a.py 0.832358837128 real 0m13.999s user 0m13.837s sys 0m0.164s
1.86271500587 real 0m24.353s user 0m24.131s sys 0m0.173sAneb, kde je chyba?
0.950555086136 real 0m15.760s user 0m15.554s sys 0m0.127sAMD Athlon64 4000+, 1MB cache, 2.4GHz, Debian Etch 64bit.
1.45540785789 real 0m26.071s user 0m25.718s sys 0m0.208s model name : Intel(R) Pentium(R) M processor 1400MHz
0.889379024506 real 0m15.625s user 0m15.377s sys 0m0.132s 0.918316841125 real 0m16.262s user 0m15.889s sys 0m0.216s 0.884744167328 real 0m15.549s user 0m15.257s sys 0m0.208s
model name : Dual-Core AMD Opteron(tm) Processor 2212 cpu MHz : 1995.064 cache size : 1024 KB 1.11980485916 real 0m18.377s user 0m18.089s sys 0m0.276s---------------------------------------------------
model name : Intel(R) Xeon(R) CPU 5110 @ 1.60GHz cpu MHz : 1600.098 cache size : 4096 KB 0.987221956253 real 0m17.045s user 0m16.705s sys 0m0.324s---------------------------------------------------
model name : Intel(R) Xeon(TM) CPU 3.00GHz cpu MHz : 3000.168 cache size : 2048 KB 1.11849689484 real 0m20.763s user 0m20.521s sys 0m0.232s
171.617203951 real 47m17.250s user 12m24.040s sys 2m5.370s(TurboSPARC 170MHz, Solaris 2.6, python 2.5.1)
0.908358097076 real 0m15.905s user 0m15.800s sys 0m0.070s
model name : Intel(R) Pentium(R) Dual CPU E2140 @ 1.60GHz stepping : 13 cpu MHz : 1999.908 cache size : 1024 KB
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.