当前位置: 首页 > article >正文

MQ2_LPG气体检测库:嵌入式LPG泄漏监测与动态校准实践

1. MQ2_LPG气体检测库深度解析面向嵌入式系统的LPG泄漏监测工程实践1.1 库定位与工程价值MQ2_LPG是一个专为嵌入式平台设计的轻量级气体传感驱动库核心目标是实现对液化石油气Liquefied Petroleum Gas, LPG中丙烷C₃H₈和丁烷C₄H₁₀成分的可靠检测。该库并非通用型MQ-2传感器抽象层而是聚焦于LPG这一特定应用场景的工程优化实现——它跳出了传统“读取ADC原始值→查表换算→经验阈值判断”的粗放模式通过动态校准机制将硬件非线性、环境温湿度漂移、传感器老化等现实约束纳入系统建模使开发者能直接获取具有工程意义的LPG浓度相对指示值。在燃气报警器、智能厨房监控、工业管道泄漏巡检等实际项目中LPG检测的可靠性直接关系人身安全。MQ2_LPG库的价值在于将传感器物理特性、电路设计约束、环境变量补偿、嵌入式资源限制等多维度工程要素封装为可复用的软件模块。其V1.0.0版本虽功能精简但已具备生产环境部署的基本能力尤其适用于Arduino、ESP8266、ESP32等资源受限但需快速验证的原型开发平台。1.2 MQ-2传感器工作原理与LPG检测机理MQ-2属于金属氧化物半导体MOS型气体传感器其核心敏感元件为二氧化锡SnO₂陶瓷管。在洁净空气中SnO₂表面吸附氧分子形成氧负离子O⁻导致材料电阻率升高当LPG等还原性气体接触敏感层时气体分子与吸附氧发生反应释放被俘获的电子使SnO₂导带电子浓度上升宏观表现为电阻值显著下降。LPG主要成分为丙烷C₃H₈和丁烷C₄H₁₀二者均属碳氢化合物在SnO₂表面催化氧化反应如下C₃H₈ 5O₂ → 3CO₂ 4H₂O 能量 C₄H₁₀ 6.5O₂ → 4CO₂ 5H₂O 能量该反应消耗表面吸附氧降低电子捕获势垒使传感器电阻Rₛ随LPG浓度增加呈指数衰减。典型MQ-2在300–500ppm LPG环境中电阻变化范围可达1kΩ–10kΩ具体取决于加热电压、环境温湿度及器件批次。因此LPG检测本质是高精度电阻测量问题而MQ2_LPG库的核心任务正是将ADC采样值稳定、可重复地映射为反映LPG浓度趋势的量化指标。1.3 硬件接口与电路设计要点MQ-2传感器需双电源供电加热丝H需5V恒压供电典型功耗约750mW确保SnO₂工作在300–400℃最佳反应温度。若使用3.3V MCU如ESP32必须外接5V LDO或DC-DC升压模块严禁直接连接MCU GPIO。测量电极A/B构成分压电路通常采用固定负载电阻Rₗ推荐10kΩ与传感器电阻Rₛ串联MCU ADC采集Rₗ两端电压Vₐ。标准分压电路输出关系为Vₐ Vcc × Rₗ / (Rₛ Rₗ)由此可推导出传感器电阻Rₛ Rₗ × (Vcc - Vₐ) / Vₐ在实际布板中需注意加热丝引脚H与测量电极A/B必须物理隔离避免热耦合干扰模拟信号走线远离数字高频信号线建议包地处理ADC参考电压需稳定推荐使用MCU内部1.1V基准或外部精密REF传感器需预热≥24小时以达到电化学平衡状态首次上电后前3分钟数据不可信。2. 动态校准机制解决嵌入式气体检测的核心痛点2.1 传统静态校准的失效场景多数MQ系列库采用单点静态校准在洁净空气中读取一次Rₛ₀作为基准再通过Rₛ/Rₛ₀比值估算气体浓度。该方法在实验室环境可行但在工程现场存在严重缺陷温湿度漂移环境温度每升高10℃MQ-2灵敏度下降约15%湿度60%RH时水分子竞争吸附位点导致响应迟钝传感器老化连续工作1000小时后SnO₂晶格结构变化使基线电阻偏移达±30%批次差异同一型号传感器Rₛ₀离散度可达±50%需逐个标定电源波动Vcc微小变化直接影响Vₐ计算精度。MQ2_LPG库提出的动态校准Dynamic Calibration机制本质是构建一个实时更新的环境自适应基准模型其核心思想是将“洁净空气”定义为当前环境下的局部最小电阻状态而非绝对固定值。2.2 动态校准算法实现逻辑库中calibrate()函数执行以下流程以ESP32平台为例// 假设ADC采样分辨率为12位0–4095 #define ADC_MAX 4095 #define CALIBRATION_WINDOW 60000 // 校准窗口60秒 uint16_t MQ2_LPG::calibrate() { uint32_t start_time millis(); uint16_t min_adc_value ADC_MAX; // 初始化为最大值 // 在60秒窗口内持续采样寻找ADC最小值 while (millis() - start_time CALIBRATION_WINDOW) { uint16_t adc_val analogRead(_pin); // 读取A/B端电压对应的ADC值 if (adc_val min_adc_value) { min_adc_value adc_val; delay(100); // 防抖延时避免瞬态干扰 } else { delay(50); } } // 计算当前环境下的基准电阻R_s0 // 注意此处Vcc取实际供电电压非标称值需通过ADC测量Vcc float vcc_actual readVcc(); // 实现见后文 float r_load 10000.0; // 10kΩ负载电阻 _r_s0 r_load * (vcc_actual - (min_adc_value * vcc_actual / ADC_MAX)) / (min_adc_value * vcc_actual / ADC_MAX); return min_adc_value; }关键创新点在于时间窗约束60秒窗口覆盖了典型环境扰动周期如人员走动引起的气流变化确保捕获到真实的“洁净空气”状态最小值追踪动态更新min_adc_value自动规避短期污染事件干扰Vcc实测补偿readVcc()函数利用ESP32内置的1.1V基准ADC通道反向测量Vcc消除电源波动影响long MQ2_LPG::readVcc() { // ADC1_11对应内部1.1V基准读取值用于计算Vcc esp_adc_cal_characteristics_t adc_chars; esp_adc_cal_value_t val_type esp_adc_cal_characterize( ADC_UNIT_1, ADC_ATTEN_DB_11, ADC_WIDTH_BIT_12, 1100, adc_chars); uint32_t voltage esp_adc_cal_raw_to_voltage(analogRead(ADC_CHANNEL_11), adc_chars); return (1100 * 4095) / voltage; // 单位mV }2.3 LPG浓度量化模型完成动态校准后readLPG()函数将实时ADC值转换为LPG浓度指示值float MQ2_LPG::readLPG() { uint16_t adc_val analogRead(_pin); float vcc readVcc() / 1000.0; // 转换为伏特 float v_a adc_val * vcc / ADC_MAX; float r_s _r_load * (vcc - v_a) / v_a; // 当前传感器电阻 // 计算相对于基准的电阻比 float rs_ratio r_s / _r_s0; // 经验公式LPG浓度(ppm) ≈ 100 * (rs_ratio)^(-1.18) // 此处返回归一化指标0.0–100.0便于阈值判断 float lpg_index 100.0 * pow(rs_ratio, -1.18); // 限幅处理避免异常值干扰 if (lpg_index 100.0) lpg_index 100.0; if (lpg_index 0.0) lpg_index 0.0; return lpg_index; }该模型基于MQ-2数据手册中LPG的典型响应曲线log(Rₛ) vs log(concentration)近似线性指数-1.18为实测拟合参数。返回的lpg_index为0–100的无量纲指标工程实践中可设定lpg_index 10安全洁净空气10 ≤ lpg_index 30预警轻微泄漏lpg_index ≥ 30危险需立即通风/关阀3. API接口详解与嵌入式集成实践3.1 核心类接口与参数说明函数签名参数说明返回值工程用途MQ2_LPG(uint8_t pin, float r_load10000.0)pin: ADC输入引脚号r_load: 负载电阻阻值Ω无构造函数初始化传感器引脚与电路参数uint16_t calibrate()无校准期间捕获的最小ADC值执行动态校准更新内部基准_r_s0float readLPG()无0.0–100.0的LPG浓度指标获取实时LPG检测结果void setCalibrationWindow(uint32_t ms)ms: 校准时间窗毫秒无自定义校准时长默认60000msfloat getRS0()无当前基准电阻值Ω调试用查看动态校准结果3.2 STM32 HAL库集成示例在STM32CubeIDE环境下需将MQ2_LPG适配HAL框架。关键修改点替换analogRead()为HAL_ADC模块调用使用HAL_TIM做精确延时启用ADC过采样提升信噪比。// HAL适配版calibrate()函数 uint16_t MQ2_LPG_HAL_Calibrate(MQ2_LPG_HandleTypeDef *hmq2) { uint32_t start_tick HAL_GetTick(); uint16_t min_adc 0xFFFF; ADC_ChannelConfTypeDef sConfig {0}; // 配置ADC通道 sConfig.Channel hmq2-adc_channel; sConfig.Rank ADC_RANK_CHANNEL_NUMBER; sConfig.SamplingTime ADC_SAMPLETIME_239CYCLES_5; HAL_ADC_ConfigChannel(hmq2-hadc, sConfig); while (HAL_GetTick() - start_tick hmq2-calib_window_ms) { HAL_ADC_Start(hmq2-hadc); HAL_ADC_PollForConversion(hmq2-hadc, HAL_MAX_DELAY); uint16_t adc_val HAL_ADC_GetValue(hmq2-hadc); if (adc_val min_adc) { min_adc adc_val; HAL_Delay(100); } else { HAL_Delay(50); } } // 计算R_s0需实现HAL版readVcc hmq2-r_s0 calculate_rs0(min_adc, hmq2-r_load, HAL_ReadVdd()); return min_adc; }3.3 FreeRTOS多任务协同设计在ESP32等多核MCU上建议将气体检测与报警逻辑分离为独立任务// 气体检测任务每2秒采样一次 void gas_monitor_task(void *pvParameters) { MQ2_LPG sensor(A0); sensor.calibrate(); // 首次上电校准 while(1) { float lpg sensor.readLPG(); xQueueSend(gas_queue, lpg, portMAX_DELAY); vTaskDelay(2000 / portTICK_PERIOD_MS); } } // 报警决策任务处理数据并触发动作 void alarm_task(void *pvParameters) { float lpg_val; while(1) { if (xQueueReceive(gas_queue, lpg_val, portMAX_DELAY) pdTRUE) { if (lpg_val 30.0) { // 触发蜂鸣器、LED闪烁、WiFi报警推送 digitalWrite(BUZZER_PIN, HIGH); xEventGroupSetBits(alarm_event_group, LPG_ALARM_BIT); } else if (lpg_val 10.0) { digitalWrite(BUZZER_PIN, LOW); xEventGroupClearBits(alarm_event_group, LPG_ALARM_BIT); } } } }此设计符合实时系统分层原则检测任务专注数据采集报警任务专注状态决策通过队列解耦避免阻塞式延时影响系统响应。4. 工程实践指南从原型到产品化4.1 环境补偿进阶方案动态校准虽解决基础漂移但对温湿度敏感性仍需强化。推荐在PCB上集成DHT22温湿度传感器构建补偿模型// 温湿度补偿系数基于实测数据拟合 float temp_compensation(float temp_c) { return 1.0 0.015 * (temp_c - 25.0); // 25℃为基准 } float humi_compensation(float rh_percent) { return 1.0 0.008 * (rh_percent - 50.0); // 50%RH为基准 } float compensated_lpg raw_lpg * temp_compensation(t) * humi_compensation(h);4.2 低功耗设计策略对于电池供电设备如无线燃气探测器可采用以下策略间歇采样设置10分钟采样间隔MCU其余时间进入Deep Sleep硬件唤醒利用MQ-2电阻突变触发GPIO中断仅在疑似泄漏时启动ADC动态分辨率正常状态下用10位ADC采样快、功耗低预警时切至12位提高精度。4.3 安全认证关键考量LPG检测设备若用于商用需满足以下强制要求响应时间从泄漏发生到报警触发≤30秒IEC 60079-29-1抗干扰性在乙醇、甲烷、CO等常见气体共存下不误报EMC防护通过IEC 61000-4-2ESD±4kV接触放电测试长期稳定性连续运行1年基线漂移≤±10%。MQ2_LPG库本身不提供认证但其动态校准机制为满足上述要求提供了软件基础——开发者需在最终产品中加入定期自检如每24小时自动触发一次校准和故障诊断ADC超限、传感器开路检测逻辑。5. 源码级调试技巧与典型问题排查5.1 关键调试信号观测点信号测试点正常范围异常分析加热丝电压H引脚对GND4.95–5.05V4.9V电源不足5.1V稳压失效A/B端空载电压A/B引脚对GND2.1–2.5V洁净空气2.0VRₛ过小污染/短路2.6VRₛ过大开路/虚焊ADC采样值MCU ADC输入1800–220012位持续1000传感器损坏持续3500分压电阻错用5.2 常见失效模式与修复现象校准后readLPG()始终返回0.0原因min_adc_value未正确更新可能因delay()被FreeRTOS替换为vTaskDelay()导致校准窗口失效。修复在校准函数中禁用RTOS调度器taskDISABLE_INTERRUPTS()或改用xTaskGetTickCount()计时。现象LPG指标剧烈跳变如0→80→0循环原因电源纹波过大导致ADC基准不稳或传感器未充分预热。修复在Vcc与GND间并联100μF电解电容0.1μF陶瓷电容延长上电后首校准等待时间至120秒。现象高温环境40℃下灵敏度骤降原因动态校准窗口内未捕获到真实洁净空气状态热空气密度低LPG易扩散。修复将校准窗口延长至120秒并在readLPG()中加入温度补偿因子。MQ2_LPG库的MIT许可证赋予开发者完全的修改自由所有源码均可根据具体硬件平台深度定制。在某燃气灶具厂商的实际项目中工程师基于该库增加了Wi-Fi OTA升级功能使10万台设备可通过云端推送新校准参数彻底解决了不同地域气候导致的批量误报问题——这印证了一个事实优秀的嵌入式驱动库其生命力不在于代码行数而在于能否成为连接硬件物理世界与软件逻辑世界的可靠桥梁。

