lds
This module contains functions and procedures that make use of location data services, such as geocoding, reverse geocoding, isolines and routing computation.
For manual installations of the CARTO Analytics Toolbox, after installing it for the first time, and before using any LDS function you need to call the SETUP procedure to configure the LDS functions. It also optionally sets default credentials.
GEOCODE_TABLE
GEOCODE_TABLE(input_table, address_column [, geom_column] [, country] [, options] [, api_base_url, api_access_token])warning
This function consumes LDS quota. Each call consumes as many units of quota as the number of rows of your input table. Before running, we recommend checking the size of the data to be geocoded and your available quota using the GET_LDS_QUOTA_INFO function.
Description
Geocodes an input table by adding an user defined column geom_column with the geographic coordinates (latitude and longitude) corresponding to a given address column. This procedure also adds a carto_geocode_metadata column with additional information of the geocoding result in JSON format. It geocodes sequentially the table in chunks of 500.
- input_table:- VARCHARname of the table to be geocoded. Please make sure you have enough permissions to alter this table, as this procedure will add two columns to it to store the geocoding result.
- address_column:- VARCHARname of the column from the input table that contains the addresses to be geocoded.
- geom_column(optional):- VARCHARcolumn name for the geometry column. Defaults to- 'geom'.
- country(optional):- VARCHARname of the country in ISO 3166-1 alpha-2. Defaults to- ''.
- options(optional):- VARCHAR|OBJECTcontaining a valid JSON with the different options. In addition to the options targeted at the geocoding service described below, a boolean option- carto_force_geocode(false by default) can be used to force geocoding rows that already have a non-null value in- geom_column. Valid options are described in the table below. If no options are indicated then 'default' values would be applied.ProviderOptionDescription- All- language- A - VARCHARthat specifies the language of the geocoding in RFC 4647 format.
- api_base_url(optional):- VARCHARurl of the API where the customer account is stored.
- api_access_token(optional):- VARCHARan API Access Token that is allowed to use the LDS API.
If the input table already contains a geometry column with the name geom_column, only those rows with NULL values will be geocoded.
Examples
CALL CARTO.CARTO.GEOCODE_TABLE('my-schema.my-table', 'my_address_column');
-- The table `my-schema.my-table` will be updated
-- adding the columns: geom, carto_geocode_metadata.CALL CARTO.CARTO.GEOCODE_TABLE('my-schema.my-table', 'my_address_column', 'my_geom_column');
-- The table `my-schema.my-table` will be updated
-- adding the columns: my_geom_column, carto_geocode_metadata.CALL CARTO.CARTO.GEOCODE_TABLE('my-schema.my-table', 'my_address_column', 'my_geom_column', 'my_country');
-- The table `my-schema.my-table` will be updated
-- adding the columns: my_geom_column, carto_geocode_metadata.CALL CARTO.CARTO.GEOCODE_TABLE('my-schema.my-table', 'my_address_column', 'my_geom_column', 'my_country', '{"language":"en-US"}');
-- The table `my-schema.my-table` will be updated
-- adding the columns: my_geom_column, carto_geocode_metadata.CALL CARTO.CARTO.GEOCODE_TABLE('my-schema.my-table', 'my_address_column', 'my_geom_column', 'my_country', {'language':'en-US'});
-- The table `my-schema.my-table` will be updated
-- adding the columns: my_geom_column, carto_geocode_metadata.CALL CARTO.CARTO.GEOCODE_TABLE('my-schema.my-table', 'my_address_column', 'my_geom_column', 'my_country', '{"language":"en-US"}', 'my_api_base_url', 'my_api_access_token');
-- The table `my-schema.my-table` will be updated
-- adding the columns: my_geom_column, carto_geocode_metadata.CALL CARTO.CARTO.GEOCODE_TABLE('my-schema.my-table', 'my_address_column', 'my_geom_column', 'my_country', {'language':'en-US'}, 'my_api_base_url', 'my_api_access_token');
-- The table `my-schema.my-table` will be updated
-- adding the columns: my_geom_column, carto_geocode_metadata.Troubleshooting
For the GEOCODE_TABLE procedure to work, the input table should be owned by the same role as the procedure. The procedure may not have access to update the table, for example, if the table was created with the ACCOUNTADMIN role, but the procedure is owned by the SYSADMIN role. In such scenario, the following error will be raised:
SQL access control error: Insufficient privileges to operate on table 'my-table'You can check the OWNERSHIP of the table with the following query:
SHOW GRANTS ON TABLE "my-schema"."my-table";To change the OWNERSHIP of to table to the SYSADMIN role, execute:
GRANT OWNERSHIP ON TABLE "my-schema"."my-table" TO ROLE SYSADMIN COPY CURRENT GRANTS;After performing this operation, you will be able to run GEOCODE_TABLE without running into privilege issues.
GEOCODE_REVERSE_TABLE
GEOCODE_REVERSE_TABLE(input_table [, geom_column] [, address_column] [, language] [, options] [, api_base_url, api_access_token])warning
This function consumes LDS quota. Each call consumes as many units of quota as the number of rows of your input table. Before running, we recommend checking the size of the data to be geocoded and your available quota using the GET_LDS_QUOTA_INFO function.
Description
Reverse-geocodes an input table by adding an user defined column address_column with the address coordinates corresponding to a given point location column. It geocodes sequentially the table in chunks of 50 rows.
- input_table:- VARCHARname of the table to be reverse-geocoded. Please make sure you have enough permissions to alter this table, as this procedure will add a columns to it to store the geocoding result.
- geom_column(optional):- GEOGRAPHYcolumn name from the input table that contains the points to be reverse-geocoded. Defaults to- 'geom'.
- address_column(optional):- VARCHARname of the column where the computed addresses will be stored. It defaults to- 'address', and it is created on the input table if it doesn't exist.
- language(optional):- VARCHARlanguage in which results should be returned. Defaults to- ''. The effect and interpretation of this parameter depends on the LDS provider assigned to your account.
- options(optional):- VARCHAR|OBJECTcontaining a valid JSON with the different options. No options are allowed currently, so this value will not be taken into account.
- api_base_url(optional):- VARCHARurl of the API where the customer account is stored.
- api_access_token(optional):- VARCHARan API Access Token that is allowed to use the LDS API.
If the input table already contains an address column with the name specified by the address_column parameter, only those rows with NULL values in it will be reverse-geocoded.
Examples
CALL CARTO.CARTO.GEOCODE_REVERSE_TABLE('my-schema.my-table');
-- The table `my-schema.my-table`, which should have a `geom` GEOGRAPHY column, will be updated
-- adding the column: `address`.CALL CARTO.CARTO.GEOCODE_REVERSE_TABLE('my-schema.my-table', 'my_geom_column');
-- The table `my-schema.my-table`, with a GEOGRAPHY column named `my_geom_column`, will be updated
-- adding the column: `address`.CALL CARTO.CARTO.GEOCODE_REVERSE_TABLE('my-schema.my-table', 'my_geom_column', 'my_address_column');
-- The table `my-schema.my-table`, with a GEOGRAPHY column named `my_geom_column`, will be updated
-- adding the column: `my_address_column` if it doesn't previously exist.CALL CARTO.CARTO.GEOCODE_REVERSE_TABLE('my-schema.my-table', 'my_geom_column', 'my_address_column', 'en-US');
-- The table `my-schema.my-table`, with a GEOGRAPHY column named `my_geom_column`, will be updated
-- adding the column: `my_address_column` if it doesn't previously exist.
-- The addresses will be in the (US) english language.CALL CARTO.CARTO.GEOCODE_REVERSE_TABLE('my-schema.my-table', 'my_geom_column', 'my_address_column', 'en-US', {}, 'my_api_base_url', 'my_api_access_token');
-- The table `my-schema.my-table`, with a GEOGRAPHY column named `my_geom_column`, will be updated
-- adding the column: `my_address_column` if it doesn't previously exist.
-- The addresses will be in the (US) english language.Troubleshooting
For the GEOCODE_REVERSE_TABLE procedure to work, the input table should be owned by the same role as the procedure. The procedure may not have access to update the table, for example, if the table was created with the ACCOUNTADMIN role, but the procedure is owned by the SYSADMIN role. In such scenario, the following error will be raised:
SQL access control error: Insufficient privileges to operate on table 'my-table'You can check the OWNERSHIP of the table with the following query:
SHOW GRANTS ON TABLE "my-schema"."my-table";To change the OWNERSHIP of to table to the SYSADMIN role, execute:
GRANT OWNERSHIP ON TABLE "my-schema"."my-table" TO ROLE SYSADMIN COPY CURRENT GRANTS;After performing this operation, you will be able to run GEOCODE_REVERSE_TABLE without running into privilege issues.
CREATE_ISOLINES
CREATE_ISOLINES(input, output_table, geom_column, mode, range, range_type [, options] [, api_base_url, api_access_token])warning
This function consumes LDS quota. Each call consumes as many units of quota as the number of rows your input table or query has. Before running, we recommend checking the size of the data to be geocoded and your available quota using the GET_LDS_QUOTA_INFO function.
Description
Calculates the isolines (polygons) from given origins (points) in a table or query. It creates a new table with the columns of the input table or query except the geom_column plus the isolines in the column geom (if the input already contains a geom column, it will be overwritten). It calculates isolines sequentially in chunks of N rows, N being the optimal batch size for this datawarehouse and the specific LDS provider that you are using.
Note that The term isoline is used here in a general way to refer to the areas that can be reached from a given origin point within the given travel time or distance (depending on the range_type parameter).
- input:- VARCHARname of the input table or query.
- output_table:- VARCHARname of the output table. It will raise an error if the table already exists.
- geom_column:- VARCHARcolumn name for the origin geography column.
- mode:- VARCHARtype of transport. The supported modes depend on the provider:- HERE: 'walk', 'car', 'truck', 'taxi', 'bus', 'private_bus'.
- TomTom: 'walk', 'car', 'bike', 'motorbike', 'truck', 'taxi', 'bus', 'van'.
- TravelTime: 'walk', 'car', 'bike', 'public_transport', 'coach', 'bus', 'train', 'ferry'.
- Mapbox: 'walk', 'car', 'bike'.
 
