import os
import pandas
import requests
import sklearn.cluster
from scipy.cluster.hierarchy import fcluster
from sklearn.cluster import KMeans
from sklearn.preprocessing import scale
from sklearn_extra.cluster import KMedoids
from statistics import mean
import sys
from sklearn.cluster import KMeans
from sklearn.preprocessing import OneHotEncoder
from sklearn.compose import ColumnTransformer
from sklearn.pipeline import Pipeline
from sklearn.impute import SimpleImputer
from sklearn.preprocessing import StandardScaler
from sklearn.metrics import pairwise_distances_argmin_min
# from functions import *

def run_experiment(data,k, distance_matrix,dist_function):


    k_means_clustering = KMeans(n_clusters=k).fit(data).labels_
    kmeans_centers = KMeans(n_clusters=k).fit(data).cluster_centers_
    kmedoids = KMedoids(n_clusters=k, metric=dist_function, init='k-medoids++')
    k_medoids_clustering = kmedoids.fit(data).labels_
    kmedoids_centers = kmedoids.cluster_centers_

   
    return k_means_clustering, k_medoids_clustering, kmeans_centers, kmedoids_centers