Last change
on this file since 59b70a was e1a46d, checked in by Frederik Heber <heber@…>, 16 years ago |
All of my python script put into ESPACK and adapted with @PYTHON@ and so on.
|
-
Property mode
set to
100755
|
File size:
1.1 KB
|
Rev | Line | |
---|
[e1a46d] | 1 | #!@PYTHON@
|
---|
| 2 | #
|
---|
| 3 | # Cuts a specific block from a given PDB file
|
---|
| 4 |
|
---|
| 5 | import sys, string, re, math
|
---|
| 6 | wrerr = sys.stderr.write
|
---|
| 7 | wrout = sys.stdout.write
|
---|
| 8 |
|
---|
| 9 | # check for parameters
|
---|
| 10 | if len(sys.argv) < 5:
|
---|
| 11 | wrerr("Usage: "+sys.argv[0]+" <datafile> <offset to x=3> <offset to ID> <border_epsilon>\n")
|
---|
| 12 | sys.exit(1)
|
---|
| 13 |
|
---|
| 14 | input = open(sys.argv[1], "r")
|
---|
| 15 | output = open(sys.argv[1]+".exttypes", "w")
|
---|
| 16 | offset=int(sys.argv[2])
|
---|
| 17 | offsetID=int(sys.argv[3])
|
---|
| 18 | border_epsilon=float(sys.argv[4])
|
---|
| 19 |
|
---|
| 20 | # get box bounds
|
---|
| 21 | min=[ 1000., 1000., 1000.]
|
---|
| 22 | max=[ 0., 0., 0.]
|
---|
| 23 | for line in input:
|
---|
| 24 | if "END" in line:
|
---|
| 25 | break
|
---|
| 26 | entries=line.split()
|
---|
| 27 | for n in range(3):
|
---|
| 28 | if max[n] < float(entries[offset+n]):
|
---|
| 29 | max[n] = float(entries[offset+n])
|
---|
| 30 | if min[n] > float(entries[offset+n]):
|
---|
| 31 | min[n] = float(entries[offset+n])
|
---|
| 32 |
|
---|
| 33 | input.seek(0)
|
---|
| 34 |
|
---|
| 35 | for line in input:
|
---|
| 36 | if "END" in line:
|
---|
| 37 | break
|
---|
| 38 | entries=line.split()
|
---|
| 39 | i=0
|
---|
| 40 | for n in range(3):
|
---|
| 41 | if (((float(entries[offset+n]) - min[n]) < border_epsilon) or ((-float(entries[offset+n]) + max[n]) < border_epsilon)):
|
---|
| 42 | i+=1
|
---|
| 43 | if i>0:
|
---|
| 44 | output.write("%d\t1\n" % (int(entries[offsetID])))
|
---|
| 45 |
|
---|
| 46 | input.close()
|
---|
| 47 | output.close()
|
---|
Note:
See
TracBrowser
for help on using the repository browser.