Teste de desempenho com números primos em BASH
Publicado por Andre Miguel (última atualização em 06/01/2010)
[ Hits: 8.222 ]
Certo dia me deparei com um bottom brincalhão que dizia: "Digite qualquer número primo de 11 dígitos para continuar". Fiquei com vontade de saber se havia tal número.
Então fiz um shellzinho para testar. Primeiros 10, beleza; primeiros 100, beleza, primeiros 1000, já não estava mais tão rápido. Percebi a oportunidade de utilizar este script como benchmark de desempenho entre servidores, sejam de mesmo hardware ou não.
Quando você executar, pode demorar a aparecer alguma coisa na tela, mas ele está rodando. Pode verificar com strace ou truss (Solaris).
Após você testar e tiver a coragem de descomentar a linha do 10000000000, me poste aqui os números primos que você achou!
Dica: para temporizar a execução, utilize a linha abaixo:
$ bash primo.sh 2>&1 |egrep 'Primo|real' |awk '{if ($2 ~ /s/){split($2,minsplit,"m");min+=minsplit[1];seg+=substr($2,3,5);}else{print min,seg; print $0; min=seg=0; }}'
Você deverá ter uma saída como esta:
0 0.1
Primo: 11
0 0.248
Primo: 13
0 0.587
Primo: 17
#for (( i=10000000000; i<= 999999999999; i++)); do for (( i=10; i<= 999; i++)); do j=$i; primo=0; time cat <<-EOF $(for (( j=$i; j>=1; j--)); do if [ `echo $((i%j))` -eq 0 ]; then ((primo++)); if [ $primo -gt 2 ]; then j=1; else if [ $primo -eq 2 ] && [ $j -eq 1 ]; then echo "Primo: $i"; fi fi fi; done;) EOF done
Cadastro Regras de Controle de Banda - CBQ
Instalar o Java diretamente do site oficial
Wayland em alta, IA em debate e novos ventos para distros e devices
Qt 6.10 e Python 3.14 puxam o ritmo do software livre nesta quarta
Atualizações de Apps, Desktop e Kernel agitam o ecossistema Linux nesta terça-feira
Miyoo Mini Plus + Onion OS (Linux)
IA local no bolso, novo visual no Raspberry Pi OS e mais destaques do software livre
Como mudar o nome de dispositivos Bluetooth via linha de comando
Adicionando o repositório backports no Debian 13 Trixie
queria saber como instalar o android power tools igual ao winux no lin... (7)
Como listar os arquivos em "bloquin... [RESOLVIDO] (6)
Como colocar atalho para uma pasta na área de trabalho do Ubuntu 24.04... (2)