Loading...
Loading...
NVIDIA DeepStream SDK 9.0 development with Python pyservicemaker API. Use when building video analytics pipelines, GStreamer-based video processing, TensorRT inference integration, object detection/tracking, or Kafka/message broker integration.
npx skill4agent add nvidia/skills deepstream-devSource → Stream Muxer → Inference → [Tracker] → OSD → Renderer[brackets]| Stage | Role | Key Element(s) | Required? |
|---|---|---|---|
| Source | Input from files, RTSP, cameras | | Yes |
| Stream Muxer | Batches streams for inference | | Yes |
| Inference | TensorRT model execution | | Yes |
| Tracker | Multi-object tracking across frames | | Only if requested |
| OSD | Draws bounding boxes, labels, overlays | | Yes (for visualization) |
| Renderer | Display or save output | | Yes |
memory:NVMMvideo/x-raw(memory:NVMM), format=NV12nvtrackernvdsanalyticsnvmsgbrokernvmsgconvnvurisrcbinnvurisrcbinfile://filesrcqtdemuxlive-source=1nvstreammuxsync=0"file://" + os.path.abspath(path).frame_items.object_itemslen()"sink_%u"pipeline.link(("decoder", "mux"), ("", "sink_%u")) # CORRECT
# pipeline.link(("decoder", "mux"), ("", "sink_0")) # WRONG - will failimport platform
sink_type = "nv3dsink" if platform.processor() == "aarch64" else "nveglglessink"tensor = buffer.extract(0).clone() # CRITICALqueue.Queuethreading.Threadmultiprocessing.Queuemultiprocessing.Processproperty:model:key: value[property]key=valuepropertytee# When using tee splits OR dynamic sources, ALL sinks MUST have async=0
pipeline.add("nveglglessink", "sink", {
"sync": 0, "qos": 0,
"async": 0 # CRITICAL - prevents state transition deadlock
})measure_fps_probenvinfernvosdbinRuntimeError: Probe failureinfer-dimsdynamic=Trueinfer-dims=C;H;W-1setDimensions: Error Code 3infer-dims=3;640;640infer-dims=3;416;416infer-dims=3;1280;1280cluster-mode| Model generation | Output tensor shape | Fields | |
|---|---|---|---|
| v8 / v11 | | | |
| v10 / v26+ | | | |
inferDims.d[0]inferDims.d[1]d={84, 8400}d={300, 6}cluster-mode: 2[N, 6]rotation_anglereferences/nvinfer_config.mdNvDsInferObjectDetectionInfoobj{}rotation_angle = 0NvDsInferObjectDetectionInfo obj;pyservicemakerpyservicemakerpyyamlpython3 -m venv venv
source venv/bin/activate
pip install /opt/nvidia/deepstream/deepstream/service-maker/python/pyservicemaker*.whl pyyaml
pip install -r requirements.txt # other dependenciesModuleNotFoundError: No module named 'pyservicemaker'/opt/nvidia/deepstream/deepstream/samples/models//opt/nvidia/deepstream/deepstream/samples/models/Primary_Detector/resnet18_trafficcamnet_pruned.onnx/opt/nvidia/deepstream/deepstream/lib/libnvds_nvmultiobjecttracker.so/opt/nvidia/deepstream/deepstream/lib/libnvds_kafka_proto.so/opt/nvidia/deepstream/deepstream/samples/configs/deepstream-app/| Document | Use When |
|---|---|
| references/gstreamer_plugins.md | Looking up plugin properties, ALL properties listed |
| references/service_maker_api.md | Using Pipeline/Flow API, metadata access, probes, EventMessageUserMetadata |
| references/use_cases_pipelines.md | Building pipelines: simple playback, multi-inference, cascaded GIE |
| references/kafka_messaging.md | Kafka/message broker setup, nvmsgconv/nvmsgbroker config, msg2p-newapi |
| references/best_practices.md | Design patterns, common pitfalls, anti-patterns |
| references/buffer_apis.md | BufferProvider/Feeder (injection), BufferRetriever/Receiver (extraction) |
| references/media_extractor_advanced.md | MediaExtractor, MediaChunk, FrameSampler |
| references/utilities_config.md | PerfMonitor, EngineFileMonitor, SourceConfig, SensorInfo, SmartRecordConfig |
| references/nvinfer_config.md | nvinfer config file format, ALL parameters |
| references/tracker_config.md | nvtracker config, NvDCF/IOU/DeepSORT/NvSORT |
| references/troubleshooting.md | Error messages and solutions |
| references/rest_api_dynamic.md | REST API, dynamic source add/remove, nvmultiurisrcbin |
| references/metamux_config.md | nvdsmetamux config, parallel multi-model inference, metadata merging, source ID filtering |
| references/docker_containers.md | Docker images, Dockerfile examples, pyservicemaker install, container run commands |
| Error | Solution |
|---|---|
| Iterate to count, don't use |
| Use |
| Queue data loss | Use |
| Config parse failed | Use |
| Use |
| Use |
| Secondary GIE inactive | Set |
| Tee/dynamic source stuck PAUSED | Set |
| RTSP no data/reconnecting | Test URL with ffplay, check credentials |
| |
| Add |
| |
| Use |