KiCad (Wikipedie), sada svobodných softwarových nástrojů pro počítačový návrh elektronických zařízení (EDA), byl vydán v nové major verzi 10.0.0 (𝕏). Přehled novinek v příspěvku na blogu.
Letošní Turingovou cenu (2025 ACM A.M. Turing Award, Nobelova cena informatiky) získali Charles H. Bennett a Gilles Brassard za základní přínosy do oboru kvantové informatiky, které převrátily pojetí bezpečné neprolomitelné komunikace a výpočetní techniky. Jejich protokol BB84 z roku 1984 umožnil fyzikálně zaručený bezpečný přenos šifrovacích klíčů, zatímco jejich práce o kvantové teleportaci položila teoretické základy pro budoucí kvantový internet. Jejich práce spojila fyziku s informatikou a ovlivnila celou generaci vědců.
Firefox 149 dostupný od 24. března přinese bezplatnou vestavěnou VPN s 50 GB přenesených dat měsíčně (s CZ a SK se zatím nepočítá) a zobrazení dvou webových stránek vedle sebe v jednom panelu (split view). Firefox Labs 149 umožní přidat poznámky k panelům (tab notes, videoukázka).
Byla vydána nová stabilní verze 7.9 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 146. Přehled novinek i s náhledy v příspěvku na blogu.
Dle plánu byla vydána Opera GX pro Linux. Ke stažení je .deb i .rpm. V plánu je flatpak. Opera GX je webový prohlížeč zaměřený na hráče počítačových her.
GNUnet (Wikipedie) byl vydán v nové major verzi 0.27.0. Jedná se o framework pro decentralizované peer-to-peer síťování, na kterém je postavena řada aplikací.
Byly publikovány informace (technické detaily) o bezpečnostním problému Snapu. Jedná se o CVE-2026-3888. Neprivilegovaný lokální uživatel může s využitím snap-confine a systemd-tmpfiles získat práva roota.
Nightingale je open-source karaoke aplikace, která z jakékoliv písničky lokálního alba (včetně videí) dokáže oddělit vokály, získat text a vše přehrát se synchronizací na úrovni jednotlivých slov a hodnocením intonace. Pro separaci vokálů využívá UVR Karaoke model s Demucs od Mety, texty písní stahuje z lrclib.net (LRCLIB), případně extrahuje pomocí whisperX, který rovněž využívá k načasování slov. V případě audiosouborů aplikace na
… více »Po půl roce vývoje od vydání verze 49 bylo vydáno GNOME 50 s kódovým názvem Tokyo (Mastodon). Podrobný přehled novinek i s náhledy v poznámkách k vydání a v novinkách pro vývojáře.
Článek na stránkách Fedora Magazinu informuje o vydání Fedora Asahi Remixu 43, tj. linuxové distribuce pro Apple Silicon vycházející z Fedora Linuxu 43.
#!/usr/bin/python
import random, time
print 'Wait ...'
fw = file('cisla.txt', 'w')
for i in range(1000000):
fw.write('%f\n' %(random.random()))
fw.close()
start = time.time()
s = 0
lines = 0
for line in file('cisla.txt'):
s += float(line)
lines += 1
print s/lines
print time.time() - start
start = time.time()
s = 0
for i, line in enumerate(file('cisla.txt')):
s += float(line)
print s/(i + 1)
print time.time() - start
start = time.time()
numbers = [float(line) for line in file('cisla.txt')]
print sum(numbers)/len(numbers)
print time.time() - start
#include<stdio.h>
int main(void){
FILE* fr;
double f, s = 0, lines = 0;
fr = fopen("cisla.txt", "r");
while (fscanf(fr, "%lf\n", &f) != EOF){
s += f;
lines += 1;
}
printf("%12.12f\n", s/lines);
fclose(fr);
return 0;
}
Je to cca 3-4 krát rychlejší než v pythonu.
#!/bin/bash
set -- `while read n; do
sucet=$((sucet + n))
lines=$((lines + 1))
echo $sucet $lines
done <subor.in | tail -n -1`
sucet=$1
lines=$2
echo $((sucet / lines))
# # ak to chces na 2 destinne miesta:
# avgfrac=$((sucet * 100 / lines))
# echo ${avgfrac%??}.${avgfrac: -2}
#!/bin/sh
text=`cat soubor_dat |tr '\n' '+'`0
pocet=`cat soubor_dat |wc -l`
prumer=`echo "($text)/$pocet"|bc -l`
echo $prumer
#!/bin/awk -f
BEGIN{lines=0;s=0;}
{lines++;s+=$1;}
END{print "prumer je", s/lines;}
no a awk už tak skoro "v shellu" je, že? Nebo teda v posixu. Teda *nixu. Teda ... no prostě je to víc v shellu než třeba bc. A určitě je to mnohem blíž shellu než python. Ale asi je to trochu dál shellu než třeba "tail". To jsou problémy ...
awk, bc, perl, python nebo C), než se snažit ji za každou cenu udolat nevhodně zvoleným nástrojem.
awk(1)
#!/usr/bin/python
# -*- coding:utf-8 -*-
import random, time
radky = 5
sloupce = 10
fw = file('cisla.txt', 'w')
for i in range(radky):
cisla_str = ['%f' %(i*j) for j in range(sloupce)]
radek = ';'.join(cisla_str)
fw.write('%s\n' %radek)
fw.close()
fr = file('cisla.txt')
sums = [float(x) for x in fr.readline().split(';')]
for i, line in enumerate(fr):
for j, val_str in enumerate(line.split(';')):
sums[j] += float(val_str)
i += 2
avgs = [x/i for x in sums]
print sums
print avgs
A na začátku se neví, kolik těch sloupců je, že?
Tiskni
Sdílej: