25.10.2016 Views

SAP HANA Predictive Analysis Library (PAL)

sap_hana_predictive_analysis_library_pal_en

sap_hana_predictive_analysis_library_pal_en

SHOW MORE
SHOW LESS

You also want an ePaper? Increase the reach of your titles

YUMPU automatically turns print PDFs into web optimized ePapers that Google loves.

<strong>PAL</strong>_LOGISTICR_STAT_TBL:<br />

<strong>PAL</strong>_LOGISTICR_PMMLMODEL_TBL:<br />

Example 2: Fitting logistic regression model with elastic net penalties<br />

SET SCHEMA DM_<strong>PAL</strong>;<br />

DROP TYPE <strong>PAL</strong>_ENET_LOGISTICR_DATA_T;<br />

CREATE TYPE <strong>PAL</strong>_ENET_LOGISTICR_DATA_T AS TABLE("V1" DOUBLE, "V2" INTEGER, "V3"<br />

DOUBLE, "V4" INTEGER, "V5" INTEGER, "V6" VARCHAR(50), "CATEGORY" INTEGER);<br />

DROP TYPE <strong>PAL</strong>_CONTROL_T;<br />

CREATE TYPE <strong>PAL</strong>_CONTROL_T AS TABLE("NAME" VARCHAR(50), "INTARGS" INTEGER,<br />

"DOUBLEARGS" DOUBLE, "STRINGARGS" VARCHAR(100));<br />

DROP TYPE <strong>PAL</strong>_ENET_LOGISTICR_RESULT_T;<br />

CREATE TYPE <strong>PAL</strong>_ENET_LOGISTICR_RESULT_T AS TABLE("Coefficient" varchar(50),<br />

"CoefficientValue" DOUBLE);<br />

DROP TYPE <strong>PAL</strong>_ENET_LOGISTICR_STAT_T;<br />

CREATE TYPE <strong>PAL</strong>_ENET_LOGISTICR_STAT_T AS TABLE( "STATISTICS" VARCHAR(20),<br />

"VALUE" DOUBLE);<br />

DROP TYPE <strong>PAL</strong>_ENET_LOGISTICR_PMMLMODEL_T;<br />

CREATE TYPE <strong>PAL</strong>_ENET_LOGISTICR_PMMLMODEL_T AS TABLE( "ID" INTEGER, "PMMLMODEL"<br />

VARCHAR(5000));<br />

DROP TABLE <strong>PAL</strong>_ENET_LOGISTICR_PDATA_TBL;<br />

CREATE COLUMN TABLE <strong>PAL</strong>_ENET_LOGISTICR_PDATA_TBL("POSITION" INT, "SCHEMA_NAME"<br />

NVARCHAR(256), "TYPE_NAME" NVARCHAR(256), "PARAMETER_TYPE" VARCHAR(7));<br />

INSERT INTO <strong>PAL</strong>_ENET_LOGISTICR_PDATA_TBL VALUES (1, 'DM_<strong>PAL</strong>',<br />

'<strong>PAL</strong>_ENET_LOGISTICR_DATA_T', 'IN');<br />

INSERT INTO <strong>PAL</strong>_ENET_LOGISTICR_PDATA_TBL VALUES (2, 'DM_<strong>PAL</strong>', '<strong>PAL</strong>_CONTROL_T',<br />

'IN');<br />

INSERT INTO <strong>PAL</strong>_ENET_LOGISTICR_PDATA_TBL VALUES (3, 'DM_<strong>PAL</strong>',<br />

'<strong>PAL</strong>_ENET_LOGISTICR_RESULT_T', 'OUT');<br />

INSERT INTO <strong>PAL</strong>_ENET_LOGISTICR_PDATA_TBL VALUES (4, 'DM_<strong>PAL</strong>',<br />

'<strong>PAL</strong>_ENET_LOGISTICR_STAT_T', 'OUT');<br />

INSERT INTO <strong>PAL</strong>_ENET_LOGISTICR_PDATA_TBL VALUES (5, 'DM_<strong>PAL</strong>',<br />

'<strong>PAL</strong>_ENET_LOGISTICR_PMMLMODEL_T', 'OUT');<br />

