import json
import csv
import numpy as np
import math
import pickle

vehicleInput = open('gt_vehicle_bbox/data.jsonl')
clusterInput = open('behavior_clusters.json')
locationInput = open('gt_location/data.jsonl')
outFile = open("predicatesObstacles.txt", "w")
json_list = list(vehicleInput)
location_list = list(locationInput)
driverLocation = {}
frames = []

with open('gnss/data.csv') as csvfile: #Code to extract location of driver vehicle
    lanes_reader = csv.reader(csvfile)
    next(lanes_reader)
    for row in lanes_reader:
        frame = row[0]
        lat_rad = (np.deg2rad(float(row[2])) + np.pi) % (2 * np.pi) - np.pi
        lon_rad = (np.deg2rad(float(row[3])) + np.pi) % (2 * np.pi) - np.pi
        R = 6378135 # Aequatorradii
        x = R * np.sin(lon_rad) * np.cos(lat_rad) # iO
        y = R * np.sin(-lat_rad) # iO
        z = row[4]
        driverLocation[frame] = (x,y,z)
        driverText = "driverLocation(" + str(frame) + ", " + str(x) + ", " + str(y) + ").\n"
        outFile.write(driverText)


cluster_json = json.load(clusterInput)
outputText = ""
for cluster_action in cluster_json:
    for cluster in cluster_json[cluster_action]:
        if math.dist([cluster['location'][0], cluster['location'][1]], [driverLocation[str(cluster['start_frame'])][0], driverLocation[str(cluster['start_frame'])][1]]) < 100:
            #change_action_cluster(FrameStart, FrameEnd, Action, C1X, C1Y, C2X, C2Y).
            ego = 'false'
            if math.dist([cluster['location'][0], cluster['location'][1]], [driverLocation[str(cluster['start_frame'])][0], driverLocation[str(cluster['start_frame'])][1]]) < 50:
                ego = 'true'
            action = cluster['action'].lower()
            start = cluster['start_frame']
            end = cluster['time_window'][::len(cluster['time_window'])-1][1]
            C1X = cluster['location'][0]
            C1Y = cluster['location'][1]
            C2X = cluster['location'][0]+5
            C2Y = cluster['location'][1]+5
            outputText = outputText + "change_action_cluster(" + str(start) + ", " + str(end) + ", " + action + ", " + ego + ', ' + str(C1X) + ", " + str(C1Y) + ", " + str(C2X) + ", " + str(C2Y) 
            outputText = outputText + ").\n"
outFile.write(outputText)

vehicles = {}
for json_str in json_list:  #Generates predicates about vehicle bounding boxes
    current_json = json.loads(json_str)
    outputText = ""
    for bounding_box_point in current_json['vehicles']:
        frame = str(current_json['frame'])
        outputText = outputText + "property(vehicle, " + str(current_json['frame'])
        outputText = outputText + ", " + str(bounding_box_point['id'])
        outputText = outputText + ", " + str(bounding_box_point['current_action']).lower()
        outputText = outputText + ", " + str(bounding_box_point['velocity'][0])
        outputText = outputText + ", " + str(bounding_box_point['velocity'][1])
        outputText = outputText + ", " + str(bounding_box_point['rotation'][2])
        xLocation = bounding_box_point['location'][0]
        yLocation = bounding_box_point['location'][2]
        if bounding_box_point['id'] in vehicles:
            vehicles[bounding_box_point['id']].append((xLocation, yLocation, bounding_box_point['velocity'][0], bounding_box_point['velocity'][1]))
        else:
            vehicles[bounding_box_point['id']] = [((xLocation, yLocation, bounding_box_point['velocity'][0], bounding_box_point['velocity'][1]))]
        outputText = outputText + ", " + str(bounding_box_point['bbox']['location'][0]+driverLocation[frame][0])
        outputText = outputText + ", " + str(bounding_box_point['bbox']['location'][2]+driverLocation[frame][1])
        outputText = outputText + ", " + str(bounding_box_point['bbox']['location'][0]+bounding_box_point['bbox']['extent'][0]+driverLocation[frame][0])
        outputText = outputText + ", " + str(bounding_box_point['bbox']['location'][2]+bounding_box_point['bbox']['extent'][1]+driverLocation[frame][1])
        outputText = outputText + ").\n"
    outFile.write(outputText)


for location in location_list: 
    current_json = json.loads(location)
    outputText = ""
    outputText = outputText + "driver_rotation("+ str(current_json['frame'])
    outputText = outputText + ", " + str(current_json['rotation'][2])
    outputText = outputText + ").\n"
    outFile.write(outputText)

frameList = "frames(["
for json_str in json_list:  #Generates predicates about frame list
    current_json = json.loads(json_str)
    frame = str(current_json['frame'])
    frames.append(current_json['frame'])
    frameList = frameList + str(frame) + ", "
frameList = frameList[:-2]+"]).\n"
outFile.write(frameList)

for frame in frames:
   with open('obstacle\\' + str(frame) + '.pkl', 'rb') as f:
        x = pickle.load(f)
        outputText = "ground_obstacle(" + str(frame) + ", true).\n"
        if(x['other_actor']):
            outputText = "ground_obstacle(" + str(frame) + ", " + str('static.prop' in str(x['other_actor']['type'])).lower() + ").\n"
        else: 
            outputText = "ground_obstacle(" + str(frame) + ", false).\n"
        outFile.write(outputText)

