Uživatelé mobilních telefonů s Linuxem si nyní mohou nainstalovat aplikaci Mobilní Datovka. Díky tomu je přístup k datovým schránkám dostupný i na zařízeních s mobilními linuxovými distribucemi, jako jsou například Mobian, NixOS Mobile, pmOS atd. Aplikace je dostupná na Flathubu.
Software Freedom Conservancy v novém dokumentu shrnuje doporučení, jak přistupovat ke generativní AI založené na LLM při přispívání do svobodného a open-source softwaru. Mimo jiné vyzývá k obezřetnosti, transparentnosti a revizi generovaného kódu člověkem.
Byla vydána nová verze 5.6.0 programu na úpravu digitálních fotografií darktable (Wikipedie).
Na čem aktuálně pracují vývojáři GNOME a KDE Plasma? Pravidelný přehled novinek v Týden v GNOME a Týden v KDE Plasma. V Týdnu v GNOME je zmíněn flatpak balíček pro GIMP 0.54.1 z roku 1996. Jedná se o poslední verzi GIMPu postavenou nad toolkitem Motif.
Home Assistant Operating System, tj. linuxová distribuce optimalizována pro hostování Home Assistanta a jeho aplikací, byl vydán v nové major verzi 18.0.
Po šestiletém úsilí byla z jádra Linux odstraněna funkce strncpy(). Všechna předchozí volání této funkce byla převedena na bezpečnější alternativy.
Byla vydána nová verze 261 správce systému a služeb systemd (Wikipedie, GitHub). Z novinek lze vypíchnout nový subsystém IMDS (Cloud "Instance Metadata Service"), nový příkaz storagectl nebo novou komponentu systemd-sysinstall.
Vývojové prostředí Qt Creator bylo vydáno ve verzi 20 (seznam změn). Novinky zahrnují hlavně rozšíření pro integraci LLM agentů nebo minimalistický editační režim uživatelského rozhraní („zen mode“).
Už jste se prolétli na webu Google Earth? Přibyl tam Simulátor letu (Nástroje / Simulátor letu). Funguje i bez účtu Google [𝕏].
Byla vydána nová verze 4.7 (𝕏, 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.
double getFi() {
final double signRe = signum(re);
final double signIm = signum(im);
if (signRe == 0.0d) {
if (signIm == 0.0d) {
return 0.0d;
} else if (signIm == 1.0d) {
return PI05;
} else {
return -PI05;
}
}
if (signIm == 0.0d) {
if (signRe == 0.0d) {
return 0.0d;
} else if (signRe == 1.0d) {
return 0.0d;
} else {
return -PI;
}
}
double result;
if (abs(im) <= abs(re)) {
result = atan(im / re);
if (signRe == 1.0d) {
if (signIm == 1.0d) {
//upper right - no change
} else {
//lower right - no change
}
} else {
if (signIm == 1.0d) {
//upper left
result = PI + result;
} else {
//lower left
result = -PI + result;
}
}
} else {
result = atan(re / im);
if (signIm == 1.0d) {
result = PI05 - result;
} else {
result = -PI05 - result;
}
}
return result;
}
Důležité je, že ta moje implementace vrací hodnoty v rozsahu <-Pi, Pi>, zatímco ta "ukázková" (triviální) jen v rozsahu <-Pi/2, Pi/2>, což způsobuje přesně tu chybu ve vykreslování, kterou jste ukázal.
Poznámky:
Complex používám názvy vnitřních proměnných re, im místo Re, ImPI05 je konstanta s hodnotou Math.PI * 0.5dgetFi() je zase možná až příliš složitá; důležité ale je, že vrací správné hodnotyJFrame až po tom stisku tlačítka. A o stisku tlačítka se dozvíte tak, že na to tlačítko "navěsíte" listener - ale tady vás opět odkážu na ten tutorial, konkrétně na kapitolu Writing Event Listeners.
Tiskni
Sdílej: