Před necelými čtyřmi měsíci byl Steven Deobald jmenován novým výkonným ředitelem GNOME Foundation. Včera skončil, protože "nebyl pro tuto roli v tento čas ten pravý".
Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 156 (pdf).
Armbian, tj. linuxová distribuce založená na Debianu a Ubuntu optimalizovaná pro jednodeskové počítače na platformě ARM a RISC-V, ke stažení ale také pro Intel a AMD, byl vydán ve verzi 25.8.1. Přehled novinek v Changelogu.
Včera večer měl na YouTube premiéru dokumentární film Python: The Documentary | An origin story.
Společnost comma.ai po třech letech od vydání verze 0.9 vydala novou verzi 0.10 open source pokročilého asistenčního systému pro řidiče openpilot (Wikipedie). Zdrojové kódy jsou k dispozici na GitHubu.
Ubuntu nově pro testování nových verzí vydává měsíční snapshoty. Dnes vyšel 4. snapshot Ubuntu 25.10 (Questing Quokka).
Řada vestavěných počítačových desek a vývojových platforem NVIDIA Jetson se rozrostla o NVIDIA Jetson Thor. Ve srovnání se svým předchůdcem NVIDIA Jetson Orin nabízí 7,5krát vyšší výpočetní výkon umělé inteligence a 3,5krát vyšší energetickou účinnost. Softwarový stack NVIDIA JetPack 7 je založen na Ubuntu 24.04 LTS.
Národní úřad pro kybernetickou a informační bezpečnost (NÚKIB) spolu s NSA a dalšími americkými úřady upozorňuje (en) na čínského aktéra Salt Typhoon, který kompromituje sítě po celém světě.
Společnost Framework Computer představila (YouTube) nový výkonnější Framework Laptop 16. Rozhodnou se lze například pro procesor Ryzen AI 9 HX 370 a grafickou kartu NVIDIA GeForce RTX 5070.
Google oznamuje, že na „certifikovaných“ zařízeních s Androidem omezí instalaci aplikací (včetně „sideloadingu“) tak, že bude vyžadovat, aby aplikace byly podepsány centrálně registrovanými vývojáři s ověřenou identitou. Tato politika bude implementována během roku 2026 ve vybraných zemích (jihovýchodní Asie, Brazílie) a od roku 2027 celosvětově.
Když jsem si dnes přečetl blogpost „Generátor jmen!“ tak jsem si řekl: proč taky neuveřejnit něco z toho, co jsem vyplodil ve školním prostředí. Takže tady to je – superjednoduchá kalkulačka v ANSI C umožňující počítat rovnice o jedné proměnné kterou jsem udělal jako semestrálku na předmět „Programování v C“).
Co je na ní tak výjimečného? Kromě toho, že je moje, tak nic. Ale konečně jsem měl důvod trošku prozkoumat numerické metody. Tak, teď už jsem v podstatě práskl vše. Pokud je zadán dostatečně malý interval ve kterém se kořeny mají hledat, pro počáteční aproximaci kořene se použije metoda bisekce a následně pro upřesnění Newtonova metoda. Pokud z nějakého důvodu nelze použít metodu bisekce (interval je příliš velký nebo se nepodařilo najít změnu znaménka) je použita přímo Newtonova metoda. Samozřejmě kvůli jejím vlastnostem se může stát, že kořen nelze nalézt.
Možná jedinou zvláštností je implementace symbolické derivace. Ovšem není použitá. Kvůli značné obecnosti použitých vzorců může dojít k nechtěnému „oddefinování“ derivace funkce v některých bodech. Krásným příkladem budiž funkce f(x) = x^2, která po zde zderivování dává výsledek x^2 * (2/x) (jak je vidno jednoduché případy jako 0*f(x) jsou ošetřeny) který evidentně není definován v 0. Bohužel vzhledem k nedostatku času jsem neměl možnost udělat kvalitnější funkci na zjednodušování takovýchto výrazů (nebo obecně výrazů jako je f(x)/g(x)). Samozřejmě se nejedná o jednoduchou věc (jinak by bylo mnohem více programů jako je Maxima nebo Mathematica) ale rozhodně se jedná zajímavý problém k vyřešení.
Takže pro všechny zvědavce, kteří by se chtěli pokochat (ne zrovna dokonalým) kódem nebo to dokonce používat, adresa je:
http://stativ.kx.cz/src/index.php?text_id=13Archiv se zdrojáky je ke stažení úplně dole.
Tiskni
Sdílej:
First problem is in ln (natural logarithm) which is undefined for numbers smaller or equal to 1Ta jednička bude asi překlep. Jinak, zkoušel jsem si to přeložit v Mac OS X (gcc 4.2.1). Kromě pár varování ve stack.c o aritmetice s void pointerem mi to hodilo chybu v support.h, kde si to stežuje, že funkce isnumber je už definována v ctype.h. Moc jsem to nezkoumal, ale kód vypadá docela pěkně, dobrá práce. Škoda toho derivování, aby to dobře derivovalo výrazy jako x^2 by snad nemělo bejt tak težký, nebo ne?
Díky, opraveno.First problem is in ln (natural logarithm) which is undefined for numbers smaller or equal to 1Ta jednička bude asi překlep.
Jinak, zkoušel jsem si to přeložit v Mac OS X (gcc 4.2.1). Kromě pár varování ve stack.c o aritmetice s void pointerem mi to hodilo chybu v support.h, kde si to stežuje, že funkce isnumber je už definována v ctype.h.To je docela zajímavý, vypadá to na nějaké nestandardní rozšíření (já třeba isnumber() v ctype.h nemám). Nicméně opravím.
Moc jsem to nezkoumal, ale kód vypadá docela pěkně, dobrá práce.Díky.
Škoda toho derivování, aby to dobře derivovalo výrazy jako x^2 by snad nemělo bejt tak težký, nebo ne?To jsem si myslel taky. Pokud by šlo jenom o případ f(x)^C, kde C by byla konstanta tak je to jednoduché. Ale pak by nebylo možno derivovat i „horší“ věci jako je třeba x^(sin(x)). Kvůli tomu používám chytrý vzoreček (opravdu je obecný, což se hodí), který mi poradili na tamějším fóru. Ten bohužel způsobuje dané problémy. Popravdě napadlo mě to rozdělit na případ, kdy je to f(x)^C a všechno ostatní, nezdá se mi to ale tak elegantní řešení. Akorát teď by to chtělo to zjednodušování výrazů
#if !defined(_ANSI_SOURCE) && (!defined(_POSIX_C_SOURCE) || defined(_DARWIN_C_SOURCE))
Ale zdá se mi, že už jsi to mezitím opravil, teď už se mi to zkompiluje.
-ansi -pedantic
(je to v makefile).
A ano opravil jsem to – přejmenoval jsem tu funkci. Vypadá to, že je běžná na BSD systémech. Proto je podle mne lepší ji přejmenovat (nemate to lidi). Člověk pak taky nemusí spoléhat na nějaké přepínače kompilátoru aby nedocházelo ke konfliktům.
Taky jsem trochu pátral a vypadá to, že definovat _ANSI_SOURCE nebo _POSIX_SOURCE není věc překladače, nýbrž programátora. Nejlepší odkaz (dotaz plus odpovědi), který jsem našel, je tento: http://www.mail-archive.com/freebsd-hackers@freebsd.org/msg23363.html.Díky, zajímavé počtení.
I tak je ale asi stejně lepší nepoužívat konfliktní názvy funkcí (pak už jen zbývá vědět, které to jsou ty konfliktníSouhlasím..