main.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. #define _GNU_SOURCE // 用于启用一些非标准的、GNU C 库扩展的特性,例如:<sched.h> 中的 CPU_ZERO 和 CPU_SET 函数。
  2. #include <stdint.h>
  3. #include <stdio.h>
  4. #include <string.h>
  5. #include <stdlib.h>
  6. #include <sys/types.h>
  7. #include <sys/stat.h>
  8. #include <errno.h>
  9. #include <sys/stat.h>
  10. #include <fcntl.h>
  11. #include <unistd.h>
  12. //#include <termios.h>
  13. //#include <poll.h>
  14. //#include <tq_uart.h>
  15. //#include <pthread.h>
  16. //#include <sched.h>
  17. //#include <time.h>
  18. #include "predict.h"
  19. #include <stdbool.h>
  20. #include <math.h>
  21. #include "main.h"
  22. #include <pthread.h>
  23. #include <stdio.h>
  24. #define CURENT_LENGTH 131 //
  25. #define AppLog(msg...) if(LogOn){printf("Log At Line[%d] >> ",__LINE__),printf(msg),printf("\n");}
  26. #define AppErr(msg...) printf("Error At Line[%d] >> ",__LINE__),printf(msg),printf("\n");
  27. unsigned char LogOn = 1;
  28. pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
  29. bool Is_opposite_signs(int *x,int *y);
  30. int min_count_abs(int x,int *arr);
  31. void array_subtraction(int *power,int *last_arr,int *current_arr,int *subtraction_arr);
  32. int current_detection(int *last,int *current,int *subtraction);
  33. int main() {
  34. //int last_arr [131] = {3,0,8,-4,-5,-5,-2,-7,-6,-4,-6,-1,-6,-3,-5,-9,-7,-9,-5,-8,-7,-7,-3,-6,0,-2,-6,-4,-3,-7,-22,-32,-11,-5,-3,-3,-3,-5,-4,-7,-6,-4,-4,-5,-5,-2,-4,-6,-4,-4,-8,-4,-4,-7,-6,0,-5,-7,-6,-2,-5,-6,-4,-7,-3,-4,-3,-3,-2,2,13,1,-3,-3,-6,-4,-3,-6,-5,-5,-1,-7,-6,-4,-5,-7,-2,-4,-4,-7,-4,-6,-5,-7,-4,-4,-6,-6,-6,-8,-5,-6,-6,-3,-3,-4,-6,-5,-13,-27,-14,-12,-5,-5,-4,-5,-3,-6,-5,-7,-4,-6,-6,-6,-15,-5,-5,-4,-6,-5,-4};
  35. //int current_arr [131] = {165,22,243,161,58,253,-546,-612,-508,-377,-369,-333,-275,-228,-189,-171,-128,-65,3,7,4,9,7,4,3,3,3,0,2,0,-4,0,2,8,8,9,10,9,1,-1,5,8,7,7,106,541,613,513,374,369,343,276,224,182,167,117,62,-9,-5,-8,-8,-6,-8,-7,-13,-9,-12,-8,-8,-6,-3,-4,1,-2,-5,-2,-6,0,0,2,3,3,1,-66,-521,-608,-517,-369,-364,-343,-273,-226,-193,-171,-124,-77,-5,-6,-6,-2,-8,-9,-9,-10,-17,-12,-14,-19,-13,-8,-8,-8,-4,-3,-1,-2,-3,1,4,7,9,9,68,530,621,540,389,384,360,291,239,198,181,132};
  36. //for(int n = 0;n<10000;n++){
  37. //int last_arr [131] = {2,0,222,-5,-6,-8,-4,-2,-7,-2,-4,-5,-5,-7,-6,-2,-4,-7,0,-5,-5,-1,0,-2,-4,-6,-4,-2,-6,-5,-6,-3,-4,-6,-7,-6,1,-5,-7,-4,-5,-7,-4,-3,-3,-6,-5,-6,-7,-1,0,-5,-6,-4,-8,-7,-6,-5,-7,-5,-4,-5,-5,-5,-6,-3,-5,-4,-6,-6,-7,-4,-6,-5,-7,-6,-7,-12,1,-8,-6,-6,-4,-6,-5,-5,-4,-4,-4,-6,-4,-8,-11,-5,-2,-6,-5,-3,-7,-4,-6,-5,-5,-6,-7,-5,0,-3,-5,-3,-6,-4,-6,-6,-7,-5,-5,-4,-6,-3,-7,-7,-5,-6,-3,-6,-9,-6,-4,-7,-4};
  38. //int current_arr [131] = {110,22,178,3,-6,-8,-4,-5,-4,-6,-7,-7,-6,-8,-4,-7,-7,-8,-5,-12,-6,-8,-6,-5,-8,-5,-8,-8,-7,-4,-8,-169,-479,-389,-380,-336,-247,-191,-151,-137,-117,-85,-16,-5,-2,-6,-3,-4,-2,-7,-2,-4,-4,-8,-6,-3,-5,-4,-3,-3,-2,-3,-6,-3,-5,-3,-1,-4,-3,1,144,468,409,363,328,238,179,148,124,108,75,6,-7,-3,-6,-5,-3,-5,-8,-5,-7,-7,-7,-7,-1,-3,-5,-5,-9,-6,0,-12,-9,-4,-10,-6,-6,-6,-10,-132,-469,-446,-367,-334,-251,-191,-153,-133,-113,-89,-20,0,-3,-2,-6,-4,-4,-4,-3,-6,-4};
  39. int subtraction_data[CURENT_LENGTH] = {0};
  40. int last_arr [CURENT_LENGTH] = {0};
  41. int current_arr [CURENT_LENGTH] = {0};
  42. FILE *file_in = fopen("temp_input.txt","r");
  43. if (file_in == NULL) {
  44. perror("Error opening file");
  45. return 1;
  46. }
  47. char line[1024]; // 假设每行不会超过1024个字符
  48. char *token;
  49. int index1 = 0, index2 = 0;
  50. // 读取第一行
  51. if (fgets(line, sizeof(line), file_in) != NULL) {
  52. token = strtok(line, ","); // 使用逗号作为分隔符
  53. while (token != NULL && index1 < CURENT_LENGTH) {
  54. last_arr[index1++] = atoi(token); // 将字符串转换为整数
  55. token = strtok(NULL, ","); // 继续获取下一个元素
  56. }
  57. }
  58. // 读取第二行
  59. if (fgets(line, sizeof(line), file_in) != NULL) {
  60. token = strtok(line, ",");
  61. while (token != NULL && index2 < CURENT_LENGTH) {
  62. current_arr[index2++] = atoi(token);
  63. token = strtok(NULL, ",");
  64. }
  65. }
  66. fclose(file_in); // 关闭文件
  67. // 输出读取到的数组
  68. // printf("Array 1: ");
  69. // for (int i = 0; i < index1; i++) {
  70. // printf("%d ", last_arr[i]);
  71. // }
  72. // printf("\n");
  73. // printf("Array 2: ");
  74. // for (int i = 0; i < index2; i++) {
  75. // printf("%d ", current_arr[i]);
  76. // }
  77. // printf("\n");
  78. int result = current_detection(last_arr,current_arr,subtraction_data);
  79. if(result == -1)
  80. {
  81. printf("******************************************************\n");
  82. printf("检测结果是:%d\n",result);
  83. // printf("last_data is [");
  84. // for(int index=0;index<131;index++)
  85. // printf("%d,",last_arr[index]);
  86. // printf("]\n");
  87. // printf("current_data is [");
  88. // for(int index=0;index<131;index++)
  89. // printf("%d,",current_arr[index]);
  90. // printf("]\n");
  91. printf("******************************************************\n");
  92. }
  93. FILE *file_out = fopen("temp_output.txt","w");
  94. if (file_out == NULL) {
  95. perror("Error opening file");
  96. return 1;
  97. }
  98. fprintf(file_out, "%d", result);
  99. fclose(file_out);
  100. //}
  101. // //double arr[128] = { -1413,-1487,-1545,-1626,-2256,-2594,-2499,-2317,-2363,-2272,-2191,-2149,-2108,-2068,-1966,-1870,-1796,-1634,-1541,-1475,-1317,-1214,-1056,-912,-744,-580,-415,-268,-143,-9,137,243,410,552,687,846,983,1133,1288,1413,1498,1551,1631,2250,2598,2481,2328,2376,2274,2195,2145,2105,2052,1955,1867,1792,1629,1531,1470,1309,1213,1052,907,743,576,414,264,150,12,-131,-236,-400,-544,-680,-837,-975,-1112,-1273,-1397,-1481,-1541,-1603,-2184,-2566,-2565,-2275,-2338,-2269,-2188,-2148,-2117,-2072,-1990,-1876,-1808,-1663,-1536,-1498,-1336,-1230,-1081,-933,-771,-598,-438,-287,-161,-22,112,231,389,532,665,825,966,1106,1272,1395,1488,1544,1609,2176,2572,2586,2401,2384,2283,2195 };
  102. // init_uart ();
  103. // char num = 0;
  104. // int index;
  105. // collect_data collect_data_test;
  106. // int arr[131] = {572,76,658,-5062,-1258,986,9294,1686,274,-1832,-4292,-876,1294,6122,1420,-804,-9456,-1772,210,7318,2224,288,-1810,-8588,-1558,544,8540,1930,0,-5700,-3572,-544,1576,4762,1112,-1118,-8924,-2196,-194,1872,4034,724,-1404,-5524,-1360,894,9512,1758,-334,-7362,-2230,-998,1194,7336,1464,-728,-9058,-1804,104,6862,2442,398,-1700,-4574,-1034,442,7892,2074,96,-3126,-3894,-646,1494,4996,1174,-984,-9384,-1742,392,7650,4230,894,-1348,-6456,-1452,776,9440,1728,-272,-7344,-2302,-368,1774,4270,1550,-608,-8530,-2022,-30,5658,3494,528,-1638,-4832,-1110,1066,8682,1566,150,-1920,-4090,-800,1378,5628,1316,-928,-9528,-1816,298,7398,2198,196,-1884,-7440,-1490,670,9080,1828,-126,-6832,-2676};
  107. // //int arr[131] = { -1413,-1487,-1545,-1626,-2256,-2594,-2499,-2317,-2363,-2272,-2191,-2149,-2108,-2068,-1966,-1870,-1796,-1634,-1541,-1475,-1317,-1214,-1056,-912,-744,-580,-415,-268,-143,-9,137,243,410,552,687,846,983,1133,1288,1413,1498,1551,1631,2250,2598,2481,2328,2376,2274,2195,2145,2105,2052,1955,1867,1792,1629,1531,1470,1309,1213,1052,907,743,576,414,264,150,12,-131,-236,-400,-544,-680,-837,-975,-1112,-1273,-1397,-1481,-1541,-1603,-2184,-2566,-2565,-2275,-2338,-2269,-2188,-2148,-2117,-2072,-1990,-1876,-1808,-1663,-1536,-1498,-1336,-1230,-1081,-933,-771,-598,-438,-287,-161,-22,112,231,389,532,665,825,966,1106,1272,1395,1488,1544,1609,2176,2572,2586,2401,2384,2283,2195,1895,57,1910 };
  108. // collect_data_test.power_p = arr[128];
  109. // collect_data_test.power_q = arr[129];
  110. // collect_data_test.power_s = arr[130];
  111. // for(index = 0;index < CURENT_LENGTH;index++)
  112. // collect_data_test.current[index] = arr[index];
  113. // while (1)
  114. // {
  115. // /* code */
  116. // procecing(&num, &collect_data_test);
  117. // sleep(5);
  118. // }
  119. }
  120. bool Is_opposite_signs(int *x,int *y)
  121. {
  122. return ((*x^*y)<0);
  123. }
  124. int min_count_abs(int x,int *arr)
  125. {
  126. if(abs(arr[x]) < abs(arr[x+1]))
  127. return x;
  128. else
  129. return x+1;
  130. }
  131. void array_subtraction(int *power,int *last_arr,int *current_arr,int *subtraction_arr){
  132. u_int8_t last_zero_node [3] = {0};
  133. u_int8_t current_zero_node [3] = {0};
  134. u_int8_t count = 0;
  135. u_int8_t node_count = 0;
  136. //printf("power is %d\n",*power);
  137. if(*power > 15){
  138. if(current_arr[0] != 0){
  139. node_count = 0;
  140. for(count = 0;count<127;count++){
  141. if(Is_opposite_signs(&current_arr[count],&current_arr[count+1])){
  142. current_zero_node[node_count]=min_count_abs(count,current_arr);
  143. node_count++;
  144. }
  145. if(node_count == 3)
  146. break;
  147. }
  148. }
  149. else{
  150. current_zero_node[0] = 0;
  151. node_count = 1;
  152. for(count = 1;count<127;count++){
  153. if(Is_opposite_signs(&current_arr[count],&current_arr[count+1])){
  154. current_zero_node[node_count]=min_count_abs(count,current_arr);
  155. node_count++;
  156. }
  157. if(node_count == 3)
  158. break;
  159. }
  160. }
  161. if(current_arr[current_zero_node[0]+3]<current_arr[current_zero_node[0]]){
  162. for(count=0;count<128;count++){
  163. if(current_arr[count]!=0)
  164. current_arr[count]= -current_arr[count];
  165. }
  166. }
  167. //AppLog("node %d is %d,node %d is %d,node %d is %d\n",current_zero_node[0],current_arr[current_zero_node[0]],current_zero_node[1],current_arr[current_zero_node[1]],current_zero_node[2],current_arr[current_zero_node[2]]);
  168. if(last_arr[0] != 0){
  169. node_count = 0;
  170. for(count = 0;count<127;count++){
  171. if(Is_opposite_signs(&last_arr[count],&last_arr[count+1])){
  172. last_zero_node[node_count]=min_count_abs(count,last_arr);
  173. node_count++;
  174. }
  175. if(node_count == 3)
  176. break;
  177. }
  178. }
  179. else{
  180. last_zero_node[0] = 0;
  181. node_count = 1;
  182. for(count = 1;count<127;count++){
  183. if(Is_opposite_signs(&last_arr[count],&last_arr[count+1])){
  184. last_zero_node[node_count]=min_count_abs(count,last_arr);
  185. node_count++;
  186. }
  187. if(node_count == 3)
  188. break;
  189. }
  190. }
  191. if(last_arr[last_zero_node[0]+3]<last_arr[last_zero_node[0]]){
  192. for(count=0;count<128;count++){
  193. if(last_arr[count]!=0)
  194. last_arr[count]= -last_arr[count];
  195. }
  196. }
  197. //AppLog("node %d is %d,node %d is %d,node %d is %d\n",last_zero_node[0],last_arr[last_zero_node[0]],last_zero_node[1],last_arr[last_zero_node[1]],last_zero_node[2],last_arr[last_zero_node[2]]);
  198. for(count=0;count<79;count++)
  199. subtraction_arr[count]=current_arr[current_zero_node[0]+count]-last_arr[last_zero_node[0]+count];
  200. for(count=79;count<128;count++)
  201. subtraction_arr[count]=subtraction_arr[count-79];
  202. }
  203. else{
  204. for(count=0;count<128;count++)
  205. subtraction_arr[count]=current_arr[count];
  206. }
  207. // printf("subtraction_data is [");
  208. // for(count=0;count<128;count++)
  209. // printf("%d,",subtraction_arr[count]);
  210. // printf("]\n");
  211. }
  212. int current_detection(int *last,int *current,int *subtraction){
  213. // printf("******************************************************\n");
  214. // printf("last_data is [");
  215. // for(int index=0;index<131;index++)
  216. // printf("%d,",last[index]);
  217. // printf("]\n");
  218. // printf("current_data is [");
  219. // for(int index=0;index<131;index++)
  220. // printf("%d,",current[index]);
  221. // printf("]\n");
  222. // printf("******************************************************\n");
  223. if(last[0] < 15){
  224. subtraction[0] = current[0];
  225. subtraction[1] = current[1];
  226. subtraction[2] = current[2];
  227. }else{
  228. subtraction[0] = current[0] - last[0];
  229. subtraction[1] = current[1] - last[1];
  230. subtraction[2] = current[2] - last[2];
  231. }
  232. array_subtraction(&last[0],&last[3],&current[3],&subtraction[3]);
  233. // printf("subtraction_data is [");
  234. // for(int index=0;index<131;index++)
  235. // printf("%d,",subtraction_data[index]);
  236. // printf("]\n");
  237. pthread_mutex_lock(&mutex);
  238. int result = run_predict(subtraction);
  239. pthread_mutex_unlock(&mutex);
  240. return result;
  241. }