A7670 LTE Cat 1 Module

View on Amazon
Overview
About A7670 LTE Cat 1 Module
The A7670 is a high-performance LTE Cat 1 module that supports LTE-TDD, LTE-FDD, GSM, GPRS, and EDGE, making it ideal for IoT applications requiring stable and efficient wireless communication. It provides downlink speeds of up to 10 Mbps and uplink speeds of up to 5 Mbps, ensuring reliable data transmission.
⚡ Key Features
- LTE Cat 1 Support – Optimized for IoT applications needing moderate data rates.
- Multi-Network Compatibility – Works with LTE-TDD, LTE-FDD, GSM, GPRS, and EDGE.
- Fast & Reliable Data Transfer – Supports 10 Mbps (downlink) and 5 Mbps (uplink).
- Versatile Applications – Suitable for smart meters, industrial IoT, and asset tracking.
🔗 Still deciding on a SIM module? Check the ESP32 SIM Modules Comparison Table for a breakdown of LTE, 3G, and GPRS options. 🚀
Get Your A7670
💡 Prices are subject to change. We earn from qualifying purchases as an Amazon Associate.
A7670 Specifications
Complete technical specification details for A7670 LTE Cat 1 Module
📊 Technical Parameters
A7670 Pinout
The A7670 pinout includes power supply, UART communication, control pins, status indicators, dual antenna connections (LTE/GSM and GPS), and SIM card interface pins for LTE Cat 1 cellular and GPS functionality.
Visual Pinout Diagram

Pin Types
Quick Tips
Cat 1 module with multi-network support (LTE-TDD, LTE-FDD, GSM, GPRS, EDGE),Data rates: 10 Mbps downlink, 5 Mbps uplink,Integrated multi-constellation GNSS (GPS, GLONASS, BeiDou, Galileo)
voltage: 3.4V to 4.2V,Peak current: 2A during transmission,Default UART baud rate: 115200 bps
voice calls, SMS, and data transfer,Requires SIM card for cellular connectivity,Dual antenna connections: LTE/GSM and GPS
Pin Descriptions
| Pin Name | Type | Description | Notes |
|---|---|---|---|
1 VBAT | Power | Power supply input (3.4V to 4.2V) | Requires stable power with peak current up to 2A |
2 GND | Ground | Ground connection | Common ground |
3 TXD | UART TX | UART Transmit Data (connects to microcontroller RX) | Default baud rate: 115200 bps |
4 RXD | UART RX | UART Receive Data (connects to microcontroller TX) | Default baud rate: 115200 bps |
5 PWRKEY | Control | Power on/off control (active low) | Pull low for at least 500ms to power on |
6 NETLIGHT | Status | Network status indication | LED indicator for network registration |
7 STATUS | Status | Module operating status indication | Shows module power state |
8 ANT_MAIN | Antenna | Main antenna connection for LTE/GSM | Requires external LTE antenna |
9 ANT_GPS | Antenna | Antenna connection for GPS | Requires external GPS antenna |
Wiring A7670 to ESP32
Connect the A7670 to your ESP32 via UART for AT command communication. The module requires a stable 3.4V-4.2V power supply with sufficient current capacity (peak 2A). External antennas are required for both LTE/GSM and GPS functionality.
Visual Wiring Diagram

