Společnost Backblaze zveřejnila statistiky spolehlivosti pevných disků používaných ve svých datových centrech za rok 2025. Ke konci roku 2025 vlastnila 349 462 pevných disků. Průměrná AFR (Annualized Failure Rate), tj. pravděpodobnost, že disk během roku selže, byla 1,36 %. V roce 2024 to bylo 1,57 %. V roce 2023 to bylo 1,70 %. V roce 2022 to bylo 1,37 %.
Nástroj sql-tap je proxy mezi aplikací a databází, které zachytává všechny SQL dotazy a zobrazuje je v terminálovém rozhraní. Zde lze téměř v reálném čase zkoumat dotazy, sledovat transakce a spouštět SQL příkaz EXPLAIN. Podporované databázové systémy jsou pouze PostgreSQL a MySQL. Zdrojový kód je dostupný na GitHubu, pod licencí MIT.
Byla vydána nová verze 9.2 textového editoru Vim (Vi IMproved). Přináší vylepšené doplňování, podporu schránky ve Waylandu, podporu XDG Base Directory (konfigurace v $HOME/.config/vim), vylepšené Vim9 skriptování nebo lepší zvýrazňování změn. Vim zůstává charityware. Nadále vybízí k podpoře dětí v Ugandě. Z důvodu úmrtí autora Vimu Brama Moolenaara a ukončení činnosti jím založené charitativní organizace ICCF Holland projekt Vim navázal spolupráci s charitativní organizaci Kuwasha.
Byl představen editor MonoSketch, webová aplikace pro tvorbu diagramů, technických nákresů, flowchartů a různých dalších vizualizací, to vše jenom z ASCII znaků. Všechny operace běží pouze v prohlížeči uživatele a neprobíhá tedy žádné nahrávání dat na server. Zdrojový kód aplikace (drtivá většina Kotlin, žádné C#) je dostupný na GitHubu pod licencí Apache 2.0.
Byla vydána nová verze 3.7.0 multiplatformního svobodného frameworku pro zpracování obrazu G'MIC (GREYC's Magic for Image Computing, Wikipedie). Přehled novinek i s náhledy nových filtrů na PIXLS.US.
Všem na AbcLinuxu vše nejlepší k Valentýnu aneb Dni lásky ke svobodnému softwaru (I love Free Software Day, Mastodon, 𝕏).
Eric Migicovsky představil Pebble Emulator, tj. emulátor hodinek Pebble (PebbleOS) běžící ve webovém prohlížeči. Za 6 hodin jej napsal Claude Code. Zdrojové kódy jsou k dispozici na GitHubu.
Byla vydána nová verze 3.41 frameworku Flutter (Wikipedie) pro vývoj mobilních, webových i desktopových aplikací a nová verze 3.11 souvisejícího programovacího jazyka Dart (Wikipedie).
Rusko zcela zablokovalo komunikační platformu WhatsApp, řekl včera mluvčí Kremlu Dmitrij Peskov. Aplikace, jejímž vlastníkem je americká společnost Meta Platforms a která má v Rusku na 100 milionů uživatelů, podle Peskova nedodržovala ruské zákony. Mluvčí zároveň lidem v Rusku doporučil, aby začali používat domácí aplikaci MAX. Kritici tvrdí, že tato aplikace ruské vládě umožňuje lidi sledovat, což úřady popírají.
Před 34 lety, ve čtvrtek 13. února 1992, se tehdejší Česká a Slovenská Federativní Republika oficiálně (a slavnostně) připojila k Internetu.
Na úvod trošku teorie.
(* 12 3 5)
Uvedený výraz v závorkách je příkladem seznamu, platí pro něj následující:
Obecný tvar výrazu vypadá takto:
(operátor hodnota1 hodnota2 ... hodnotaN)
Základní matematické operátory naleznete v tabulce:
| + | sčítání |
| - | odčítání |
| * | násobení |
| / | dělení |
Hodnotou může být jiný výraz nebo číselná konstanta, následující seznam obsahuje jejich příklady:
(1 3/2 3.14 2.66e25 -3 1+3i)
Je vidět, že Scheme zvládá nejen celá a racionální čísla, ale i čísla komplexní a zlomky.
Nyní na ukázku vyjádříme nějaký matematický výpočet pomocí syntaxe Scheme:
(11 - 3 + 4 - 2) * 3 / (15 + 3 + 2) * (5 * 6/7) (/ (* (- (+ 11 4) 3 2) 3) (* (+ 15 3 2) (* 5 6/7))) ; výsledek je 7/20
Poslední uvedený příklad vám možná přišel poněkud nepřehledný. Naštěstí nám Scheme poskytuje dostatek volnosti při formátování zdrojového kódu. Výraz pak může vypadat třeba takto:
(/ (* (- (+ 11 4) 3 2)
3)
(* (+ 15 3 2)
(* 5 6/7)))
Představte si, že potřebujete napsat ve Scheme nějaký složitý výraz, v němž se často vyskytuje nějaká konstanta. Kdybyste psali na její místo stále patřičnou hodnotu, bylo by možné, že
Naštěstí existuje konstrukce let, která uvedený problém řeši. Má tvar:
(let ((jméno1 hodnota1)
(jméno2 hodnota2)
...
jménoN hodnotaN))
(výraz))
K tématu si ukážeme jednoduchý příklad nezakládající se na realitě (neodvozoval jsem si jej, prachsprostě jsem si jej vymyslel):
(let ((pi 3.14) (x (+ -5/7 0.3e-3)))
(/ (* (+ pi x)
(- pi x))
2))
; výsledek je cca 4.675
Chceme-li proměnnou využívat i mimo výraz v konstrukci let, definujeme novou proměnnou:
(define jméno hodnota)
Například tedy:
(define pi 3.14) (define r 5) (* 2 pi r) ; obvod kruhu je 31.4
Kostrukce let nám mnohdy pomůže, ale jsou situace, kdy je úroveň abstrakce, kterou poskytuje, příliš nízká, protože umožňuje pouze nahrazení konkrétními čísly. Pokud chceme nahrazovat obecným vzorcem, použijeme konstrukci lambda:
((lambda (jméno) (vzorec)) (výraz))
Ještě si ukážeme jednoduchý příklad:
((lambda (x) (+ x x)) (* 2 8)) ; výsledek je 32
Konstrukce let a lambda jsou velmi užitečné na úrovni výrazů, jenže nám nepomohou, pohybujeme-li se na úrovni celého programu. Pak nastupují na řadu procedury. Zkráceně se zapisují:
(define (jméno argumenty) (tělo_funkce))
Argumenty jsou vstupní hodnoty s nimiž procedura pracuje.
(define (mocnina x) (* x x)) (* 3.14 (mocnina 5)) ; obsah kruhu o poloměru 5 je 78.5
Pokud píšeme nějaký program a chceme jej do budoucna uchovat, musíme jej zapsat do souboru (nejlépe s příponou .scm). Z interaktivního interpreta jej načteme konstrukcí load:
(load "cesta_k_souboru")
Malá ukázka:
david@schematic:~$ cat > priklad.scm (define (mocnina x) (* x x)) (mocnina 12) david@schematic:~$ mzscheme Welcome to MzScheme version 360, Copyright (c) 2004-2006 PLT Scheme Inc. > (load "priklad.scm") 144 >
Příště se budeme věnovat podmínkám a rekurzi -- Scheme právě jí nahrazuje cykly.
Přidávám několik odkazů na jiné zdroje. Jedná se o knihy (v angličtině) dostupné on-line:
Nástroje: Tisk bez diskuse
Tiskni
Sdílej:
"Kostrukce let nám mnohdy pomůže, ale jsou situace, kdy je úroveň abstrakce, kterou poskytuje, příliš nízká, protože umožňuje pouze nahrazení konkrétními čísly. Pokud chceme nahrazovat obecným vzorcem, použijeme konstrukci lambda"Přiznám se, že téhle pasáži moc nerozumím. Let není nic jiného než převlečená lambda.
((lambda (jméno) (vzorec)) (výraz))je přesně totéž, co
(let ((jméno výraz)) (vzorec))Možná by bylo lépe zřejmé, co máš na mysli tou "nízkou úrovní abstrakce", kdybys lépe vysvětlil to "nahrazení konkrétními čísly".
Konstrukce let a lambda jsou velmi užitečné na úrovni výrazů, jenže nám nepomohou, pohybujeme-li se na úrovni celého programu. Pak nastupují na řadu procedury.Tomu taky nerozumím.
To, co vytváří lambda, se také nazývá procedura. Tzv. top-level define forma
(define (jméno argumenty) (tělo_funkce))obdobně prostou transformací vede na
(define jméno
(lambda (argumenty)
(tělo_funkce)))
Tohle dokonce člověk najde přímo v R5RS.
Seznamy lze samozřejmě vnořovat, pak se vyhodnocují od toho nejhlouběji vnořeného.Tohle taky nedává smysl. Seznamy se přeci nevyhodnocují. Nepleteš si to s formami? A nezmizely Ti někam odkazy na konci článku?
Růžový čumáček drží palce do dalšího schemování a doporučuje přečíst si Lambda Papery, RnRS a SICP, aby nedošlo k nedorozumění studenta s jazykem.
Seznamy lze samozřejmě vnořovat, pak se vyhodnocují od toho nejhlouběji vnořeného.co naplat, ony vyhodnocovat pri trose dobre vule jdou
(eval (list '+ 1 2 3)), ale je to spis problem vadnosti celeho popisu a terminologie ;-] (btw. termin forma je lispovsky, r5rs tento termin nepouziva a pouziva misto toho jina zverstva, ale to je na uplne jinou diskuzi ;-])
pokud predpokladame vyhodnocovani z leva doprava (r5rs to nepredpoklada) pak v (+ (+ 1 2) (+ (+ 1 2) (+ 3 4))) vyraz (+ 3 4) bude vyhodnoceny jako jeden z poslednich.
cely ten clanek je takovy... jak bych to rekl... napsat clanek vyhodnocovani programu ve schemu, kde se termin symbol nebo s-vyraz nevyskytuje ani jednou a kdy termin ,,vyhodnocuje'' se vyskytuje prave jednou... je docela kumst.
define je trosku neco jineho, nez prirazeni hodnoty v klasickem smyslu, jak jsme u programovacim jazyku zvykli. Vytvari se tim nove prostredi, ve kterem se navaze na urcity symbol vyhodnoceni vyrazu. No a to ma zajimave dusledky, protoze s prostredim se daji delat psi kusy a s nim uzce souvisi i continuations, s kterymi se daji delat dalsi psi kusy (treba celkem jednoducha implementace multitaskingu) a doufam, ze se o techto tematech v nejakem budoucim pokracovani docteme.
define zadne prostredi nevytvari. define navaze v aktualnim prostredi hodnotu na symbol. nic vic nic min. ke vzniku prostredi dochazi v momente ,,zavolani uzivatelske funkce''.
(define foo (lambda (x) (* x x)) ; zadne prostredi nevzniklo, jen na symbol,
; foo je navazana funkce, ktera v sobe drzi
; (ukazatel na) rodicovske prostredi
(foo 1) ; vzniklo nove prostredi, kde na hodnotu x je navazana jednicka
; a v tomto prostredi se vyhodnoti (* x x)
A nezmizely Ti někam odkazy na konci článku?Viz "Odkazy a zdroje".
Nehlede na to, ze konstrukce let a lambda je mozne pouzit i na top-level urovni a define i v 'zanorene' urovni (s drobnou odchylkou v semantice oproti top-level define).Konstrukce let a lambda jsou velmi užitečné na úrovni výrazů, jenže nám nepomohou, pohybujeme-li se na úrovni celého programu. Pak nastupují na řadu procedury.Tomu taky nerozumím.To, co vytváří
lambda, se také nazývá procedura. Tzv. top-leveldefineforma