lt_fdc2214.c 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621
  1. #include "lt_fdc2214_iic.h"
  2. #include "lt_fdc2214.h"
  3. #include "stdlib.h"
  4. #include "math.h"
  5. #include "main.h"
  6. #include "cmsis_os.h"
  7. /**
  8. ******************************************************************************
  9. * @file lt_fdc2214.c
  10. ******************************************************************************
  11. * @attention
  12. * FDC2214的SD引脚,拉高关机,拉低开机。
  13. *
  14. ******************************************************************************
  15. */
  16. uint8_t CHx_FIN_SEL[4];
  17. double fREFx[4];
  18. double FRE[4];
  19. uint32_t ch0,ch1,ch2,ch3;
  20. /*!
  21. * @brief IIC写FDC2214
  22. * @param Slve_Addr 器件地址
  23. * @param reg 寄存器
  24. * @param data 数据
  25. * @since v1.0
  26. * Sample usage: FDC2214_Write16(FDC2214_Addr, FDC2214_CONFIG, 0xFFFF);
  27. */
  28. void FDC2214_Write16(uint8_t Slve_Addr, uint8_t reg, uint16_t data)
  29. {
  30. uint8_t dat;
  31. FDC2214_IIC_Start();
  32. FDC2214_IIC_Send_Byte(Slve_Addr << 1);
  33. FDC2214_IIC_Wait_Ack();
  34. FDC2214_IIC_Send_Byte(reg);
  35. FDC2214_IIC_Wait_Ack();
  36. dat=(data >> 8);
  37. FDC2214_IIC_Send_Byte(dat);
  38. FDC2214_IIC_Wait_Ack();
  39. dat=data & 0xFF;
  40. FDC2214_IIC_Send_Byte(dat);
  41. FDC2214_IIC_Wait_Ack();
  42. FDC2214_IIC_Stop();
  43. }
  44. /*!
  45. * @brief IIC读FDC2214
  46. * @param Slve_Addr 器件地址
  47. * @param reg 寄存器
  48. * @return 寄存器值
  49. * @since v1.0
  50. * Sample usage: FDC2214_Read16(FDC2214_Addr, FDC2214_CONFIG);
  51. */
  52. uint16_t FDC2214_Read16(uint8_t Slve_Addr, uint8_t reg)
  53. {
  54. uint16_t temp;
  55. FDC2214_IIC_Start();
  56. FDC2214_IIC_Send_Byte(Slve_Addr << 1);
  57. FDC2214_IIC_Wait_Ack();
  58. FDC2214_IIC_Send_Byte(reg);
  59. FDC2214_IIC_Wait_Ack();
  60. FDC2214_IIC_Start();
  61. FDC2214_IIC_Send_Byte((Slve_Addr << 1) | 0x01);
  62. FDC2214_IIC_Wait_Ack();
  63. temp = (uint16_t)(FDC2214_IIC_Read_Byte(1) << 8);
  64. temp |= FDC2214_IIC_Read_Byte(0);
  65. FDC2214_IIC_Stop();
  66. return temp;
  67. }
  68. /*!
  69. * @brief 读取FDC2214一个通道的转换值
  70. * @param channel 通道
  71. * @param *data 读取的数据
  72. * @return 0:失败;1:成功
  73. * @since v1.0
  74. * Sample usage: FDC2214_GetChannelData(FDC2214_Channel_0, &CH0_DATA);
  75. */
  76. uint8_t FDC2214_GetChannelData(FDC2214_channel_t channel, uint32_t *data)
  77. {
  78. int16_t timeout = 100;
  79. uint8_t dateReg_H;
  80. uint8_t dateReg_L;
  81. uint8_t bitUnreadConv;
  82. uint16_t status;
  83. uint32_t dataRead;
  84. switch(channel)
  85. {
  86. case FDC2214_Channel_0:
  87. dateReg_H = FDC2214_DATA_CH0;
  88. dateReg_L = FDC2214_DATA_LSB_CH0;
  89. bitUnreadConv = 0x0008;
  90. break;
  91. case FDC2214_Channel_1:
  92. dateReg_H = FDC2214_DATA_CH1;
  93. dateReg_L = FDC2214_DATA_LSB_CH1;
  94. bitUnreadConv = 0x0004;
  95. break;
  96. case FDC2214_Channel_2:
  97. dateReg_H = FDC2214_DATA_CH2;
  98. dateReg_L = FDC2214_DATA_LSB_CH2;
  99. bitUnreadConv = 0x0002;
  100. break;
  101. case FDC2214_Channel_3:
  102. dateReg_H = FDC2214_DATA_CH3;
  103. dateReg_L = FDC2214_DATA_LSB_CH3;
  104. bitUnreadConv = 0x0001;
  105. break;
  106. }
  107. status = FDC2214_Read16(FDC2214_Addr, FDC2214_STATUS);//读取状态寄存器的值
  108. while(timeout && !(status & bitUnreadConv))//检查是否有未读数据
  109. {
  110. status = FDC2214_Read16(FDC2214_Addr, FDC2214_STATUS);
  111. timeout--;
  112. }
  113. if(timeout)
  114. {
  115. dataRead = (uint32_t)(FDC2214_Read16(FDC2214_Addr, dateReg_H) << 16);
  116. dataRead |= FDC2214_Read16(FDC2214_Addr, dateReg_L);
  117. *data = dataRead;
  118. return 1;
  119. }
  120. else
  121. {
  122. //超时
  123. return 0;
  124. }
  125. }
  126. /*!
  127. * @brief 设置FDC2214一个通道的转换时间,转换时间(tCx)=(CHx_RCOUNT?16) / fREFx。
  128. * @param channel 通道
  129. * @param rcount CHx_RCOUNT
  130. * @since v1.0
  131. * Sample usage: FDC2214_SetRcount(FDC2214_Channel_0, 0x0FFF);
  132. */
  133. void FDC2214_SetRcount(FDC2214_channel_t channel, uint16_t rcount)
  134. {
  135. if(rcount <= 0x00FF) return;
  136. switch(channel)
  137. {
  138. case FDC2214_Channel_0:
  139. FDC2214_Write16(FDC2214_Addr, FDC2214_RCOUNT_CH0, rcount);
  140. break;
  141. case FDC2214_Channel_1:
  142. FDC2214_Write16(FDC2214_Addr, FDC2214_RCOUNT_CH1, rcount);
  143. break;
  144. case FDC2214_Channel_2:
  145. FDC2214_Write16(FDC2214_Addr, FDC2214_RCOUNT_CH2, rcount);
  146. break;
  147. case FDC2214_Channel_3:
  148. FDC2214_Write16(FDC2214_Addr, FDC2214_RCOUNT_CH3, rcount);
  149. break;
  150. }
  151. }
  152. /*!
  153. * @brief 设置FDC2214一个通道的建立时间,使LC传感器可以在通道x开始转换之前稳定下来,建立时间(tSx) = (CHx_SETTLECOUNT?16) ÷ fREFx。
  154. CHx_SETTLECOUNT = 0x00, 0x01时(tSx) = 32 ÷ fREFx。
  155. * @param channel 通道
  156. * @param count CHx_SETTLECOUNT
  157. * @since v1.0
  158. * @note CHx_SETTLECOUNT > Vpk × fREFx × C × π^2 / (32 × IDRIVEX)
  159. * Sample usage: FDC2214_SetSettleCount(FDC2214_Channel_0, 0x00FF);
  160. */
  161. void FDC2214_SetSettleCount(FDC2214_channel_t channel, uint16_t count)
  162. {
  163. switch(channel)
  164. {
  165. case FDC2214_Channel_0:
  166. FDC2214_Write16(FDC2214_Addr, FDC2214_SETTLECOUNT_CH0, count);
  167. break;
  168. case FDC2214_Channel_1:
  169. FDC2214_Write16(FDC2214_Addr, FDC2214_SETTLECOUNT_CH1, count);
  170. break;
  171. case FDC2214_Channel_2:
  172. FDC2214_Write16(FDC2214_Addr, FDC2214_SETTLECOUNT_CH2, count);
  173. break;
  174. case FDC2214_Channel_3:
  175. FDC2214_Write16(FDC2214_Addr, FDC2214_SETTLECOUNT_CH3, count);
  176. break;
  177. }
  178. }
  179. /*!
  180. * @brief 设置FDC2214一个通道的的时钟频率,
  181. 差分传感器配置:
  182. 0x01 -- 传感器频率0.01MHz和8.75MHz
  183. 0x02 -- 传感器频率5MHz和10MHz
  184. 单端传感器配置:
  185. 0x01 -- 传感器频率0.01MHz和10MHz
  186. * @param channel 通道
  187. * @param frequency_select 时钟选择
  188. * @param divider 分频器,fREFx = fCLK / CHx_FREF_DIVIDER,
  189. * @note fREFx is > 4 × fSENSOR(外部LC振荡器频率)
  190. * @since v1.0
  191. * Sample usage: FDC2214_SetChannelClock(FDC2214_Channel_0, 0x01, 0xFF);
  192. */
  193. void FDC2214_SetChannelClock(FDC2214_channel_t channel, uint8_t frequency_select, uint16_t divider)
  194. {
  195. uint16_t temp = 0;
  196. temp = (uint16_t)(frequency_select << 12) | (divider & 0x03FF);
  197. CHx_FIN_SEL[channel] = frequency_select;//记录时钟选择
  198. FDC_PRINTF("Frequency_select : %d \r\n",frequency_select);
  199. fREFx[channel] = (double)ClockFrequency / divider;//记录时钟频率
  200. switch(channel)
  201. {
  202. case FDC2214_Channel_0:
  203. // printf("CHx_FIN_SEL[0] %d \r\n",CHx_FIN_SEL[0]);
  204. // printf("FREFx[0] : [%f] \r\n",fREFx[0]);
  205. FDC2214_Write16(FDC2214_Addr, FDC2214_CLOCK_DIVIDERS_CH0, temp);
  206. break;
  207. case FDC2214_Channel_1:
  208. FDC2214_Write16(FDC2214_Addr, FDC2214_CLOCK_DIVIDERS_CH1, temp);
  209. break;
  210. case FDC2214_Channel_2:
  211. FDC2214_Write16(FDC2214_Addr, FDC2214_CLOCK_DIVIDERS_CH2, temp);
  212. break;
  213. case FDC2214_Channel_3:
  214. FDC2214_Write16(FDC2214_Addr, FDC2214_CLOCK_DIVIDERS_CH3, temp);
  215. break;
  216. }
  217. }
  218. /*!
  219. * @brief 配置INTB引脚中断功能
  220. * @param mode 1:开中断;0:关中断
  221. * @since v1.0
  222. * Sample usage: FDC2214_SetDriveCurrent(FDC2214_Channel_0, FDC2214_Drive_Current_0_025);
  223. */
  224. void FDC2214_SetINTB(uint8_t mode)
  225. {
  226. uint16_t temp = 0;
  227. temp = FDC2214_Read16(FDC2214_Addr, FDC2214_CONFIG);
  228. temp &= 0xFF7F;
  229. if(mode)
  230. temp |= 0x0080;
  231. FDC2214_Write16(FDC2214_Addr, FDC2214_CONFIG, temp);
  232. temp = FDC2214_Read16(FDC2214_Addr, FDC2214_ERROR_CONFIG);
  233. temp &= 0xFFFE;
  234. if(mode)
  235. temp |= 0x0001;
  236. FDC2214_Write16(FDC2214_Addr, FDC2214_ERROR_CONFIG, temp);
  237. }
  238. /*!
  239. * @brief 激活FDC2214的一个通道,单通道模式
  240. * @param channel 通道
  241. * @since v1.0
  242. * Sample usage: FDC2214_SetActiveChannel(FDC2214_Channel_0);
  243. */
  244. void FDC2214_SetActiveChannel(FDC2214_channel_t channel)
  245. {
  246. uint16_t temp = 0;
  247. temp = FDC2214_Read16(FDC2214_Addr, FDC2214_CONFIG);
  248. temp &= 0x3FFF;
  249. temp |= (uint16_t)(channel << 14);
  250. FDC2214_Write16(FDC2214_Addr, FDC2214_CONFIG, temp);
  251. }
  252. /*!
  253. * @brief 设置FDC2214的工作模式:正常、睡眠。
  254. * @param mode 0:正常工作;1:睡激活模式选择。眠
  255. * @since v1.0
  256. * Sample usage: FDC2214_SetSleepMode(0);
  257. */
  258. void FDC2214_SetSleepMode(uint8_t mode)
  259. {
  260. uint16_t temp = 0;
  261. temp = FDC2214_Read16(FDC2214_Addr, FDC2214_CONFIG);
  262. temp &= 0xDFFF;
  263. if(mode)temp |= 0x2000;
  264. FDC2214_Write16(FDC2214_Addr, FDC2214_CONFIG, temp);
  265. }
  266. /*!
  267. * @brief FDC2214激活模式选择。
  268. * @param mode 0:全电流激活模式;1:低功率激活模式
  269. * @since v1.0
  270. * Sample usage: FDC2214_SetCurrentMode(1);
  271. */
  272. void FDC2214_SetCurrentMode(uint8_t mode)
  273. {
  274. uint16_t temp = 0;
  275. temp = FDC2214_Read16(FDC2214_Addr, FDC2214_CONFIG);
  276. temp &= 0xF7FF;
  277. if(mode)
  278. temp |= 0x800;
  279. FDC2214_Write16(FDC2214_Addr, FDC2214_CONFIG, temp);
  280. }
  281. /*!
  282. * @brief 设置FDC2214时钟源
  283. * @param src 0:内部时钟源;1:外部时钟源
  284. * @since v1.0
  285. * Sample usage: FDC2214_SetClockSource(1);
  286. */
  287. void FDC2214_SetClockSource(uint8_t src)
  288. {
  289. uint16_t temp = 0;
  290. temp = FDC2214_Read16(FDC2214_Addr, FDC2214_CONFIG);
  291. temp &= 0xFDFF;
  292. if(src)
  293. temp |= 0x200;
  294. FDC2214_Write16(FDC2214_Addr, FDC2214_CONFIG, temp);
  295. }
  296. /*!
  297. * @brief 高电流传感器驱动,只适用于单通道模式。
  298. * @param mode 0:正常(最大1.5mA);1:高电流传感器驱动(>1.5mA)
  299. * @since v1.0
  300. * Sample usage: FDC2214_SetHighCurrentMode(0);
  301. */
  302. void FDC2214_SetHighCurrentMode(uint8_t mode)
  303. {
  304. uint16_t temp = 0;
  305. temp = FDC2214_Read16(FDC2214_Addr, FDC2214_CONFIG);
  306. temp &= 0xFFBF;
  307. if(mode)
  308. temp |= 0x40;
  309. FDC2214_Write16(FDC2214_Addr, FDC2214_CONFIG, temp);
  310. }
  311. /*!
  312. * @brief 设置FDC2214的MUX CONFIG寄存器
  313. * @param autoscan 自动扫描模式 0:关闭,1:打开
  314. * @param channels 自动扫描通道
  315. * @param bandwidth 数字滤波器带宽,大于外部LC振荡器频率
  316. * @since v1.0
  317. * Sample usage: FDC2214_SetMUX_CONFIG(1, FDC2214_Channel_Sequence_0_1_2, FDC2214_Bandwidth_10M);
  318. */
  319. void FDC2214_SetMUX_CONFIG(uint8_t autoscan, FDC2214_channel_sequence_t channels, FDC2214_filter_bandwidth_t bandwidth)
  320. {
  321. uint16_t temp = 0;
  322. if(autoscan)
  323. {
  324. temp = (uint16_t)(autoscan << 15) | (channels << 13) | 0x0208 | bandwidth;
  325. }
  326. else
  327. {
  328. temp = 0x0208 | bandwidth;
  329. }
  330. FDC2214_Write16(FDC2214_Addr, FDC2214_MUX_CONFIG, temp);
  331. }
  332. /*!
  333. * @brief 传感器复位
  334. * @since v1.0
  335. * Sample usage: FDC2214_Reset();
  336. */
  337. void FDC2214_Reset(void)
  338. {
  339. FDC2214_Write16(FDC2214_Addr, FDC2214_RESET_DEV, 0x8000);
  340. }
  341. /*!
  342. * @brief 设置FDC2214的一个通道传感器驱动电流,确保振荡幅度在1.2V和1.8V之间。
  343. * @param channel 通道
  344. * @param current 电流大小
  345. * @since v1.0
  346. * Sample usage: FDC2214_SetDriveCurrent(FDC2214_Channel_0, FDC2214_Drive_Current_0_025);
  347. */
  348. void FDC2214_SetDriveCurrent(FDC2214_channel_t channel, FDC2214_drive_current_t current)
  349. {
  350. uint16_t temp = 0;
  351. temp = (uint16_t)(current << 11);
  352. switch(channel)
  353. {
  354. case FDC2214_Channel_0:
  355. FDC2214_Write16(FDC2214_Addr, FDC2214_DRIVE_CURRENT_CH0, temp);
  356. break;
  357. case FDC2214_Channel_1:
  358. FDC2214_Write16(FDC2214_Addr, FDC2214_DRIVE_CURRENT_CH1, temp);
  359. break;
  360. case FDC2214_Channel_2:
  361. FDC2214_Write16(FDC2214_Addr, FDC2214_DRIVE_CURRENT_CH2, temp);
  362. break;
  363. case FDC2214_Channel_3:
  364. FDC2214_Write16(FDC2214_Addr, FDC2214_DRIVE_CURRENT_CH3, temp);
  365. break;
  366. }
  367. }
  368. /*!
  369. * @brief 计算传感器频率
  370. * @param channel 通道
  371. * @param datax 读取的转换值
  372. * @return 频率,单位Hz
  373. * @since v1.0
  374. * Sample usage: FDC2214_CalculateFrequency(FDC2214_Channel_0, 0xFF);
  375. */
  376. double FDC2214_CalculateFrequency(FDC2214_channel_t channel, uint32_t datax)
  377. {
  378. double frequency = 0.0;
  379. frequency = (double)(CHx_FIN_SEL[channel] * fREFx[channel] * datax) / 268435456.0;//2^28 0.298*data
  380. // printf("CHx_FIN_SEL[0] %d \r\n",CHx_FIN_SEL[0]);
  381. return frequency;
  382. }
  383. /*!
  384. * @brief 计算外部电容大小
  385. * @param frequency 频率大小,单位Hz
  386. * @param inductance 板载电感大小,单位uH
  387. * @param capacitance 板载电容大小,单位pF
  388. * @return 外部电容大小,单位pF
  389. * @since v1.0
  390. * Sample usage: FDC2214_CalculateCapacitance(FDC2214_Channel_0, 6000000, 18, 33);
  391. */
  392. double FDC2214_CalculateCapacitance(double frequency, float inductance, float capacitance)
  393. {
  394. double cap = 0.0;
  395. cap = (double)(1000000000000000000/ (inductance * (2 * PI * frequency) * (2 * PI * frequency)))-capacitance; //
  396. return cap;
  397. }
  398. /*!
  399. * @brief FDC2214初始化函数
  400. * @return 1:成功;0:失败
  401. * @since v1.0
  402. * Sample usage: FDC2214_Init();
  403. * RCOUNT:值越大,分辨率越高,但速度越慢。5000 合理,建议范围 2000 ~ 10000
  404. * SETTLECOUNT:不能太小。建议 settleCount = fSensor / fRef * 10,可先设为 500 或 1000 测试。实际电路中电容越大、阻抗越高需要越大的 settleCount。
  405. * FDC2214_Drive_Current_0_081:电容值小/感应距离短时,低电流更稳定。电容大或探测距离远时,可尝试 0.146mA、0.206mA 等更大电流
  406. */
  407. uint8_t FDC2214_Init(void)
  408. {
  409. FDC_PRINTF("\r\n=== FDC2214_deviceID ===\r\n");
  410. uint16_t deviceID = 0;
  411. deviceID = FDC2214_Read16(FDC2214_Addr, FDC2214_DEVICE_ID);//读器件ID
  412. FDC_PRINTF("FDC2214_deviceID : 0x%02x \r\n" ,deviceID );
  413. uint16_t RCOUNT = 20000; // 5000对应2000us 转换周期
  414. uint16_t SETTLECOUNT = 4000; // 200对应200 cycles 等待时间
  415. if(deviceID == FDC2214_ID)
  416. {
  417. FDC2214_Reset();
  418. // 通道0
  419. FDC2214_SetRcount(FDC2214_Channel_0, RCOUNT);// 转换周期
  420. FDC2214_SetSettleCount(FDC2214_Channel_0, SETTLECOUNT);// cycles 等待时间
  421. FDC2214_SetChannelClock(FDC2214_Channel_0, 0x02, 1);//设置时钟分频,1分频,40MHz
  422. // // 通道1
  423. // FDC2214_SetRcount(FDC2214_Channel_1, RCOUNT);//2000us 转换周期
  424. // FDC2214_SetSettleCount(FDC2214_Channel_1, SETTLECOUNT);//200 cycles 等待时间
  425. // FDC2214_SetChannelClock(FDC2214_Channel_1, 1, 1);//设置时钟分频,1分频,40MHz
  426. // // 通道2
  427. // FDC2214_SetRcount(FDC2214_Channel_2, RCOUNT);//2000us 转换周期
  428. // FDC2214_SetSettleCount(FDC2214_Channel_2, SETTLECOUNT);//200 cycles 等待时间
  429. // FDC2214_SetChannelClock(FDC2214_Channel_2, 1, 1);//设置时钟分频,1分频,40MHz
  430. // // 通道3
  431. // FDC2214_SetRcount(FDC2214_Channel_3, RCOUNT);//2000us 转换周期
  432. // FDC2214_SetSettleCount(FDC2214_Channel_3, SETTLECOUNT);//200 cycles 等待时间
  433. // FDC2214_SetChannelClock(FDC2214_Channel_3, 1, 1);//设置时钟分频,1分频,40MHz
  434. FDC2214_SetINTB(0);//关闭INTB中断
  435. FDC2214_SetCurrentMode(1);//全电流激活模式
  436. FDC2214_SetClockSource(1);//1外部时钟源 0内部晶振
  437. FDC2214_SetHighCurrentMode(0);//0:正常(最大1.5mA);1:高电流传感器驱动(>1.5mA)
  438. FDC2214_SetMUX_CONFIG(1, FDC2214_Channel_Sequence_0_1, FDC2214_Bandwidth_3_3M); // 0关闭自动扫描,设置带宽, 带宽调小,抗干扰性更强
  439. FDC2214_SetActiveChannel(FDC2214_Channel_0);//激活通道0
  440. // FDC2214_SetMUX_CONFIG(1, FDC2214_Channel_Sequence_0_1, FDC2214_Bandwidth_10M);//开启01通道采集,打开自动扫描,10MHz带宽
  441. // FDC2214_SetMUX_CONFIG(1, FDC2214_Channel_Sequence_0_1_2_3, FDC2214_Bandwidth_3_3M);//开启0123通道采集,打开自动扫描,10MHz带宽
  442. FDC2214_SetDriveCurrent(FDC2214_Channel_0, FDC2214_Drive_Current_0_356);//通道0驱动电流
  443. // FDC2214_SetDriveCurrent(FDC2214_Channel_1, FDC2214_Drive_Current_1_006);//通道1驱动电流
  444. // FDC2214_SetDriveCurrent(FDC2214_Channel_2, FDC2214_Drive_Current_1_006);//通道2驱动电流
  445. // FDC2214_SetDriveCurrent(FDC2214_Channel_3, FDC2214_Drive_Current_1_006);//通道3驱动电流
  446. FDC2214_SetSleepMode(0);//退出睡眠状态,开始工作
  447. FDC_PRINTF("FDC2214 Init OK!\r\n");
  448. FDC_PRINTF("============================\r\n");
  449. osDelay(100);
  450. return 0;
  451. }
  452. else
  453. {
  454. FDC_PRINTF("FDC2214 Init Failed!! \r\n");
  455. FDC_PRINTF("============================\r\n");
  456. return 1;
  457. }
  458. }
  459. /*
  460. long filterread(FDC2214_channel_t channel, uint32_t *data)
  461. {
  462. uint16_t i=0;
  463. long result=0;
  464. long Data[20],Sum=0,max=0,min=0;
  465. for(i=0; i<=19; i++)
  466. {
  467. if(FDC2214_GetChannelData(channel,data)==1)
  468. {
  469. Data[i]=*data;
  470. }
  471. else
  472. {
  473. i--;
  474. }
  475. delay_us(100);
  476. }
  477. Sum=Data[0];
  478. max=Data[0];
  479. min=Data[0];
  480. for(i=1; i<=19; i++)
  481. {
  482. if(max<Data[i])max=Data[i];
  483. if(min>Data[i])min=Data[i];
  484. Sum=Data[i]+Sum;//累加
  485. }
  486. result=(Sum-max-min)/18;
  487. return result;
  488. }
  489. */
  490. long filterread(FDC2214_channel_t channel, uint32_t *data)
  491. {
  492. uint16_t i = 0, try_count = 0;
  493. long result = 0;
  494. long Data[20], Sum = 0, max = 0, min = 0;
  495. while (i < 20 && try_count < 100)
  496. {
  497. try_count++;
  498. if (FDC2214_GetChannelData(channel, data) == 1)
  499. {
  500. Data[i++] = *data;
  501. }
  502. delay_us(100);
  503. }
  504. if (i < 20) {
  505. DEBUG_PRINTF("FDC2214 data read timeout! Only %d samples.\r\n", i);
  506. return -1; // 读取失败
  507. }
  508. Sum = Data[0];
  509. max = Data[0];
  510. min = Data[0];
  511. for (i = 1; i < 20; i++)
  512. {
  513. if (max < Data[i]) max = Data[i];
  514. if (min > Data[i]) min = Data[i];
  515. Sum += Data[i];
  516. }
  517. result = (Sum - max - min) / 18;
  518. return result;
  519. }
  520. double getcap(uint8_t channel,double dg,double dr)
  521. {
  522. double Cap=0.0;
  523. switch(channel)
  524. {
  525. case 0:
  526. ch0=filterread(FDC2214_Channel_0,&ch0);
  527. FRE[0]=FDC2214_CalculateFrequency(FDC2214_Channel_0,ch0);
  528. DEBUG_PRINTF("\r\nCH0 RAW: [%u], Frequency: [%lf] MHz", ch0, FRE[0]/1000000);
  529. Cap=FDC2214_CalculateCapacitance(FRE[0], dg, dr);
  530. break;
  531. case 1:
  532. ch1=filterread(FDC2214_Channel_1,&ch1);
  533. FRE[1]=FDC2214_CalculateFrequency(FDC2214_Channel_1,ch1);
  534. DEBUG_PRINTF("CH1 RAW = %u, Frequency = %lf KHz\r\n", ch1, FRE[1]/1000);
  535. Cap=FDC2214_CalculateCapacitance(FRE[1], dg, dr);
  536. break;
  537. case 2:
  538. ch2=filterread(FDC2214_Channel_2,&ch2);
  539. FRE[2]=FDC2214_CalculateFrequency(FDC2214_Channel_2,ch2);
  540. DEBUG_PRINTF("CH2 RAW = %u, Frequency = %lf KHz\r\n", ch2, FRE[2]/1000);
  541. Cap=FDC2214_CalculateCapacitance(FRE[2], dg, dr);
  542. break;
  543. case 3:
  544. ch3=filterread(FDC2214_Channel_3,&ch3);
  545. FRE[3]=FDC2214_CalculateFrequency(FDC2214_Channel_3,ch3);
  546. DEBUG_PRINTF("CH3 RAW = %u, Frequency = %lf KHz\r\n", ch3, FRE[3]/1000);
  547. Cap=FDC2214_CalculateCapacitance(FRE[3], dg, dr);
  548. break;
  549. }
  550. return Cap;
  551. }