相关文章:

MQ2_LPG气体检测库:嵌入式LPG泄漏监测与动态校准实践

1. MQ2_LPG气体检测库深度解析:面向嵌入式系统的LPG泄漏监测工程实践 1.1 库定位与工程价值 MQ2_LPG是一个专为嵌入式平台设计的轻量级气体传感驱动库,核心目标是实现对液化石油气(Liquefied Petroleum Gas, LPG)中丙烷&#xff…...

OpenClaw多模态开发:Qwen2.5-VL-7B实现自动化图文内容审核

OpenClaw多模态开发:Qwen2.5-VL-7B实现自动化图文内容审核 1. 为什么需要本地化内容审核 去年我接手了一个社区运营项目,每天需要审核数百张用户上传的图片和文字内容。最初尝试用第三方审核API,但很快遇到三个痛点:一是敏感数据…...

AI 伦理与可解释AI

**AI伦理与可解释AI:技术发展的双刃剑** 人工智能(AI)的快速发展正在深刻改变社会,但随之而来的伦理问题与“黑箱”难题也引发广泛讨论。AI伦理关注技术应用的道德边界,而可解释AI(XAI)则致力于…...

C++ STL 内存管理策略

C STL内存管理策略解析 C标准模板库(STL)以其高效性和灵活性成为开发者不可或缺的工具,而内存管理策略是其核心优势之一。STL通过智能分配器、容器内部机制及算法优化,实现了内存的高效利用与动态扩展。本文将深入探讨STL的内存管…...

