abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 21:11 | Nová verze

    Byl vydán Debian 13 s kódovým názvem Trixie. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 1
    včera 15:55 | Zajímavý software

    WLED je open-source firmware pro ESP8266/ESP32, který umožňuje Wi-Fi ovládání adresovatelných LED pásků se stovkami efektů, synchronizací, audioreaktivním módem a Home-Assistant integrací. Je založen na Arduino frameworku.

    Indiánský lotr | Komentářů: 0
    8.8. 15:33 | Nová verze

    Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána v nové verzi 2025.8.

    Ladislav Hagara | Komentářů: 4
    8.8. 14:22 | IT novinky

    Herní studio Hangar 13 vydalo novou Mafii. Mafia: Domovina je zasazena do krutého sicilského podsvětí na začátku 20. století. Na ProtonDB je zatím bez záznamu.

    Ladislav Hagara | Komentářů: 1
    8.8. 13:22 | IT novinky

    Operátor O2 má opět problémy. Jako omluvu za pondělní zhoršenou dostupnost služeb dal všem zákazníkům poukaz v hodnotě 300 Kč na nákup telefonu nebo příslušenství.

    Ladislav Hagara | Komentářů: 8
    8.8. 05:55 | IT novinky

    Společnost OpenAI představila GPT-5 (YouTube).

    Ladislav Hagara | Komentářů: 2
    8.8. 05:00 | Nová verze

    Byla vydána (𝕏) červencová aktualizace aneb nová verze 1.103 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.103 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    7.8. 17:33 | IT novinky

    Americký prezident Donald Trump vyzval nového generálního ředitele firmy na výrobu čipů Intel, aby odstoupil. Prezident to zdůvodnil vazbami nového šéfa Lip-Bu Tana na čínské firmy.

    Ladislav Hagara | Komentářů: 10
    7.8. 16:55 | Nová verze

    Bylo vydáno Ubuntu 24.04.3 LTS, tj. třetí opravné vydání Ubuntu 24.04 LTS s kódovým názvem Noble Numbat. Přehled novinek a oprav na Discourse.

    Ladislav Hagara | Komentářů: 0
    7.8. 16:44 | Nová verze

    Byla vydána verze 1.89.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (46%)
     (20%)
     (4%)
     (5%)
     (3%)
     (1%)
     (1%)
     (19%)
    Celkem 318 hlasů
     Komentářů: 23, poslední 4.8. 13:01
    Rozcestník

    Dotaz: strojove epsilon a 32bit OS vs. 64bit OS

    7.3.2006 13:10 oxymoron
    strojove epsilon a 32bit OS vs. 64bit OS
    Přečteno: 724×
    zaujimalo by ma cim to je ze ked skomilujem a spustim toto :
    #include <float.h>
    #include <stdio.h>
    
    int main(int argc, char* argv[])
    {
    
    
            double eps=1.0;
            while(1) {
                    eps=eps/2.0;
                    if( (1.0 + (eps/2.0)) == 1.0 ) break;
            }
            printf("vypocitane eps= %.67f\n",eps);
            printf("konstanta DBL = %.67f\n",DBL_EPSILON);
            
            return 0;
    }
    
    pod gentoo 32bit vysledok je :
    32bit Linux OS
    0.00000000000000000010842021724855044340074528008699417114257812500     -vypocitane eps
    0.00000000000000022204460492503130808472633361816406250000000000000     -konstanta DBL_EPSILON
    
    a pod gentoo 64bit vysledok je :
    0.00000000000000022204460492503130808472633361816406250000000000000     -vypocitane eps
    0.00000000000000022204460492503130808472633361816406250000000000000     -konstanta DBL_EPSILON
    
    nemalo by byt pod 64bit strojove epsilon mensie ako pod 32bit?

    Odpovědi

    7.3.2006 16:21 Lubos
    Rozbalit Rozbalit vše Re: strojove epsilon a 32bit OS vs. 64bit OS
    Proc je tam ten rozdil nereknu, ale jde o double precision floating point operaci, na delce integer registru cpu tim padem kulovy zalezi. Takze jde o implementaci knihoven pro double, tudiz ask your c libraries author :)
    7.3.2006 16:26 Lubos
    Rozbalit Rozbalit vše Re: strojove epsilon a 32bit OS vs. 64bit OS
    Mozna bych to radeji zkusil zapsat takto:
    
    double eps=1.0;
    double jedna=1.0;
    double dva=2.0;
    while(1)
     {
      eps=eps/dva;
      if( (jedna + (eps/dva)) == jedna ) break;
     }
    
    Schvalne, co to spocita takhle.
    7.3.2006 19:04 oxymoron
    Rozbalit Rozbalit vše Re: strojove epsilon a 32bit OS vs. 64bit OS
    je to to iste :)
    7.3.2006 21:57 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: strojove epsilon a 32bit OS vs. 64bit OS
    Zkuste se podívat na výsledný kód (použijte -S). Zatímco 32-bitová verze používá registry koprocesoru a nechává koprocesor provést i porovnání, 64-bitová pracuje s registry %xmm0 a spol. Problém je pravděpodobně v tom, že koprocesor interně pracuje s vyšší přesností, než jakou následně prezentuje ven (pokud si dobře vzpomínám, interně koprocesor pracuje s 96-bitovými hodnotami, zatímco typ long double je pouze 64-bitový). Tomu by nasvědčovala i skutečnost, že pokud si výraz (1.0 + (eps/2.0)) necháte uložit do proměnné a tu porovnáte s jedničkou, vyjde vám to na obou platformách stejně.

    Aneb další příklad na známý poznatek, že porovnávat reálná čísla na rovnost znamená koledovat si o naprosto nedeterministické chování programu.

    7.3.2006 22:02 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: strojove epsilon a 32bit OS vs. 64bit OS
    Oprava, mělo tam být "…zatímco typ double je pouze 64-bitový", což je pravda (pro gcc 4.0.2) ve 32-bitové i 64-bitové verzi. Typ long double je různý: s -m32 96-bitový a s -m64 128-bitový.

    Založit nové vláknoNahoru

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

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.