annotate SMART/Java/Python/ncList/test/Test_randExample.py @ 6:769e306b7933

Change the repository level.
author yufei-luo
date Fri, 18 Jan 2013 04:54:14 -0500
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
6
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
1 import unittest
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
2 import time
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
3 from SMART.Java.Python.ncList.test.MockFindOverlaps_randomExample import *
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
4 from SMART.Java.Python.FindOverlapsOptim import FindOverlapsOptim
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
5
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
6 class Test_F_FindOverlaps_randomExample(unittest.TestCase):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
7
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
8 def setUp(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
9 self._output_optim = 'output_optim.gff3'
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
10
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
11 def test_creatRandomExampleWithMOverlaps(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
12 inputRefGff3FileName = 'refMOverlaps.gff3'
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
13 inputQueryGff3FileName = 'queryMOverlaps.gff3'
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
14 outputDataName = 'timeResult.dat'
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
15 fTime = open(outputDataName, 'w')
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
16 fTime.write('NbRef\tNbQuery\tNbOverlap\ttime\n')
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
17 numberOfRefReads = 1000
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
18 chromSize = 100000
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
19 while numberOfRefReads <= 1000:
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
20 numberOfQReads = 1000
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
21 while numberOfQReads <= 1000:
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
22 print 'ref size = %d, query size = %d' %(numberOfRefReads, numberOfQReads)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
23 iMFOR_ref = MockFindOverlaps_randomExample(inputRefGff3FileName, 'ref', numberOfRefReads, chromSize)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
24 iMFOR_ref.write()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
25 iMFOR_query = MockFindOverlaps_randomExample(inputQueryGff3FileName,'q', numberOfQReads, chromSize)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
26 iMFOR_query.write()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
27 iFOO = FindOverlapsOptim(0)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
28 iFOO.setRefFileName(inputRefGff3FileName, "gff3")
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
29 iFOO.setQueryFileName(inputQueryGff3FileName, "gff3")
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
30 iFOO.setOutputFileName(self._output_optim)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
31 iFOO.prepareIntermediateFiles()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
32 iFOO.createNCLists()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
33
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
34 startTime_optim = time.time()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
35 iFOO.compare()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
36 endTime_optim = time.time()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
37 totalTime_optim = endTime_optim - startTime_optim
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
38 print 'we took %s second.' % (totalTime_optim)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
39 nbOverlap = iFOO._nbOverlaps
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
40 iFOO.close()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
41 fTime.write('%d\t%d\t%d\t%.2f\n' % (numberOfRefReads, numberOfQReads, nbOverlap, totalTime_optim))
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
42 numberOfQReads *= 10
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
43 numberOfRefReads *= 10
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
44 fTime.close()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
45 os.remove(inputQueryGff3FileName)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
46 os.remove(inputRefGff3FileName)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
47 os.remove(self._output_optim)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
48
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
49
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
50 if __name__ == "__main__":
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
51 unittest.main()