annotate commons/pyRepetUnit/convCoord/ConvMapChr2Chunk.py @ 18:94ab73e8a190

Uploaded
author m-zytnicki
date Mon, 29 Apr 2013 03:20:15 -0400
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
18
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
1 from copy import deepcopy
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
2 from commons.core.sql.TableMapAdaptator import TableMapAdaptator
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
3 from commons.core.coord.Map import Map
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
4 import os
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
5
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
6 class ConvMapChr2Chunk(object):
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
7
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
8 def __init__(self, db, table, chunk_table, outtable):
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
9 self._tablename = table
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
10 self._chunk_table = chunk_table
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
11 self._db = db
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
12 self._outtable = outtable
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
13
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
14 def convert(self):
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
15 """
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
16 Convert a 'set' table format.
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
17 """
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
18 temp_file=str(os.getpid()) + ".on_chunk"
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
19 fout=open(temp_file,'w')
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
20
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
21 str_mask = "SELECT * FROM "+\
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
22 self._chunk_table + " WHERE chr='%s' AND ("+\
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
23 "(%d BETWEEN LEAST(start,end) AND GREATEST(start,end))"+\
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
24 " OR (%d BETWEEN LEAST(start,end) AND GREATEST(start,end))"+\
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
25 " OR (%d <= LEAST(start,end) AND %d >= GREATEST(start,end)));"
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
26
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
27 iTMA = TableMapAdaptator(self._db, self._tablename)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
28 chr_list = iTMA.getSeqNameList()
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
29
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
30 for chr in chr_list:
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
31 mlist = iTMA.getMapListFromChr(chr)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
32 for m in mlist:
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
33 sql_cmd = str_mask%(m.seqname,m.getMin(),m.getMax(),m.getMin(),m.getMax())
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
34 self._db.execute(sql_cmd)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
35 res = self._db.fetchall()
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
36 for i in res:
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
37 chunk = Map(i[0],i[1],int(i[2]),int(i[3]))
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
38
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
39 new_m = deepcopy(m)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
40 new_m.seqname = chunk.name
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
41
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
42 if (m.start > chunk.start and m.start < chunk.end):
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
43 new_m.start = m.start - chunk.start + 1
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
44 if (m.end > chunk.start and m.end < chunk.end):
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
45 new_m.end = m.end - chunk.start + 1
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
46
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
47 if m.isOnDirectStrand():
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
48 if m.start <= chunk.start:
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
49 new_m.start = 1
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
50 if m.end >= chunk.end:
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
51 new_m.end = chunk.end - chunk.start + 1
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
52 else:
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
53 if m.end <= chunk.start:
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
54 new_m.end = 1
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
55 if m.start >= chunk.end:
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
56 new_m.start = chunk.end - chunk.start + 1
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
57
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
58 new_m.write(fout)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
59
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
60 fout.close()
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
61
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
62 self._db.createTable(self._outtable, "map", temp_file)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
63
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
64 os.remove(temp_file)