abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 01:00 | Nová verze Ladislav Hagara | Komentářů: 0
    včera 19:55 | IT novinky

    Intel na veletrhu Computex 2024 představil (YouTube) mimo jiné procesory Lunar Lake a Xeon 6.

    Ladislav Hagara | Komentářů: 0
    včera 13:44 | IT novinky

    Na blogu Raspberry Pi byl představen Raspberry Pi AI Kit určený vlastníkům Raspberry Pi 5, kteří na něm chtějí experimentovat se světem neuronových sítí, umělé inteligence a strojového učení. Jedná se o spolupráci se společností Hailo. Cena AI Kitu je 70 dolarů.

    Ladislav Hagara | Komentářů: 0
    včera 13:22 | Nová verze

    Byla vydána nová verze 14.1 svobodného unixového operačního systému FreeBSD. Podrobný přehled novinek v poznámkách k vydání.

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

    Společnost Kaspersky vydala svůj bezplatný Virus Removal Tool (KVRT) také pro Linux.

    Ladislav Hagara | Komentářů: 3
    včera 12:33 | Nová verze

    Grafický editor dokumentů LyX, založený na TeXu, byl vydán ve verzi 2.4.0 shrnující změny za šest let vývoje. Novinky zahrnují podporu Unicode jako výchozí, export do ePub či DocBook 5 a velké množství vylepšení uživatelského rozhraní a prvků editoru samotného (např. rovnic, tabulek, citací).

    Fluttershy, yay! | Komentářů: 0
    včera 12:00 | Nová verze

    Byla vydána (𝕏) nová verze 7.0 LTS open source monitorovacího systému Zabbix (Wikipedie). Přehled novinek v oznámení na webu, v poznámkách k vydání a v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 0
    včera 11:11 | Nová verze

    Organizace Apache Software Foundation (ASF) vydala verzi 22 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.

    Ladislav Hagara | Komentářů: 0
    3.6. 17:00 | IT novinky

    Společnost AMD na veletrhu Computex 2024 představila (YouTube) mimo jiné nové série procesorů pro desktopy AMD Ryzen 9000 a notebooky AMD Ryzen AI 300.

    Ladislav Hagara | Komentářů: 0
    3.6. 16:22 | Nová verze

    OpenCV (Open Source Computer Vision, Wikipedie), tj. open source multiplatformní knihovna pro zpracování obrazu a počítačové vidění, byla vydána ve verzi 4.10.0 . Přehled novinek v ChangeLogu. Vypíchnout lze Wayland backend pro Linux.

    Ladislav Hagara | Komentářů: 0
    Rozcestník

    Dotaz: cast int na double

    20.1.2017 20:11 Pavel
    cast int na double
    Přečteno: 472×
    Dneska jsem v logu jednoho programu viděl změnu:
      int giveMeAnInt();
      double giveMeADouble();
      
      double a = giveMeADouble();
    - double b = giveMeAnInt();
    - double c = a / b;
    + int b = giveMeAnInt();
    + double c = a / static_cast<double>(b);
    
    Může mi někdo vysvětlit přínos takové změny? Za sebe musím říct, že se mi změna nezdá a na jakýchsi (neznámých) platformách, kde double nemůže reprezentovat všechny hodnoty intu, nový kód pravděpodobněji skryje problém / potlačí varování kompilátoru o možné ztrátě přesnosti.

    Odpovědi

    20.1.2017 21:04 Sten
    Rozbalit Rozbalit vše Re: cast int na double
    Pokud se b nikde dál nepoužívá, tak je oboje totožné. Pokud by double nedokázal reprezentovat přesnou hodnotu intu, tak se použije nejbližší hodnota, a to i v prvním případě velmi pravděpodobně bez varování, protože to není constexpr a u runtime ztráty přesnosti kompilátor nevaruje (nemá jak).
    20.1.2017 22:13 Pavel
    Rozbalit Rozbalit vše Re: cast int na double
    Pokud si vzpomínám, tak při konverzi uint64_t na double mi kompilátor kdysi hlásil "Possible loss of precision".
    20.1.2017 22:20 Pavel
    Rozbalit Rozbalit vše Re: cast int na double
    Už jsem to našel
    #include <iostream>
    
    int main()
    {
        long a;
        long b;
        
        std::cin >> a >> b;
        
        double ad = a;
        double bd = static_cast<double>(b);
        std::cout << ad << bd;
    }
    
    Zkompiluju g++ -Wconversion -o a a.cpp. Dostanu
    a.cpp: In function ‘int main()’:
    a.cpp:10:17: warning: conversion to ‘double’ from ‘long int’ may alter its value [-Wconversion]
         double ad = a;
                     ^
    
    Static cast mi tedy potlačí varování na platformě, kde nelze provést konverzi pro všechny hodnoty zdrojového typu.
    25.1.2017 01:02 Sten
    Rozbalit Rozbalit vše Re: cast int na double
    Hmm, zajímavé. Je pravda, že ISO C++ definuje, jak se to má převést, ale už nedefinuje, jestli je to úmyslné chování (a tedy není nutné varovat, jako třeba převod int na bool) nebo jen definovaný vedlejší efekt (a tedy je vhodné varovat, jako u převodu int na char).
    24.1.2017 21:48 Vladimír Čunát | skóre: 19
    Rozbalit Rozbalit vše Re: cast int na double
    int je standardně 32-bit i na 64-bit (unix-like) platformách a myslím že 32-bit jde vždy v doublu reprezentovat bezztrátově (mantissa má ~50 bitů).
    25.1.2017 01:32 Sten
    Rozbalit Rozbalit vše Re: cast int na double
    Na to není dobré spoléhat. Třeba knihovny Intel MKL používají ILP64, takže pokud kompilujete vůči nim (rozšíření FORTRANu), budete mít 64bitové inty. Na druhou stranu ISO C++ povoluje, aby double byl stejně přesný jako float, takže u soft float architektur (třeba ARMv5) může mít váš program klidně doubly s 24bitovou mantisou.

    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.