Connection Status
Protocol
Pin Connections
| A7670 Pin | Connection | ESP32 Pin | Description |
|---|---|---|---|
1 VBAT Required | 3.7V-4.2V Power Supply | Provide stable power (NOT from ESP32 pin) | |
2 GND Required | GND | Common ground connection | |
3 TXD Required | GPIO16 (RX2) | A7670 TX to ESP32 RX | |
4 RXD Required | GPIO17 (TX2) | A7670 RX to ESP32 TX | |
5 PWRKEY Optional | GPIO4 | Power control (pull low to power on) | |
6 ANT_MAIN Required | External LTE Antenna | Connect LTE/GSM antenna | |
7 ANT_GPS Optional | External GPS Antenna | Connect GPS antenna (optional) |
CRITICAL: Use a dedicated power supply (3.4V-4.2V, 2A peak) - DO NOT power from ESP32 pin!
UART baud rate is 115200 bps
Cat 1 provides 10 Mbps downlink, 5 Mbps uplink
LTE/GSM antenna is mandatory for network connectivity
antenna is optional but required for location services
PWRKEY low for at least 500ms to power on the module
NETLIGHT pin for network registration status
active SIM card before powering on
multiple frequency bands - check local carrier compatibility
good antenna placement for optimal signal reception
GNSS: GPS, GLONASS, BeiDou, Galileo
A7670 Troubleshooting
Common issues and solutions to help you get your sensor working
Common Issues
Issue: The A7670 module does not power up or respond to commands.
Possible causes include insufficient power supply, incorrect wiring, or faulty hardware.
Solution: Ensure the module is connected to a stable power source within the recommended voltage range of 3.4V to 4.2V. Verify that all connections are secure and correctly configured. If the problem persists, consider testing the module with a different power source or replacing it.
Issue: The module fails to detect or register the SIM card.
Possible causes include improper SIM card insertion, unsupported SIM card type, or SIM card lock.
Solution: Ensure the SIM card is properly inserted into the module's SIM card slot and is compatible with the GSM network. Verify that the SIM card is active and unlocked. If necessary, test the SIM card in another device to confirm its functionality.
Issue: The module experiences weak signal strength or fails to maintain a stable network connection.
Possible causes include improper antenna connection, environmental interference, or network coverage limitations.
Solution: Ensure the GSM antenna is securely connected to the module and positioned for optimal signal reception. Avoid placing the module near sources of electromagnetic interference. Check the network coverage in your area to ensure adequate signal strength.
Issue: The module does not respond to AT commands sent from the microcontroller or computer.
Possible causes include incorrect baud rate settings, faulty serial connections, or improper command syntax.
Solution: Verify that the baud rate of the module matches that of the microcontroller or computer; the default baud rate is 115200 bps. Check that the TX and RX lines are correctly connected and that there are no loose connections. Ensure that AT commands are correctly formatted and terminated with a carriage return.
Issue: The A7670 module fails to acquire GPS signals or provide location data.
Possible causes include improper antenna connection, obstructed view of the sky, or GPS functionality not enabled.
Solution: Ensure the GPS antenna is properly connected and has a clear view of the sky to receive satellite signals. Verify that the GPS functionality is enabled by sending the appropriate AT commands to power on the GPS engine.
Debugging Tips
Use the Serial Monitor to check for error messages and verify the sensor's output. Add debug prints in your code to track the sensor's state.
Use a multimeter to verify voltage levels and check for continuity in your connections. Ensure the power supply is stable and within the sensor's requirements.
Additional Resources
A7670 Programming Examples
Ready-to-use code examples for different platforms and frameworks
#include <SoftwareSerial.h>
SoftwareSerial a7670(10, 11); // RX, TX
#define PWRKEY 9
void powerOnA7670() {
pinMode(PWRKEY, OUTPUT);
digitalWrite(PWRKEY, LOW);
delay(1000); // Hold PWRKEY low for 1 second
digitalWrite(PWRKEY, HIGH);
delay(5000); // Wait for the module to initialize
}
void setup() {
Serial.begin(9600);
a7670.begin(9600);
powerOnA7670();
// Test AT command
a7670.println("AT");
delay(1000);
while (a7670.available()) {
Serial.write(a7670.read());
}
// Set SMS text mode
a7670.println("AT+CMGF=1");
delay(1000);
while (a7670.available()) {
Serial.write(a7670.read());
}
// Send SMS
a7670.println("AT+CMGS=\"+1234567890\""); // Replace with recipient's number
delay(1000);
a7670.print("Hello from A7670");
a7670.write(26); // CTRL+Z to send
delay(5000);
while (a7670.available()) {
Serial.write(a7670.read());
}
}
void loop() {
// Add code to handle incoming messages or other functionalities
}#include <stdio.h>
#include "driver/uart.h"
#include "driver/gpio.h"
#include "freertos/task.h"
#define TX_PIN 17
#define RX_PIN 16
#define PWRKEY_PIN 4
#define UART_PORT UART_NUM_1
void init_uart() {
uart_config_t uart_config = {
.baud_rate = 9600,
.data_bits = UART_DATA_8_BITS,
.parity = UART_PARITY_DISABLE,
.stop_bits = UART_STOP_BITS_1,
.flow_ctrl = UART_HW_FLOWCTRL_DISABLE
};
uart_param_config(UART_PORT, &uart_config);
uart_set_pin(UART_PORT, TX_PIN, RX_PIN, UART_PIN_NO_CHANGE, UART_PIN_NO_CHANGE);
uart_driver_install(UART_PORT, 1024, 0, 0, NULL, 0);
}
void power_on_a7670() {
gpio_set_direction(PWRKEY_PIN, GPIO_MODE_OUTPUT);
gpio_set_level(PWRKEY_PIN, 0);
vTaskDelay(1000 / portTICK_PERIOD_MS); // Hold PWRKEY low for 1 second
gpio_set_level(PWRKEY_PIN, 1);
vTaskDelay(5000 / portTICK_PERIOD_MS); // Wait for the module to initialize
}
void app_main(void) {
init_uart();
power_on_a7670();
char *test_cmd = "AT\r\n";
uart_write_bytes(UART_PORT, test_cmd, strlen(test_cmd));
while (true) {
char data[128];
int len = uart_read_bytes(UART_PORT, data, sizeof(data), 100 / portTICK_PERIOD_MS);
if (len > 0) {
data[len] = '\0';
printf("Response: %s\n", data);
}
vTaskDelay(1000 / portTICK_PERIOD_MS);
}
}uart:
tx_pin: GPIO17
rx_pin: GPIO16
baud_rate: 9600
switch:
- platform: gpio
name: "A7670 Power"
pin:
number: GPIO4
inverted: true
switch:
- platform: template
name: "Send AT Command"
turn_on_action:
- uart.write: "AT\r\n"
sensor:
- platform: custom
lambda: |-
return {nullptr};
sensors:
- name: "A7670 Response"platformio.ini
[env:a7670]
platform = espressif32
board = esp32dev
framework = arduino
monitor_speed = 115200main.cpp
#include <HardwareSerial.h>
#include <Arduino.h>
HardwareSerial a7670(1);
#define PWRKEY 4
void power_on_a7670() {
pinMode(PWRKEY, OUTPUT);
digitalWrite(PWRKEY, LOW);
delay(1000); // Hold PWRKEY low for 1 second
digitalWrite(PWRKEY, HIGH);
delay(5000); // Wait for initialization
}
void setup() {
Serial.begin(115200);
a7670.begin(9600, SERIAL_8N1, 16, 17); // RX, TX
power_on_a7670();
// Test AT command
a7670.println("AT");
delay(1000);
while (a7670.available()) {
Serial.write(a7670.read());
}
// Send SMS
a7670.println("AT+CMGF=1"); // Set SMS to text mode
delay(1000);
a7670.println("AT+CMGS=\"+1234567890\""); // Replace with recipient's number
delay(1000);
a7670.print("Hello from A7670");
a7670.write(26); // CTRL+Z to send SMS
delay(5000);
}
void loop() {
// Handle incoming data or other functionalities
}from machine import UART, Pin
import time
# Initialize UART
uart = UART(2, baudrate=9600, tx=17, rx=16)
pwrkey = Pin(4, Pin.OUT)
def power_on_a7670():
pwrkey.value(0)
time.sleep(1) # Hold PWRKEY low for 1 second
pwrkey.value(1)
time.sleep(5) # Wait for module to initialize
def send_at(command):
uart.write(command + '\r\n')
time.sleep(1)
while uart.any():
print(uart.read().decode('utf-8'), end='')
# Power on the module
power_on_a7670()
# Test communication
send_at('AT')
# Send SMS
send_at('AT+CMGF=1') # Set SMS to text mode
send_at('AT+CMGS="+1234567890"') # Replace with recipient's number
uart.write("Hello from A7670" + chr(26))Wrapping Up A7670
The ESP32 A7670 LTE Cat 1 Module is a powerful SIM sensor that offers excellent performance and reliability. With support for multiple development platforms including Arduino, ESP-IDF, ESPHome, PlatformIO, and MicroPython, it's a versatile choice for your IoT projects.
Best Practices
For optimal performance, ensure proper wiring and follow the recommended configuration for your chosen development platform.
Safety First
Always verify power supply requirements and pin connections before powering up your project to avoid potential damage.
Ready to Start Building?
Now that you have all the information you need, it's time to integrate the A7670 into your ESP32 project and bring your ideas to life!
Explore Alternative Sensors
Looking for alternatives to the A7670? Check out these similar sensors that might fit your project needs.

SIM7600G LTE CAT1 Module
The SIM7600G is a versatile LTE CAT1 module that provides reliable communication capabilities for various IoT applications. Its compact...

SIM800L GSM/GPRS Module
The SIM800L is a GSM/GPRS communication module that supports voice, SMS, and data transmission. It is ideal for IoT applications requiring...

SIM800C GSM/GPRS Module
The SIM800C is a versatile GSM/GPRS module that provides quad-band connectivity for voice, SMS, and data applications. Its compact design...





