diff spring_minz.py @ 16:16eb2acaaa20 draft

"planemo upload commit 0e4e1f8de9464b411152c44f4edd099db8ad9e0b"
author guerler
date Sat, 24 Oct 2020 17:48:06 +0000
parents 4a4888bf0338
children c790d25086dc
line wrap: on
line diff
--- a/spring_minz.py	Sun Sep 27 20:52:58 2020 +0000
+++ b/spring_minz.py	Sat Oct 24 17:48:06 2020 +0000
@@ -13,12 +13,12 @@
 		for index, line in enumerate(file):
 			columns = line.split()
 			core = columns[0]
-			partner = columns[2]
+			partner = columns[-1]
 			if core not in crossreference:
 				crossreference[core] = []
 			crossreference[core].append(partner)
 	print ("Loaded cross reference from `%s`." % args.crossreference)
-	targets = get_template_scores(args.target, args.minscore, args.idx)
+	toptarget, targets = get_template_scores(args.target, args.minscore, args.idx)
 	interactions = []
 	if not targets:
 		print("No targets found `%s`" % args.target)
@@ -27,8 +27,9 @@
 		for name in names:
 			input_directory = args.inputs.rstrip("/")
 			input_file = "%s/%s" % (input_directory, name)
-			templates = get_template_scores(input_file, args.minscore, args.idx)
+			toptemplate, templates = get_template_scores(input_file, args.minscore, args.idx)
 			minz = 0
+			mint = ""
 			for t in targets:
 				if t in crossreference:
 					partners = crossreference[t]
@@ -37,16 +38,18 @@
 							score = min(targets[t], templates[p])
 							if score > minz:
 								minz = score
+								mint = "%s\t%s\t%s\t%s" % (toptarget, toptemplate, t, p)
 			if minz > args.minscore:
-				interactions.append((name, minz))
-				print("Predicting: %s, min-Z: %s" % (name, minz))
+				interactions.append((name, minz, mint))
+				print("Predicting: %s, min-Z: %s, templates: %s" % (name, minz, mint))
 		interactions.sort(key=lambda tup: tup[1], reverse=True)
 	with open(args.output, 'a+') as output_file:
 		for i in interactions:
-			output_file.write("%s\t%s\t%s\n" % (args.name, i[0], i[1]))
+			output_file.write("%s\t%s\t%s\t%s\n" % (args.name, i[0], i[1], i[2]))
 
 def get_template_scores(hhr_file, min_score, identifier_length):
 	result = {}
+	toptemplate = None
 	identifier_length = identifier_length + 4
 	if os.path.isfile(hhr_file):
 		with open(hhr_file) as file:
@@ -57,8 +60,10 @@
 					template_id = line[4:identifier_length]
 					template_score = float(line[57:63])
 					if template_score > min_score:
+						if toptemplate is None:
+							toptemplate = template_id
 						result[template_id] = template_score
-	return result
+	return toptemplate, result
 
 if __name__ == "__main__":
 	parser = argparse.ArgumentParser(description='This script identifies interactions by detecting matching HH-search results.')
@@ -68,7 +73,7 @@
 	parser.add_argument('-x', '--idx', help='Length of identifier', type=int, default=6)
 	parser.add_argument('-l', '--list', help='Text file containing identifiers.', required=True)
 	parser.add_argument('-i', '--inputs', help='Directory containing `hhr` files', required=True)
-	parser.add_argument('-o', '--output', help='Output file containing minZ-scores`', required=True)
+	parser.add_argument('-o', '--output', help='Output file containing min-Z scores`', required=True)
 	parser.add_argument('-m', '--minscore', help='min-Z score threshold', type=int, default=10)
 	args = parser.parse_args()
 	main(args)
\ No newline at end of file