import pandas as pd
import time

def cal_ground_sat(g_time, data):
    last = 'target1'
    service_time = {} 
    ground_sat = {} 
    for i in range(data.shape[0]):
        ground =data.iloc[i][0]
        sat = data.iloc[i][1]
        start = 60*data.iloc[i][2]
        end = 60*data.iloc[i][3]

        if (ground != last):
            service_time = sorted(service_time.items(), key=lambda kv: (kv[1], kv[0]))
            non_zero_sat = [sat for sat, ser_time in service_time if ser_time != 0.0]
            print(ground)
            try:
                sat_index = non_zero_sat
                ground_sat[last] = sat_index
                service_time = {}
            except:
                print("error")

        if (g_time >= start) & (g_time <= end):
            ser_time = end - g_time
            service_time[sat] = ser_time

        if (g_time < start):
            service_time[sat] = 0.0
        
        if (g_time > end):
            service_time[sat] = 0.0
        if (i + 1) == data.shape[0]:
            service_time = sorted(service_time.items(), key=lambda kv: (kv[1], kv[0]))
            non_zero_sat = [sat for sat, ser_time in service_time if ser_time != 0.0]

            sat_index = non_zero_sat
            ground_sat[ground] = sat_index
        last = ground

    return ground_sat