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?
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.
Implementace VPN softwaru WireGuard (Wikipedie) pro Windows, tj. WireGuard pro Windows a WireGuardNT, dospěly do verze 1.0.
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 [𝕏].
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.
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.
Qwen (čínská firma Alibaba Cloud) představila novou verzi svého modelu, Qwen3.6‑35B‑A3B. Jedná se o multimodální MoE model s 35 miliardami parametrů (3B aktivních), nativní kontextovou délkou až 262 144 tokenů, 'silným multimodálním vnímáním a schopností uvažování' a 'výjimečnou schopností agentického kódování, která se může měřit s mnohem rozsáhlejšími modely'. Model a dokumentace jsou volně dostupné na Hugging Face, případně na čínském Modelscope. Návod na spuštění je už i na Unsloth.
Sniffnet, tj. multiplatformní (Windows, macOS a Linux) open source grafická aplikace pro sledování internetového provozu, byl vydán ve verzi 1.5. V přehledu novinek je vypíchnuta identifikace aplikací komunikujících po síti.
V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Forgejo byla vydána ve verzi 15.0 (Mastodon). Forgejo je fork Gitei.
Současně se SUSECON 2026 proběhne příští čtvrtek v Praze také komunitní Open Developer Summit (ODS) zaměřený na open source a openSUSE. Akce se koná ve čtvrtek 23. 4. (poslední den SUSECONu) v Hilton Prague (místnost Berlin 3) a je zcela zdarma, bez nutnosti registrace na SUSECON. Na programu jsou témata jako automatizace (AutoYaST), DevOps, AI v terminálu, bezpečnost, RISC-V nebo image-based systémy. Všichni jste srdečně zváni.
function random(min, max) {
var num = Math.floor(Math.random() * (max - min + 1)) + min;
return num;
}
Já jsem si usmyslel, že když ji budu volat v rozmezí čísel -3 až 3 (tedy random(-3, 3)), nechci jako výsledek dostat nulu. Tak jsem funkci upravil následovně:
function random(min, max) {
var num = Math.floor(Math.random() * (max - min + 1)) + min;
if (num == 0) {random(min, max)} else {return num};
}
Jenže jsem zjistil, že funkce kromě celých čísel v zadaném rozsahu občas vrací i undefined. Tak jsem hledal čím to a našel jsem diskuse, zda je vhodné psát return do bloku else. Z nich jsem sice nepochopil, proč dostávám jako výslednou hodnotu někdy undefined, ale stejně jsem funkci upravil na
function random(min, max) {
var num = Math.floor(Math.random() * (max - min + 1)) + min;
if (num == 0) random(min, max);
return num;
}
Výsledkem této úpravy bylo, že undefined se už mezi výslednými hodnotami funkce nevyskytovalo, zato se mezi ostatními čísly vyskytovala nula; čili jako by podmínka ve funkci nebyla. Už ani nevím, proč mě napadlo udělat ještě jednu úpravu, a to
var num;
function random(min, max) {
num = Math.floor(Math.random() * (max - min + 1)) + min;
if (num == 0) random(min, max);
return num;
}
a teprve potom funkce fungovala tak, jak jsem si představoval na začátku, to znamená, že při volání random(-3, 3) vracela čísla -3, -2, -1, 1, 2, 3, ale nikdy nulu (a taky nikdy undefined).
Moje otázka zní, proč je to tak, jak to je. Tuším, že to nějak souvisí s platností proměnné num, ale nevím, jak.
Děkuji za vysvětlení.
Řešení dotazu:
Proměnná num je lokální pro daný běh funkce. Pokud tu funkci zavoláš (třeba rekurzivně) víckrát, má každý běh této funkce svoji nezávislou proměnnou num. Tudíž ten řádek:
if (num == 0) random(min, max);
změní hodnotu num jen v tom vnitřním volání random(), zatímco tady zůstane hodnota nezměněná. Funkce sice na tomhle řádku vrátí hodnotu, ale ta se okamžitě zahodí, protože ji nepřiřazuješ do žádné proměnné. Musel bys tam mít:
if (num == 0) num = random(min, max);
aby to něco dělalo.
Před rekurzivním voláním random(min, max) chybí return. Od toho se celý problém odvíjí. Hodnota vrácená rekurzivním voláním se tím pádem zahodí a nikam dál se nevrací.
Vůbec nepíšeš, co přesně má ta funkce dělat, jaké vstupy má podporovat a jaké výstupy má generovat. Mají to být všechno integery? Libovolná čísla? Něco jiného? Hint: Co když bude min mít (zhruba) hodnotu pí? Na takový dotaz se pak odpovídá těžko.
Budu tedy dál předpokládat, že argumenty mají být integery. (To by se ale mělo v prakticky použitelném kódu ověřit, případně specifikovat, co se má stát, pokud to nebudou integery.) Takže první iterace:
function random(min, max) {
var num = Math.floor(Math.random() * (max - min + 1)) + min;
return num == 0 ? random(min, max) : num;
}
To^^^ je ale pořád ještě fujtajbl, protože dobu běhu té funkce a počet úrovní rekurze je potřeba deterministicky omezit. Sice je krajně nepravděpodobné, že by hloubka rekurze překročila povolenou hloubku zásobníku, ale spoléhat se tímto způsobem na náhodu je ošklivé. Vznikají tak chyby, kvůli kterým pak software jednou za rok za podivných okolností zařve. Takové chyby jsou těžko reprodukovatelné a těžko odhalitelné.
Takový jednoduchý nápad: Co takhle zjistit, jestli zadaný rozsah čísel obsahuje nulu, a pokud ano, jednoduše se jí při generování náhodného čísla vyhnout?
function random(min, max) {
if (min > max) [min, max] = [max, min];
var num = function(range) {
return Math.floor(Math.random() * range) + min;
};
if (min > 0 || max < 0) {
return num(max - min + 1);
} else {
var result = num(max - min);
return result >= 0 ? result + 1 : result;
}
}
Tohle^^^ je pořád hodně ošklivé, ale vrací to náhodné číslo z celého rozsahu kromě nuly a nemá to v sobě žádnou náhodnou rekurzi.
function random(min, max) {
var num = Math.floor(Math.random() * (max - min)) + min;
return (num >= 0) ? (num + 1) : num;
}
Tohle přece nefunguje. Pro záporné rozsahy nikdy nevrací max (random(-2, -1)) a pro kladné rozsahy nikdy nevrací min (random(1, 2)). Jo, kdyby se to aspoň chovalo konzistentně co do vyloučení / zahrnutí mezí, ale ani to ne.
Nazývejme prosím věci pravými jmény. Korektní řešení problému se nejmenuje „komplikace“ a vracení čísel z jiného než požadovaného rozsahu se nejmenuje „řešení“.
Takže v tomto případě nevidím nic špatného ve spolehání se na náhodu.
Ne, spoléhat se na náhodu není nikdy přijatelné. Programování je přesná technická disciplína, nikoliv modlitba k bohu slunce.
Ještě pár reakcí na tyhle nesmysly těžkého kalibru:
Za prvé, abych nepokoušel dobrou vůli těch, kteří jsou ochotni odpovědět, jsem se zeptal jen na jednu izolovanou věc, po nikom jsem nechtěl, aby řešil ještě spoustu dalších věcí kolem.
Není jistější způsob, jak pokoušet dobrou vůli těch, kdo chtějí odpovědět, než ptát se nepřesně a vágně.
Proč bych tedy psal, jaké vstupy má funkce přijímat či jaké očekávané hodnoty má vracet, když to s jádrem problému nesouvisí?
Protože to s jádrem problému nejen souvisí, ale dokonce to je samotné jádro problému. Jádrem samotného programování je totiž přesné pochopení problému, přesná specifikace problému a rozdělení problému do menších celků, které lze vyjádřit ve formě zdrojového kódu. Pokud první dvě fáze celého procesu selhaly (a zjevně selhaly), jaký má potom smysl zabývat se nějak izolovaně tou třetí fází?
Za druhé ovšem stejně nechápu ta dodatečná bezpečnostní opatření.
To nejsou žádná „bezpečnostní opatření“; jde o nezbytnou součást korektního řešení daného problému. Je zkrátka několik jednoduchých zásad, bez kterých se člověk při programování neobejde. Zásada číslo jedna: Na náhodu se nikdy nespoléhá.
Funkce má přece volat samu sebe jen v případě, kdy se do proměnné num dosadí hodnota 0 - a to sice může nastat několikrát po sobě, ale rozhodně ne tolikrát, aby kvůli tomu hrozila nějaká havárie.
Kde přesně je tohle zaručeno a jak? Znova: Pokud si můžu být něčím naprosto jistý, neexistuje důvod spoléhat na náhodu.
…maximálně třikrát nebo čtyřikrát…Čím je to maximum omezené? Pětkrát se to stát nemůže? Šestkrát taky ne? Jak to? Kdyby programátoři uvažovali takhle, použitelný počítač by se na světě hledal velmi těžko.
function random(min, max) {
var num = Math.floor(Math.random() * (max - min + 1)) + min;
return (num == 0) ? random(min, max) : num;
}
Tiskni
Sdílej: