GuessRedditDateSumo/linear_regression.py

40 lines
1.7 KiB
Python
Raw Normal View History

2020-05-05 16:02:39 +02:00
import csv
2020-05-05 14:17:49 +02:00
import pickle
from sklearn.decomposition import TruncatedSVD
2020-04-19 19:30:57 +02:00
from sklearn.feature_extraction.text import TfidfVectorizer
from sklearn.feature_extraction.text import CountVectorizer
import sklearn
import pandas as pd
import math
import re
2020-05-05 14:17:49 +02:00
from sklearn.linear_model import LinearRegression
2020-04-19 19:30:57 +02:00
2020-05-05 14:17:49 +02:00
def train():
2020-05-05 16:02:39 +02:00
created_dictionary=pd.read_csv("train/in.tsv", delimiter="\t", header=None, names=["txt"], quoting=csv.QUOTE_NONE)
#Pandas - służy do analizy danych (wszystko to co umożliwia SQL, Excel itd.)
#delimiter - alternatywny argument do separacji, header - numer wiersza, który ma być traktowany jako nazwa
#names - określenie nazw kolumn jak ich nie ma dajemy None
#quoting - służy do interpretacji pól
2020-05-05 16:38:35 +02:00
#chunksize - służy by ładować duże ilości danych
2020-05-05 17:30:04 +02:00
created_dictionary = created_dictionary["txt"][:20000]
2020-05-05 16:02:39 +02:00
expected_dictionary=pd.read_csv("train/expected.tsv", header=None)
2020-05-05 17:30:04 +02:00
expected_dictionary = expected_dictionary[:20000]
2020-04-19 19:30:57 +02:00
#tfidf = TfidfVectorizer(min_df=1,stop_words='english')
2020-05-05 14:17:49 +02:00
tfidf = TfidfVectorizer(stop_words='english', ngram_range=(1,1)) #Konwertuje tekst w dokumencie do macierzy tfidf , ngram_range - lb słów w sekwencji
x = tfidf.fit_transform(created_dictionary)
#PCA - principal component analysis
2020-05-05 15:19:10 +02:00
pca = TruncatedSVD(n_components=100) # Liniowa redukcja wymiarów , n_components - Pożądana wymiarowość danych wyjściowych
2020-05-05 14:17:49 +02:00
x_pca = pca.fit_transform(x)
l_regression = LinearRegression()
l_regression.fit(x_pca,expected_dictionary)
with open('l_regression.pkl','wb') as f:
pickle.dump(l_regression,f)
with open('tfidf_model.pkl', 'wb') as f:
pickle.dump(tfidf,f)
2020-05-05 16:02:39 +02:00
2020-05-05 14:17:49 +02:00
train()