Go测试框架与基准测试

Go测试框架与基准测试:高效代码质量的守护者 在软件开发中,测试是确保代码质量的关键环节。Go语言凭借其简洁高效的特性,内置了强大的测试工具链,包括单元测试框架和基准测试功能。无论是验证逻辑正确性,还是评估性能…...

OpenClaw长期运行方案:Phi-3-mini-128k-instruct服务的稳定性保障

OpenClaw长期运行方案:Phi-3-mini-128k-instruct服务的稳定性保障 1. 为什么需要长期运行方案? 去年冬天的一个深夜,我被手机警报惊醒——部署在家庭服务器的OpenClaw服务崩溃了。当时正在运行的自动化周报生成任务因此中断,导致…...

Go gRPC 流通信机制详解

Go gRPC 流通信机制详解 在现代分布式系统中,高效的数据传输是核心需求之一。gRPC作为Google开源的高性能RPC框架,凭借其基于HTTP/2的流式通信能力,成为微服务通信的热门选择。Go语言因其简洁性和高并发特性,与gRPC结合尤为紧密。…...

Python高频面试题:python里面模块和包之间有什么区别?

大家好,我是锋哥。今天分享关于【Python高频面试题:python里面模块和包之间有什么区别?】面试题 。希望对大家有帮助; Python高频面试题:python里面模块和包之间有什么区别? 在 Python 里,**模…...

Java高频面试题:Netty的内存池机制怎样设计的?

大家好,我是锋哥。今天分享关于【Java高频面试题:Netty的内存池机制怎样设计的?】面试题 。希望对大家有帮助;Java高频面试题:Netty的内存池机制怎样设计的?Netty 的内存池机制是一个非常核心且复杂的部分,它的设计主…...

网络SEO的主要指标有哪些

网络SEO的主要指标有哪些 前言 在当今数字化时代,网络SEO(搜索引擎优化)是每一个网站拥有高流量和高曝光度的关键。SEO是一个复杂而又充满挑战的领域,涉及许多技术和策略。究竟有哪些是网络SEO的主要指标呢?本文将详…...

Go netpoll 实现机制分析

Go netpoll 实现机制分析 在现代高并发网络编程中,高效的事件驱动机制是提升性能的关键。Go语言通过其独特的netpoll模块,实现了轻量级且高效的I/O多路复用,支撑了Go标准库中net包的强大能力。本文将深入分析Go netpoll的实现机制&#xff0…...

5个贝叶斯概率实战案例:从医学诊断到垃圾邮件过滤(附Python代码)

5个贝叶斯概率实战案例:从医学诊断到垃圾邮件过滤(附Python代码) 贝叶斯概率不仅是统计学中的经典理论,更是解决现实问题的利器。想象一下:医生如何通过检测结果判断患者真实患病概率?邮箱如何智能识别垃圾…...

5个实战案例解析:如何用VLA模型让机器人听懂人话并执行任务(附开源项目推荐)

5个实战案例解析:如何用VLA模型让机器人听懂人话并执行任务(附开源项目推荐) 当机器人能像人类助手一样理解"把茶几上的遥控器拿过来"这样的日常指令时,具身智能才真正开始改变我们的生活。视觉-语言-动作(V…...

Playwright同步与异步模式全对比:从基础使用到多线程实战避坑

Playwright同步与异步模式全对比:从基础使用到多线程实战避坑 在自动化测试和网页爬虫领域,Playwright凭借其跨浏览器支持和现代化API设计迅速成为开发者新宠。但对于Python开发者而言,面对同步和异步两种编程模式的选择,常常陷入…...

虚拟列表原理与实现,并在 Vue 项目场景中怎么实现

这是前端面试里的中高频题,尤其是你简历里如果写了:长列表优化大数据量渲染性能优化表格优化Vue 项目优化那几乎很容易被问到。这道题如果只回答:“虚拟列表就是只渲染可视区域的数据。”这个回答方向没错,但太浅。 如果你能讲到&…...

OpenClaw技能扩展:Qwen3.5-9B支持的内容创作自动化实践

OpenClaw技能扩展:Qwen3.5-9B支持的内容创作自动化实践 1. 为什么选择OpenClawQwen3.5-9B组合 去年冬天,当我第一次尝试用AI自动化处理每周的技术博客草稿时,最头疼的就是如何在本地环境实现稳定的内容生成与发布流程。经过多次尝试&#x…...

【LaTeX】入门和使用拾遗

文章目录0 前言1 基本概述1.1 代码框架1.2 环境配置2 常用指令2.1 中文支持2.2 字号及其单位2.3 插图2.4 插入参考文献2.5 设置跳转链接2.6 双栏显示2.7 常用输入0 前言 记得最早接触LaTeX还是在大二参加数学建模大赛的时候,当时比较懵懂,对工具非常“迷…...

WinAsar实战指南:高效处理Electron asar文件的专业工具

WinAsar实战指南:高效处理Electron asar文件的专业工具 【免费下载链接】WinAsar Portable and lightweight GUI utility to pack and extract asar( Electron archive ) files, Only 551 KB! 项目地址: https://gitcode.com/gh_mirrors/wi/WinAsar WinAsar是…...

GPT-SoVITS V3 API实战:用Python几行代码实现流式语音合成与格式转换

GPT-SoVITS V3 API实战:用Python几行代码实现流式语音合成与格式转换 语音合成技术正在经历一场革命性的变革。从早期机械感十足的TTS系统,到如今能够模仿人类情感起伏的AI语音,技术的进步让合成语音越来越自然。GPT-SoVITS V3作为这一领域的…...

NCM解密工具全解析:突破加密壁垒实现音频自由

NCM解密工具全解析:突破加密壁垒实现音频自由 【免费下载链接】ncmdump 项目地址: https://gitcode.com/gh_mirrors/ncmd/ncmdump 问题剖析:加密格式如何成为数字资产的枷锁? 在数字音乐时代,我们常常面临一个矛盾&#…...

离线语音识别新选择:Whisper Web本地部署与内网穿透实战指南

1. 为什么选择Whisper Web进行本地语音识别 在当今AI技术快速发展的时代,语音识别已经成为我们日常工作和生活中不可或缺的工具。但大多数语音识别服务都需要依赖云端,这不仅带来了隐私泄露的风险,还受限于网络连接质量。Whisper Web的出现完…...

MAX31865驱动PT100温度测量全栈指南

1. MAX31865高精度PT100 RTD温度传感器接口芯片深度解析 MAX31865是Maxim Integrated(现属Analog Devices)推出的专用RTD(Resistance Temperature Detector,热电阻)数字转换器,专为工业级铂电阻温度测量而设…...

如何利用 Google Analytics 来优化网站 SEO

如何利用 Google Analytics 来优化网站 SEO 在当今数字营销中,SEO(搜索引擎优化)无疑是每个网站主的首要任务之一。而在SEO优化的过程中,Google Analytics 作为一款强大的分析工具,能够为网站主提供宝贵的数据和洞察&…...

OpenClaw成本优化:Qwen3.5-9B长任务拆解与Token消耗监控

OpenClaw成本优化:Qwen3.5-9B长任务拆解与Token消耗监控 1. 为什么需要关注OpenClaw的Token消耗 上周我让OpenClaw帮我整理一个季度的工作报告,结果第二天发现账户里的大模型调用额度几乎见底。查看日志才发现,这个看似简单的任务竟然消耗了…...

C/C++标准库解析:从原理到实践

1. C/C 标准库的本质与标准化过程作为一名长期从事系统开发的程序员,我经常遇到新手对标准库的困惑:这些看似"凭空出现"的函数和类到底从何而来?让我们从最基础的概念开始拆解。C和C标准库的本质是一套经过严格定义的编程接口规范。…...

Linux驱动开发:从入门到精通的成长路径

1. 职业选择中的偶然与必然刚毕业那会儿,我压根没想过自己会走上Linux驱动开发这条路。就像很多同行一样,职业方向往往不是自己主动选择的,而是被第一份工作推着走的。记得入职第一天,主管把我叫到会议室:"Vincen…...

3步终极指南:用Docker容器让老旧打印机秒变AirPrint无线打印神器

3步终极指南:用Docker容器让老旧打印机秒变AirPrint无线打印神器 【免费下载链接】cups-avahi-airprint Docker image for CUPS intended as an AirPrint relay 项目地址: https://gitcode.com/gh_mirrors/cu/cups-avahi-airprint 还在为家里或办公室的老旧打…...

基于springboot+vue大学生租房平台hx0096FFZC

文章目录详细视频演示技术介绍功能介绍核心代码系统效果图源码获取详细视频演示 文章底部名片,获取项目的完整演示视频,免费解答技术疑问 技术介绍 开发语言:Java 框架:ssm JDK版本:JDK1.8 服务器:tomca…...

微信聊天记录如何实现本地永久备份?开源工具WeChatMsg守护你的数字资产

微信聊天记录如何实现本地永久备份?开源工具WeChatMsg守护你的数字资产 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_T…...

抖音批量下载怎么做到又快又好?douyin-downloader帮你3步搞定

抖音批量下载怎么做到又快又好?douyin-downloader帮你3步搞定 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallbac…...