Sponsored Content
Top Forums Shell Programming and Scripting Taking largest (negative) number from column of coordinates and adding positive form to every other Post 302561889 by Corona688 on Wednesday 5th of October 2011 12:58:38 PM
Old 10-05-2011
That always seems to be the first column of that group in your data, though I presume it's not always so.

But that's why it always becomes zero here:

[code]$ awk '{ MIN=0;
for(N=6; N<=8; N++) if($N < MIN) MIN=$N
for(N=6; N<=8; N++) $N -= MIN }' < data
HETATM 1 C UNK 0 0 33.504 34.109 0.00 0.00 C+0
HETATM 2 C UNK 0 0 33.316 32.133 0.00 0.00 C+0
HETATM 3 C UNK 0 0 31.589 30.717 0.00 0.00 C+0
HETATM 4 C UNK 0 0 31.406 28.736 0.00 0.00 C+0
HETATM 5 C UNK 0 0 29.676 27.329 0.00 0.00 C+0
HETATM 6 C UNK 0 0 29.478 25.34 0.00 0.00 C+0
HETATM 7 C UNK 0 0 27.745 23.945 0.00 0.00 C+0
HETATM 8 C UNK 0 0 27.545 21.957 0.00 0.00 C+0
HETATM 9 C UNK 0 0 25.814 20.563 0.00 0.00 C+0
HETATM 10 C UNK 0 0 25.602 18.572 0.00 0.00 C+0
HETATM 11 C UNK 0 0 23.861 17.196 0.00 0.00 C+0
HETATM 12 C UNK 0 0 23.634 15.2 0.00 0.00 C+0
HETATM 13 C UNK 0 0 21.906 13.789 0.00 0.00 C+0
HETATM 14 C UNK 0 0 21.758 11.82 0.00 0.00 C+0
HETATM 15 C UNK 0 0 20.051 10.34 0.00 0.00 C+0
HETATM 16 C UNK 0 0 19.948 8.395 0.00 0.00 C+0
HETATM 17 O UNK 0 0 18.448 7.194 0.00 0.00 O+0
HETATM 18 P UNK 0 0 17.805 5.177 0.00 0.00 P+0
HETATM 19 O UNK 0 0 16.082 4.405 0.00 0.00 O+0
HETATM 20 O UNK 0 0 19.303 5.032 0.00 0.00 O+0
HETATM 21 O UNK 0 0 17.351 4.065 0.00 0.00 O+0
HETATM 22 H UNK 0 0 19.82 7.866 0.00 0.00 H+0
HETATM 23 H UNK 0 0 21.257 8.578 0.00 0.00 H+0
HETATM 24 H UNK 0 0 18.735 10.148 0.00 0.00 H+0
HETATM 25 H UNK 0 0 20.163 10.855 0.00 0.00 H+0
HETATM 26 H UNK 0 0 23.064 11.989 0.00 0.00 H+0
HETATM 27 H UNK 0 0 21.636 11.282 0.00 0.00 H+0
HETATM 28 H UNK 0 0 22.037 14.337 0.00 0.00 H+0
HETATM 29 H UNK 0 0 20.608 13.629 0.00 0.00 H+0
HETATM 30 H UNK 0 0 24.915 15.331 0.00 0.00 H+0
HETATM 31 H UNK 0 0 23.487 14.623 0.00 0.00 H+0
HETATM 32 H UNK 0 0 24.015 17.783 0.00 0.00 H+0
HETATM 33 H UNK 0 0 22.587 17.076 0.00 0.00 H+0
HETATM 34 H UNK 0 0 26.883 18.7 0.00 0.00 H+0
HETATM 35 H UNK 0 0 25.456 17.993 0.00 0.00 H+0
HETATM 36 H UNK 0 0 24.534 20.435 0.00 0.00 H+0
HETATM 37 H UNK 0 0 25.962 21.143 0.00 0.00 H+0
HETATM 38 H UNK 0 0 28.83 22.093 0.00 0.00 H+0
HETATM 39 H UNK 0 0 27.4 21.385 0.00 0.00 H+0
HETATM 40 H UNK 0 0 27.891 24.522 0.00 0.00 H+0
HETATM 41 H UNK 0 0 26.462 23.814 0.00 0.00 H+0
HETATM 42 H UNK 0 0 30.762 25.474 0.00 0.00 H+0
HETATM 43 H UNK 0 0 29.332 24.766 0.00 0.00 H+0
HETATM 44 H UNK 0 0 29.818 27.897 0.00 0.00 H+0
HETATM 45 H UNK 0 0 28.389 27.189 0.00 0.00 H+0
HETATM 46 H UNK 0 0 31.264 28.168 0.00 0.00 H+0
HETATM 47 H UNK 0 0 32.692 28.876 0.00 0.00 H+0
HETATM 48 H UNK 0 0 30.298 30.572 0.00 0.00 H+0
HETATM 49 H UNK 0 0 31.728 31.281 0.00 0.00 H+0
HETATM 50 H UNK 0 0 34.611 32.285 0.00 0.00 H+0
HETATM 51 H UNK 0 0 33.183 31.578 0.00 0.00 H+0
HETATM 52 H UNK 0 0 34.736 35.051 0.00 0.00 H+0
HETATM 53 H UNK 0 0 32.247 34.011 0.00 0.00 H+0
HETATM 54 H UNK 0 0 33.681 34.721 0.00 0.00 H+0
$[/code]
Doesn't do what you want.

