pwm_app.lua 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. --[[
  2. @module pwm_app
  3. @summary PWM 输出功能模块
  4. @version 1.0
  5. @date 2025.11.05
  6. @author 马梦阳
  7. @usage
  8. 本功能模块演示的内容为:
  9. 1. 旧风格 PWM 演示:
  10. 使用 pwm.open() 完成 PWM 通道的配置与启动
  11. 使用 pwm.close() 关闭 PWM 通道
  12. 旧风格 PWM 接口不支持单独配置和动态调整占空比和信号频率
  13. 2. 新风格 PWM 演示:
  14. 使用 pwm.setup() 完成 PWM 通道的配置
  15. 使用 pwm.start() 启动 PWM 输出
  16. 使用 pwm.setDuty() 动态调整占空比
  17. 使用 pwm.setFreq() 动态调整信号频率
  18. 使用 pwm.stop() 停止 PWM 输出
  19. 新风格 PWM 接口支持在运行中动态调整占空比和信号频率
  20. 3. 综合任务调度:顺序运行上述两种风格示例,并在关键节点进行日志输出
  21. 注意事项:
  22. 1. 本 demo 演示所使用的是 Air780EHM/EHV/EGH 模组的 PWM4 通道(GPIO27,PIN16);
  23. 2. 该引脚需要通过 LuatIO 工具进行复用配置:
  24. pins_Air780EHM.json 为 Air780EHM 模组的复用配置文件;
  25. pins_Air780EHV.json 为 Air780EHV 模组的复用配置文件;
  26. pins_Air780EGH.json 为 Air780EGH 模组的复用配置文件;
  27. 3. 关于 LuatIO 工具的使用介绍以及如何生成 json 文件,请参考 https://docs.openluat.com/air780epm/common/luatio/;
  28. 3. 将通过 LuatIO 工具配置好复用关系后生成的 json 文件与脚本文件一同烧录到模组中即可实现 PWM 输出功能;
  29. 本文件没有对外接口,直接在 main.lua 中 require "pwm_app" 就可以加载运行;
  30. ]]
  31. --[[
  32. 旧风格 PWM 演示函数
  33. 使用 pwm.open() 一次性完成配置和启动
  34. 适合固定频率/占空比、无需中途调整的场景
  35. ]]
  36. local function task1_old_pwm()
  37. log.info("PWM", "旧风格 PWM 示例开始")
  38. -- 选择 PWM 通道 4
  39. -- 注意:本 demo 演示所使用的是 Air780EHM/EHV/EGH 模组的 PWM4 通道(GPIO27,PIN16);
  40. -- 该引脚需要通过 LuatIO 工具进行复用配置,详细说明看最顶部的注意事项;
  41. local pwm_channel = 4
  42. -- 第一次输出:1 kHz,45% 占空比,分频精度 100
  43. local pwm_success = pwm.open(pwm_channel, 1000, 45, 0, 100)
  44. if pwm_success then
  45. log.info("PWM", "PWM4 通道开启成功: 信号频率 1000 Hz, 分频精度 100, 占空比 45%")
  46. else
  47. log.info("PWM", "PWM4 通道开启失败")
  48. end
  49. -- 持续 1 s 后关闭
  50. sys.wait(1000)
  51. pwm.close(pwm_channel)
  52. log.info("PWM", "PWM4 通道已关闭")
  53. -- 增加 1 秒的间隔时间
  54. sys.wait(1000)
  55. -- 第二次输出:500 Hz,60% 占空比,分频精度 100
  56. local pwm_success = pwm.open(pwm_channel, 500, 60, 0, 100)
  57. if pwm_success then
  58. log.info("PWM", "PWM4 通道开启成功: 信号频率 500 Hz, 分频精度 100, 占空比 60%")
  59. else
  60. log.info("PWM", "PWM4 通道开启失败")
  61. end
  62. -- 持续 2 s 后关闭
  63. sys.wait(2000)
  64. pwm.close(pwm_channel)
  65. log.info("PWM", "PWM4 通道已关闭")
  66. -- 增加 1 秒的间隔时间
  67. sys.wait(1000)
  68. -- 第三次输出:300 Hz,80% 占空比,分频精度 100
  69. local pwm_success = pwm.open(pwm_channel, 300, 80, 0, 100)
  70. if pwm_success then
  71. log.info("PWM", "PWM4 通道开启成功: 信号频率 300 Hz, 分频精度 100, 占空比 80%")
  72. else
  73. log.info("PWM", "PWM4 通道开启失败")
  74. end
  75. -- 持续 3 s 后关闭
  76. sys.wait(3000)
  77. pwm.close(pwm_channel)
  78. log.info("PWM", "PWM4 通道已关闭")
  79. log.info("PWM", "旧风格 PWM 示例结束")
  80. end
  81. --[[
  82. 新风格 PWM 演示函数
  83. 使用 pwm.setup() 分步完成配置与启动,支持运行中动态修改频率和占空比
  84. 适合需要实时调节输出参数的场景
  85. ]]
  86. local function task2_new_pwm()
  87. log.info("PWM", "新风格 PWM 示例开始")
  88. -- 选择 PWM 通道 4
  89. -- 注意:本 demo 演示所使用的是 Air780EHM/EHV/EGH 模组的 PWM4 通道(GPIO27,PIN16);
  90. -- 该引脚需要通过 LuatIO 工具进行复用配置,详细说明看最顶部的注意事项;
  91. local pwm_channel = 4
  92. -- 配置 PWM 参数:频率 1000 Hz、占空比 50%、分频精度 100
  93. local setup_success = pwm.setup(pwm_channel, 1000, 50, 0, 100)
  94. if setup_success then
  95. log.info("PWM", "PWM4 配置成功: 信号频率 1000 Hz, 分频精度 100, 占空比 50%")
  96. else
  97. log.info("PWM", "PWM4 配置失败")
  98. end
  99. -- 启动 PWM 输出
  100. local pwm_success = pwm.start(pwm_channel)
  101. if pwm_success then
  102. log.info("PWM", "PWM4 启动成功")
  103. else
  104. log.info("PWM", "PWM4 启动失败")
  105. end
  106. -- 持续输出 2 秒
  107. sys.wait(2000)
  108. -- 动态调整占空比至 25%
  109. local setduty_success = pwm.setDuty(pwm_channel, 25)
  110. if setduty_success then
  111. log.info("PWM", "PWM4 占空比更新为 25%")
  112. else
  113. log.info("PWM", "PWM4 占空比设置失败")
  114. end
  115. -- 持续输出 2 秒
  116. sys.wait(2000)
  117. -- 动态调整信号频率为 2000 Hz
  118. local setfreq_success = pwm.setFreq(pwm_channel, 2000)
  119. if setfreq_success then
  120. log.info("PWM", "PWM4 频率更新为 2000 Hz")
  121. else
  122. log.error("PWM", "PWM4 频率设置失败")
  123. end
  124. -- 持续输出 2 秒
  125. sys.wait(2000)
  126. -- 停止 PWM 输出
  127. local pwm_success = pwm.stop(pwm_channel)
  128. if pwm_success then
  129. log.info("PWM", "PWM4 停止成功")
  130. else
  131. log.info("PWM", "PWM4 停止失败")
  132. end
  133. log.info("PWM", "新风格 PWM 示例结束")
  134. end
  135. --[[
  136. 主演示任务:
  137. 顺序调用旧风格与新风格 PWM 示例函数
  138. 并在两者之间插入 3 秒间隔方便区分新旧风格示例输出情况
  139. ]]
  140. local function pwm_demo_task()
  141. log.info("PWM", "PWM 综合演示任务开始")
  142. -- 运行旧风格 PWM 示例
  143. task1_old_pwm()
  144. -- 间隔 3 秒
  145. sys.wait(3000)
  146. -- 运行新风格 PWM 示例
  147. task2_new_pwm()
  148. log.info("PWM", "PWM 综合演示任务结束")
  149. end
  150. -- 创建并启动一个 task
  151. -- 用于运行 pwm_demo_task 函数
  152. sys.taskInit(pwm_demo_task)