2022-05-17 23:11:21 +02:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# coding: utf-8
|
|
|
|
|
|
|
|
# In[1]:
|
|
|
|
|
|
|
|
|
|
|
|
import os
|
|
|
|
import pandas as pd
|
|
|
|
import numpy as np
|
|
|
|
import sklearn
|
|
|
|
from sklearn.feature_extraction.text import TfidfVectorizer
|
|
|
|
from sklearn.linear_model import LinearRegression
|
|
|
|
from sklearn.metrics import mean_squared_error
|
2022-05-18 00:12:24 +02:00
|
|
|
from sklearn.pipeline import make_pipeline
|
2022-05-17 23:11:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
# In[2]:
|
|
|
|
|
|
|
|
|
|
|
|
train = pd.read_csv('train/train.tsv', header=None, sep='\t', error_bad_lines=False)
|
|
|
|
print(len(train))
|
2022-05-18 01:06:51 +02:00
|
|
|
train = train[:30000]
|
2022-05-17 23:11:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
# In[3]:
|
|
|
|
|
|
|
|
|
|
|
|
x_train = train[4]
|
|
|
|
y_train = train[0]
|
|
|
|
|
|
|
|
|
|
|
|
# In[4]:
|
|
|
|
|
|
|
|
|
2022-05-18 01:06:51 +02:00
|
|
|
model = make_pipeline(TfidfVectorizer(), LinearRegression())
|
|
|
|
model.fit(x_train, y_train)
|
2022-05-17 23:11:21 +02:00
|
|
|
|
|
|
|
|
2022-05-18 00:53:58 +02:00
|
|
|
# In[5]:
|
2022-05-17 23:11:21 +02:00
|
|
|
|
|
|
|
|
2022-05-18 01:06:51 +02:00
|
|
|
def readFile(filename):
|
|
|
|
result = []
|
|
|
|
with open(filename, 'r', encoding="utf-8") as file:
|
|
|
|
for line in file:
|
|
|
|
text = line.split("\t")[0].strip()
|
|
|
|
result.append(text)
|
|
|
|
return result
|
2022-05-17 23:11:21 +02:00
|
|
|
|
|
|
|
|
2022-05-18 00:53:58 +02:00
|
|
|
# In[6]:
|
2022-05-17 23:11:21 +02:00
|
|
|
|
|
|
|
|
2022-05-18 01:06:51 +02:00
|
|
|
x_dev0 = readFile('dev-0/in.tsv')
|
|
|
|
dev_predicted = model.predict(x_dev0)
|
2022-05-17 23:11:21 +02:00
|
|
|
with open('dev-0/out.tsv', 'wt') as f:
|
|
|
|
for i in dev_predicted:
|
|
|
|
f.write(str(i)+'\n')
|
|
|
|
|
|
|
|
|
2022-05-18 01:06:51 +02:00
|
|
|
# In[ ]:
|
2022-05-17 23:11:21 +02:00
|
|
|
|
|
|
|
|
2022-05-18 01:06:51 +02:00
|
|
|
x_dev1 = readFile('dev-0/in.tsv')
|
|
|
|
dev_predicted = model.predict(x_dev1)
|
|
|
|
with open('dev-0/out.tsv', 'wt') as f:
|
|
|
|
for i in dev_predicted:
|
|
|
|
f.write(str(i)+'\n')
|
2022-05-17 23:11:21 +02:00
|
|
|
|
|
|
|
|
2022-05-18 01:06:51 +02:00
|
|
|
# In[ ]:
|
2022-05-17 23:11:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
with open('test-A/in.tsv', 'r', encoding = 'utf-8') as f:
|
|
|
|
x_test = f.readlines()
|
|
|
|
|
2022-05-18 00:12:24 +02:00
|
|
|
# x_test = pd.Series(x_test)
|
|
|
|
# x_test = vectorizer.transform(x_test)
|
2022-05-17 23:11:21 +02:00
|
|
|
|
2022-05-18 00:12:24 +02:00
|
|
|
test_predicted = model.predict(x_test)
|
2022-05-17 23:11:21 +02:00
|
|
|
|
|
|
|
with open('test-A/out.tsv', 'wt') as f:
|
|
|
|
for i in test_predicted:
|
|
|
|
f.write(str(i)+'\n')
|
|
|
|
|
2022-05-18 00:12:24 +02:00
|
|
|
|
2022-05-18 01:06:51 +02:00
|
|
|
# In[ ]:
|
2022-05-18 00:12:24 +02:00
|
|
|
|
|
|
|
|
|
|
|
get_ipython().system('jupyter nbconvert --to script run.ipynb')
|
|
|
|
|