Tối ưu hóa các mô hình AI bằng cách tỉa thưa (pruning) — giảm độ phức tạp, tăng hiệu quả và triển khai nhanh hơn trên các thiết bị biên mà không làm giảm hiệu suất.
Pruning is a strategic model optimization technique used to reduce the size and computational complexity of neural networks by removing unnecessary parameters. Much like a gardener trims dead or overgrown branches to help a tree thrive, pruning algorithms identify and eliminate redundant weights and biases that contribute little to a model's predictive power. The primary objective is to create a compressed, "sparse" model that maintains high accuracy while consuming significantly less memory and energy. This reduction is essential for improving inference latency, allowing advanced architectures to run efficiently on resource-constrained hardware like mobile phones and embedded devices.
Modern deep learning models are often over-parameterized, meaning they contain far more connections than necessary to solve a specific task. Pruning exploits this by removing connections that have values close to zero, under the assumption that they have a negligible impact on the output. After parameters are removed, the model typically undergoes a process of fine-tuning, where it is retrained briefly to adjust the remaining weights and recover any lost performance. This concept is closely related to the Lottery Ticket Hypothesis, which suggests that large networks contain smaller, highly efficient subnetworks capable of reaching similar accuracy.
Có hai loại chiến lược cắt tỉa chính:
Việc cắt tỉa cây là không thể thiếu để cho phép AI biên hoạt động trong nhiều ngành công nghiệp khác nhau, nơi tài nguyên phần cứng bị hạn chế:
While state-of-the-art models like YOLO26 are designed for efficiency, developers can apply pruning to further optimize layers using libraries like PyTorch. The following example demonstrates how to apply unstructured pruning to a convolutional layer.
import torch
import torch.nn.utils.prune as prune
# Initialize a standard convolutional layer
layer = torch.nn.Conv2d(in_channels=3, out_channels=32, kernel_size=3)
# Apply L1 unstructured pruning to remove 30% of weights with the lowest magnitude
prune.l1_unstructured(layer, name="weight", amount=0.3)
# Verify sparsity (percentage of zero parameters)
sparsity = 100.0 * float(torch.sum(layer.weight == 0)) / layer.weight.nelement()
print(f"Sparsity achieved: {sparsity:.2f}%")
Để tối ưu hóa mô hình một cách hiệu quả cho việc triển khai , cần phân biệt giữa việc cắt tỉa và các chiến lược khác:
Để quản lý vòng đời toàn diện, bao gồm huấn luyện, chú thích và triển khai các mô hình được tối ưu hóa, người dùng có thể tận dụng Nền tảng Ultralytics . Điều này đơn giản hóa quy trình làm việc từ quản lý tập dữ liệu đến xuất mô hình ở các định dạng thân thiện với phần cứng như ONNX hoặc TensorRT .