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 16:44 | Nová verze

    Svobodný multiplatformní herní engine Bevy napsaný v Rustu byl vydán ve verzi 0.18. Díky 174 přispěvatelům.

    Ladislav Hagara | Komentářů: 2
    včera 15:11 | IT novinky

    Miliardy korun na digitalizaci služeb státu nestačily. Stát do ní v letech 2020 až 2024 vložil víc než 50 miliard korun, ale původní cíl se nepodařilo splnit. Od loňského února měly být služby státu plně digitalizované a občané měli mít právo komunikovat se státem digitálně. Do tohoto data se povedlo plně digitalizovat 18 procent agendových služeb státu. Dnes to uvedl Nejvyšší kontrolní úřad (NKÚ) v souhrnné zprávě o stavu digitalizace v Česku. Zpráva vychází z výsledků víc než 50 kontrol, které NKÚ v posledních pěti letech v tomto oboru uskutečnil.

    Ladislav Hagara | Komentářů: 8
    včera 13:55 | IT novinky

    Nadace Wikimedia, která je provozovatelem internetové encyklopedie Wikipedia, oznámila u příležitosti 25. výročí vzniku encyklopedie nové licenční dohody s firmami vyvíjejícími umělou inteligenci (AI). Mezi partnery encyklopedie tak nově patří Microsoft, Amazon a Meta Platforms, ale také start-up Perplexity a francouzská společnost Mistral AI. Wikimedia má podobnou dohodu od roku 2022 také se společností Google ze skupiny

    … více »
    Ladislav Hagara | Komentářů: 0
    včera 02:22 | Nová verze

    D7VK byl vydán ve verzi 1.2. Jedná se o fork DXVK implementující překlad volání Direct3D 5, 6 a 7 na Vulkan. DXVK zvládá Direct3D 8, 9, 10 a 11.

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

    Byla vydána verze 12.0.0 knihovny libvirt (Wikipedie) zastřešující různé virtualizační technologie a vytvářející jednotné rozhraní pro správu virtuálních strojů. Současně byl ve verzi 12.0.0 vydán související modul pro Python libvirt-python. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    15.1. 19:22 | Humor

    CreepyLink.com je nový zkracovač URL adres, 'díky kterému budou vaše odkazy vypadat tak podezřele, jak je to jen možné'. Například odkaz na abclinuxu.cz tento zkracovač převádí do podoby 'https://netflix.web-safe.link/logger_8oIlgs_free_money.php'. Dle prohlášení autora je CreepyLink alternativou ke zkracovači ShadyURL (repozitář na githubu), který dnes již bohužel není v provozu.

    NUKE GAZA! 🎆 | Komentářů: 3
    15.1. 12:33 | IT novinky

    Na blogu Raspberry Pi byla představena rozšiřující deska Raspberry Pi AI HAT+ 2 s akcelerátorem Hailo-10 a 8 GB RAM. Na rozdíl od předchozí Raspberry Pi AI HAT+ podporuje generativní AI. Cena desky je 130 dolarů.

    Ladislav Hagara | Komentářů: 3
    15.1. 12:11 | Komunita

    Wikipedie slaví 25. výročí svého založení. Vznikla 15. ledna 2001 jako doplňkový projekt k dnes již neexistující encyklopedii Nupedia. Doména wikipedia.org byla zaregistrována 12. ledna 2001. Zítra proběhne v Praze Večer svobodné kultury, který pořádá spolek Wikimedia ČR.

    Ladislav Hagara | Komentářů: 1
    15.1. 04:44 | Nová verze

    Po více než dvou letech od vydání předchozí verze 2.12 byla vydána nová stabilní verze 2.14 systémového zavaděče GNU GRUB (GRand Unified Bootloader, Wikipedie). Přehled novinek v souboru NEWS a v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 2
    15.1. 02:22 | Nová verze

    Google Chrome 144 byl prohlášen za stabilní. Nejnovější stabilní verze 144.0.7559.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 10 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře (YouTube).

    Ladislav Hagara | Komentářů: 4
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (5%)
     (0%)
     (9%)
     (19%)
     (3%)
     (6%)
     (3%)
     (11%)
     (42%)
    Celkem 463 hlasů
     Komentářů: 12, poslední 14.1. 21:12
    Rozcestník

    Octave - 9 (cykly)

    23. 3. 2006 | Jiří Poláček | Programování | 6780×

    Konečně můžeme v Octave začít programovat – seznámíme se s konstrukcí cyklů while, do-until a for.

    Cyklus s podmínkou

    Cyklus v programu dovoluje opakovat stále tytéž příkazy – což neznamená, že by produkovaly stále tytéž výsledky. Obvykle příkazy pracují s nějakými proměnnými, jejichž obsah se v průběhu smyček cyklu může měnit. Bývá také záhodno cyklus po určité době ukončit – typicky na základě platnosti nějaké podmínky, která se velice často vztahuje na hodnoty proměnných, s kterými příkazy cyklu pracují.

    Klíčové slovo while otevírá programovou konstrukci cyklu s podmínkou na začátku, za kterým následuje podmínka – výraz, u kterého Octave stejně jako u větvení vyhodnotí, zda platí, či neplatí. V případě, že je podmínka splněna, provedou se příkazy uvedené dále až do výskytu klíčového slova end (respektive endwhile), které konstrukci cyklu uzavírají, a – což je důležité – vracíme se zpět na začátek cyklu. Opět se tedy testuje podmínka, zda (stále ještě) platí – a opět se provádí příkazy v těle cyklu, je-li podmínka splněna – a tak pořád dokola, dokud podmínka splněna není. V takovém případě docházení k okamžitému ukončení cyklu – příkazy v těle cyklu se již neprovádějí, program pokračuje příkazy uvedenými za ukončovacím end cyklu.

    Příkladem cyklu s podmínkou budiž házení kostkou – dokud nepadne šestka, házíme znovu:

    >> hod=0; while hod ~= 6 hod=fix(rand(1)*6)+1, end
    hod = 5
    hod = 1
    hod = 1
    hod = 4
    hod = 4
    hod = 4
    hod = 6
    

    Podmínkou příkladu je výraz hod ~=6, tj. že hodnota proměnné hod je různá od šesti. Je-li tato podmínka splněna, provede se příkaz hod=fix(rand(1)*6)+1, který říká, aby se do proměnné hod uložilo náhodně vygenerované celé číslo z intervalu 16 – tímto způsobem simulujeme jedno hození kostkou. Princip cyklu nás vrací na začátek, kdy se znovu testuje podmínka, v našem případě, zda-li již jsme tu šestku hodili, či nikoliv. V okamžiku, kdy padne, se další házení již neprovádí, cyklus končí, jak je také patrno z výpisu. Úvodní přiřazovací příkaz na řádku provádí inicializaci proměnné – abychom mohli v cyklu nejdříve testovat a pak teprve házet, musí být proměnná hod zavedena předem (s hodnotou takovou, aby podmínka pro první testování splněna byla).

    Jiné vhodné využití cyklu while je například v programu pro výpočet zbytku po dělení dvou čísel s výhradním použitím operace odečítání:

    --[funkce zbytek.m]--
    function vysl=zbytek(delenec, delitel)
    while delenec > delitel
      delenec = delenec - delitel;
    end
    vysl = delenec;  
    --[konec funkce]--
    >> zbytek(46,7)
    ans = 4
    

    Doplňující drobnosti

    Octave také obsahuje variantu cyklu s podmínkou na konci. Cyklus začíná slovem do, za kterým následuje blok příkazů. Ten je uzavřen klíčovým slovem until následovaným podmínkou. Podmínka je tedy úplně na konci cyklu (slovo end se zde nepoužívá) a od cyklu while se odlišuje také tím, že k opakování příkazů v těle cyklu dochází v případě, kdy podmínka splněna není! Při splnění podmínky se cyklus opouští; příklad na házení kostkou, dokud nepadne šestka, tedy lze ekvivalentně zapsat takto:

    >> do hod=fix(rand(1)*6)+1, until hod==6
    

    Všimněte si též, že příkazy cyklu s podmínkou na konci se vždy alespoň jednou provedou (neboť až poté se testuje podmínka), inicializace proměnné hod tedy v tomto případě není potřeba.

    Jedna poznámka k psaní podmínek v cyklech a větveních programu – častou programátorskou chybou je zapsání příkazu přiřazení namísto porovnání dvou hodnot (tj. namísto dvou rovnítek pouze jedno), což samozřejmě vede k neočekávaným výsledkům. Octave ve výchozím nastavení na tuto skutečnost upozorňuje varováním:

    >> a=10; if a=4 disp('Podminka plati'); end
    warning: suggest parenthesis around assignment used as truth value
    Podminka plati
    

    Varování lze vypnout přiřazením nuly do vestavěné proměnné warn_assign_as_truth_value.

    Cyklus s předem známým počtem opakování

    Někdy jsme předem schopni vyjádřit, kolikrát se má daný blok příkazů provést. Pro Octave, respektive Matlab, je typické, že se nějaké příkazy mají provést pro všechny prvky vektoru či matice, a to právě jednou – celkem se tedy cyklus provede právě tolikrát, kolik prvků daný vektor či matice obsahuje. U cyklu while můžeme tento problém vyřešit zavedením čítače – proměnné, ve které budeme počítat, kolikrát již daný cyklus proběhl, a v podmínce cyklu budeme kontrolovat, zda už cyklus proběhl „dostatečněkrát“. Mějme například funkci, která vstupní vektor pozmění tak, že ke každému prvku přičte pozici, na které se ve vektoru nachází, tj. například z vektoru [1 1 4] udělá vektor [2 3 7]:

    --[funkce pricitani.m]--
    function w=pricitani(v)
    citac = 1;
    pocet_prvku = length(v);
    while citac <= pocet_prvku
    	w(citac) = v(citac) + citac;
    	citac = citac + 1;
    end
    --[konec funkce]--
    

    Před začátkem cyklu bylo nutno čítač inicializovat a v těle cyklu pak jej zvyšovat o jedničku. Tyto starosti, které jsou často příčinou chyb v programu, lze hodit za hlavu s konstrukcí cyklu s předem známým počtem opakovaní uvozované klíčovým slovem for. Přepišme naši funkci pricitani to této podoby:

    --[funkce pricitani.m]--
    function w=pricitani(v)
    pocet_prvku = length(v);
    for citac = 1:pocet_prvku
    	w(citac) = v(citac) + citac;
    end
    --[konec funkce]--
    

    Inicializace a navyšování čítače z programu zmizely a namísto podmínky cyklu je zde přiřazovací výraz. Jak to tedy funguje? Už víme, že zápis 1:pocet_prvku nám vytvoří posloupnost od jedničky do hodnoty uložené v proměnné pocet_prvku s krokem jedna, v „uvažování“ Octave se tedy jedná o vektor [1 2 3 4 5 ... pocet_prvku]. Hlavní trik cyklu for spočívá v přiřazování tohoto vektoru do čítače – narozdíl od přiřazování kdekoliv jinde v programu se zde neuloží celý vektor do proměnné najednou, ale v každé smyčce cyklu postupně pouze jeden prvek vektoru (přesněji řečeno jeden sloupec proměnné, která je výsledkem výrazu – u matic by se tedy jednalo o sloupcové vektory, kterých by čítač postupně nabýval).

    Cyklus tedy pracuje tak, že nejdříve do čítače uloží hodnotu prvního prvku z vektoru, v našem případě tedy číslo 1, a nechá proběhnout tělo cyklu, pak do čítače vloží následující hodnotu z vektoru – číslo 2 – a nechá proběhnout tělo cyklu podruhé, a tak dále, dokud nevyčerpá všechny prvky vektoru.

    Jiné příklady – bude-li výraz 1:10, cyklus proběhne desetkrát s hodnotami čítače od jedné do desíti; bude-li výraz [4 7 -1 3] proběhne cyklus čtyřikrát, přičemž čítač postupně nabude hodnot 4, 7, -1 a 3.

    Nejčtenější články posledního měsíce

    Týden na ITBiz: Trhy zapochybovaly o návratnosti investic do AI
    Událo se v týdnu 51/2025
    Týden na ScienceMag.cz: Vyvinuli novou metodu měření vlastností krátkých spinových vln

    Nejkomentovanější články posledního měsíce

    Týden na ITBiz: Prodejci věří, že AI dokáže vylepšit většinu IT produktů
      všechny statistiky »

    Seriál Octave (dílů: 16)

    Octave - 1 (je to kalkulačka) (první díl)
    <—« Octave - 8 (větvení programu)
    »—> Octave - 10 (zbylé řídicí struktury)
    Octave - 16 (a co dál?) (poslední díl)

    Související články

    Octave - 1 (je to kalkulačka)
    Octave - 2 (počítání s maticemi)
    Octave - 3 (přístup k jednotlivým položkám matice)
    Octave - 4 (je to pravda?)
    Octave - 5 (práce s řetězci)
    Octave - 6 (práce se soubory)
    Octave - 7 (vlastní skripty a funkce)
    Octave - 8 (větvení programu)
    Octave - 10 (zbylé řídicí struktury)
    Octave - 11 (kreslíme grafy)
    Octave - 12 (měřítko os a speciální grafy)
    Octave - 13 (dokončení grafiky)
    Octave - 14 (finance a statistika)
    Octave - 15 (špetka matematiky)
    Octave - 16 (a co dál?)
    Vektorový elegán Ipe
    Recenze: Kniha kódů a šifer
    Awk & sed: Příručka pro dávkové zpracování textu
    SETI@home
    Jak se píše procesor
    GnuCash - domácí účetnictví na úrovni
    Použití gnuplot pro tvorbu grafů v PHP
    Hra s písmenky - wxMaxima

    Další články z této rubriky

    LLVM a Clang – více než dobrá náhrada za GCC
    Ze 4 s na 0,9 s – programovací jazyk Vala v praxi
    Reverzujeme ovladače pro USB HID zařízení
    Linux: systémové volání splice()
    Programování v jazyce Vala - základní prvky jazyka
           

    Hodnocení: 100 %

            špatnédobré        

    Nástroje: Tisk bez diskuse

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

    Komentáře

    Vložit další komentář

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