/qreg

This is the repository for QReg, the query-centric regression

Primary LanguagePythonApache License 2.0Apache-2.0

QReg Repository

Overview

This project implements QReg: Query-Centric Regression for In-DBMS Analytics. 22nd International Workshop On Design, Optimization, Languages and Analytical Processing of Big Data (DOLAP 2020). Paper is available at http://ceur-ws.org/Vol-2572/paper6.pdf. QReg is an ensemble method based on various base regression models.

Current QReg supports linear, polynomial, decision tree, xgboost, gboosting regression as its base models.

Dependencies

Python 3.6 or higher, requires scipy, xgboost, numpy, scikit-learn

How to install

pip install qregpy

How to use

Example I

from qregpy import qreg
import numpy as np
# The target fitting function is y=x1+2x2
X = np.array([[1,2],[2,5],[3,7],[4,9],[1,3],[2,4], [3,5], [4,2], [5,1]])
y= np.array([5.2, 12, 17.5, 21.2,7.2, 11,13, 7.8, 6.9])

# train the regression
reg = qreg.QReg(base_models=["linear", "polynomial"], verbose=True).fit(X, y)

# make the prediction for point [3,4]
print(reg.predict([[3,4]]))

Example II

from qregpy import qreg
import pandas as pd

# load the files
df = pd.read_csv("../data/10k.csv")
headerX = ["ss_list_price", "ss_wholesale_cost"]
headerY = "ss_wholesale_cost"

# prepare X and y
X = df[headerX].values
y = df[headerY].values

# train the regression using base models linear regression and XGBoost regression.
reg = qreg.QReg(base_models=["linear","xgboost"], verbose=True).fit(X, y)

# make predictions
reg.predict([[93.35, 53.04], [60.84, 41.96]])

Example III (Generate Samples First, scaled version)

from qregpy import qreg, sampling
import pandas as pd

input='../data/10k.csv'   # original file, in csv format, with headers.
sample='../data/sample.csv' # the file where the generated sample will be stored
n=1000  ##number of records in the sample

# generate the sample
sampling.build_reservoir('../data/10k.csv',100,output='../data/sample.csv')

# read the data
# load the files
df = pd.read_csv(sample)
headerX = ["ss_list_price", "ss_wholesale_cost"]
headerY = "ss_wholesale_cost"

# prepare X and y
X = df[headerX].values
y = df[headerY].values

# train the regression using base models linear regression and XGBoost regression.
reg = qreg.QReg(base_models=["linear","xgboost"], verbose=True).fit(X, y)

# make predictions
reg.predict([[93.35, 53.04], [60.84, 41.96]])