Skip to content
/ ubxlib Public
forked from u-blox/ubxlib

Latest commit

 

History

History
 
 

location

Introduction

These examples demonstrate how to establish location in three different configurations:

Usage

To build and run these examples on a supported platform you need to travel down into the port/platform/<platform>/mcu/<mcu> directory of your choice and find the runner build. The instructions there will tell you how to set/override #defines. The following #defines are relevant:

U_CFG_APP_FILTER: set this to exampleLoc (noting that NO quotation marks should be included) to run just these examples, as opposed to all the examples and unit tests.

For the remainder of the #defines you may either override their values in the same way or, if you are only running these examples, you may edit the values directly in main_loc_gnss.c, main_loc_gnss_cell.c and main_loc_cell_locate.c before compiling.

The GNSS Examples main_loc_gnss.c And main_loc_gnss_continuous.c

If you have a GNSS chip attached directly to this MCU then you can run the main_loc_gnss.c/main_loc_gnss_continuous.c examples and the following values should be set.

U_CFG_TEST_GNSS_MODULE_TYPE: consult u_gnss_type.h to determine the type name for the GNSS module you intend to use. For instance, to use an M8 module you would set U_CFG_TEST_GNSS_MODULE_TYPE to U_GNSS_MODULE_TYPE_M8.

U_CFG_APP_PIN_GNSS_xxx: the default values for the MCU pins connecting your GNSS module to your MCU are #defined in the file port/platform/<platform>/mcu/<mcu>/cfg/cfg_app_platform_specific.h. You should check if these are correct for your board and, if not, override the values of the #defines (where -1 means "not connected").

U_CFG_APP_GNSS_UART / U_CFG_APP_GNSS_I2C / U_CFG_APP_GNSS_SPI: this sets the internal HW block that your chosen MCU will use to talk to the GNSS module. For a UART the default is usually acceptable while for I2C and SPI we usually set our default value to -1 and so you must set a value yourself: consult the file port/platform/<platform>/mcu/<mcu>/cfg/cfg_hw_platform_specific.h for options.

You will also need an antenna connected to the GNSS chip.

The GNSS Cellular Examples main_loc_gnss_cell.c And main_loc_gnss_cell_continuous.c

If you have a GNSS chip attached via a cellular module then you can run the main_loc_gnss_cell.c/main_loc_gnss_cell_continuous.c examples and the following values should be set. Note, however, that Cell Locate will in fact make use of a GNSS chip attached via a cellular module as well and hence it may be simpler to use the main_loc_cell_locate.c example unless you want to take control of, for instance, the configuration of the GNSS chip, yourself or you need a relatively high (e.g. each second) location rate.

U_CFG_TEST_GNSS_MODULE_TYPE: consult u_gnss_type.h to determine the type name for the GNSS module you intend to use. For instance, to use an M8 module you would set U_CFG_TEST_GNSS_MODULE_TYPE to U_GNSS_MODULE_TYPE_M8.

U_CFG_TEST_CELL_MODULE_TYPE: consult u_cell_module_type.h to determine the type name for the cellular module you intend to use. For instance, to use SARA-R5 you would set U_CFG_TEST_CELL_MODULE_TYPE to U_CELL_MODULE_TYPE_SARA_R5.

U_CFG_APP_PIN_CELL_xxx: the default values for the MCU pins connecting your cellular module to your MCU are #defined in the file port/platform/<platform>/mcu/<mcu>/cfg/cfg_app_platform_specific.h. You should check if these are correct for your board and, if not, override the values of the #defines (where -1 means "not connected").

U_CFG_APP_CELL_UART: this sets the internal HW UART block that your chosen MCU will use to talk to the cellular module. The default is usually acceptable but if you wish to change it then consult the file port/platform/<platform>/mcu/<mcu>/cfg/cfg_hw_platform_specific.h for other options.

The Cell Locate Example main_loc_cell_locate.c

If you do not have a GNSS chip you may establish approximate location (e.g. within a kilometre) via a cellular module using the Cell Locate service as shown in the main_loc_cell_locate.c example.

For this example the settings of the GNSS Cellular Example above must be followed and then in addition:

U_CFG_APP_CELL_LOC_AUTHENTICATION_TOKEN: must be set to a valid authentication token for the u-blox Cell Locate service, obtainable from your Thingstream portal, noting that NO quotation marks should be included.

U_CFG_TEST_CELL_LOCATE must be defined to include the body of the main_loc_cell_locate.c in your build.

You will need a SIM in your board, a cellular antenna connected and you may need to know the APN associated with the SIM (though accepting the network default often works).

The GNSS Cloud Locate Example main_loc_gnss_cloud_locate.c

You may take advantage of positioning assistance information known to u-blox servers by using the u-blox Cloud Locate service with your GNSS chip, as shown in the main_loc_gnss_cloud_locate.c example. This example assumes a cellular module that includes a GNSS module inside it, e.g. SARA-R5180M8S or SARA-R422M8S.

First, you must log-in to your Thingstream account and, under Location Services, add a Cloud Locate thing (if you don't already have one). The thing will have a set of credentials associated with it; client ID, username and password. Edit main_loc_gnss_cloud_locate.c to put these credentials into the MY_THINGSTREAM_CLIENT_ID, MY_THINGSTREAM_USERNAME and MY_THINGSTREAM_PASSWORD conditional compilation flags respectively.

Then perform the settings of the GNSS Cellular Example above.

You will need a SIM in your board, a cellular antenna connected and you may need to know the APN associated with the SIM (though accepting the network default often works).