Byla vydána nová verze 4.6 multiplatformního integrovaného vývojového prostředí (IDE) pro rychlý vývoj aplikaci (RAD) ve Free Pascalu Lazarus (Wikipedie). Využíván je Free Pascal Compiler (FPC) 3.2.2.
Byla vydána nová verze 3.23.0 FreeRDP, tj. svobodné implementace protokolu RDP (Remote Desktop Protocol). Opravuje 11 bezpečnostních chyb.
Španělský softwarový inženýr oznámil, že se mu podařilo na dálku ovládat sedm tisíc robotických vysavačů po celém světě. Upozornil tak na slabé kybernetické zabezpečení těchto technologií a jejich možné a snadné zneužití. Nesnažil se hacknout všechny robotické vysavače po světě, ale pouze propojil svůj nový DJI Romo vysavač se zařízením Playstation. Aplikace podle něj ihned začala komunikovat se všemi sedmi tisíci spotřebiči a on je
… více »Momo je fenka cavapoo, která svými náhodnými stisky kláves bezdrátové klávesnice vytváří jednoduché počítačové hry. Technicky to funguje tak, že Raspberry Pi s připojenou bluetooth klávesnicí posílá text do Claude Code, který pak v Godotu píše hry a sám je i testuje pomocí screenshotů a jednoduchých simulovaných vstupů. Za stisky kláves je Momo automaticky odměňována pamlsky. Klíčový je pro projekt prompt, který instruuje AI, aby i
… více »GNU awk (gawk), implementace specializovaného programovacího jazyka pro zpracování textu, byl vydán ve verzi 5.4.0. Jedná se o větší vydání po více než dvou letech. Mezi četnými změnami figuruje např. MinRX nově jako výchozí implementace pro regulární výrazy.
Internetový prohlížeč Ladybird ohlásil tranzici z programovacího jazyka C++ do Rustu. Přechod bude probíhat postupně a nové komponenty budou dočasně koexistovat se stávajícím C++ kódem. Pro urychlení práce bude použita umělá inteligence, při portování první komponenty prohlížeče, JavaScriptového enginu LibJS, bylo během dvou týdnů pomocí nástrojů Claude Code a Codex vygenerováno kolem 25 000 řádků kódu. Nejedná se o čistě autonomní vývoj pomocí agentů.
Byl vydán Mozilla Firefox 148.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Nově lze snadno povolit nebo zakázat jednotlivé AI funkce. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 148 bude brzy k dispozici také na Flathubu a Snapcraftu.
Byla vydána nová verze 22.1.0, tj. první stabilní verze z nové řady 22.1.x, překladačové infrastruktury LLVM (Wikipedie). Přehled novinek v poznámkách k vydání: LLVM, Clang, LLD, Extra Clang Tools a Libc++.
X86CSS je experimentální webový emulátor instrukční sady x86 napsaný výhradně v CSS, tedy bez JavaScriptu nebo dalších dynamických prvků. Stránka 'spouští' assemblerovový program mikroprocesoru 8086 a názorně tak demonstruje, že i prosté CSS může fungovat jako Turingovsky kompletní jazyk. Zdrojový kód projektu je na GitHubu.
Po šesti letech byla vydána nová verze 1.3 webového rozhraní ke gitovým repozitářům CGit.
#!/bin/bash
avg=$(
sum=0
count=0
while read line; do
sum=$(($sum + $line))
count=$(($count + 1))
echo $(($sum / $count))
done |
tail -1)
echo $avg
Neexistuje nejake krajsie riesenie? Alebo nejaky obecny trik na podobne ulohy?
Trik so
set -- niecov tomto pripade tiez nepomaha. este jedno riesnie bez pipy a tail, ale podobne odporne
avg=$(sum=0
count=0
while read line; do
sum=$(($sum + $line))
count=$(($count + 1))
echo -n " $(($sum / $count))"
done)
echo ${avg##* }
sum=0
count=0
while read line; do
sum=$((sum + line))
count=$((count + 1))
done
avg=$((sum/count))
echo $avg
#!/bin/bash
sum=0
count=0
echo -e "1\n2\n3" |
while read line; do
sum=$((sum + line))
count=$((count + 1))
done
echo $count
avg=$((sum/count))
echo $avg
Takze takto malo vyzerat povodne zadanie. To ze prenasat premenne nejdu viem, ale zaujima ma potom, ci niekto nepozna nejaky elegantnejsi trik ako to obist.
Cele to potrebujem na skript, ktory cez identify (z ImageMagick) si pozistuje velkosti vysku mnoziny obrazkov, a potom vsetky upravi na ich priemernu vysku.
A cele by som to chcel mat zavisle na co najmensej mnozine softwaru. Zatial si vystacim s bashom, sedom a ImageMagickom. A aj bez toho sedu by som sa zaobisiel.
for line in `echo -e "1\n2\n3"` ; do sum=$((sum + line)) count=$((count + 1)) done
sum=0
count=0
while read line; do
sum=$((sum + line))
count=$((count + 1))
done < vstupni_soubor
echo $count
avg=$((sum/count))
echo $avg
for i in `TU SA NIECO ROZBALI`; do ... done
mktemp) nebo použít pojmenovanou rouru (mkfifo). Jinak novější bash dokáže konstrukci for i in `TU SA NIECO ROZBALI` zvládnout pro libovolně velký výsledek. Při práci s čísly se to dá asi tolerovat, ale ...
Cele to potrebujem na skript, ktory cez identify (z ImageMagick) si pozistuje velkosti vysku mnoziny obrazkov, a potom vsetky upravi na ich priemernu vysku. A cele by som to chcel mat zavisle na co najmensej mnozine softwaru. Zatial si vystacim s bashom, sedom a ImageMagickom. A aj bez toho sedu by som sa zaobisiel.Já bych to dělal takhle:
#!/usr/bin/env python
import os, Image
def find_avg_height(filenames):
sum_height = 0.0
for filename in filenames:
im = Image.open(filename)
sum_height += im.size[1] #height
return sum_height / len(filenames)
def change_height(filenames, newheight):
for filename in filenames:
im = Image.open(filename)
ratio = im.size[1] / newheight
new_size = (int(round(im.size[0] / ratio)),
int(round(newheight)))
out = im.resize(new_size, Image.ANTIALIAS)
out.save('n_' + filename)
filenames = os.listdir('.')
avg_height = find_avg_height(filenames)
print 'Average height is', avg_height
change_height(filenames, avg_height)
Je to program, který projde všechny obrázky v daném adresáři, u každého zjistí rozměry a spočítá z nich průměrnou výšku (Pozor na skripty v shellu - celočíselné dělení nestačí). Pak opět projde všechny obrázky a u každého z nich změní velikost tak, aby výška byla ta vypočítaná a poměr stran zůstal. Nový obrázek bude mít na začátku "n_".
ok, a teraz verziu pracujucu s cmdline zadavanim suborov.No když to musí být ...
import sys filenames = sys.argv[1:]
Inak, celociselne delenie v pohode staci, ale ktovie, mozno vie python vygenerovat aj pol pixeluReálná čísla jsou v mém případě potřeba především kvůli výpočtu nové hodnoty šířky (trojčlenkou).
python nebo perl, případně awk. Druhé řešení je použít stdout tak jak jsi to naznačil a nejedná se o žádný trik. Jen bych podotknul, že mi není jasné, proč to tiskneš pořád dokola, aby jsi to použil jen jednou. Třeba takto
avg=$(
echo -e "1\n2\n3" |
(
sum=0
count=0
while read line
do
let sum+=line
let count++
done
[[ $count -gt 0 ]] && echo $((sum/count))
)
)
echo $avgMyslím, že to není až tak obskurní řešení. Obskurní je nepoužít nějaký ze silnějších jazyků
Tiskni
Sdílej: