Spaces:
Sleeping
Sleeping
#!/usr/bin/env python | |
# coding: utf-8 | |
import os | |
script_dir = os.path.dirname(os.path.abspath(__file__)) | |
import pandas as pd | |
import numpy as np | |
import itertools | |
import multiprocessing | |
from scipy.spatial.distance import cdist | |
from numpy.linalg import norm | |
from scipy.stats import spearmanr | |
from tqdm import tqdm | |
manager = multiprocessing.Manager() | |
similarity_list = manager.list() | |
proteinListNew = manager.list() | |
representation_dataframe = "" | |
protein_names = "" | |
representation_name = "" | |
similarity_tasks = "" | |
detailed_output = False | |
def parallelSimilarity(paramList): | |
protein_embedding_dataframe = representation_dataframe | |
i = paramList[0] | |
j = paramList[1] | |
if j > i: | |
protein1 = proteinListNew[i] | |
protein2 = proteinListNew[j] | |
if protein1 in protein_names and protein2 in protein_names: | |
prot1vec = np.asarray(protein_embedding_dataframe.query("Entry == @protein1")['Vector'].item()) | |
prot2vec = np.asarray(protein_embedding_dataframe.query("Entry == @protein2")['Vector'].item()) | |
# Calculate Manhattan Distance and normalize | |
manhattanDist = cdist(prot1vec.reshape(1,-1), prot2vec.reshape(1,-1), 'cityblock') | |
manhattanDistNorm = manhattanDist / (norm(prot1vec,1) + norm(prot2vec,1)) | |
manhattanSim = 1 - manhattanDistNorm.item() | |
if norm(prot1vec, 1) == 0 and norm(prot2vec, 1) == 0: | |
manhattanSim = 1.0 | |
real = paramList[2] | |
similarity_list.append((real, manhattanSim)) | |
return similarity_list | |
def calculateCorrelationforOntology(aspect, matrix_type): | |
similarity_list[:] = [] | |
proteinListNew[:] = [] | |
similarityMatrixNameDict = { | |
"All": os.path.join(script_dir, "../data/preprocess/human_" + aspect + "_proteinSimilarityMatrix.csv"), | |
"500": os.path.join(script_dir, "../data/preprocess/human_" + aspect + "_proteinSimilarityMatrix_for_highest_annotated_500_proteins.csv"), | |
"Sparse": os.path.join(script_dir, "../data/preprocess/human_" + aspect + "_proteinSimilarityMatrix_for_highest_annotated_500_proteins.csv"), | |
"200": os.path.join(script_dir, "../data/preprocess/human_" + aspect + "_proteinSimilarityMatrix_for_highest_annotated_200_proteins.csv") | |
} | |
similarityMatrixFileName = similarityMatrixNameDict[matrix_type] | |
human_proteinSimilarityMatrix = pd.read_csv(similarityMatrixFileName) | |
human_proteinSimilarityMatrix.set_index(human_proteinSimilarityMatrix.columns, inplace=True) | |
proteinList = human_proteinSimilarityMatrix.columns | |
for prot in proteinList: | |
proteinListNew.append(prot) | |
if matrix_type == "Sparse": | |
sparsified_path = os.path.join(script_dir, "../data/auxilary_input/SparsifiedSimilarityCoordinates_" + aspect + "_for_highest_500.npy") | |
sparsified_similarity_coordinates = np.load(sparsified_path) | |
protParamList = sparsified_similarity_coordinates | |
else: | |
i = range(len(proteinList)) | |
j = range(len(proteinList)) | |
protParamList = list(itertools.product(i, j)) | |
protParamListNew = [] | |
for tup in tqdm(protParamList): | |
i = tup[0] | |
j = tup[1] | |
if matrix_type == "Sparse": | |
protein1 = proteinListNew[i] | |
protein2 = proteinListNew[j] | |
real = human_proteinSimilarityMatrix.loc[protein1, protein2] | |
tupNew = (tup[0],tup[1],real) | |
protParamListNew.append(tupNew) | |
else: | |
if j > i: | |
protein1 = proteinListNew[i] | |
protein2 = proteinListNew[j] | |
real = human_proteinSimilarityMatrix.loc[protein1, protein2] | |
tupNew = (tup[0],tup[1],real) | |
protParamListNew.append(tupNew) | |
pool = multiprocessing.Pool() | |
similarity_listRet = [] | |
for similarity_listRet in tqdm(pool.imap_unordered(parallelSimilarity, protParamListNew), total=len(protParamListNew), position=0, leave=True): | |
pass | |
pool.close() | |
pool.join() | |
real_distance_list = [value[0] for value in similarity_listRet] | |
manhattan_distance_list = [value[1] for value in similarity_listRet] | |
manhattanCorr = spearmanr(real_distance_list, manhattan_distance_list) | |
return (manhattanCorr[0], manhattanCorr[1]) | |
def calculate_all_correlations(): | |
results = {} | |
for similarity_matrix_type in similarity_tasks: | |
matrix_results = {} | |
for aspect in ["MF", "BP", "CC"]: | |
corr, p_value = calculateCorrelationforOntology(aspect, similarity_matrix_type) | |
corr_key = f"{similarity_matrix_type}_{aspect}_correlation" | |
p_value_key = f"{similarity_matrix_type}_{aspect}_p_value" | |
results[corr_key] = corr | |
results[p_value_key] = p_value | |
return results |