#!/usr/bin/env python3
# -*- coding: utf-8 -*-

## Structured selection with hierarchical models a la Roth and Fischer
import rpy2
import rpy2.robjects.numpy2ri
rpy2.robjects.numpy2ri.activate()
import rpy2.robjects as robjects
from rpy2.robjects import numpy2ri
from rpy2.robjects import default_converter
from rpy2.robjects.packages import importr

r = robjects.r

agp = importr('activegp')
base = importr('base')

def C_GP(X,y):
    X_arr = robjects.FloatVector(X.T.flatten())
    X_R = robjects.r['matrix'](X_arr, nrow = X.shape[0])

    y_arr = robjects.FloatVector(y)
    y_R = robjects.r['matrix'](y_arr, ncol = 1)

    fit = agp.C_GP(X_R, y_R)
    return base.as_matrix(fit)

