У меня проблемы с:
- Список пакетов и функций R, доступных для PostgreSQL.
- Установка пакета (например, Kendall ) для использования с PL / R
- Вызов функции R в PostgreSQL
Список доступных пакетов R
Q.1. Как узнать, какие модули R были загружены?
SELECT * FROM r_typenames();
Показывает доступные типы, но как насчет проверки, загружен ли Kendall( X, Y )
? Например, документация показывает:
CREATE TABLE plr_modules (
modseq int4,
modsrc text
);
Это, кажется, позволяет вставлять записи, чтобы продиктовать загрузку Kendall
, но следующий код синтаксически не объясняет, как обеспечить загрузку:
INSERT INTO plr_modules
VALUES (0, 'pg.test.module.load <-function(msg) {print(msg)}');
Q.2. Как бы выглядела строка выше, если вы пытаетесь загрузить Kendall
?
Q.3. Это применимо?
Установка пакетов R
С помощью менеджера пакетов «synaptic» были установлены следующие пакеты:
r-base
r-base-core
r-base-dev
r-base-html
r-base-latex
r-cran-acepack
r-cran-boot
r-cran-car
r-cran-chron
r-cran-cluster
r-cran-codetools
r-cran-design
r-cran-foreign
r-cran-hmisc
r-cran-kernsmooth
r-cran-lattice
r-cran-matrix
r-cran-mgcv
r-cran-nlme
r-cran-quadprog
r-cran-robustbase
r-cran-rpart
r-cran-survival
r-cran-vr
r-recommended
Q.4. Как я узнаю, что Кендалл там?
Q.5. Если это не так, как мне узнать, в каком пакете он находится?
Q.6. Если его нет в пакете, подходящем для установки с apt-get
(aptitude
, synaptic
, dpkg
, что у вас), как мне его установить? в Ubuntu?
Q.7. Где документированы этапы установки?
Вызов функций R
У меня есть следующий код:
EXECUTE 'SELECT '
'regr_slope( amount, year_taken ),'
'regr_intercept( amount, year_taken ),'
'corr( amount, year_taken ),'
'sum( measurements ) AS total_measurements '
'FROM temp_regression'
INTO STRICT slope, intercept, correlation, total_measurements;
Этот код вызывает функцию PostgreSQL corr
для вычисления корреляции Пирсона по данным. В идеале я хотел бы сделать следующее (переключив corr
на plr_kendall
):
EXECUTE 'SELECT '
'regr_slope( amount, year_taken ),'
'regr_intercept( amount, year_taken ),'
'plr_kendall( amount, year_taken ),'
'sum( measurements ) AS total_measurements '
'FROM temp_regression'
INTO STRICT slope, intercept, correlation, total_measurements;
Q.8. Должен ли я сам написать plr_kendall
Q.9. Где я могу найти простой пример, который проходит через:
- Загрузка модуля R в PG.
- Написание оболочки PG для желаемой функции R.
- Вызов оболочки PG из SELECT.
Например, будут ли последние два шага выглядеть так:
create or replace function plr_kendall( _float8, _float8 ) returns float as '
agg_kendall(arg1, arg2)
' language 'plr';
CREATE AGGREGATE agg_kendall (
sfunc = plr_array_accum,
basetype = float8, -- ???
stype = _float8, -- ???
finalfunc = plr_kendall
);
А потом SELECT
как выше?
Спасибо!