234 lines
7.7 KiB
PL/PgSQL
234 lines
7.7 KiB
PL/PgSQL
-- Moran's I Global Measure (public-facing)
|
|
CREATE OR REPLACE FUNCTION
|
|
CDB_AreasOfInterestGlobal(
|
|
subquery TEXT,
|
|
column_name TEXT,
|
|
w_type TEXT DEFAULT 'knn',
|
|
num_ngbrs INT DEFAULT 5,
|
|
permutations INT DEFAULT 99,
|
|
geom_col TEXT DEFAULT 'the_geom',
|
|
id_col TEXT DEFAULT 'cartodb_id')
|
|
RETURNS TABLE (moran NUMERIC, significance NUMERIC)
|
|
AS $$
|
|
plpy.execute('SELECT cdb_crankshaft._cdb_crankshaft_activate_py()')
|
|
from crankshaft.clustering import moran_local
|
|
# TODO: use named parameters or a dictionary
|
|
return moran(subquery, column_name, w_type, num_ngbrs, permutations, geom_col, id_col)
|
|
$$ LANGUAGE plpythonu;
|
|
|
|
-- Moran's I Local (internal function)
|
|
CREATE OR REPLACE FUNCTION
|
|
_CDB_AreasOfInterestLocal(
|
|
subquery TEXT,
|
|
column_name TEXT,
|
|
w_type TEXT,
|
|
num_ngbrs INT,
|
|
permutations INT,
|
|
geom_col TEXT,
|
|
id_col TEXT)
|
|
RETURNS TABLE (moran NUMERIC, quads TEXT, significance NUMERIC, rowid INT, vals NUMERIC)
|
|
AS $$
|
|
plpy.execute('SELECT cdb_crankshaft._cdb_crankshaft_activate_py()')
|
|
from crankshaft.clustering import moran_local
|
|
# TODO: use named parameters or a dictionary
|
|
return moran_local(subquery, column_name, w_type, num_ngbrs, permutations, geom_col, id_col)
|
|
$$ LANGUAGE plpythonu;
|
|
|
|
-- Moran's I Local (public-facing function)
|
|
CREATE OR REPLACE FUNCTION
|
|
CDB_AreasOfInterestLocal(
|
|
subquery TEXT,
|
|
column_name TEXT,
|
|
w_type TEXT DEFAULT 'knn',
|
|
num_ngbrs INT DEFAULT 5,
|
|
permutations INT DEFAULT 99,
|
|
geom_col TEXT DEFAULT 'the_geom',
|
|
id_col TEXT DEFAULT 'cartodb_id')
|
|
RETURNS TABLE (moran NUMERIC, quads TEXT, significance NUMERIC, rowid INT, vals NUMERIC)
|
|
AS $$
|
|
|
|
SELECT moran, quads, significance, rowid, vals
|
|
FROM cdb_crankshaft._CDB_AreasOfInterestLocal(subquery, column_name, w_type, num_ngbrs, permutations, geom_col, id_col);
|
|
|
|
$$ LANGUAGE SQL;
|
|
|
|
-- Moran's I only for HH and HL (public-facing function)
|
|
CREATE OR REPLACE FUNCTION
|
|
CDB_GetSpatialHotspots(
|
|
subquery TEXT,
|
|
column_name TEXT,
|
|
w_type TEXT DEFAULT 'knn',
|
|
num_ngbrs INT DEFAULT 5,
|
|
permutations INT DEFAULT 99,
|
|
geom_col TEXT DEFAULT 'the_geom',
|
|
id_col TEXT DEFAULT 'cartodb_id')
|
|
RETURNS TABLE (moran NUMERIC, quads TEXT, significance NUMERIC, rowid INT, vals NUMERIC)
|
|
AS $$
|
|
|
|
SELECT moran, quads, significance, rowid, vals
|
|
FROM cdb_crankshaft._CDB_AreasOfInterestLocal(subquery, column_name, w_type, num_ngbrs, permutations, geom_col, id_col)
|
|
WHERE quads IN ('HH', 'HL');
|
|
|
|
$$ LANGUAGE SQL;
|
|
|
|
-- Moran's I only for LL and LH (public-facing function)
|
|
CREATE OR REPLACE FUNCTION
|
|
CDB_GetSpatialColdspots(
|
|
subquery TEXT,
|
|
attr TEXT,
|
|
w_type TEXT DEFAULT 'knn',
|
|
num_ngbrs INT DEFAULT 5,
|
|
permutations INT DEFAULT 99,
|
|
geom_col TEXT DEFAULT 'the_geom',
|
|
id_col TEXT DEFAULT 'cartodb_id')
|
|
RETURNS TABLE (moran NUMERIC, quads TEXT, significance NUMERIC, rowid INT, vals NUMERIC)
|
|
AS $$
|
|
|
|
SELECT moran, quads, significance, rowid, vals
|
|
FROM cdb_crankshaft._CDB_AreasOfInterestLocal(subquery, attr, w_type, num_ngbrs, permutations, geom_col, id_col)
|
|
WHERE quads IN ('LL', 'LH');
|
|
|
|
$$ LANGUAGE SQL;
|
|
|
|
-- Moran's I only for LH and HL (public-facing function)
|
|
CREATE OR REPLACE FUNCTION
|
|
CDB_GetSpatialOutliers(
|
|
subquery TEXT,
|
|
attr TEXT,
|
|
w_type TEXT DEFAULT 'knn',
|
|
num_ngbrs INT DEFAULT 5,
|
|
permutations INT DEFAULT 99,
|
|
geom_col TEXT DEFAULT 'the_geom',
|
|
id_col TEXT DEFAULT 'cartodb_id')
|
|
RETURNS TABLE (moran NUMERIC, quads TEXT, significance NUMERIC, rowid INT, vals NUMERIC)
|
|
AS $$
|
|
|
|
SELECT moran, quads, significance, rowid, vals
|
|
FROM cdb_crankshaft._CDB_AreasOfInterestLocal(subquery, attr, w_type, num_ngbrs, permutations, geom_col, id_col)
|
|
WHERE quads IN ('HL', 'LH');
|
|
|
|
$$ LANGUAGE SQL;
|
|
|
|
-- Moran's I Global Rate (public-facing function)
|
|
CREATE OR REPLACE FUNCTION
|
|
CDB_AreasOfInterestGlobalRate(
|
|
subquery TEXT,
|
|
numerator TEXT,
|
|
denominator TEXT,
|
|
w_type TEXT DEFAULT 'knn',
|
|
num_ngbrs INT DEFAULT 5,
|
|
permutations INT DEFAULT 99,
|
|
geom_col TEXT DEFAULT 'the_geom',
|
|
id_col TEXT DEFAULT 'cartodb_id')
|
|
RETURNS TABLE (moran FLOAT, significance FLOAT)
|
|
AS $$
|
|
plpy.execute('SELECT cdb_crankshaft._cdb_crankshaft_activate_py()')
|
|
from crankshaft.clustering import moran_local
|
|
# TODO: use named parameters or a dictionary
|
|
return moran_rate(subquery, numerator, denominator, w_type, num_ngbrs, permutations, geom_col, id_col)
|
|
$$ LANGUAGE plpythonu;
|
|
|
|
|
|
-- Moran's I Local Rate (internal function)
|
|
CREATE OR REPLACE FUNCTION
|
|
_CDB_AreasOfInterestLocalRate(
|
|
subquery TEXT,
|
|
numerator TEXT,
|
|
denominator TEXT,
|
|
w_type TEXT,
|
|
num_ngbrs INT,
|
|
permutations INT,
|
|
geom_col TEXT,
|
|
id_col TEXT)
|
|
RETURNS
|
|
TABLE(moran NUMERIC, quads TEXT, significance NUMERIC, rowid INT, vals NUMERIC)
|
|
AS $$
|
|
plpy.execute('SELECT cdb_crankshaft._cdb_crankshaft_activate_py()')
|
|
from crankshaft.clustering import moran_local_rate
|
|
# TODO: use named parameters or a dictionary
|
|
return moran_local_rate(subquery, numerator, denominator, w_type, num_ngbrs, permutations, geom_col, id_col)
|
|
$$ LANGUAGE plpythonu;
|
|
|
|
-- Moran's I Local Rate (public-facing function)
|
|
CREATE OR REPLACE FUNCTION
|
|
CDB_AreasOfInterestLocalRate(
|
|
subquery TEXT,
|
|
numerator TEXT,
|
|
denominator TEXT,
|
|
w_type TEXT DEFAULT 'knn',
|
|
num_ngbrs INT DEFAULT 5,
|
|
permutations INT DEFAULT 99,
|
|
geom_col TEXT DEFAULT 'the_geom',
|
|
id_col TEXT DEFAULT 'cartodb_id')
|
|
RETURNS
|
|
TABLE(moran NUMERIC, quads TEXT, significance NUMERIC, rowid INT, vals NUMERIC)
|
|
AS $$
|
|
|
|
SELECT moran, quads, significance, rowid, vals
|
|
FROM cdb_crankshaft._CDB_AreasOfInterestLocalRate(subquery, numerator, denominator, w_type, num_ngbrs, permutations, geom_col, id_col);
|
|
|
|
$$ LANGUAGE SQL;
|
|
|
|
-- Moran's I Local Rate only for HH and HL (public-facing function)
|
|
CREATE OR REPLACE FUNCTION
|
|
CDB_GetSpatialHotspotsRate(
|
|
subquery TEXT,
|
|
numerator TEXT,
|
|
denominator TEXT,
|
|
w_type TEXT DEFAULT 'knn',
|
|
num_ngbrs INT DEFAULT 5,
|
|
permutations INT DEFAULT 99,
|
|
geom_col TEXT DEFAULT 'the_geom',
|
|
id_col TEXT DEFAULT 'cartodb_id')
|
|
RETURNS
|
|
TABLE(moran NUMERIC, quads TEXT, significance NUMERIC, rowid INT, vals NUMERIC)
|
|
AS $$
|
|
|
|
SELECT moran, quads, significance, rowid, vals
|
|
FROM cdb_crankshaft._CDB_AreasOfInterestLocalRate(subquery, numerator, denominator, w_type, num_ngbrs, permutations, geom_col, id_col)
|
|
WHERE quads IN ('HH', 'HL');
|
|
|
|
$$ LANGUAGE SQL;
|
|
|
|
-- Moran's I Local Rate only for LL and LH (public-facing function)
|
|
CREATE OR REPLACE FUNCTION
|
|
CDB_GetSpatialColdspotsRate(
|
|
subquery TEXT,
|
|
numerator TEXT,
|
|
denominator TEXT,
|
|
w_type TEXT DEFAULT 'knn',
|
|
num_ngbrs INT DEFAULT 5,
|
|
permutations INT DEFAULT 99,
|
|
geom_col TEXT DEFAULT 'the_geom',
|
|
id_col TEXT DEFAULT 'cartodb_id')
|
|
RETURNS
|
|
TABLE(moran NUMERIC, quads TEXT, significance NUMERIC, rowid INT, vals NUMERIC)
|
|
AS $$
|
|
|
|
SELECT moran, quads, significance, rowid, vals
|
|
FROM cdb_crankshaft._CDB_AreasOfInterestLocalRate(subquery, numerator, denominator, w_type, num_ngbrs, permutations, geom_col, id_col)
|
|
WHERE quads IN ('LL', 'LH');
|
|
|
|
$$ LANGUAGE SQL;
|
|
|
|
-- Moran's I Local Rate only for LH and HL (public-facing function)
|
|
CREATE OR REPLACE FUNCTION
|
|
CDB_GetSpatialOutliersRate(
|
|
subquery TEXT,
|
|
numerator TEXT,
|
|
denominator TEXT,
|
|
w_type TEXT DEFAULT 'knn',
|
|
num_ngbrs INT DEFAULT 5,
|
|
permutations INT DEFAULT 99,
|
|
geom_col TEXT DEFAULT 'the_geom',
|
|
id_col TEXT DEFAULT 'cartodb_id')
|
|
RETURNS
|
|
TABLE(moran NUMERIC, quads TEXT, significance NUMERIC, rowid INT, vals NUMERIC)
|
|
AS $$
|
|
|
|
SELECT moran, quads, significance, rowid, vals
|
|
FROM cdb_crankshaft._CDB_AreasOfInterestLocalRate(subquery, numerator, denominator, w_type, num_ngbrs, permutations, geom_col, id_col)
|
|
WHERE quads IN ('HL', 'LH');
|
|
|
|
$$ LANGUAGE SQL;
|