Awk: subtrai a primeira linha de todas as linhas e multiplica por fator

0

Eu tenho um arquivo que contém alguns números

$ cat file.dat
0.092593
0.048631
0.027957
0.030699
0.026250
0.038156
0.011823
0.013284
0.024529
0.022498
0.013217
0.007105
0.018916
0.014079

Eu quero subtrair o primeiro número de todos os outros números e, em seguida, multiplicar a diferença com 627,509. Saída esperada

$ cat newfile.dat
0.000000
-27.586551
-40.559672
-38.839042
-41.630830
-34.159707
-50.683902
-49.767111
-42.710773
-43.985243
-49.809154
-53.644489
-46.232981
-49.268242

Supondo que eu queira fazer isso com o awk, eu preciso criar uma variável contendo o primeiro número antes da instrução awk, por exemplo

factor=$(head -1 myfile.dat)

ou posso fazer isso completamente com o awk?

    
por Yoda 19.09.2018 / 17:27

2 respostas

1

Que tal

awk 'NR == 1 {DELTA = $0} {$0 = ($0 - DELTA) * FAC; print}' FAC=627.509 file
    
por 19.09.2018 / 17:32
0

Isso parece funcionar:

$ awk -v c=627.509 'NR==1 { b=$1 } { printf( "%0.6f\n", ( $1-b ) * c ) }' file.dat
0.000000
-27.586551
-40.559672
-38.839042
-41.630830
-34.159707
-50.683902
-49.767111
-42.710773
-43.985243
-49.809154
-53.644489
-46.232981
-49.268242
    
por 19.09.2018 / 19:09

Tags