import numpy as np
import matplotlib.pyplot as plt
from stage3 import stage_embedding, evaluate_kendall_abs
from scipy.optimize import linear_sum_assignment
from scipy.stats import kendalltau, rankdata
from scipy.spatial.distance import pdist, sqeuclidean, euclidean, squareform, cdist
from scipy.linalg import eigh # For symmetric matrix eigenvalues/vectors
from scipy.sparse import lil_matrix, csr_matrix, vstack as sp_vstack
from scipy.sparse.linalg import lsqr # Solver for sparse least squares
import umap
import mdso
from sklearn.manifold import TSNE
from sklearn.decomposition import FastICA, PCA
import time
import warnings
import pathlib, urllib.request, gzip, pandas as pd
import GEOparse
import scanpy as sc
import pyreadr
from mpl_toolkits import mplot3d
from experiment_utils import fiedler_permutation, spectral_ordering
from util_functions import spectral_lin_reg




X = np.array(pyreadr.read_r('embryo_expr.Rds')[None])

hour_collected = np.array(pyreadr.read_r("embryo_order.Rds")[None])
hour_collected = np.ndarray.flatten(hour_collected)


pca_obj = PCA(n_components=2)
pca_result = pca_obj.fit_transform(X)


umap_obj = umap.UMAP(n_components=1)
umap_result = np.ndarray.flatten(umap_obj.fit_transform(pca_result))
UMAP_order_indices = rankdata(umap_result)
tau = evaluate_kendall_abs(hour_collected, UMAP_order_indices)
print("UMAP Kendall's Tau: ", tau)

start = time.time()
_, fiedler_order_indices = fiedler_permutation(pca_result, sigma = 200)
tau = evaluate_kendall_abs(hour_collected, fiedler_order_indices)
print("Fiedler Kendall's Tau: ", tau)

start = time.time()
t_SNE_order_indices = rankdata(np.ndarray.flatten(TSNE(n_components = 1, perplexity = 30).fit_transform(pca_result)))
tau = evaluate_kendall_abs(hour_collected, t_SNE_order_indices)
print("tSNE Kendall's Tau: ", tau)

start = time.time()
recanati_order_indices = np.argsort(spectral_ordering(pca_result, sigma = 100))
tau = evaluate_kendall_abs(hour_collected, recanati_order_indices)
print("Recanati Kendall's Tau: ", tau)

_, stage_order_indices = stage_embedding(pca_result, r = 50, neighbour_min = 5, embedding = "linreg")
tau = evaluate_kendall_abs(hour_collected, stage_order_indices)
print("STAGE Kendall's Tau: ", tau)

# umap_obj = umap.UMAP(n_components=1)
# umap_result = np.ndarray.flatten(umap_obj.fit_transform(X))
# UMAP_order_indices = rankdata(umap_result)
# tau = evaluate_kendall_abs(hour_collected, UMAP_order_indices)
# print("UMAP Kendall's Tau: ", tau)

# start = time.time()
# _, fiedler_order_indices = fiedler_permutation(X, sigma = 100)
# tau = evaluate_kendall_abs(hour_collected, fiedler_order_indices)
# print("Fiedler Kendall's Tau: ", tau)

# start = time.time()
# t_SNE_order_indices = rankdata(np.ndarray.flatten(TSNE(n_components = 1, perplexity = 30).fit_transform(X)))
# tau = evaluate_kendall_abs(hour_collected, t_SNE_order_indices)
# print("tSNE Kendall's Tau: ", tau)

# start = time.time()
# recanati_order_indices = np.argsort(spectral_ordering(X, sigma = 100))
# tau = evaluate_kendall_abs(hour_collected, recanati_order_indices)
# print("Recanati Kendall's Tau: ", tau)

# _, stage_order_indices = stage_embedding(X, r = 250, neighbour_min = 5, embedding = "linreg")
# tau = evaluate_kendall_abs(hour_collected, stage_order_indices)
# print("STAGE Kendall's Tau: ", tau)