CALL SYS.AFLLANG_WRAPPER_PROCEDURE_DROP('DM_<strong>PAL</strong>', '<strong>PAL</strong>_ENET_LOGISTICR_PROC');<br />

CALL SYS.AFLLANG_WRAPPER_PROCEDURE_CREATE('AFL<strong>PAL</strong>','LOGISTICREGRESSION',<br />

'DM_<strong>PAL</strong>', '<strong>PAL</strong>_ENET_LOGISTICR_PROC',<strong>PAL</strong>_ENET_LOGISTICR_PDATA_TBL);<br />

DROP TABLE <strong>PAL</strong>_ENET_LOGISTICR_DATA_TBL;<br />

CREATE COLUMN TABLE <strong>PAL</strong>_ENET_LOGISTICR_DATA_TBL LIKE <strong>PAL</strong>_ENET_LOGISTICR_DATA_T;<br />

INSERT INTO <strong>PAL</strong>_ENET_LOGISTICR_DATA_TBL VALUES (4,1, 0.86,0,0, 'blue', 1);<br />

INSERT INTO <strong>PAL</strong>_ENET_LOGISTICR_DATA_TBL VALUES (8,0, 0.45,1,2, 'blue', 1);<br />

INSERT INTO <strong>PAL</strong>_ENET_LOGISTICR_DATA_TBL VALUES (7,1, 0.99,1,2, 'yellow', 0);<br />

INSERT INTO <strong>PAL</strong>_ENET_LOGISTICR_DATA_TBL VALUES (12,1, 0.84,2,2, 'red', 1);<br />

INSERT INTO <strong>PAL</strong>_ENET_LOGISTICR_DATA_TBL VALUES (6,1, 0.85,2,2, 'red', 0);<br />

INSERT INTO <strong>PAL</strong>_ENET_LOGISTICR_DATA_TBL VALUES (9,0, 0.67,3,3, 'yellow', 0);<br />

INSERT INTO <strong>PAL</strong>_ENET_LOGISTICR_DATA_TBL VALUES (10,1, 0.91,2,2 ,'yellow', 0);<br />

INSERT INTO <strong>PAL</strong>_ENET_LOGISTICR_DATA_TBL VALUES (14,0, 0.29, 0,0, 'red', 1);<br />

INSERT INTO <strong>PAL</strong>_ENET_LOGISTICR_DATA_TBL VALUES (7,0, 0.88, 1,0, 'yellow', 1);<br />

DROP TABLE #<strong>PAL</strong>_CONTROL_TBL;<br />

CREATE LOCAL TEMPORARY COLUMN TABLE #<strong>PAL</strong>_CONTROL_TBL ("NAME" VARCHAR(50),<br />

"INTARGS" INTEGER, "DOUBLEARGS" DOUBLE, "STRINGARGS" VARCHAR(100));<br />

INSERT INTO #<strong>PAL</strong>_CONTROL_TBL VALUES ('METHOD', 2, null, null);<br />

INSERT INTO #<strong>PAL</strong>_CONTROL_TBL VALUES ('CATEGORY_COL', 1, null, null);<br />

INSERT INTO #<strong>PAL</strong>_CONTROL_TBL VALUES ('CATEGORY_COL', 3, null, null);<br />

INSERT INTO #<strong>PAL</strong>_CONTROL_TBL VALUES ('CATEGORY_COL', 4, null, null);<br />

INSERT INTO #<strong>PAL</strong>_CONTROL_TBL VALUES ('PMML_EXPORT', 1, null, null);<br />

INSERT INTO #<strong>PAL</strong>_CONTROL_TBL VALUES ('ENET_LAMBDA', null, 0.03613, null);<br />

INSERT INTO #<strong>PAL</strong>_CONTROL_TBL VALUES ('ENET_ALPHA', null, 0.7, null);<br />

<strong>SAP</strong> <strong>HANA</strong> <strong>Predictive</strong> <strong>Analysis</strong> <strong>Library</strong> (<strong>PAL</strong>)<br />

<strong>PAL</strong> Functions P U B L I C 173

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!