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 04:55 | Zajímavý software

    Microsoft zveřejnil na GitHubu zdrojové kódy MS-DOSu 4.0 pod licencí MIT. Ve stejném repozitáři se nacházejí i před lety zveřejněné zdrojové k kódy MS-DOSu 1.25 a 2.0.

    Ladislav Hagara | Komentářů: 1
    včera 17:33 | Nová verze

    Canonical vydal (email, blog, YouTube) Ubuntu 24.04 LTS Noble Numbat. Přehled novinek v poznámkách k vydání a také příspěvcích na blogu: novinky v desktopu a novinky v bezpečnosti. Vydány byly také oficiální deriváty Edubuntu, Kubuntu, Lubuntu, Ubuntu Budgie, Ubuntu Cinnamon, Ubuntu Kylin, Ubuntu MATE, Ubuntu Studio, Ubuntu Unity a Xubuntu. Jedná se o 10. LTS verzi.

    Ladislav Hagara | Komentářů: 8
    včera 14:22 | Komunita

    Na YouTube je k dispozici videozáznam z včerejšího Czech Open Source Policy Forum 2024.

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

    Fossil (Wikipedie) byl vydán ve verzi 2.24. Jedná se o distribuovaný systém správy verzí propojený se správou chyb, wiki stránek a blogů s integrovaným webovým rozhraním. Vše běží z jednoho jediného spustitelného souboru a uloženo je v SQLite databázi.

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

    Byla vydána nová stabilní verze 6.7 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 124. Přehled novinek i s náhledy v příspěvku na blogu. Vypíchnout lze Spořič paměti (Memory Saver) automaticky hibernující karty, které nebyly nějakou dobu používány nebo vylepšené Odběry (Feed Reader).

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

    OpenJS Foundation, oficiální projekt konsorcia Linux Foundation, oznámila vydání verze 22 otevřeného multiplatformního prostředí pro vývoj a běh síťových aplikací napsaných v JavaScriptu Node.js (Wikipedie). V říjnu se verze 22 stane novou aktivní LTS verzí. Podpora je plánována do dubna 2027.

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

    Byla vydána verze 8.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a v informačním videu. Zdůrazněn je průvodce migrací hostů z VMware ESXi do Proxmoxu.

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

    R (Wikipedie), programovací jazyk a prostředí určené pro statistickou analýzu dat a jejich grafické zobrazení, bylo vydáno ve verzi 4.4.0. Její kódové jméno je Puppy Cup.

    Ladislav Hagara | Komentářů: 0
    24.4. 22:44 | IT novinky

    IBM kupuje společnost HashiCorp (Terraform, Packer, Vault, Boundary, Consul, Nomad, Waypoint, Vagrant, …) za 6,4 miliardy dolarů, tj. 35 dolarů za akcii.

    Ladislav Hagara | Komentářů: 13
    24.4. 15:55 | Nová verze

    Byl vydán TrueNAS SCALE 24.04 “Dragonfish”. Přehled novinek této open source storage platformy postavené na Debianu v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    KDE Plasma 6
     (73%)
     (9%)
     (2%)
     (16%)
    Celkem 779 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Octave - 3 (přístup k jednotlivým položkám matice)

    1. 2. 2006 | Jiří Poláček | Programování | 8341×

    Naplnění matice funkcí, rozměry matice, operátor dvojtečka, přístup k jednotlivým složkám vektoru a matice.

    Naplnění matice funkcí

    V minulém díle (Octave - 2 (počítání s maticemi)) jsme si ukázali vytvoření matice ručně - výčtem hodnot. Matici můžeme získat i jinak - Octave disponuje celou řadou funkcí pro tvorbu matic určitého typu. S výjimkou permutace mají všechny níže uvedené funkce dva parametry, kterými říkáme, kolik řádků a kolik sloupců má výsledná matice mít (vhodnými parametry jsou tedy pouze kladná čísla). Pokud uvedeme pouze jeden parametr, výsledná matice bude čtvercová. Funkce jsou tedy následující:

    • zeros - vytvoří matici se samými nulami
    • ones - vytvoří matici se samými jedničkami
    • eye - vytvoří jednotkovou matici
    • rand, randn - vytvoří matici s náhodnými čísly v intervalu od nuly do jedné (rovnoměrné nebo normální rozložení)
    • randperm(n) - vytvoří vektor s čísly od 1 do n, náhodně permutovaný
    • tril, triu - podle hlavní diagonály extrahuje dolní, respektive horní trojúhelníkovou matici ze zadané matice. Druhý volitelný parametr posouvá dělící diagonálu.

    Příklady pro představu:

    >> zeros(2,4)
    ans =
      0  0  0  0
      0  0  0  0
    >> 4 * ones(2,3)
    ans =
      4  4  4
      4  4  4
    >> eye(3)
    ans =
      1  0  0
      0  1  0
      0  0  1
    >> randn(2,5)
    ans =
       1.324077  -0.408510   1.516083  -0.372057  -0.138184
       0.787720  -0.186652   0.079070   0.056826   1.679005
    >> floor(rand(4,6)*20)+1 % Chceme celá čísla od 1 do 20
    ans =
       3  10   2   6   5  16
       6   4  10   8  19   9
      18  20   1  18  13   8
      17   8  13   7  12  20
    >> randperm(8)
    ans =
      4  6  5  7  2  8  3  1
    >> tril(ones(3))
    ans =
      1  0  0
      1  1  0
      1  1  1
    >> triu(ones(5),-2)
    ans =
      1  1  1  1  1
      1  1  1  1  1
      1  1  1  1  1
      0  1  1  1  1
      0  0  1  1  1

    Octave také obsahuje funkce pro výrobu speciálních matic, jakými jsou například Hankelova, Hilbertova, Sylvesterova či Toeplitzova matice. Popis parametrů je v nápovědě.

    Rozměry matice

    Funkce size s parametrem nějaké matice vrací dvouprvkový vektor, ve kterém první hodnota odpovídá počtu řádků dané matice a druhá počtu sloupců:

    >> size(ones(5))
    ans =
      5  5

    Funkce rows a columns vrací pouze odpovídající složku z dvouprvkového výsledku funkce size, tj. počet řádků, respektive počet sloupců z dané matice:

    >> rows([1:5]')
    ans = 5
    >> columns(zeros(4,60))
    ans = 60

    Počet řádků a počet sloupců nějaké matice tedy lze do proměnných uložit dvěma následujícími ekvivalentními způsoby:

    >> Matice=zeros(5,20);
    >> [radky, sloupce]=size(Matice)
    radky = 5
    sloupce = 20
    >> radky=rows(Matice), sloupce=columns(Matice)
    radky = 5
    sloupce = 20

    Funkce length vrací větší z hodnot vrácených funkcí size, typicky se používá pro výpočet počtu prvků v nějakém vektoru, přičemž se nemusíme starat o to, zda je tento vektor řádkový či sloupcový:

    >> length([1 2 3 8])
    ans = 4

    Operátor dvojtečka

    Znak dvojtečka slouží k zhuštěnému zápisu řádkového vektoru obsahujícího nějakou aritmetickou posloupnost. Obecně v zápisu figurují tři čísla oddělená dvojtečkami. První z nich představuje počáteční člen posloupnosti, druhé velikost kroku a třetí poslední přípustný člen řady. Více to bude patrno z příkladů:

    >> 1:1:6
    ans =
      1  2  3  4  5  6

    Posloupnost čísel od jedné do šesti s krokem jedna:

    >> 1.5:2.5:7.9
    ans =
      1.5000  4.0000  6.5000

    Následující potenciální člen posloupnosti 6,5 + 2,5 = 9 již je číslo větší jak nejvyšší přípustný člen posloupnosti, tj. číslo 7,9, proto již v posloupnosti obsažen není. Všimněme si, že v zápisu samozřejmě lze pracovat s reálnými čísly, nejenom s celými.

    >> 5:-1:-1
    ans =
       5   4   3   2   1   0  -1
    >> 0:8
    ans =
      0  1  2  3  4  5  6  7  8

    V případě, že není krok uveden - zápis sestává pouze ze dvou čísel oddělených jednou dvojtečkou - považuje se za krok hodnota 1. Zápis posloupnosti s dvojtečkovou notací se používá zejména při indexovaném přístupu k obsahu matic, lze tak snadno vybrat například druhý až jedenáctý řádek dané matice. Více viz následující odstavce.

    Přístup k jednotlivým složkám vektoru

    Nezřídka se může stát, že při výpočtu je potřeba pracovat pouze s určitými prvky nějakého vektoru či matice, nikoliv s celým obsahem proměnné najednou. V kulatých závorkách uvedených bezprostředně za názvem proměnné lze uvést index prvku, s kterým se má pracovat:

    >> X=5:-1:-4
    X =
       5   4   3   2   1   0  -1  -2  -3  -4
    >> X(1)
    ans = 5
    >> X(4)
    ans = 2
    >> X(end)
    ans = -4

    Zadáním jednoho čísla se odkazujeme na pozici v daném vektoru. Pozice se číslují od jedničky, na poslední pozici se lze odvolat pomocí klíčového slůvka end. Jedním výběrem však pozic můžeme vybrat více - výsledkem je „podvektor“ složený z prvků vybraných z původního vektoru v uvedeném pořadí:

    >> X(3:7)
    ans =
       3   2   1   0  -1
    >> X(end:-2:1)
    ans =
      -4  -2   0   2   4
    >> X([8,5,7,1])
    ans =
      -2   1  -1   5
    >> X([9,9,9,1,1])
    ans =
      -3  -3  -3   5   5

    Poslední uvedený příklad ukazuje, že není problémem vybrat prvek na zvolené pozici vícekrát - při budování výsledného vektoru se právě tolikrát a právě v takovém pořadí vybrané prvky objeví. Za povšimnutí stojí též fakt, že zadání více pozic je nutno zapsat jako vektor těchto pozic (tj. v hranatých závorkách), na úrovni kulatých závorek lze totiž u vektoru zadat pouze jeden parametr indexování.

    Přístup k jednotlivým složkám matice

    Přístup k prvkům matice analogicky odpovídá přístupu ke složkám vektoru s tím rozdílem, že je nutno zadat indexy dva - řádkový a sloupcový oddělené čárkou (no, není to tak úplně pravda, ale to se ukáže až později):

    >> M=fix(rand(5)*21)-10;
    
    % Vyber prvek z druhého řádku a čtvrtého sloupce
    >> M(2,4)
    ans = -9
    
    % Vyber první-až-třetí řádek průnik třetí-až-pátý sloupec
    >> M(1:3,3:5)
    ans =
        0    7   10
       10   -9   -5
       -2   -8   -1
    
    % Vyber postupně pátý, třetí a první řádek skrze všechny sloupce
    >> M([5,3,1],:)
    ans =
       -5    5   -1   -5   -2
        5   -7   -2   -8   -1
       -8   -2    0    7   10

    V případě, kdy chce uživatel vybrat všechny řádky respektive všechny sloupce, stačí na místě příslušného indexu uvést pouze znak „:“ namísto ekvivalentního 1:end.

    Výběr určitých prvků z matice lze činit také proto, abychom tyto prvky nahradili jinými hodnotami. Oblast výběru svými rozměry musí vždy odpovídat rozměrům vkládané matice:

    >> M(1,2)=-4
    >> M(1,:)=M(3,:)
    >> M([2,4],[2,4])=ones(2)
    >> M(:,2)=[]

    První příkaz nahradil prvek v prvním řádku a druhém sloupci hodnotou -4; druhý zkopíroval třetí řádek na první řádek; třetí nahradil prvky v matici ve druhém a čtvrtém řádku i sloupci jedničkami; poslední pak smazal druhý sloupec - mazání se provádí vložením prázdné matice (viz minulý díl). Aby byla zachována konzistence matice, je nutno mazat vždy celé řádky či sloupce.

    Příště

    Příští díl se bude věnovat relačním a logickým operátorům v Octave.

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

    Jaderné noviny – přehled za březen 2024
    Týden na ScienceMag.cz: Přišli s novým nápadem, jak poznat, zda text napsala umělá inteligence
    Týden na ITBiz: Efektivní podnikání se bez edge computingu neobejde

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

    Týden na ScienceMag.cz: Přišli s novým nápadem, jak poznat, zda text napsala umělá inteligence
      všechny statistiky »

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

    Octave - 1 (je to kalkulačka) (první díl)
    <—« Octave - 2 (počítání s maticemi)
    »—> Octave - 4 (je to pravda?)
    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 - 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 - 9 (cykly)
    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

    Odkazy a zdroje

    Octave

    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ář

    1.2.2006 10:45 herhor
    Rozbalit Rozbalit vše Re: Octave - 3 (přístup k jednotlivým položkám matice)
    Já jsem tedy jednoznačně proti tomu, aby tady vycházely tutoriály pro idioty. Uvod do Octave pro nezasvěcené má vypadat nějak takhle http://www.root.cz/clanky/octave-programovaci-jazyk-pro-neprogramatory/. Pro koho je určené tohle vážně nechápu.
    1.2.2006 11:04 Robert Krátký | skóre: 94 | blog: Robertův bloček
    Rozbalit Rozbalit vše Re: Octave - 3 (přístup k jednotlivým položkám matice)
    Každý někdy začínal. Připadá-li ti článek příliš podrobný nebo jednoduchý, nelze poradit nic jiného, než abys ho nečetl. Nikdo tě nenutí. Buď ale tolerantní a ponech ho nám ostatním.
    1.2.2006 12:21 coccyx
    Rozbalit Rozbalit vše Re: Octave - 3 (přístup k jednotlivým položkám matice)
    mne sa tento serial celkom paci a urcite si nemyslim ze dobry clanok by mal byt suhrn linkov na manual programu. A celkom by som bol rad keby po dokonceni serialu vysla aj nejaka kompaktna PDF verzia.
    1.2.2006 12:42 Robert Krátký | skóre: 94 | blog: Robertův bloček
    Rozbalit Rozbalit vše Re: Octave - 3 (přístup k jednotlivým položkám matice)
    Po dokončení bude celý seriál v jednom z vydání PDF Abíčka.
    1.2.2006 12:42 jam001 | skóre: 19
    Rozbalit Rozbalit vše Re: Octave - 3 (přístup k jednotlivým položkám matice)
    Nieco taketo nestaci? http://www.octave.org/doc/index.html
    menphis avatar 1.2.2006 12:45 menphis | skóre: 22 | blog: menphis_blog
    Rozbalit Rozbalit vše Re: Octave - 3 (přístup k jednotlivým položkám matice)
    Jj, taky si myslim,ze by clanek mohl byt trochu odborneji pojat. Na 3. dil je prace s prvky hodne malo!
    1.2.2006 12:25 coccyx
    Rozbalit Rozbalit vše dlhy vypis
    by som sa chcel spytat ako sa da vypnut funkcia, ktora umoznuje prezeranienie vypisu dlhych vysledkov, mi to pripada ako prikaz more ale ked mam program v skripte mi vadi ze program zastavuje na tomto vypise.
    1.2.2006 13:16 jam001 | skóre: 19
    Rozbalit Rozbalit vše Re: dlhy vypis
    Bohuzial nerozumiem tvojej otazke (vlastne tam ani ziadna otazka nie je).

    Nepomoze ti ';' na konci kazdeho prikazu? To sposobi, ze vysledok prikazu nie je vypisany.
    1.2.2006 14:26 coccyx
    Rozbalit Rozbalit vše Re: dlhy vypis
    no praveze ja som chcel ten vysledok vidiet, len aby sa to nezastavovalo na tom vypise, napriklad v koctave si mozem vyskrolovat vsetky vysledky ...

    riesenie: page_screen_output=0

    -- Built-in Variable: page_screen_output If the value of `page_screen_output' is nonzero, all output intended for the screen that is longer than one page is sent through a pager. This allows you to view one screenful at a time. Some pagers (such as `less'--see *Note Installation::) are also capable of moving backward on the output. The default value is 1.
    1.2.2006 22:23 GeBu | skóre: 27 | blog: zápisky
    Rozbalit Rozbalit vše Re: Octave - 3 (přístup k jednotlivým položkám matice)
    Nevíte někdo jestli neexistuje manuál v češtině?

    Založit nové vláknoNahoru

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