Last edited by Corona688; 10-05-2011 at 01:59 PM.. Reason: columns off by one
 

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

Help in adding positive & negative values in a column

Hi Gurus, In my file I have an amount field from position 74 to 87, which contains values starting with '+' as well as '-'. I want to add all positive values in a varible called "CREDIT" and all negative values in a variable "DEBIT". I know, we can use grep to identify values with positive and... (4 Replies)
Discussion started by: berlin_germany
4 Replies

2. Programming

Adding 2 difft int to form a number

got 1 problem.. can someone help me wit the logic? Money Money ::operator+(const Money &rhs)const { Money temp; temp.a = a+rhs.a; temp.b = b+rhs.b; return temp; }//end i got 2 number e.g 6.2 and 3.8 (1 Reply)
Discussion started by: xiaojesus
1 Replies

3. Shell Programming and Scripting

Perl output with negative and positive numbers

Hello, For my weather station I have made a little perl script to put the data into cacti. The next problem I have. I can only get positive numbers or negative numbers. What do I do: Though a shell scrip I call the perl script. Shell script: #!/bin/sh cat data.txt | stats.pl Perl... (4 Replies)
Discussion started by: rbl-blacklight
4 Replies

4. Shell Programming and Scripting

Finding the most positive and negative value and defining its position

Hi, I have a file that looks like this: Jake 2 3 4 6 4 3 -2 -1 Jerry 1 2 3 2 1 7 -6 -1 Timmy -1 -4 -5 -8 9 3 1 I want to find the most positive and negative value for each row and also define its position (based on column #) So the output would look... (7 Replies)
Discussion started by: gisele_l
7 Replies

5. Shell Programming and Scripting

Sorting positive and negative values

Hello, I have a list like this : 1 2 -4 0 -3 -7 5 6 etc. Is there a way to remove all the positive values and print only the negative values, without using grep, sed or awk? Thanks, Prasanna (4 Replies)
Discussion started by: prasanna1157
4 Replies

6. Shell Programming and Scripting

addition of both positive and negative numbers

Let, I have three numbers +00123.25 -00256.54 +00489.23 I need to sum up all those three numbers, after storing them in three variables (say var1, var2, var3). I used both expr and BC, but they didn't work for me. But, I am not able to sum up them, as I don't have any idea how to... (13 Replies)
Discussion started by: mady135
13 Replies

7. Shell Programming and Scripting

Splitting a file based on positive and negative numbers

Dear All, I have to split a tab delimited file in two files based on the presence of a positive or negative in column number 9 , for example file: A 1 5 erg + 6766 0.9889 0.9817 9.01882 erg inside upstream B 1 8 erg2 + 6766 0.9889 0.9817 -9.22 erg2 inside... (3 Replies)
Discussion started by: paolo.kunder
3 Replies

8. Shell Programming and Scripting

Print smallest negative number with corresponding index from a column

considering the following table: ID col1 col2 col3 col4 1 -16.06801249 13.49785832 -56.57087607 -27.00500526 2 -1.53315720 0.71731735 -42.03602078 -39.78554623 3 -1.53315190 0.71731587 -42.03601548 ... (3 Replies)
Discussion started by: Birda
3 Replies

9. UNIX for Beginners Questions & Answers

Converting negative number to positive in a file

Hi ALL, I am having semi column separated file as below. I am having negative values for the records starting with 11095. How can I convert that positive number I tried this below seems not working sed 's/ \(*\)$/ -\1/;t;s/\(.*\)-/\1/ myfile myfile... (6 Replies)
Discussion started by: arunkumar_mca
6 Replies

10. UNIX for Beginners Questions & Answers

Splitting a file based on negative and positive numbers

I have a file that is pipe delimited and in Column F they have number values, both positive and negative. I need to take the one file I am starting with and split it into two separate files based on negative and positive numbers. What is the command to do so? And then I need to also transfer... (4 Replies)
Discussion started by: cckaiser15
4 Replies
COLRM(1)						    BSD General Commands Manual 						  COLRM(1)

NAME
colrm -- remove columns from a file SYNOPSIS
colrm [start [stop]] DESCRIPTION
The colrm utility removes selected columns from the lines of a file. A column is defined as a single character in a line. Input is read from the standard input. Output is written to the standard output. If only the start column is specified, columns numbered less than the start column will be written. If both start and stop columns are spec- ified, columns numbered less than the start column or greater than the stop column will be written. Column numbering starts with one, not zero. Tab characters increment the column count to the next multiple of eight. Backspace characters decrement the column count by one. ENVIRONMENT
The LANG, LC_ALL and LC_CTYPE environment variables affect the execution of colrm as described in environ(7). EXIT STATUS
The colrm utility exits 0 on success, and >0 if an error occurs. SEE ALSO
awk(1), column(1), cut(1), paste(1) HISTORY
The colrm command appeared in 3.0BSD. BSD
August 4, 2004 BSD
All times are GMT -4. The time now is 07:30 AM.
Unix & Linux Forums Content Copyright 1993-2022. All Rights Reserved.
Privacy Policy