-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_lengths.py
101 lines (90 loc) · 3.2 KB
/
test_lengths.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
# import necessary modules
import numpy as np
import random
import pandas as pd
from sklearn.neighbors import NearestNeighbors
from sklearn.preprocessing import MinMaxScaler
import matplotlib.pyplot as plt
import json
from pprint import pprint
import time
import sys
import os
import math
import multiprocessing
import itertools
#our modules
import helper
import prodplay
import algos
import plot
import testing
from songdataset import SongDataset, SegmentDataset
def perQuadrant(oq, dq):
qc = "{}{}".format(oq, dq)
pairs = point_combos[qc]
helper.makeDir("{}/{}".format(dirname, qc))
for dataset in datasets:
helper.makeDir(f"{dirname}/{qc}/{dataset.name}")
for orig, dest in pairs:
curdirname = f"{dirname}/{qc}/{dataset.name}/{orig}-{dest}"
helper.makeDir(curdirname)
for variable in variables:
# TODO: update default / variable arguments for each test.
playlistDF = prodplay.makePlaylist(
dataset, orig, dest, variable,
score = testing.DEF_DISTANCES,
neighbors = testing.DEF_NEIGHBORS_K,
verbose = 0
)
# Save playlist DataFrame to CSV. TODO: update name.
playlistDF.to_csv("{}/{}.csv".format(curdirname, str(variable)))
if __name__ == "__main__":
samplecount = int(sys.argv[1]) if len(sys.argv) > 1 else 100
info = helper.loadConfig("config.json")
# set up output directory. TODO: update for each test.
dirname = helper.makeTestDir("lengths")
# Points for testing.
point_combos = testing.load_samples(testing.QUADRANT_JSON, samplecount)
# Load datasets and variables. TODO: update for each test.
# dataset = SongDataset(
# name="Deezer+Spotify+MSD",
# cols=info["cols"]["deezer"] + info["cols"]["spotify"] + info["cols"]["msd"],
# path=testing.DEEZER_SPO_MSD, verbose=True, knn=True,
# )
datasets = [
SongDataset(
name="Spotify",
cols=info["cols"]["deezer"] + info["cols"]["spotify"],
path=testing.DEEZER_SPO_MSD, verbose=True,
),
SongDataset(
name="MSD",
cols=info["cols"]["deezer"] + info["cols"]["msd"],
path=testing.DEEZER_SPO_MSD, verbose=True,
),
SongDataset(
name="All",
cols=info["cols"]["deezer"] + info["cols"]["spotify"] + info["cols"]["msd"],
path=testing.DEEZER_SPO_MSD, verbose=True,
),
SongDataset(
name="PCA-Spotify",
path=testing.DEEZER_PCA_SPO,
verbose=True,
),
SongDataset(
name="PCA-MSD",
path=testing.DEEZER_PCA_MSD,
verbose=True,
),
SongDataset(
name="PCA-All",
path=testing.DEEZER_PCA_ALL,
verbose=True,
)
]
variables = testing.ARG_LENGTHS
# Run a process for each quadrant combo (12 in total).
pQuadrants = multiprocessing.Pool(len(testing.QUADRANT_COMBOS))
pQuadrants.starmap(perQuadrant, testing.QUADRANT_COMBOS)