Byla vydána nová verze 4.6 (𝕏, Bluesky, Mastodon) multiplatformního open source herního enginu Godot (Wikipedie, GitHub). Přehled novinek i s náhledy v příspěvku na blogu.
Rozsáhlá modernizace hardwarové infrastruktury Základních registrů měla zabránit výpadkům digitálních služeb státu. Dnešnímu výpadku nezabránila.
Čínský startup Kimi představil open-source model umělé inteligence Kimi K2.5. Nová verze pracuje s textem i obrázky a poskytuje 'paradigma samosměřovaného roje agentů' pro rychlejší vykonávání úkolů. Kimi zdůrazňuje vylepšenou schopnost modelu vytvářet zdrojové kódy přímo z přirozeného jazyka. Natrénovaný model je dostupný na Hugging Face, trénovací skripty však ne. Model má 1 T (bilion) parametrů, 32 B (miliard) aktivních.
V Raspberry Pi OS lze nově snadno povolit USB Gadget Mode a díky balíčku rpi-usb-gadget (CDC-ECM/RNDIS) mít možnost se k Raspberry Pi připojovat přes USB kabel bez nutnosti konfigurování Wi-Fi nebo Ethernetu. K podporovaným Raspberry Pi připojeným do USB portu podporujícího OTG.
Konference Installfest 2026 proběhne o víkendu 28. a 29. března v budově FELu na Karlově náměstí v Praze. Přihlásit přednášku nebo workshop týkající se Linuxu, otevřených technologií, sítí, bezpečnosti, vývoje, programování a podobně lze do 18. února 0:15.
Fedora Flock 2026, tj. konference pro přispěvatele a příznivce Fedory, bude opět v Praze. Proběhne od 14. do 16. června. Na Flock navazuje DevConf.CZ 2026, který se uskuteční 18. a 19. června v Brně. Organizátoři konferencí hledají přednášející, vyhlásili Call for Proposals (CfP).
Z80-μLM je jazykový model 'konverzační umělé inteligence' optimalizovaný pro běh na 8-bitovém 4Mhz procesoru Z80 s 64kB RAM, technologii z roku 1976. Model používá 2-bitovou kvantizaci a trigramové hashování do 128 položek, což umožňuje zpracování textu i při velmi omezené paměti. Natrénovaný model se vejde do binárního souboru velkého pouhých 40 KB. Tento jazykový model patrně neprojde Turingovým testem 😅.
Digitální a informační agentura (DIA) na přelomu roku dokončila rozsáhlou modernizaci hardwarové infrastruktury základních registrů. Projekt za 236 milionů korun by měl zabránit výpadkům digitálních služeb státu, tak jako při loňských parlamentních volbách. Základní registry, tedy Registr práv a povinností (RPP), Informační systém základních registrů (ISZR) a Registr obyvatel (ROB), jsou jedním z pilířů veřejné správy. Denně
… více »Evropská komise (EK) zahájila nové vyšetřování americké internetové platformy 𝕏 miliardáře Elona Muska, a to podle unijního nařízení o digitálních službách (DSA). Vyšetřování souvisí se skandálem, kdy chatbot s umělou inteligencí (AI) Grok na žádost uživatelů na síti 𝕏 generoval sexualizované fotografie žen a dětí. Komise o tom dnes informovala ve svém sdělení. Americký podnik je podezřelý, že řádně neposoudil a nezmírnil rizika spojená se zavedením své umělé inteligence na on-line platformě.
Bratislava OpenCamp pokračuje vo svojej tradícii a fanúšikovia otvorených technológií sa môžu tešiť na 4. ročník, ktorý sa uskutoční 25. 4. 2026 na FIIT STU v Bratislave. V súčasnosti prebieha prihlasovanie prednášok a workshopov – ak máte nápad, projekt, myšlienku, o ktoré sa chcete podeliť s komunitou, OpenCamp je správne miesto pre vás.
Tak jsem si řekl, že zkusím programování v nějakém tom „skriptovacím“, opravdu vysokoúrovňovém jazyce, což mi přinese obrovskou produktivitu a pravděpodobně i sex-appeal. Už nějaký čas jsem chtěl prozkoušet Python ale řekl jsem si, že půjdu se současným hype a zkusím Ruby.
Na první pohled se mi Ruby moc líbí. Syntaxe je hezká, opravdu všechno je objekt. Nikdy jsem nepochopil, proč se délka seznamu v Pythonu získá jako len(s) a nikoliv s.len(). V Ruby jsou všechno objekty, kterým se posílají zprávy. Takže s.size. Je to konzistentní a elegantní.
Velmi pěkná je konvence s otazníky a vykřičníky v názvech metod. Metody často mají dvě verze, jednu s vykřičníkem na konci a druhou bez (například downcase a downcase! pro String). Vykřičníková verze změní vnitřní stav objektu. Verze bez vykřičníku vrátí modifikovaný objekt, ale původní objekt zůstane nezměněn. Metody končící otazníkem vracejí booleovskou hodnotu. Tyto konvence zlepšují čitelnost kódu.
Asi nejzásadnější vlastností jsou uzávěry (closures). Je to takové posílání bloků kódu jako parametr. Moc se mi to líbí a skoro jsem se na tom stal závislý. Dají se s tím dělat roztodivná kouzla ale praktický důsledek je ten, že zapomenete psát for-cykly. Výpis prvků seznamu vypadá následovně:
["ahoj", "nazdar", "blekota"].each {|s| puts s}
Mixování modulů do tříd se mi taky líbí. I když vícenásobná dědičnost z Pythonu je asi taky v pohodě (na rozdíl od C++).
Naprosto úchvatná je pružnost jazyka. Například aspektově orientované programování. Dolepit AOP například do Javy znamená buď nějaký preprocesing zdrojáku nebo postprocesing bajtkódu. V Ruby, kde můžete za běhu přejmenovávat metody (a na jejich místo vkládat svoje AOP interceptory), tohle problém není.
Přestože Ruby je z Japonska, jazyk nemá nějakou pořádnou podporu unicode. V podstatě jediná podpora je ta, že stringy můžou být kódované UTF-8 a nehrozí jim poškození. To vlastně není ani není problém, protože jazyky s podporou Unicode jako Java/C# používají kódování UTF-16 a tak funkce pro vrácení délky řetězce obecně nemusí vrátit počet znaků (viz muj starší post o unicode). IMHO lepší takhle mizerná leč konzistentní podpora v Ruby než dva typy řetězců (obyč a unicode) v Pythonu.
Díky přizpůsobivosti jazyka není problém dodat třídě String příslušnou funkcionalitu. Je několik projektů, které navážejí do jazyka Unicode z knihovny ICU, ale bohužel není žádné hotové, standardní a obecně používané řešení.
Vlákna jsou asi největší (a pro mě osobně nepřekonatelná) slabina Ruby. Ruby nepoužívá vlákna operačního systému (jako posix threads), ale má svoji vlastní implementaci. I když interpret vlákna pravidelně střídá a vytváří tak jakous takous preempci, vše běží v jednom systémovém vlákně. V době nástupu vícejádrových procesorů je to nešťastné. Ve webových aplikacích se to dá obejít puštěním více procesů přes (fast)CGI, jenže já chci psát i výkonné desktopové aplikace.
Musím říct, že to byla moc příjemná zkušenost. Programuje se v tom opravdu hezky a zdá se, že opravdu rychleji než třeba v Javě. Samozřejmě jsem v tom nepsal nic velkého (a díky těm zpropadeným vláknům ani nebudu) takže těžko říct, jestli se v tom něco opravdu velkého napsat dá.
Jdu vyzkoušet Groovy 
Tiskni
Sdílej:
„Přestože Ruby je z Japonska, jazyk nemá nějakou pořádnou podporu unicode.“Ne „přestože“, ale „protože“. Japonci mají s Unicode docela problémy. Sice nejsou tak velcí, aby s tím trendem něco, zmohli, ale koušou, potvůrky...
Pokud jde o vlákna, má to i svoje výhody. Vlákna mimo OS mají obrovský výkon (viz Erlang) a Ruby svůj vláknový kód houfně používá pro kontinuace. Navíc díky tomu běhá Ruby i na OS, které vlákna nemají (32b DOS...
) Návrh implementace je zkrátka hromada kompromisů... Navíc Ruby poměrně dost řeší neblokování vláken při interakci se systémem (IO) - no, nevýhoda je ten SMP provoz a některé ty homebrew Cčkové extenze se nemusejí chovat hezky, to je pravda. Ale ono se už něco vaří (přesněji YARV). Věřím, že pro některé účely v jazyku green threads asi zůstanou (mj. pro ty kontinuace), ale vychytat takový složitý model v úplnosti asi nebude sranda. Jsem docela zvědavý...
Holt si to lingvisticky zkazili v polovině prvního tisíciletí n.l.
Na druhou stranu, pak by Japonci nebyli schopni psát tak krásné básně. Co na tom, že jim člověk bez znalosti japonštiny neporozumí a přeložit to nejde.
["a", "b", "c"].each {|s| puts s}“, o kterých se zmiňuješ, se mi moc nelíbí, a dělá mi problém to vůbec přečíst a zorientovat se v tom. I když je pravda, že až donedávna jsem nevěděl, co ta konstrukce vlastně dělá. Raději si tam dám for a rozhodím to na dva řádky, než luštit hromadu závorek a |kolejniček|.
Jak píšeš v druhém odstavci o občas menší objektovosti Pythonu (len(s)), také mě to zezačátku překvapilo. Osobně a skromně si myslím, že je to možná kvůli rychlosti. Jinak fajnovej blogpost, tento typ článků bych na netu viděl rád častěji.
Scheme na vás, holomci...
Ten len() taky musí kontrolovat typ objektu v paměti, žádná výhra. O rychlosti to nebude, spíš o Kvídově „přelétavém návrhu“. Matz měl v tomhle změru jasnou vizi, ostatně to celé postavil na Smalltalku. No, docela si tím zjednodušil práci...
(#inject a spol...)
>>> s = 'abc'
>>> s.__len__()
3
BTW, ta podtržítka by se měla zakázat, to má být ta čitelnost?
Podle mně jsou tam úplně zbytečně...
. Je to trochu nekonzistentní syntaxe. Asi je to proto, že v Pythonu je možné psát čistě procedurálně.
A uzávěry (closures), ty se mi na Smalltaku také líbily, zvláště metody select, accept, reject a tak dále.
. Kdyby mi neslo o vlastnosti jazyka, tak se nebudu ptat na to, jestli jdou Ruby a C-syntax dohromady.
chmod 111
root /devel/sh # chmod 111 ie6 root /devel/sh # ./ie6a IE6 nastartoval
* dev-php5/php-qt
Available versions: !0.0.2
Installed: none
Homepage: http://php-qt.berlios.de
Description: PHP 5 bindings for the Qt4 framework.
) Ale diky.
Takže asi něco jako kdybych ve webové aplikaci používal glib? (Předtím jsem tomu rozuměl tak, že bych přes Qt např. namaloval dialog a on se zobrazil jako webová stránka.)
No tak to by dost možná šlo udělat, jen by se musel udělat poměrně šílený backend (ajaxový?
), kromě stávajícího Xkového, jablečného a wokýnkového...
Já radši dám přednost tomu pluginu do browseru, přijde mi docela sexy.