generation.c 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261
  1. #include "generation.h"
  2. /* Default values of client's registers
  3. * f1: 16kHz
  4. * D1: 49.2%
  5. * Ph2: 0.0
  6. * D2: 49.2%
  7. * Ph3: 0.0
  8. * f3: 1.15MHz
  9. * N3: 10 impules
  10. * D3: 4%
  11. */
  12. void init_params(tweaked_params_s * pParams) {
  13. pParams->f1 = 16000;
  14. pParams->D1 = 0.492 * FXP_SCALING;//49.2 %
  15. pParams->D2 = 0.492 * FXP_SCALING;//49.2 %
  16. pParams->Ph2 = 0.00 * FXP_SCALING;
  17. pParams->Ph3 = 0.00 * FXP_SCALING;
  18. pParams->f3 = 1150000;
  19. pParams->D3 = 40;//4%
  20. pParams->N3 = 10;
  21. pParams->ena = ENABLE_FORCE_NONE;
  22. pParams->_period1 = DIV_ROUND(BASE_FREQ, pParams->f1);
  23. pParams->_duty1 = pParams->_period1 * pParams->D1 / FXP_SCALING;
  24. pParams->_duty2 = pParams->_period1 * pParams->D2 / FXP_SCALING;
  25. pParams->_phase2 = pParams->Ph2 * pParams->_period1 / FXP_SCALING;
  26. pParams->_period3 = DIV_ROUND(BASE_FREQ, pParams->f3);
  27. }
  28. void validate_generation_values(tweaked_params_s * pParams)
  29. {
  30. init_params(pParams);
  31. }
  32. void update_three_signal_values()
  33. {
  34. //printf("Updating 3signal values\n");
  35. // read values of updated registers
  36. }
  37. void inc_f1(tweaked_params_s * pParams){
  38. int32_t f1 = pParams->f1;
  39. f1 += 5;
  40. if(f1>MAX_FREQ1)
  41. return;
  42. int32_t _period1 = DIV_ROUND(BASE_FREQ, f1);
  43. uint32_t pulses_time = pParams->_period3*(pParams->N3+2)*N_PULSE_TRAINS;
  44. if(pulses_time>_period1)
  45. return;
  46. int32_t _duty1 = _period1*pParams->D1/4000;
  47. int32_t _duty2 = _period1*pParams->D2/4000;
  48. int32_t _phase2 = _period1*pParams->Ph2/4000;
  49. pParams->_duty1 = _duty1;
  50. pParams->_duty2 = _duty2;
  51. pParams->_phase2 = _phase2;
  52. pParams->_period1 = _period1;
  53. pParams->f1 = f1;
  54. }
  55. void dec_f1(tweaked_params_s * pParams) {
  56. int32_t f1 = pParams->f1;
  57. f1 -= 5;
  58. if(f1<MIN_FREQ1)
  59. return;
  60. int32_t _period1 = DIV_ROUND(BASE_FREQ, f1);
  61. int32_t _duty1 = _period1*pParams->D1/4000;
  62. int32_t _duty2 = _period1*pParams->D2/4000;
  63. int32_t _phase2 = _period1*pParams->Ph2/4000;
  64. pParams->_duty1 = _duty1;
  65. pParams->_duty2 = _duty2;
  66. pParams->_phase2 = _phase2;
  67. pParams->_period1 = _period1;
  68. pParams->f1 = f1;
  69. }
  70. void inc_D1(tweaked_params_s * pParams) {
  71. int32_t D1 = pParams->D1;
  72. D1++;
  73. if(D1>MAX_D1D2)
  74. return;
  75. int32_t _duty1 = pParams->_period1*D1/4000;
  76. if(_duty1+pParams->_phase2 >= pParams->_period1/2)
  77. return;
  78. pParams->D1 = D1;
  79. pParams->_duty1 = _duty1;
  80. }
  81. void dec_D1(tweaked_params_s * pParams) {
  82. int32_t D1 = pParams->D1;
  83. D1--;
  84. if(D1<MIN_D1D2)
  85. return;
  86. int32_t _duty1 = pParams->_period1*D1/4000;
  87. pParams->D1 = D1;
  88. pParams->_duty1 = _duty1;
  89. }
  90. void inc_D2(tweaked_params_s * pParams) {
  91. int32_t D2 = pParams->D2;
  92. D2++;
  93. if(D2>MAX_D1D2)
  94. return;
  95. int32_t _duty2 = pParams->_period1*D2/4000;
  96. pParams->D2 = D2;
  97. pParams->_duty2 = _duty2;
  98. }
  99. void dec_D2(tweaked_params_s * pParams) {
  100. int32_t D2 = pParams->D2;
  101. D2--;
  102. if(D2<MIN_D1D2)
  103. return;
  104. int32_t _duty2 = pParams->_period1*D2/4000;
  105. pParams->D2 = D2;
  106. pParams->_duty2 = _duty2;
  107. }
  108. void inc_Ph2(tweaked_params_s * pParams) {
  109. int32_t Ph2 = pParams->Ph2;
  110. Ph2++;
  111. int32_t _phase2 = Ph2*pParams->_period1/4000;
  112. if(pParams->_duty1+_phase2 >= pParams->_period1/2)
  113. return;
  114. pParams->Ph2 = Ph2;
  115. pParams->_phase2 = _phase2;
  116. }
  117. void dec_Ph2(tweaked_params_s * pParams) {
  118. int32_t Ph2 = pParams->Ph2;
  119. Ph2--;
  120. if(Ph2<0)
  121. return;//limit value
  122. int32_t _phase2 = Ph2*pParams->_period1/4000;
  123. pParams->Ph2 = Ph2;
  124. pParams->_phase2 = _phase2;
  125. }
  126. void inc_Ph3(tweaked_params_s * pParams) {
  127. int32_t Ph3 = pParams->Ph3;
  128. Ph3++;
  129. if(Ph3>MAX_PH3)
  130. return;//limit value
  131. pParams->Ph3 = Ph3;
  132. }
  133. void dec_Ph3(tweaked_params_s * pParams) {
  134. int32_t Ph3 = pParams->Ph3;
  135. Ph3--;
  136. if(Ph3<0)
  137. return;//limit value
  138. pParams->Ph3 = Ph3;
  139. }
  140. void inc_f3(tweaked_params_s * pParams) {
  141. int32_t f3 = pParams->f3;
  142. f3 += 10000;
  143. if(f3>MAX_FREQ3)
  144. return;
  145. int32_t _period3 = DIV_ROUND(BASE_FREQ, f3);
  146. pParams->f3 = f3;
  147. pParams->_period3 = _period3;
  148. }
  149. void dec_f3(tweaked_params_s * pParams) {
  150. int32_t f3 = pParams->f3;
  151. f3 -= 10000;
  152. if(f3<MIN_FREQ3)
  153. return;
  154. int32_t _period3 = DIV_ROUND(BASE_FREQ, f3);
  155. uint32_t pulses_time = _period3*(pParams->N3+2)*N_PULSE_TRAINS;
  156. if(pulses_time>pParams->_period1)
  157. return;
  158. pParams->f3 = f3;
  159. pParams->_period3 = _period3;
  160. }
  161. void inc_D3(tweaked_params_s * pParams) {
  162. int32_t D3 = pParams->D3;
  163. D3 += 5;
  164. if(D3>1000)
  165. return;
  166. pParams->D3 = D3;
  167. }
  168. void dec_D3(tweaked_params_s * pParams) {
  169. int32_t D3 = pParams->D3;
  170. D3 -= 5;
  171. if(D3<0)
  172. return;
  173. pParams->D3 = D3;
  174. }
  175. void inc_N3(tweaked_params_s * pParams) {
  176. int32_t N3 = pParams->N3;
  177. N3++;
  178. if(N3>254)
  179. return;
  180. uint32_t pulses_time = pParams->_period3*(N3+2)*N_PULSE_TRAINS;
  181. if(pulses_time>pParams->_period1)
  182. return;
  183. pParams->N3 = N3;
  184. }
  185. void dec_N3(tweaked_params_s * pParams) {
  186. int32_t N3 = pParams->N3;
  187. N3--;
  188. if(N3<1)
  189. return;
  190. pParams->N3 = N3;
  191. }
  192. void ena_force_toggle(tweaked_params_s * pParams) {
  193. enable_force_t ena = pParams->ena;
  194. ena = ena==ENABLE_FORCE_DISABLE?ENABLE_FORCE_ENABLE:ENABLE_FORCE_DISABLE;
  195. pParams->ena = ena;
  196. }