superscript.py v 0.0.1.002

This commit is contained in:
ltcptgeneral 2020-03-04 15:57:20 -06:00
parent a8be0bab6a
commit cd44f8a856
3 changed files with 18 additions and 77 deletions

View File

@ -3,14 +3,13 @@ import pymongo
import pandas as pd
import time
def pull_new_tba_matches(apikey, competition, cutoff = time_last_upd):
def pull_new_tba_matches(apikey, competition, cutoff):
api_key= apikey
x=requests.get("https://www.thebluealliance.com/api/v3/event/"+competition+"/matches/simple", headers={"X-TBA-Auth_Key":api_key})
out = []
for i in x.json():
if (i["actual_time"]-cutoff >= 0 and i["comp_level"] == "qm"):
out.append({"match" : i['match_number'], "blue" : list(map(lambda x: int(x[3:]), i['alliances']['blue']['team_keys'])), "red" : list(map(lambda x: int(x[3:]), i['alliances']['red']['team_keys'])), "winner": i["winning_alliance"]})
time_last_upd = time.time()
return out
def get_team_match_data(apikey, competition, team_num):
@ -22,14 +21,11 @@ def get_team_match_data(apikey, competition, team_num):
out[i['match']] = i['data']
return pd.DataFrame(out)
def get_team_pit_data(apikey, competition, team_num):
def get_team_metrics_data(apikey, competition, team_num):
client = pymongo.MongoClient(apikey)
db = client.data_scouting
mdata = db.pitdata
out = {}
for i in mdata.find({"competition" : competition, "team_scouted": team_num}):
out[i['match']] = i['data']
return pd.DataFrame(out)
db = client.data_processing
mdata = db.team_metrics
return mdata.find_one({"competition" : competition, "team": team_num})
def unkeyify_2l(layered_dict):
out = {}

View File

@ -3,10 +3,12 @@
# Notes:
# setup:
__version__ = "0.0.1.001"
__version__ = "0.0.1.002"
# changelog should be viewed using print(analysis.__changelog__)
__changelog__ = """changelog:
0.0.1.002:
- started implement of metrics
0.0.1.001:
- cleaned up imports
0.0.1.000:
@ -59,6 +61,8 @@ from analysis import analysis as an
import data as d
import time
main()
def main():
while(True):
current_time = time.time()
@ -70,6 +74,7 @@ def main():
print("loading database keys")
apikey = an.load_csv("keys.txt")[0][0]
tbakey = an.load_csv("keys.txt")[1][0]
print("loaded keys")
print("loading data")
@ -79,6 +84,10 @@ def main():
print("running tests")
results = simpleloop(data, config)
print("finished tests")
print("running metrics")
metrics = metricsloop(apikey, competition, current_time)
print("finished metrics")
print("pushing to database")
push_to_database(apikey, competition, results, None)
@ -138,72 +147,8 @@ def push_to_database(apikey, competition, results, metrics):
d.push_team_tests_data(apikey, competition, team, results[team])
def metricsloop(group_data, observations, database, tests): # listener based metrics update
def metricsloop(apikey, competition, timestamp): # listener based metrics update
pass
matches = d.pull_new_tba_matches(apikey, competition, timestamp)
"""
class database:
data = {}
elo_starting_score = 1500
N = 1500
K = 32
gl2_starting_score = 1500
gl2_starting_rd = 350
gl2_starting_vol = 0.06
def __init__(self, team_lookup):
super().__init__()
for team in team_lookup:
elo = elo_starting_score
gl2 = {"score": gl2_starting_score, "rd": gl2_starting_rd, "vol": gl2_starting_vol}
ts = Trueskill.Rating()
data[str(team)] = {"elo": elo, "gl2": gl2, "ts": ts}
def get_team(self, team):
return data[team]
def get_elo(self, team):
return data[team]["elo"]
def get_gl2(self, team):
return data[team]["gl2"]
def get_ts(self, team):
return data[team]["ts"]
def set_team(self, team, ndata):
data[team] = ndata
def set_elo(self, team, nelo):
data[team]["elo"] = nelo
def set_gl2(self, team, ngl2):
data[team]["gl2"] = ngl2
def set_ts(self, team, nts):
data[team]["ts"] = nts
def save_database(self, location):
pickle.dump(data, open(location, "wb"))
def load_database(self, location):
data = pickle.load(open(location, "rb"))
"""
main()
return