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 15:33 | IT novinky

    Po 26 letech od protiprávního policejního zásahu, který byl spuštěn na základě podnětu společnosti Microsoft, Obvodní soud pro Prahu 2 rozsudkem potvrdil, že Mironet prokázal významnou část svého nároku na náhradu škody vůči Ministerstvu spravedlnosti ČR. Soudem nyní přiznaná část nároku znamená rekordní odškodné, jaké kdy české soudy přiznaly za nesprávný postup státu. Spor byl rozdělen na několik škod, u pravomocně uzavřených částí

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

    Lehké desktopové prostředí LXQt bylo vydáno ve verzi 2.4.0. Jde o převážně opravné vydání s drobnými vylepšeními podpory Waylandu.

    |🇵🇸 | Komentářů: 0
    včera 12:44 | IT novinky

    Počítačová hra Kingdom Come: Deliverance 2 českého studia Warhorse získala cenu BAFTA v kategorii nejlepší příběh. V konkurenci pěti dalších nominovaných děl porazila i úspěšnou francouzskou hru Clair Obscur: Expedition 33, která v letošním ročníku získala cenu za nejlepší hru roku.

    Ladislav Hagara | Komentářů: 1
    včera 12:22 | Komunita

    Projekt KDE oslaví v říjnu 30 let. Matthias Ettrich poslal 14. října 1996 do diskusní skupiny comp.os.linux.misc zprávu, která započala historii projektu. Důležité milníky jsou zobrazeny na časové ose KDE.

    Ladislav Hagara | Komentářů: 2
    včera 02:55 | Komunita

    Byly vyhlášeny výsledky letošní volby vedoucí/ho projektu Debian (DPL, Wikipedie). Poprvé povede Debian žena. Novou vedoucí je Sruthi Chandran. Letos byla jedinou kandidátkou. Kandidovala již v letech 2020, 2021, 2024 a 2025. Na konferenci DebConf19 měla přednášku Is Debian (and Free Software) gender diverse enough?

    Ladislav Hagara | Komentářů: 16
    včera 00:55 | Nová verze

    Byla vydána nová verze 10.3 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Přidána byla podpora Orange Pi 4 LTS. Přibyl balíček Prometheus.

    Ladislav Hagara | Komentářů: 0
    19.4. 18:55 | Nová verze

    Implementace VPN softwaru WireGuard (Wikipedie) pro Windows, tj. WireGuard pro Windows a WireGuardNT, dospěly do verze 1.0.

    Ladislav Hagara | Komentářů: 2
    19.4. 16:11 | IT novinky

    V Pekingu dnes proběhl 2. ročník půlmaratonu humanoidních robotů. První 3 místa obsadili roboti Honor Lightning v různých týmech. Nový rekord autonomního robota je 50 minut a 26 sekund. Operátorem řízený robot to zvládl i s pádem za 48 minut a 19 sekund. Řízení roboti měli časovou penalizaci 20 %. Před rokem nejrychlejší robot zvládl půlmaraton za 2 hodiny 40 minut a 42 sekund. Aktuální lidský rekord drží Jacob Kiplimo z Ugandy s časem 57 minut a 20 sekund [𝕏].

    Ladislav Hagara | Komentářů: 6
    17.4. 17:11 | Zajímavý článek

    Stanislav Fort, vedoucí vědecký pracovník z Vlčkovy 'kyberbezpečnostní' firmy AISLE, zkoumal dopady Anthropic Mythos (nový AI model od Anthropicu zaměřený na hledání chyb, který před nedávnem vyplašil celý svět) a předvedl, že schopnosti umělé inteligence nejsou lineárně závislé na velikosti nebo ceně modelu a dokázal, že i některé otevřené modely zvládly v řadě testů odhalit ve zdrojových kódech stejné chyby jako Mythos (například FreeBSD CVE-2026-4747) a to s výrazně nižšími provozními náklady.

    MakeIranBombedAgain❗ | Komentářů: 8
    17.4. 12:44 | IT novinky

    Federální návrh zákona H.R.8250 'Parents Decide Act', 13. dubna předložený demokratem Joshem Gottheimerem a podpořený republikánkou Elise Stefanik coby spolupředkladatelkou (cosponsor), by v případě svého schválení nařizoval všem výrobcům operačních systémů při nastavování zařízení ověřovat věk uživatelů a při používání poskytovat tento věkový údaj aplikacím třetích stran. Hlavní rozdíl oproti kalifornskému zákonu AB 1043 a kolorádskému SB26-051 je ten, že federální návrh by platil rovnou pro celé USA.

    MakeIranBombedAgain❗ | Komentářů: 13
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (8%)
     (1%)
     (12%)
     (30%)
     (3%)
     (6%)
     (2%)
     (15%)
     (25%)
    Celkem 1365 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník


    Vložit další komentář
    25.6.2007 15:46 kaaja | skóre: 24 | blog: Sem tam něco | Podbořany, Praha
    Rozbalit Rozbalit vše Re: Algoritmus pro gemerování znaků
    Záleží co se myslí větičkou
    Generované znaky musí být v poměru zadaném uživatelem.
    Může se tím myslet, že znaků musí být přesně v daném poměru (ale to lze jenom při správném počtu znaků), nebo mají být generovány s pravděpodobnostmi v tom poměru (tady by se skutečný poměr měl přibližovat k zadanému s rostoucím počtem čísel).
    25.6.2007 17:42 Radek Trnka | skóre: 26 | blog: Jen_tak | kousek od ČB
    Rozbalit Rozbalit vše Re: Algoritmus pro gemerování znaků
    Mám to osetrene tak, ze zaokrouhluje na cela cisla. takze vypocitám a zaokrouhlim pocet cisel. Pismana=celkovy_pocet-cisel.
    Černé díry jsou tam, kde Bůh dělil nulou. -- Steven Wright one Liners
    25.6.2007 16:06 miso | skóre: 36 | blog: iSCSI_initiator_howto | Praha
    Rozbalit Rozbalit vše Re: Algoritmus pro gemerování znaků
    gemerator by si mal najst tu
    Project Satan infects Calculon with Werecar virus
    stativ avatar 25.6.2007 16:12 stativ | skóre: 54 | blog: SlaNé roury
    Rozbalit Rozbalit vše Re: Algoritmus pro gemerování znaků
    Nejspíš bych nejdřív použil generátor náhodných čísel a pak bych do for smyčky dal if podmínky, kde v případě, že by vygenerované číslo bylo sudé, tak by to pokračovalo generováním čísla, když by bylo liché, tak čísla. Zároveň bych do obou podmínek dal nějakou bool proměnou, která by určovala, jestli už je jich vygenerováno dostatek. Když by jich bylo dost, generování by se pro daný typ ukončilo.
    Ať sežeru elfa i s chlupama!!! ljirkovsky.wordpress.com stativ.tk
    stativ avatar 25.6.2007 16:31 stativ | skóre: 54 | blog: SlaNé roury
    Rozbalit Rozbalit vše Re: Algoritmus pro gemerování znaků
    Rychla ukazka:
    short cisel = 0.3; // 30% tohle at se vsechno nastavi nekde na vstupu
    short pismen = 0.7; // 70%
    int celkem = 100;
    
    int celkem_cisel = celkem*cisel;
    int celkem_pismen = celkem*pismen;
    
    for (i=0,i<=celkem ,i++){
       srand((unsigned)time(0)); // aby cisla byla na pohled nahodna
       int rozhodovac = rand();
       if (((rozhodovac%2)=0 && celkem_cisel>=0) || celkem_pismen=0){
          // generovani 1 cisla se zapisem do souboru atd., nechce se mi nad tim premyslet
          --celkem_cisel;
       }
       if (((rozhodovac%2)!=0 && celkem_pismen>=0 || celkem_cisel=0){
          // generovani 1 pismena se zapisem do souboru atd
          --celkem_pismen;
       }
    }
    Ať sežeru elfa i s chlupama!!! ljirkovsky.wordpress.com stativ.tk
    25.6.2007 16:41 spang
    Rozbalit Rozbalit vše Re: Algoritmus pro gemerování znaků
    Jenže takhle se ti budou čísla objevovat s mnohem větší pravděpodobností na začátku, než na konci, protože je jich méně.

    Já bych potřebný počet čísel i písmen vygeneroval předem a do pořadí z nich vybíral podle daného poměru, výskyt bude rovnoměrný.
    stativ avatar 25.6.2007 19:30 stativ | skóre: 54 | blog: SlaNé roury
    Rozbalit Rozbalit vše Re: Algoritmus pro gemerování znaků
    Tak příslušně opravit tu dělitelnost proměnné rozhodovac, nebo tuhle část mírně opravit tak, aby tam bylo něco, u čeho je pravděpodobnost pravdivého výsledku odpovídající počtu čísel k nalezení. Pokud by se tam dala delitelnost 3, hned by byla menší pravděpodobnost, že se všechna čísla vypancají na začátku.
    Ať sežeru elfa i s chlupama!!! ljirkovsky.wordpress.com stativ.tk
    25.6.2007 16:15 UFI
    Rozbalit Rozbalit vše Re: Algoritmus pro gemerování znaků
    Uchovávej si informaci o tom kolik čísel si vygeneroval a tomu přizpůsob pravděpodobnosti při generování dalšího znaku. Pokud už tedy budeš mít plný počet čísel, bude nulová pravděpodobnost vygenerování čísla.
    25.6.2007 17:44 Radek Trnka | skóre: 26 | blog: Jen_tak | kousek od ČB
    Rozbalit Rozbalit vše Re: Algoritmus pro gemerování znaků
    bohužel hrátky s pravděpodobností nepovolil :-(
    Černé díry jsou tam, kde Bůh dělil nulou. -- Steven Wright one Liners
    25.6.2007 17:57 UFI
    Rozbalit Rozbalit vše Re: Algoritmus pro gemerování znaků
    To znamená že musí být pořád stejná pravděpodobnost že vygeneruješ číslo? Potom to snad ani nejde udělat.

    Leda vygenerovat nejdřív 30 čísel pak 70 znaků a pak ten soubor náhodně zpřeházet :)
    Petr Tomášek avatar 26.6.2007 11:09 Petr Tomášek | skóre: 39 | blog: Vejšplechty
    Rozbalit Rozbalit vše Re: Algoritmus pro gemerování znaků
    A co vygenerovat urcity pocet znaku a vedle toho urcity pocet cisel a nejak nahodne zamichat?
    multicult.fm | monokultura je zlo | welcome refugees!
    25.6.2007 16:16 Michal Vyskočil | skóre: 60 | blog: miblog | Praha
    Rozbalit Rozbalit vše Re: Algoritmus pro gemerování znaků
    Nijak bych se s tím nedrbal a pro rozhodování, co vygenerovat, bych použil pravděpodobnost - vygeneruješ si náhodné číslo z intervalu 0 až 99 a pokud je výsledek z první třetiny, vygeneruješ číslo, jinak znak ...
    import random
    import re
    
    # vrati znak 0-9
    def getNumber():
        return chr(random.randrange(ord('0'), ord('9')))
    
    # vrati A-Za-z
    def getChar():
        ret = chr(91)
        while not re.match('[A-Za-z]', ret):
            ret = chr(random.randrange(ord('A'), ord('z')))
        return ret
    
    # pomer pouze ciselnych ku neciselnym
    num_ratio = 0.3
    
    # celkovy pocet cisel
    count = random.randrange(150, 250)
    
    # generovani
    while count:
        if (random.randint(0, 99) <= 100*num_ratio):
            print getNumber()
        else:
            print getChar()    
        count -= 1
    
    Dokonalejší verze by si ještě pamatovala počty už vygenerovaných čísel/znaků, ale s tím se mi popravdě už psát nechtělo :-D
    When your hammer is C++, everything begins to look like a thumb.
    25.6.2007 18:00 Honza "tux" Friesse | skóre: 15 | blog: Tuxův blog | Vyškov
    Rozbalit Rozbalit vše Re: Algoritmus pro gemerování znaků
    Doufám že jsem to z toho popisu pochopil správně.

    Implementace v DrScheme
    (define (gen-items noitems fromc toc)
      (if (= noitems 0) '() 
            (append (gen-items (- noitems 1) fromc toc) 
                    (list (integer->char 
                           (+ (random (+ (- (char->integer toc) (char->integer fromc)) 1)) (char->integer fromc)))))))
    
    (define (shake noshakes str)
      (if (= noshakes 0) str
        (let* ((pos1 (random (string-length str))) (pos2 (random (string-length str))) 
              (ch1 (string-ref str pos1)) (ch2 (string-ref str pos2)))
          (string-set! str pos1 ch2)
          (string-set! str pos2 ch1)
          (shake (- noshakes 1) str))))
    
          
    ;Tohle si definuje uzivatel
    (define nonums 0.2)
    (define nosc   0.3)
    (define nolc   0.5)
    ;A tohle uz se pocita
    (define noitems (+ 150 (random (+ 1 (- 250 150)))))
    
    (define str (list->string (append (gen-items (inexact->exact (round (* noitems nolc))) #\A #\Z) 
            (gen-items (inexact->exact (round (* noitems nosc))) #\a #\z) 
            (gen-items (inexact->exact (round (* noitems nonums))) #\0 #\9))))
    
    (shake (* (string-length str) 2) str)
    
    26.6.2007 21:23 Kyosuke | skóre: 28 | blog: nalady_v_modre
    Rozbalit Rozbalit vše Re: Algoritmus pro gemerování znaků
    Na můj vkus moc složité a neřeší malá a velká písmena. ;-) Já bych na to hrubou silou:
    (use srfi-13)
    (use srfi-27)
    
    ;; Ze znaku retezce retezec generuje nahodny retezec delky delka ;)
    (define (nahodny-retezec retezec delka)
      (string-tabulate (lambda _
    		     (string-ref retezec (random-integer (string-length retezec))))
    		   delka))
    
    ;; nahodne prohazi seznam
    (define (prohazej seznam)
      (map cdr
           (sort (map (cut cons (random-real) <>) seznam)
    	     (lambda (a b) (< (car a) (car b))))))
    
    (define (generuj delka)
      (let* ((cislic (round (* 0.3 delka)))
    	 (retezec-k-prohazeni (string-concatenate 
    			       (map nahodny-retezec
    				    '("abcdefghijklmnopqrstuvxwyzABCDEFGHIJKLMNOPQRSTUVXWYZ"
    				      "0123456789")                     ; mnoziny znaku
    				    (list (- delka cislic) cislic)))))  ; prislusne pocty
        (list->string (prohazej (string->list retezec-k-prohazeni)))))
    
    (dotimes (i 10) (display (generuj 20)) (newline))
    29.6.2007 20:42 Kyosuke | skóre: 28 | blog: nalady_v_modre
    Rozbalit Rozbalit vše Re: Algoritmus pro gemerování znaků
    Mimochodem, 1337 řešení pro rub1s7y: ;-)
    CHARS = (('a'..'z').to_a + ('A'..'Z').to_a)
    NUMS = (0..9).to_a
    
    def generate(l)
      c = (l*0.3).round
      t = [[CHARS, l-c], [NUMS, c]].map{|ch, n| Array.new(n){ch[rand(ch.size)]}}
      t.flatten.sort_by {rand}.join
    end
    Přijde mi rozumně kompaktní a dá se rozšířit na více skupin ekvivalence
    25.6.2007 19:32 skeptik
    Rozbalit Rozbalit vše Re: Algoritmus pro generování znaků
    Chceš-li mít zastoupení "přesné" (až na zaokrouhlení) a přesto opravdu náhodné pořadí, nezbývá ti než vygenerovat písmena a čísla zvlášť (znak po znaku to z principu nejde) a pak je teprve náhodně seřadit (např. přes pomocný přiřazený double). Je to časově náročnější, ale jedině tak to bude "přesné".
    25.6.2007 20:08 Radek Trnka | skóre: 26 | blog: Jen_tak | kousek od ČB
    Rozbalit Rozbalit vše Re: Algoritmus pro generování znaků
    Takže díky za rady. Nyní jsem dospěl do stádia kdy mám přesné procenta, ale vždy mi ulítne 1 až 2 znaky navíc. Vypadá to nějak takto :
    if ((procent>0) and (procent<100)) then {generuje pismena i znaky}
        begin
          cisel:=Int((pocet/100)*procent);
          pismen:=(pocet-cisel);
          c:=0;
          p:=0;
    
        for i:=1 to ((pocet)) do
         begin
          pom:=random(2);
    
          if ((pom=0) and (c<>cisel)) then
               generuj_cisla;
    
          if ((pom=0) and (c=cisel)) then
               generuj_znaky;
    
          if ((pom=1) and (p<>pismen)) then
               generuj_znaky;
    
          if ((pom=1) and (p=pismen)) then
               generuj_cisla;
         end
      end;
    
    Generuj_cisla a generuj_znaky jsou procedury, které vypadají takto :
    procedure generuj_cisla;
    begin
       znak := random(10)+48; {generuje cisla}
       c:=c+1;
       write(vystup,chr(znak));
    end;
    
    procedure generuj_znaky;
    begin
     if (random(2))=0 then
       begin
         znak := random(26)+65; {generuje velka pismena}
         p:=p+1;
         write(vystup,chr(znak))
       end
     else
       begin
         znak := random(26)+97; {generuje male pismena}
         p:=p+1;
         write(vystup,chr(znak));
       end;
    end;
    
    Netušíte někdo jak to odladit aby mi neulítával ten jeden či dva znaky? Vyjma možnosti, že je na konci spočítám a přebývající smažu.
    Černé díry jsou tam, kde Bůh dělil nulou. -- Steven Wright one Liners
    25.6.2007 23:15 zuzi
    Rozbalit Rozbalit vše Re: Algoritmus pro generování znaků
    Za predpokladu ze by to misto nul generovalo znaky a misto jednicek cisla tak je to to cos hledal?
    int main(int argc,char **argv)
    {
       // pocet znaku
       const int count = 1000;
    
       // pomer
       float rate = 0.256;
       int zero_rate = (int)(rate*(float)count);
       int sum = count;
    
       int z_cnt = 0;
       int o_cnt = 0;
    
       do {
          if (rand()%sum < zero_rate) {
             putchar('0');
             z_cnt++;
             zero_rate--;
          }
          else {
             putchar('1');
             o_cnt++;
          }
       } while(--sum > 0);
    
       register float f_count = (float)count;
       printf("\nfinal rate: %f : %f\n",(float)z_cnt/f_count,(float)o_cnt/f_count);
    
       return 0;
    }
    
    27.6.2007 10:32 Lukáš Zapletal | skóre: 42 | blog: lzapův svět | Olomouc
    Rozbalit Rozbalit vše Re: Algoritmus pro generování znaků
    cat /dev/urandom | tr -cd A-Za-z0-9 | fold -w8 | head -n 1
    27.6.2007 10:38 Kyosuke | skóre: 28 | blog: nalady_v_modre
    Rozbalit Rozbalit vše Re: Algoritmus pro generování znaků
    A co procentní podíly? ;-) Ale cat+tr je dobrá kombinace. :-)

    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.