- range:- INTrange of the isoline in seconds (for- range_type'time') or meters (for- range_type'distance').
- range_type:- VARCHARtype of range. Supported: 'time' (for isochrones), 'distance' (for isodistances).
- options(optional):- VARCHAR|OBJECTcontaining a valid JSON with the different options. Valid options are described in the table below. If no options are indicated then 'default' values would be applied.ProviderOptionDescription- HERE- arrival_time- A - VARCHARthat specifies the time of arrival. If the value is set, a reverse isoline is calculated. If set to- "any", then time-dependent effects will not be taken into account. It cannot be used in combination with- departure_time. Supported:- "any",- "now"and date-time as- "<YYYY-MM-DD>T<hh:mm:ss>".- HERE- departure_time- Default: - "any". A- VARCHARthat specifies the time of departure. If set to- "any", then time-dependent effects will not be taken into account. It cannot be used in combination with- arrival_time. Supported:- "any",- "now"and date-time as- "<YYYY-MM-DD>T<hh:mm:ss>".- HERE- optimize_for- Default: - "balanced". A- VARCHARthat specifies how isoline calculation is optimized. Supported:- "quality"(calculation of isoline focuses on quality, that is, the graph used for isoline calculation has higher granularity generating an isoline that is more precise),- "performance"(calculation of isoline is performance-centric, quality of isoline is reduced to provide better performance) and- "balanced"(calculation of isoline takes a balanced approach averaging between quality and performance).- HERE- routing_mode- Default: - "fast". A- VARCHARthat specifies which optimization is applied during isoline calculation. Supported:- "fast"(route calculation from start to destination optimized by travel time. In many cases, the route returned by the fast mode may not be the route with the fastest possible travel time. For example, the routing service may favor a route that remains on a highway, even if a faster travel time can be achieved by taking a detour or shortcut through an inconvenient side road) and- "short"(route calculation from start to destination disregarding any speed information. In this mode, the distance of the route is minimized, while keeping the route sensible. This includes, for example, penalizing turns. Because of that, the resulting route will not necessarily be the one with minimal distance).- TomTom- departure_time- Default: - "now". A- VARCHARthat specifies the time of departure. Supported:- "now"and date-time as- "<YYYY-MM-DD>T<hh:mm:ss>".- TomTom- traffic- Default: - false. A- BOOLEANthat specifies if all available traffic information will be taken into consideration. Supported:- trueand- false.- TravelTime- level_of_detail- A JSON string. In the most typical case, you will want to use a string in the form - { scale_type: 'simple_numeric', level: -N }, with- Nbeing the detail level (-8 by default). Higher Ns (more negative levels) will simplify the polygons more but will reduce performance. There are other ways of setting the level of detail. Check the [https://docs.traveltime.com/api/reference/isochrones#arrival_searches-level_of_detail](TravelTime docs) for more info.- TravelTime- departure_time- Default: - "now". A- STRINGthat specifies the time of departure. Supported:- "now"and date-time as- "<YYYY-MM-DD>T<hh:mm:ss>Z".
- api_base_url(optional):- VARCHARurl of the API where the customer account is stored.
- api_access_token(optional):- VARCHARan API Access Token that is allowed to use the LDS API.
warning
Before running, we recommend checking your provider using the GET_LDS_QUOTA_INFO function. Notice that some of the parameters are provider dependant. Please contact your CARTO representative if you have questions regarding the service provider configured in your organization.
Examples
CALL CARTO.CARTO.CREATE_ISOLINES(
    'my-schema.my-table',
    'my-schema.my-output-table',
    'my_geom_column',
    'car', 300, 'time'
);
-- The table `my-schema.my-output-table` will be created
-- with the columns of the input table except `my_geom_column`.
-- Isolines will be added in the "geom" column.CALL CARTO.CARTO.CREATE_ISOLINES(
    'my-schema.my-table',
    'my-schema.my-output-table',
    'my_geom_column',
    'car', 1000, 'distance'
);
-- The table `my-schema.my-output-table` will be created
-- with the columns of the input table except `my_geom_column`.
-- Isolines will be added in the "geom" column.CALL CARTO.CARTO.CREATE_ISOLINES(
    'my-schema.my-table',
    'my-schema.my-output-table',
    'my_geom_column',
    'car', 300, 'time',
    '{"polygons_filter": {"limit": 1}}',
    'my_api_base_url',
    'my_api_access_token'
);
-- The table `my-schema.my-output-table` will be created
-- with the columns of the input table except `my_geom_column`.
-- Isolines will be added in the "geom" column.CREATE_ROUTES
CREATE_ROUTES(input, output_table, geom_column, mode[, options] [, api_base_url, api_access_token])warning
This function consumes LDS quota. Each call consumes as many units of quota as the number of rows your input query has. Before running, we recommend checking the size of the data used to create the routes and your available quota using the GET_LDS_QUOTA_INFO function.
Description
Calculates the routes (line strings) between given origins and destinations (points) in a query. It creates a new table with the columns of the input query with the resulting route in the user defined column geom_column (if the input already contains a column named geom_column, it will be overwritten) and a carto_routing_metadata column with the response of the service provider except for the route geometry. It calculates routes sequentially in chunks of 100 rows.
Note that routes are calculated using the external LDS provider assigned to your CARTO account. Currently TomTom and HERE are supported.
- input:- VARCHARname of the input query, which must have columns named- ORIGINand- DESTINATIONof type- GEOGRAPHYand containing points. If a column named- WAYPOINTSis also present, it should contain a VARCHAR with the coordinates of the desired intermediate points with the format- "lon1,lat1:lon2,lat2...".
- output_table:- VARCHARname of the output table. It will raise an error if the table already exists.
- geom_column:- VARCHARcolumn name for the generated routes geography column.
- mode:- VARCHARtype of transport. The supported modes depend on the provider:- TomTom: 'car', 'pedestrian', 'bicycle', 'motorcycle', 'truck', 'taxi', 'bus', 'van'.
- HERE: 'car', 'truck', 'pedestrian', 'bicycle', 'scooter', 'taxi', 'bus', 'privateBus'.
 
- options(optional):- VARCHAR|OBJECTcontaining a valid JSON with optional parameters. This is intended for advanced use: additional parameters can be passed directly to the Routing provider by placing them in this JSON string. To find out what your provider is, check the- GET_LDS_QUOTA_INFOfunction. The following are some of the most common parameters for each provider:- TomTom:- avoid: Specifies something that the route calculation should try to avoid when determining the route. Possible values (several of them can be used at the same time):- tollRoads
- motorways
- ferries
- unpavedRoads
- carpools
- alreadyUsedRoads
- Avoids
- This
- borderCrossings
- tunnels
- carTrains
- lowEmissionZones
 
- routeType: Specifies the type of optimization used when calculating routes. Possible values:- fastest,- shortest,- short- eco,- thrilling
- traffic: Set to true- trueto consider all available traffic information during routing. Set to- falseotherwise
- departAt: The date and time of departure at the departure point. It should be specified in RFC 3339 format with an optional time zone offset.
- arriveAt: The date and time of arrival at the destination point. It should be specified in RFC 3339 format with an optional time zone offset.
- vehicleMaxspeed: Maximum speed of the vehicle in kilometers/hour.
 
- HERE- avoid: Elements or areas to avoid. Information about avoidance can be found here
- departureTime: The date and time of departure at the departure point. It should be specified in RFC 3339 format with an optional time zone offset.
- arrivalTime: The date and time of arrival at the destination point. It should be specified in RFC 3339 format with an optional time zone offset.
- language: The language to use. Supported language codes can be found here
 
 - For more advanced usage, check the documentation of your provider's routing API. 
- api_base_url(optional):- VARCHARurl of the API where the customer account is stored.
- api_access_token(optional):- VARCHARan API Access Token that is allowed to use the LDS API.
warning
Before running, we recommend checking your provider using the GET_LDS_QUOTA_INFO function. Notice that some of the parameters are provider dependant. Please contact your CARTO representative if you have questions regarding the service provider configured in your organization.
Examples
CALL CARTO.CARTO.CREATE_ROUTES(
    'my-schema.my-table',
    'my-schema.my-output-table',
    'GEOM',
    'car'
);
-- The table `my-schema.my-output-table` will be created
-- with the columns of the input table and 'GEOM' and 'CARTO_ROUTING_METADATA'.
-- Routes will be added in the "GEOM" column.CALL CARTO.CARTO.CREATE_ROUTES(
    'my-schema.my-table',
    'my-schema.my-output-table',
    'GEOM',
    'car',
    '{"arriveAt":"2023-06-11T19:00:00+02:00"}'
);
-- The table `my-schema.my-output-table` will be created
-- with the columns of the input table except and 'GEOM' and 'CARTO_ROUTING_METADATA'.
-- Routes will be added in the "GEOM" column.CALL CARTO.CARTO.CREATE_ROUTES(
    'my-schema.my-table',
    'my-schema.my-output-table',
    'GEOM',
    'car',
    {"arriveAt":"2023-06-11T19:00:00+02:00"}
);
-- The table `my-schema.my-output-table` will be created
-- with the columns of the input table and 'GEOM' and 'CARTO_ROUTING_METADATA'.
-- Routes will be added in the "GEOM" column.CALL CARTO.CARTO.CREATE_ROUTES(
    'my-schema.my-table',
    'my-schema.my-output-table',
    'GEOM',
    'car',
    '{"arriveAt":"2023-06-11T19:00:00+02:00"}',
    'my_api_base_url',
    'my_api_access_token'
);
-- The table `my-schema.my-output-table` will be created
-- with the columns of the input table except and 'GEOM' and 'CARTO_ROUTING_METADATA'.
-- Routes will be added in the "GEOM" column.CALL CARTO.CARTO.CREATE_ROUTES(
    'my-schema.my-table',
    'my-schema.my-output-table',
    'GEOM',
    'car',
    {"arriveAt":"2023-06-11T19:00:00+02:00"},
    'my_api_base_url',
    'my_api_access_token'
);
-- The table `my-schema.my-output-table` will be created
-- with the columns of the input table and 'GEOM' and 'CARTO_ROUTING_METADATA'.
-- Routes will be added in the "GEOM" column.GEOCODE
GEOCODE(address [, country] [, options] [, api_base_url, api_access_token])warning
This function consumes LDS quota. Each call consumes one unit of quota. Before running, check the size of the data to be geocoded and make sure you store the result in a table to avoid misuse of the quota. To check the information about available and consumed quota use the function GET_LDS_QUOTA_INFO.
We recommend using this function only with an input of up to 10 records. In order to geocode larger sets of addresses, we strongly recommend using the GEOCODE_TABLE procedure. Likewise, in order to materialize the results in a table.
Description
Geocodes an address into a point with its geographic coordinates (latitude and longitude).
- address:- VARCHARinput address to geocode.
- country(optional):- VARCHARname of the country in ISO 3166-1 alpha-2. Defaults to- ''.
- options(optional):- VARCHAR|OBJECTcontaining a valid JSON with the different options. Valid options are described in the table below. If no options are indicated then 'default' values would be applied.ProviderOptionDescription- All- language- A - VARCHARthat specifies the language of the geocoding in RFC 4647 format.
- api_base_url(optional):- VARCHARurl of the API where the customer account is stored.
- api_access_token(optional):- VARCHARan API Access Token that is allowed to use the LDS API.
Return type
GEOGRAPHY
Constraints
This function performs requests to the CARTO Location Data Services API. Snowflake makes parallel requests depending on the number of records you are processing, potentially hitting the limit of the number of requests per seconds allowed for your account. The payload size of these requests depends on the number of records and could cause a timeout in the external function, with the error message External function timeout. Unexpected server errors will force Snowflake to retry the requests. The limit is around 500 records but could vary with the provider. To avoid this error, please try geocoding smaller volumes of data or using the procedure GEOCODE_TABLE instead. This procedure manages concurrency and payload size to avoid exceeding this limit.
Examples
SELECT CARTO.CARTO.GEOCODE('Madrid');
-- { "coordinates": [ -3.69196, 40.41956 ], "type": "Point" }SELECT CARTO.CARTO.GEOCODE('Madrid', 'es');
-- { "coordinates": [ -3.69196, 40.41956 ], "type": "Point" }SELECT CARTO.CARTO.GEOCODE('Madrid', 'es', '{"language":"es-ES"}');
-- { "coordinates": [ -3.69196, 40.41956 ], "type": "Point" }SELECT CARTO.CARTO.GEOCODE('Madrid', 'es', {'language':'en-US'});
-- { "coordinates": [ -3.69196, 40.41956 ], "type": "Point" }SELECT CARTO.CARTO.GEOCODE('Madrid', 'es', '{"language":"es-ES"}', 'my_api_base_url', 'my_api_access_token');
-- { "coordinates": [ -3.69196, 40.41956 ], "type": "Point" }SELECT CARTO.CARTO.GEOCODE('Madrid', 'es', {'language':'en-US'}, 'my_api_base_url', 'my_api_access_token');
-- { "coordinates": [ -3.69196, 40.41956 ], "type": "Point" }CREATE TABLE my_geocoded_table AS
SELECT ADDRESS, CARTO.CARTO.GEOCODE(ADDRESS) AS GEOM FROM my_table
-- Table my_geocoded_table successfully created.GEOCODE_REVERSE
GEOCODE_REVERSE(geom [, language] [, options] [, api_base_url, api_access_token])warning
This function consumes LDS quota. Each call consumes one unit of quota. Before running, check the size of the data to be reverse geocoded and make sure you store the result in a table to avoid misuse of the quota. To check the information about available and consumed quota use the function GET_LDS_QUOTA_INFO.
We recommend using this function only with an input of up to 10 records. In order to reverse-geocode larger sets of locations, we strongly recommend using the GEOCODE_REVERSE_TABLE procedure. Likewise, in order to materialize the results in a table.
Description
Performs a reverse geocoding of the point received as input.
- geom:- GEOGRAPHYinput point to obtain the address.
- language(optional):- VARCHARlanguage in which results should be returned.
- options(optional):- VARCHAR|OBJECTcontaining a valid JSON with the different options. No options are allowed currently, so this value will not be taken into account.
- api_base_url(optional):- VARCHARurl of the API where the customer account is stored.
- api_access_token(optional):- VARCHARan API Access Token that is allowed to use the LDS API.
Return type
VARCHAR
Constraints
This function performs requests to the CARTO Location Data Services API. Snowflake makes parallel requests depending on the number of records you are processing, potentially hitting the limit of the number of requests per seconds allowed for your account. The payload size of these requests depends on the number of records and could cause a timeout in the external function, with the error message External function timeout. Unexpected server errors will force Snowflake to retry the requests. The limit is around 500 records but could vary with the provider. To avoid this error, please try processing smaller volumes of data.
Examples
SELECT CARTO.CARTO.GEOCODE_REVERSE(ST_POINT(-74.0060, 40.7128));
-- 254 Broadway, New York, NY 10007, USASELECT CARTO.CARTO.GEOCODE_REVERSE(ST_POINT(-74.0060, 40.7128), 'en-US');
-- 254 Broadway, New York, NY 10007, USASELECT CARTO.CARTO.GEOCODE_REVERSE(ST_POINT(-74.0060, 40.7128), 'en-US', {}, 'my_api_base_url', 'my_api_access_token');
-- 254 Broadway, New York, NY 10007, USAISOLINE
ISOLINE(origin, mode, range, range_type [, options] [, api_base_url, api_access_token])warning
This function consumes LDS quota. Each call consumes one unit quota. Before running, check the size of the data and make sure you store the result in a table to avoid misuse of the quota. To check the information about available and consumed quota use the function GET_LDS_QUOTA_INFO.
We recommend using this function only with an input of up to 10 records. In order to calculate isolines for larger sets of locations, we strongly recommend using the CREATE_ISOLINES procedure. Likewise, in order to materialize the results in a table.
Description
Creates an isoline from the provided origin.
Note that The term isoline is used here in a general way to refer to the areas that can be reached from a given origin point within the given travel time or distance (depending on the range_type parameter).
- origin:- GEOGRAPHYof the origin of the isoline.
- mode:- VARCHARtype of transport. The supported modes depend on the provider:- HERE: 'walk', 'car', 'truck', 'taxi', 'bus', 'private_bus'.
- TomTom: 'walk', 'car', 'bike', 'motorbike', 'truck', 'taxi', 'bus', 'van'.
- TravelTime: 'walk', 'car', 'bike', 'public_transport', 'coach', 'bus', 'train', 'ferry'.
- Mapbox: 'walk', 'car', 'bike'.
 
- range:- INTrange of the isoline in seconds (for- range_type‘time’) or meters (for- range_type‘distance’).
- range_type:- VARCHARof the range type. Supported: ‘time’ (for isochrones), ‘distance’ (for isodistances).
- options(optional):- VARCHAR|OBJECTcontaining a valid JSON with the different options. Valid options are described in the table below. If no options are indicated then 'default' values would be applied.ProviderOptionDescription- HERE- arrival_time- A - VARCHARthat specifies the time of arrival. If the value is set, a reverse isoline is calculated. If set to- "any", then time-dependent effects will not be taken into account. It cannot be used in combination with- departure_time. Supported:- "any",- "now"and date-time as- "<YYYY-MM-DD>T<hh:mm:ss>".- HERE- departure_time- Default: - "now". A- VARCHARthat specifies the time of departure. If set to- "any", then time-dependent effects will not be taken into account. It cannot be used in combination with- arrival_time. Supported:- "any",- "now"and date-time as- "<YYYY-MM-DD>T<hh:mm:ss>".- HERE- optimize_for- Default: - "balanced". A- VARCHARthat specifies how isoline calculation is optimized. Supported:- "quality"(calculation of isoline focuses on quality, that is, the graph used for isoline calculation has higher granularity generating an isoline that is more precise),- "performance"(calculation of isoline is performance-centric, quality of isoline is reduced to provide better performance) and- "balanced"(calculation of isoline takes a balanced approach averaging between quality and performance).- HERE- routing_mode- Default: - "fast". A- VARCHARthat specifies which optimization is applied during isoline calculation. Supported:- "fast"(route calculation from start to destination optimized by travel time. In many cases, the route returned by the fast mode may not be the route with the fastest possible travel time. For example, the routing service may favor a route that remains on a highway, even if a faster travel time can be achieved by taking a detour or shortcut through an inconvenient side road) and- "short"(route calculation from start to destination disregarding any speed information. In this mode, the distance of the route is minimized, while keeping the route sensible. This includes, for example, penalizing turns. Because of that, the resulting route will not necessarily be the one with minimal distance).- TomTom- departure_time- Default: - "now". A- VARCHARthat specifies the time of departure. If set to- "any", then time-dependent effects will not be taken into account. Supported:- "any",- "now"and date-time as- "<YYYY-MM-DD>T<hh:mm:ss>".- TomTom- traffic- Default: - true. A- BOOLEANthat specifies if all available traffic information will be taken into consideration. Supported:- trueand- false.- TravelTime- level_of_detail- A JSON string. In the most typical case, you will want to use a string in the form - { scale_type: 'simple_numeric', level: -N }, with- Nbeing the detail level (-8 by default). Higher Ns (more negative levels) will simplify the polygons more but will reduce performance. There are other ways of setting the level of detail. Check the [https://docs.traveltime.com/api/reference/isochrones#arrival_searches-level_of_detail](TravelTime docs) for more info.- TravelTime- departure_time- Default: - "now". A- STRINGthat specifies the time of departure. Supported:- "now"and date-time as- "<YYYY-MM-DD>T<hh:mm:ss>Z".
- api_base_url(optional):- VARCHARurl of the API where the customer account is stored.
- api_access_token(optional):- VARCHARan API Access Token that is allowed to use the LDS API.
warning
Before running, we recommend checking your provider using the GET_LDS_QUOTA_INFO function. Notice that some of the parameters are provider dependant. Please contact your CARTO representative if you have questions regarding the service provider configured in your organization.
Return type
GEOGRAPHY
Constraints
This function performs requests to the CARTO Location Data Services API. Snowflake makes parallel requests depending on the number of records you are processing, potentially hitting the limit of the number of requests per seconds allowed for your account. The payload size of these requests depends on the number of records and could cause a timeout in the external function, with the error message External function timeout. Unexpected server errors will force Snowflake to retry the requests. The limit is around 500 records but could vary with the provider. To avoid this error, please try processing smaller volumes of data.
Examples
SELECT CARTO.CARTO.ISOLINE(ST_MAKEPOINT(-3, 40), 'car', 300, 'time');
-- { "coordinates": [ [ [ -3.0127745, 40.00472 ], [ -3.0131316, 40.004993 ], [ -3.0131316, 40.006092 ], [ -3.0134888, 40.006367 ], [ ...SELECT CARTO.CARTO.ISOLINE(ST_MAKEPOINT(-3, 40), 'car', 1000, 'distance');
-- { "coordinates": [ [ [ -3.002268, 39.99645 ], [ -3.002268, 39.995907 ], [ -3.001917, 39.995636 ], [ -3.0012143, 39.995636 ], [ ...SELECT CARTO.CARTO.ISOLINE(ST_MAKEPOINT(-3, 40), 'car', 300, 'time', {'departure_time':'any'}, 'my_api_base_url', 'my_api_access_token');
-- { "coordinates": [ [ [ -3.0127745, 40.00472 ], [ -3.0131316, 40.004993 ], [ -3.0131316, 40.006092 ], [ -3.0134888, 40.006367 ], [ ...GET_LDS_QUOTA_INFO
GET_LDS_QUOTA_INFO([api_base_url, api_access_token])Description
Returns statistics about the LDS quota. LDS quota is an annual quota that defines how much geocoding and isolines you can compute. Each geocoded row or computed isolines counts as one LDS quota unit. The single element in the result of GET_LDS_QUOTA_INFO will show your LDS quota for the current annual period (annual_quota), how much you’ve spent (used_quota), and which LDS providers are in use.
- api_base_url(optional):- VARCHARurl of the API where the customer account is stored.
- api_access_token(optional):- VARCHARan API Access Token that is allowed to use the LDS API.
Return type
VARCHAR
Examples
SELECT CARTO.CARTO.GET_LDS_QUOTA_INFO();
-- [
--   {
--     "used_quota": 10,
--     "annual_quota": 100000,
--     "providers": {
--         "geocoding": "tomtom",
--         "isolines": "here",
--         "routing":"tomtom"
--     }
--   }
-- ]SELECT CARTO.CARTO.GET_LDS_QUOTA_INFO('my_api_base_url', 'my_api_access_token');
-- [
--   {
--     "used_quota": 10,
--     "annual_quota": 100000,
--     "providers": {
--         "geocoding": "tomtom",
--         "isolines": "here",
--         "routing":"tomtom"
--     }
--   }
-- ]CREATE_ROUTING_MATRIX
CREATE_ROUTING_MATRIX(origins_table, origins_geom_column, destinations_table, destinations_geom_column, output_table, mode [, options] [, api_base_url, api_access_token])warning
This function consumes LDS quota. Each call consumes as many units of quota as the number of rows of the origins table multiplied by the rows of destinations table. Before running, we recommend checking the size of the data used to create the routes and your available quota using the GET_LDS_QUOTA_INFO function.
Description
Calculates the routes (line strings) between given origins and destinations (points) in two table. It creates a new table with the cross join of the origin and destination geom columns adding the distance or time between the different routes. A carto_routing_matrix_metadata column will also be added containing pottential errors thrown by the service provider for particular origin-destination combinations.
Note that routes are calculated using the external LDS provider assigned to your CARTO account. Currently TomTom and TravelTime are supported.
- origins_table:- VARCHARname of the origins input table.
- origins_geom_column:- VARCHARcolumn name for the origin geometry column.
- destinations_table:- VARCHARname of the destinations input table.
- destinations_geom_column:- VARCHARcolumn name for the destination geometry column.
- output_table:- VARCHARname of the output table. It will raise an error if the table already exists.
- geom_column:- VARCHARcolumn name for the generated geography column that will contain the resulting routes.
- mode:- VARCHARtype of transport. The supported modes depend on the provider:- TomTom: 'car', 'truck', 'pedestrian'.
- TravelTime: 'cycling', 'driving', 'driving+train', 'driving+public_transport', 'public_transport', 'walking', 'coach', 'bus', 'train', 'ferry', 'driving+ferry', 'cycling+ferry', 'cycling+public_transport'.
 
- options(optional):- VARCHAR|OBJECTcontaining a valid JSON with optional parameters. This is intended for advanced use: additional parameters can be passed directly to the Routing provider by placing them in this JSON string. To find out what your provider is, check the- GET_LDS_QUOTA_INFOfunction. The following are some of the most common parameters for each provider:ProviderOptionDescription- TomTom- avoid- Default: - []. An- ARRAYthat specifies something that the route calculation should try to avoid when determining the route. Supported:- ["tollRoads"],- ["unpavedRoads"].- TomTom- departAt- Default: - "any". A- STRINGthat specifies the time of departure. Supported:- "now",- "any"and date-time as- "<YYYY-MM-DD>T<hh:mm:ss>".- TomTom- routeType- Default: - "fastest". A- STRINGthat specifies the type of optimization used when calculating routes. Supported:- "fastest",- "shortest".- TomTom- traffic- Default: - historical. A- STRINGthat decides how traffic is considered for computing routes. Supported:- historicaland- live.- livemay not be used in conjunction with- departAt=any.- TomTom- vehicleMaxSpeed- Default: - 0. A- NUMBERthat specifies the maximum speed of the vehicle in kilometers/hour. Supported: a value in the range [0, 250]. A value of- 0means that an appropriate value for the vehicle will be determined and applied during route planning.- TravelTime- departure_time- Default: - "now". A- STRINGthat specifies the time of departure. Supported:- "now"and date-time as- "<YYYY-MM-DD>T<hh:mm:ss>Z".- TravelTime- travel_time- Default: - 14400(4 hours). A- NUMBERthat specifies the maximum travel time in seconds. Supported: a value in the range [0, 14400].- For more advanced usage, check the documentation of your provider's matrix routing API. 
- api_base_url(optional):- VARCHARurl of the API where the customer account is stored.
- api_access_token(optional):- VARCHARan API Access Token that is allowed to use the LDS API.- The following are options provided by CARTO in order to adjust the procedure performance: OptionDescription- carto_origins_batch_size- Default: - TomTom: 100,- TravelTime: 1. Max:- TomTom: 10000,- TravelTime: 10. A- NUMBERthat specifies the number of origins rows to process in each batch. Increasing this value in the case of Traveltime can cause some origins-destinations combinations to be skipped when the origin is not found.- carto_destinations_batch_size- Default: - TomTom: 100,- TravelTime: 2000. Max:- TomTom: 10000,- TravelTime: 2000. A- NUMBERthat specifies the number of destinations rows to process in each batch.- In the case of - TomTomthe next requirements must be met:- If - departAt=nowor- departAT=dateTimethen:- The size of the matrix should not be larger than 2500. 
- The number of origins should not be larger than 1000. 
- The number of destinations should not be larger than 1000. 
- The bounding box should not be larger than 400km X 400km. Example: 2X1000, 5X500, 100X25, etc. 
 
- If - departAt=anythen:- The size of the matrix can be as large as 100M. 
- The number of origins should not be larger than 10000. 
- The number of destinations should not be larger than 10000. 
 
 
warning
We recommend the product of carto_origins_batch_size x carto_destinations_batch_size to be lower than 10000 to ensure that the batches sizes is small enough to be processed.
warning
Before running, we recommend checking your provider using the GET_LDS_QUOTA_INFO function. Notice that some of the parameters are provider dependant. Please contact your CARTO representative if you have questions regarding the service provider configured in your organization.
Return type
The results are stored in the table named <output_table>, which contains the following columns:
- origin_geom:- VARCHARthe origin geometry.
- destination_geom:- VARCHARthe destination geometry.
- route_distance:- INTthe distance of the route in meters.
- route_duration:- INTthe duration of the route in seconds.
- carto_routing_matrix_metadata:- VARCHARpossible errors thrown by the service provider for particular origin-destination combinations.
When generating the output table origin-destination combinations, duplicated or null geometries will not be processed.
Examples
CALL CARTO.CARTO.CREATE_ROUTING_MATRIX(
    'my-schema.my-origins-table',
    'my_origins_geom_column',
    'my-schema.my-destinations-table',
    'my_destinations_geom_column',
    'my-schema.my-output-table',
    'car'
);
-- The table `my-schema.my-output-table` will be created
-- with the columns from both input tables, `route_distance`, `route_duration` and `carto_routing_matrix_metadata`.Examples with TomTom specific parameters:
CALL CARTO.CARTO.CREATE_ROUTING_MATRIX(
    'my-schema.my-origins-table',
    'my_origins_geom_column',
    'my-schema.my-destinations-table',
    'my_destinations_geom_column',
    'my-schema.my-output-table',
    'car',
    '{"departAt":"now"}'
);
-- The table `my-schema.my-output-table` will be created
-- with the columns from both input tables, `route_distance`, `route_duration` and `carto_routing_matrix_metadata`.CALL CARTO.CARTO.CREATE_ROUTING_MATRIX(
    'my-schema.my-origins-table',
    'my_origins_geom_column',
    'my-schema.my-destinations-table',
    'my_destinations_geom_column',
    'my-schema.my-output-table',
    'car',
    {"departAt":"now"}
);
-- The table `my-schema.my-output-table` will be created
-- with the columns from both input tables, `route_distance`, `route_duration` and `carto_routing_matrix_metadata`.CALL CARTO.CARTO.CREATE_ROUTING_MATRIX(
    'my-schema.my-origins-table',
    'my_origins_geom_column',
    'my-schema.my-destinations-table',
    'my_destinations_geom_column',
    'my-schema.my-output-table',
    'car',
    '{"departAt":"now"}',
    'my_api_base_url',
    'my_api_access_token'
);
-- The table `my-schema.my-output-table` will be created
-- with the columns from both input tables, `route_distance`, `route_duration` and `carto_routing_matrix_metadata`.CALL CARTO.CARTO.CREATE_ROUTING_MATRIX(
    'my-schema.my-origins-table',
    'my_origins_geom_column',
    'my-schema.my-destinations-table',
    'my_destinations_geom_column',
    'my-schema.my-output-table',
    'car',
    {"departAt":"now"},
    'my_api_base_url',
    'my_api_access_token'
);
-- The table `my-schema.my-output-table` will be created
-- with the columns from both input tables, `route_distance`, `route_duration` and `carto_routing_matrix_metadata`.Example with batch sizes:
CALL CARTO.CARTO.CREATE_ROUTING_MATRIX(
    'my-schema.my-origins-table',
    'my_origins_geom_column',
    'my-schema.my-destinations-table',
    'my_destinations_geom_column',
    'my-schema.my-output-table',
    'car',
    '{"carto_origins_batch_size": 10, "carto_destinations_batch_size": 1000}'
);
-- The table `my-schema.my-output-table` will be created
-- with the columns from both input tables, `route_distance`, `route_duration` and `carto_routing_matrix_metadata`.Last updated
Was this helpful?
