1. Učit se
  2. /
  3. Kurzy
  4. /
  5. Tvorba doporučovacích systémů s PySparkem

Connected

Cvičení

Spuštění implicitního ALS modelu s křížovou validací

Teď, když máme několik ALS modelů, každý s jinou sadou hodnot hyperparametrů, je můžeme trénovat na trénovací části datasetu msd pomocí křížové validace a poté je spustit na testovací sadě dat a vyhodnotit jejich výkon pomocí funkce ROEM, o které jsme si povídali dříve. Tato operace by bohužel v rámci tohoto cvičení trvala příliš dlouho, takže ji bylo nutné provést zvlášť. Jako referenci tu ale uvádíme, jak lze model_list vyhodnotit pomocí následujícího cyklu (v tomto případě používáme dataset msd):

# Split the data into training and test sets
(training, test) = msd.randomSplit([0.8, 0.2])

#Building 5 folds within the training set.
train1, train2, train3, train4, train5 = training.randomSplit([0.2, 0.2, 0.2, 0.2, 0.2], seed = 1)
fold1 = train2.union(train3).union(train4).union(train5)
fold2 = train3.union(train4).union(train5).union(train1)
fold3 = train4.union(train5).union(train1).union(train2)
fold4 = train5.union(train1).union(train2).union(train3)
fold5 = train1.union(train2).union(train3).union(train4)

foldlist = [(fold1, train1), (fold2, train2), (fold3, train3), (fold4, train4), (fold5, train5)]

# Empty list to fill with ROEMs from each model
ROEMS = []

# Loops through all models and all folds
for model in model_list:
    for ft_pair in foldlist:

        # Fits model to fold within training data
        fitted_model = model.fit(ft_pair[0])

        # Generates predictions using fitted_model on respective CV test data
        predictions = fitted_model.transform(ft_pair[1])

        # Generates and prints a ROEM metric CV test data
        r = ROEM(predictions)
        print ("ROEM: ", r)

    # Fits model to all of training data and generates preds for test data
    v_fitted_model = model.fit(training)
    v_predictions = v_fitted_model.transform(test)
    v_ROEM = ROEM(v_predictions)

    # Adds validation ROEM to ROEM list
    ROEMS.append(v_ROEM)
    print ("Validation ROEM: ", v_ROEM)

Pro účely tohoto cvičení jsou testovací predikce pro 192 modelů již vygenerovány a jejich hodnota ROEM je vypočítána. Najdeš je v připraveném seznamu ROEMS. Protože seznam není specifický pro PySpark a numpy se seznamy pracuje velmi dobře, použijeme zde právě numpy. Postupuj podle pokynů níže a najdi nejlepší hodnotu ROEM i model, který ji poskytl.

Pokyny

100 XP
  • Importuj numpy.
  • Z připraveného seznamu ROEMS vytiahni nejmenší hodnotu ROEM pomocí numpy.argmin(). Metoda .argmin() vrátí index nejnižší hodnoty v zadaném seznamu. Výsledek ulož jako i a vypiš i.
  • Pomocí indexování seznamu najdi hodnotu v seznamu ROEMS na indexu i.