Retrieving the Location for MKR GSM 1400
Retrieve the location of your board using GPRS (General Packet Radio Service).
Introduction
In this tutorial, we will use the
GSMLocationGSMLocationGoals
The goals of this project are:
- Read the location of the MKR GSM 1400.
- Print the longitude, latitude, altitude values in the Serial Monitor.
- Print the accuracy of the signal (in meters).
Hardware & Software Needed
- Arduino IDE (online or offline).
- MKRGSM library installed.
- Arduino MKR GSM 1400.
- Antenna.
- SIM card from an operator in your country.
Using GPRS to Track Location
GPRS, short for General Packet Radio Service, is a platform for mobile communication, which is used to transfer data to and from mobile devices. In comparison to using a Global Positioning System (GPS), GPRS is not quite as accurate. While GPS can pinpoint your exact location with incredible accuracy, GPRS can only give an estimate. It is because the location data is only provided based on cellular networks, while GPS uses several satellites in orbit.
However, as GPRS is also connected to the Internet, the location can be viewed as an additional feature that can be used for projects that does not require high accuracy. When running the code sample in this tutorial, we started of with an accuracy of 868km (not very helpful), but after a few minutes, it was able to get within 200 meters (a bit more helpful).
Using GPRS as a location tracking of course does not guarantee 100% accuracy, but as an additional feature, it does the job quite well.
Circuit
 
  
    
    
Creating the Program
We will now get to the programming part of this tutorial, in which we will need to:
- Configure the credentials (APN, PIN, USERNAME, PASSWORD).
- Connect to the GPRS network.
- Print location data in the Serial Monitor.
1. First, let's make sure we have the drivers installed. If we are using the Web Editor, we do not need to install anything. If we are using an offline editor, we need to install it manually. This can be done by navigating to Tools > Board > Board Manager.... Here we need to look for the Arduino SAMD boards (32-bits Arm® Cortex®-M0+) and install it.
2. Now, we need to install the libraries needed. If we are using the Web Editor, there is no need to install anything. If we are using an offline editor, simply go to Tools > Manage libraries.., and search for MKRGSM and install it.
3. We can now take a look at some of the core functions of this sketch:
 - base class for GSM functions for location.- GSMLocation location
 - base class for all GSM functions.- GSM gsmAccess
 - base class for all GPRS functions.- GPRS gprs
 - checks for available location data.- location.available()
 - retrieves longitude coordinates.- location.longitude()
 - retrieves latitude coordinates.- location.latitude()
 - retrieves altitude data.- location.altitude()
 - retrieves accuracy of location.- location.accuracy()
The sketch can be found in the snippet below. You can also find the sketch in File > Examples > MKRGSM > GsmLocation. Upload the code to the board, and make sure the right board and port are selected.
1// libraries2#include <MKRGSM.h>3
4#include "arduino_secrets.h"5// Please enter your sensitive data in the Secret tab or arduino_secrets.h6// PIN Number7const char PINNUMBER[]     = SECRET_PINNUMBER;8// APN data9const char GPRS_APN[]      = SECRET_GPRS_APN;10const char GPRS_LOGIN[]    = SECRET_GPRS_LOGIN;11const char GPRS_PASSWORD[] = SECRET_GPRS_PASSWORD;12
13// initialize the library instance14GSMLocation location;15GPRS gprs;16GSM gsmAccess;17
18void setup() {19  // initialize serial communications and wait for port to open:20  Serial.begin(9600);21  while (!Serial) {22    ; // wait for serial port to connect. Needed for native USB port only23  }24
25  Serial.println("Starting GSM location.");26  // connection state27  bool connected = false;28
29  // After starting the modem with GSM.begin()30  // connect to the GPRS network with the APN, login and password31  while (!connected) {32    if ((gsmAccess.begin(PINNUMBER) == GSM_READY) &&33        (gprs.attachGPRS(GPRS_APN, GPRS_LOGIN, GPRS_PASSWORD) == GPRS_READY)) {34      connected = true;35    } else {36      Serial.println("Not connected");37      delay(1000);38    }39  }40
41  location.begin();42}43
44void loop() {45  if (location.available()) {46    Serial.print("Location: ");47    Serial.print(location.latitude(), 7);48    Serial.print(", ");49    Serial.println(location.longitude(), 7);50
51    Serial.print("Altitude: ");52    Serial.print(location.altitude());53    Serial.println("m");54
55    Serial.print("Accuracy: +/- ");56    Serial.print(location.accuracy());57    Serial.println("m");58
59    Serial.println();60  }61}Testing It Out
After we have uploaded the code successfully, open the Serial Monitor. Now, the text
"Starting GSM location" 
  
    
    
But after a while, the readings get much closer, and accuracy is down to +/- 500 meters. Considerably better than 860 kilometers!
 
  
    
    
As mentioned earlier in this tutorial, the GPRS module may not be able to pinpoint your exact location, but more of an estimate. As we received a +/- accuracy of 500 meters, we can brainstorm ways of tracking where only an estimated location is needed.
Troubleshoot
If the code is not working, there are some common issues we can troubleshoot:
- We have not installed the MKRGSM library.
- We have entered the wrong pin number.
- We have entered the wrong APN.
- We are out of coverage (no signal).
- SIM card may not be activated.
Conclusion
In this tutorial we have used the
GSMlocationFor more accurate location tracking, you can check out the MKR GPS basics tutorial, which uses the MKR GPS Shield to track location in a very accurate fashion. This shield can be used directly with the MKR GSM 1400.
Suggested changes
The content on docs.arduino.cc is facilitated through a public GitHub repository. You can read more on how to contribute in the contribution policy.
License
The Arduino documentation is licensed under the Creative Commons Attribution-Share Alike 4.0 license.