## Regression ### Predictive geographically weighted regression (GWR) Predictive GWR generates estimates of the dependent variable at locations where it has not been observed. It predicts these unknown values by first using the GWR model estimation analysis with known data values of the dependent and independent variables sampled from around the prediction location(s) to build a geographically weighted, spatially-varying regression model. It then uses this model and known values of the independent variables at the prediction locations to predict the value of the dependent variable where it is otherwise unknown. For predictive GWR to work, a dataset needs known independent variables, some known dependent variables, and some unknown dependent variables. The dataset also needs to have geometry data (e.g., point, lines, or polygons). #### Arguments | Name | Type | Description | |------|------|-------------| | subquery | TEXT | SQL query that expose the data to be analyzed (e.g., `SELECT * FROM regression_inputs`). This query must have the geometry column name (see the optional `geom_col` for default), the id column name (see `id_col`), and the dependent (`dep_var`) and independent (`ind_vars`) column names. | | dep_var | TEXT | Name of the dependent variable in the regression model | | ind_vars | TEXT[] | Text array of independent variable column names used in the model to describe the dependent variable. | | bw (optional) | NUMERIC | Value of bandwidth. If `NULL` then select optimal (default). | | fixed (optional) | BOOLEAN | True for distance based kernel function and False (default) for adaptive (nearest neighbor) kernel function. Defaults to `False`. | | kernel (optional)| TEXT | Type of kernel function used to weight observations. One of `gaussian`, `bisquare` (default), or `exponential`. | #### Returns | Column Name | Type | Description | |-------------|------|-------------| | coeffs | JSON | JSON object with parameter estimates for each of the dependent variables. The keys of the JSON object are the dependent variables, with values corresponding to the parameter estimate. | | stand_errs | JSON | Standard errors for each of the dependent variables. The keys of the JSON object are the dependent variables, with values corresponding to the respective standard errors. | | t_vals | JSON | T-values for each of the dependent variables. The keys of the JSON object are the dependent variable names, with values corresponding to the respective t-value. | | predicted | NUMERIC | predicted value of y | | residuals | NUMERIC | residuals of the response | | r_squared | NUMERIC | R-squared for the parameter fit | | bandwidth | NUMERIC | bandwidth value consisting of either a distance or N nearest neighbors | | rowid | INTEGER | row id of the original row | #### Example Usage ```sql SELECT g.cartodb_id, g.the_geom, g.the_geom_webmercator, (gwr.coeffs->>'pctblack')::numeric as coeff_pctblack, (gwr.coeffs->>'pctrural')::numeric as coeff_pctrural, (gwr.coeffs->>'pcteld')::numeric as coeff_pcteld, (gwr.coeffs->>'pctpov')::numeric as coeff_pctpov, gwr.residuals FROM cdb_crankshaft.CDB_GWR_Predict('select * from g_utm'::text, 'pctbach'::text, Array['pctblack', 'pctrural', 'pcteld', 'pctpov']) As gwr JOIN g_utm as g on g.cartodb_id = gwr.rowid ``` Note: See [PostgreSQL syntax for parsing JSON objects](https://www.postgresql.org/docs/9.5/static/functions-json.html). ### Geographically weighted regression model estimation This analysis generates the model coefficients for a geographically weighted, spatially-varying regression. The model coefficients, along with their respective statistics, allow one to make inferences or describe a dependent variable based on a set of independent variables. Similar to traditional linear regression, GWR takes a linear combination of independent variables and a known dependent variable to estimate an optimal set of coefficients. The model coefficients are spatially varying (controlled by the `bandwidth` and `fixed` parameters), so that the model output is allowed to vary from geometry to geometry. This allows GWR to capture non-stationarity -- that is, how local processes vary over space. In contrast, coefficients obtained from estimating a traditional linear regression model assume that processes are constant over space. #### Arguments | Name | Type | Description | |------|------|-------------| | subquery | TEXT | SQL query that expose the data to be analyzed (e.g., `SELECT * FROM regression_inputs`). This query must have the geometry column name (see the optional `geom_col` for default), the id column name (see `id_col`), dependent and independent column names. | | dep_var | TEXT | name of the dependent variable in the regression model | | ind_vars | TEXT[] | Text array of independent variables used in the model to describe the dependent variable | | bw (optional) | NUMERIC | Value of bandwidth. If `NULL` then select optimal (default). | | fixed (optional) | BOOLEAN | True for distance based kernel function and False for adaptive (nearest neighbor) kernel function (default). Defaults to false. | | kernel | TEXT | Type of kernel function used to weight observations. One of `gaussian`, `bisquare` (default), or `exponential`. | #### Returns | Column Name | Type | Description | |-------------|------|-------------| | coeffs | JSON | JSON object with parameter estimates for each of the dependent variables. The keys of the JSON object are the dependent variables, with values corresponding to the parameter estimate. | | stand_errs | JSON | Standard errors for each of the dependent variables. The keys of the JSON object are the dependent variables, with values corresponding to the respective standard errors. | | t_vals | JSON | T-values for each of the dependent variables. The keys of the JSON object are the dependent variable names, with values corresponding to the respective t-value. | | predicted | NUMERIC | predicted value of y | | residuals | NUMERIC | residuals of the response | | r_squared | NUMERIC | R-squared for the parameter fit | | bandwidth | NUMERIC | bandwidth value consisting of either a distance or N nearest neighbors | | rowid | INTEGER | row id of the original row | #### Example Usage ```sql SELECT g.cartodb_id, g.the_geom, g.the_geom_webmercator, (gwr.coeffs->>'pctblack')::numeric as coeff_pctblack, (gwr.coeffs->>'pctrural')::numeric as coeff_pctrural, (gwr.coeffs->>'pcteld')::numeric as coeff_pcteld, (gwr.coeffs->>'pctpov')::numeric as coeff_pctpov, gwr.residuals FROM cdb_crankshaft.CDB_GWR('select * from g_utm'::text, 'pctbach'::text, Array['pctblack', 'pctrural', 'pcteld', 'pctpov']) As gwr JOIN g_utm as g on g.cartodb_id = gwr.rowid ``` Note: See [PostgreSQL syntax for parsing JSON objects](https://www.postgresql.org/docs/9.5/static/functions-json.html). ## Advanced reading * Fotheringham, A. Stewart, Chris Brunsdon, and Martin Charlton. 2002. Geographically Weighted Regression: The Analysis of Spatially Varying Relationships. John Wiley & Sons. * Brunsdon, Chris, A. Stewart Fotheringham, and Martin E. Charlton. 1996. "Geographically Weighted Regression: A Method for Exploring Spatial Nonstationarity." Geographical Analysis 28 (4): 281–98. * Brunsdon, Chris, Stewart Fotheringham, and Martin Charlton. 1998. "Geographically Weighted Regression." Journal of the Royal Statistical Society: Series D (The Statistician) 47 (3): 431–43. * Fotheringham, A. S., M. E. Charlton, and C. Brunsdon. 1998. "Geographically Weighted Regression: A Natural Evolution of the Expansion Method for Spatial Data Analysis." Environment and Planning A 30 (11): 1905–27. doi:10.1068/a301905. ### GWR for prediction * Harris, P., A. S. Fotheringham, R. Crespo, and M. Charlton. 2010. "The Use of Geographically Weighted Regression for Spatial Prediction: An Evaluation of Models Using Simulated Data Sets." Mathematical Geosciences 42 (6): 657–80. doi:10.1007/s11004-010-9284-7. ### GWR in application * Cahill, Meagan, and Gordon Mulligan. 2007. "Using Geographically Weighted Regression to Explore Local Crime Patterns." Social Science Computer Review 25 (2): 174–93. doi:10.1177/0894439307298925. * Gilbert, Angela, and Jayajit Chakraborty. 2011. "Using Geographically Weighted Regression for Environmental Justice Analysis: Cumulative Cancer Risks from Air Toxics in Florida." Social Science Research 40 (1): 273–86. doi:10.1016/j.ssresearch.2010.08.006. * Ali, Kamar, Mark D. Partridge, and M. Rose Olfert. 2007. "Can Geographically Weighted Regressions Improve Regional Analysis and Policy Making?" International Regional Science Review 30 (3): 300–329. doi:10.1177/0160017607301609. * Lu, Binbin, Martin Charlton, and A. Stewart Fotheringhama. 2011. "Geographically Weighted Regression Using a Non-Euclidean Distance Metric with a Study on London House Price Data." Procedia Environmental Sciences, Spatial Statistics 2011: Mapping Global Change, 7: 92–97. doi:10.1016/j.proenv.2011.07.017.