for frame in frames:
   with open('obstacle\\' + str(frame) + '.pkl', 'rb') as f:
        x = pickle.load(f)
        outputText = "pred_obstacle(" + str(frame) + ", true).\n"
        if(x['other_actor']):
            outputText = "pred_obstacle(" + str(frame) + ", false).\n"
        else: 
            outputText = "pred_obstacle(" + str(frame) + ", false).\n"
        outFile.write(outputText)

recordingUncertaintyTotal = 0
uncertainties = []
for frame in frames:
    uncertaintyNP = np.load("front_camera_uncertainty\\" + str(frame) + "_epistemic.npy")
    total = 0
    index = 0
    for row in uncertaintyNP:
        for col in row:
            total += col
            index += 1
    imageUncertainty = total/index
    recordingUncertaintyTotal = recordingUncertaintyTotal + imageUncertainty
    uncertainties.append((frame, imageUncertainty))
threshhold = recordingUncertaintyTotal / len(frames)
for frame in uncertainties:
    outputText = "frame_uncertain(" + str(frame[0]) + ", " + str(frame[1] > .05).lower() + ").\n"
    outFile.write(outputText)



junctionInput = open('gt_junctions/data.jsonl')
json_list = list(junctionInput)
upText = ""
downText = ""
leftText = ""
rightText = ""
for json_str in json_list:
    current_json = json.loads(json_str)
    for bounding_box_point in current_json['junctions']:
        junctionX = ((bounding_box_point['bounding_box']['location'][0]) + (bounding_box_point['bounding_box']['location'][0]+bounding_box_point['bounding_box']['extent'][0]))/2
        junctionY = ((bounding_box_point['bounding_box']['location'][1]) + (bounding_box_point['bounding_box']['location'][1]+bounding_box_point['bounding_box']['extent'][1]))/2
        if math.dist([junctionX, junctionY], [driverLocation[str(current_json['frame'])][0], driverLocation[str(current_json['frame'])][1]]) < 50:
            outputText = "property(intersection, " + str(current_json['frame'])
            outputText = outputText + ", " + str(bounding_box_point['id'])
            outputText = outputText + ", " + str(bounding_box_point['bounding_box']['location'][0])
            outputText = outputText + ", " + str(bounding_box_point['bounding_box']['location'][1])
            outputText = outputText + ", " + str(bounding_box_point['bounding_box']['location'][0]+bounding_box_point['bounding_box']['extent'][0])
            outputText = outputText + ", " + str(bounding_box_point['bounding_box']['location'][1]+bounding_box_point['bounding_box']['extent'][1])
            outputText = outputText + ").\n"
            outFile.write(outputText)
            #property(intersection_side_up, Object_id, IS1X, IS1Y, W, H),
            upText = upText + "property(intersection_side_up, " + str(current_json['frame']) + ", " + str(bounding_box_point['id'])
            upText = upText + ", " + str(bounding_box_point['bounding_box']['location'][0])
            upText = upText + ", " + str(bounding_box_point['bounding_box']['location'][1]+bounding_box_point['bounding_box']['extent'][1]/2)
            upText = upText + ", " + str(bounding_box_point['bounding_box']['extent'][0])
            upText = upText + ", " + str(bounding_box_point['bounding_box']['extent'][1]/2) + ").\n"
            downText = downText + "property(intersection_side_down, " + str(current_json['frame']) + ", " + str(bounding_box_point['id'])
            downText = downText + ", " + str(bounding_box_point['bounding_box']['location'][0])
            downText = downText + ", " + str(bounding_box_point['bounding_box']['location'][1])
            downText = downText + ", " + str(bounding_box_point['bounding_box']['extent'][0])
            downText = downText + ", " + str(bounding_box_point['bounding_box']['extent'][1]/2) + ").\n"
            lefText = leftText + "property(intersection_side_left, " + str(current_json['frame']) + ", " + str(bounding_box_point['id'])
            lefText = lefText + ", " + str(bounding_box_point['bounding_box']['location'][0])
            lefText = lefText + ", " + str(bounding_box_point['bounding_box']['location'][1])
            lefText = lefText + ", " + str(bounding_box_point['bounding_box']['extent'][0]/2)
            lefText = lefText + ", " + str(bounding_box_point['bounding_box']['extent'][1]) + ").\n"
            rightText = rightText + "property(intersection_side_right, " + str(current_json['frame']) + ", " + str(bounding_box_point['id'])
            rightText = rightText + ", " + str(bounding_box_point['bounding_box']['location'][0]+bounding_box_point['bounding_box']['extent'][0]/2)
            rightText = rightText + ", " + str(bounding_box_point['bounding_box']['location'][1])
            rightText = rightText + ", " + str(bounding_box_point['bounding_box']['extent'][0]/2)
            rightText = rightText + ", " + str(bounding_box_point['bounding_box']['extent'][1]) + ").\n"
outFile.write(upText)
outFile.write(downText)
outFile.write(leftText)
outFile.write(rightText)
outFile.close()





