Advertisement
Sidsh

LSA+Dijkstra 2.0

Feb 9th, 2022
192
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
VeriLog 13.51 KB | None | 0 0
  1. module LSA(
  2.     output [7:0]m1,  //motor1                                            PIN_D3
  3.     output [7:0]m2,  //motor2                                            PIN_C3
  4.     input [11:0]s1,  //12-bit output of ch. 5 (parallel)
  5.     input [11:0]s2,  //12-bit output of ch. 6 (parallel)
  6.     input [11:0]s3,  //12-bit output of ch. 7 (parallel)
  7.     input clk_50,    //50 MHz clock
  8.     input reset,
  9.      output Led1,    //Led used to indicate position of bot i.e. node or line
  10.      output Led2,
  11.      output Led3,
  12.      output HL1,        // to control uart
  13.      output [2:0] id
  14.     );
  15.  
  16. reg signed[7:0]error = 0;
  17. reg signed[7:0]difference = 0;
  18. reg signed[7:0]correction = 0;
  19. reg signed[7:0]cumulative_error = 0;
  20. reg signed[7:0]preverror = 0;
  21. reg [3:0]nodecount = -4'd1;     //No. of nodes bot has traversed, initially set to -1
  22. //reg [3:0]flag=0;
  23. reg flag = 0;  
  24.  
  25. reg [6:0]k, l, adj, near, parnode;
  26.  
  27. reg [11:0] dist [0:36];
  28. reg [6:0] parent [0:36];
  29. reg visited[0:36];
  30.  
  31. reg [6:0] length=0;    // length of path
  32. reg [6:0] sp[0:36];     // Store path
  33. reg [1:0] p_dc[0:36];       //Stores The turns
  34.  
  35.  
  36. reg led1=0;
  37. reg led2=0;
  38. reg led3=0;
  39.  
  40. parameter V = 37;
  41.  
  42. reg [7:0] i,j;
  43.  
  44. reg [11:0] cost [0:36][0:36];
  45. reg [11:0] cost2 [0:36][0:36];
  46.  
  47. // Function to find out the shortest distance
  48. function automatic [6:0]minNode;
  49.     input [6:0]a;
  50.     reg [6:0]minValue = 999;
  51.    reg [6:0]minNode1 = 0;
  52.     begin
  53.         for (k = 0; k < V; k=k+1)
  54.         begin
  55.         if (dist[k] < minValue && visited[k] == 0)
  56.         begin
  57.             minValue = dist[k];
  58.             minNode1 = k;
  59.                 //$display("Enter min");
  60.         end
  61.         end
  62.     minNode = minNode1;
  63.      //$display("Function Called %6d", minNode1);
  64.     end
  65. endfunction
  66. //
  67.  
  68.  
  69. //Storing Values of the cost matrix
  70. initial begin
  71. for(i=0;i<V;i=i+1)
  72. begin
  73.     for(j=0;j<V;j=j+1) begin
  74.        
  75.         if(i==j) begin
  76.                 cost2[i][j] = 0;
  77.                 cost[i][j] = 0;
  78.           end
  79.         else begin
  80.                 cost2[i][j] = 999;
  81.                 cost[i][j] = 999;
  82.           end
  83.     end
  84. end
  85. cost2[0][1] = 3;
  86. cost2[0][2] = 2;
  87. cost2[0][8] = 1;
  88.  
  89. cost2[1][0] = 4;
  90.  
  91. cost2[2][0] = 1;
  92. cost2[2][3] = 2;
  93. cost2[2][4] = 3;
  94.  
  95. cost2[3][2] = 1;
  96. cost2[3][6] = 3;
  97. cost2[3][17] = 2;
  98.  
  99. cost2[4][2] = 4;
  100. cost2[4][5] = 2;
  101. cost2[4][11] = 3;
  102.  
  103. cost2[5][4] = 1;
  104.  
  105. cost2[6][3] = 4;
  106. cost2[6][7] = 2;
  107. cost2[6][14] = 3;
  108.  
  109. cost2[7][6] = 1;
  110.  
  111. cost2[8][0] = 4;
  112. cost2[8][10] = 2;
  113. cost2[8][33] = 3;
  114.  
  115. cost2[9][10] = 3;
  116.  
  117. cost2[10][8] = 1;
  118. cost2[10][9] = 4;
  119. cost2[10][11] = 2;
  120.  
  121. cost2[11][4] = 4;
  122. cost2[11][10] = 1;
  123. cost2[11][12] = 2;
  124. cost2[11][18] = 3;
  125.  
  126. cost2[12][11] = 1;        //M
  127. cost2[12][13] = 4;
  128. cost2[12][14] = 2;
  129. cost2[12][23] = 3;
  130.  
  131. cost2[13][12] = 3;
  132.  
  133. cost2[14][6] = 4;        //O
  134. cost2[14][12] = 1;
  135. cost2[14][15] = 2;
  136.  
  137. cost2[15][14] = 1;
  138. cost2[15][16] = 4;
  139. cost2[15][17] = 2;
  140.  
  141. cost2[16][15] = 3;       //Q
  142.  
  143. cost2[17][15] = 1;
  144. cost2[17][3] = 4;
  145. cost2[17][26] = 3;
  146.  
  147. cost2[18][19] = 2;
  148. cost2[18][11] = 4;
  149. cost2[18][21] = 3;       //S
  150.  
  151. cost2[19][18] = 1;
  152.  
  153. cost2[20][21] = 2;       //U
  154.  
  155. cost2[21][20] = 1;
  156. cost2[21][22] = 2;
  157. cost2[21][28] = 3;
  158. cost2[21][18] = 4;
  159.  
  160. cost2[22][21] = 1;       //W
  161.  
  162. cost2[23][24] = 2;
  163. cost2[23][12] = 4;
  164. cost2[23][34] = 3;
  165.  
  166. cost2[24][22] = 1;
  167.  
  168. cost2[25][26] = 2;       //Z
  169.  
  170. cost2[26][25] = 1;
  171. cost2[26][17] = 4;
  172. cost2[26][34] = 3;       //AA
  173.  
  174. cost2[27][28] = 2;
  175.  
  176. cost2[28][27] = 1;
  177. cost2[28][21] = 4;
  178. cost2[28][29] = 2;
  179. cost2[28][31] = 3;
  180.  
  181. cost2[29][28] = 1;       //AD
  182.  
  183. cost2[30][31] = 2;
  184.  
  185. cost2[31][30] = 1;       //AF
  186. cost2[31][28] = 4;
  187. cost2[31][32] = 2;
  188. cost2[31][33] = 3;
  189.  
  190. cost2[32][31] = 1;       //AG
  191.  
  192. cost2[33][31] = 4;
  193. cost2[33][8] = 1;
  194. cost2[33][34] = 2;
  195.  
  196. cost2[34][35] = 2;
  197. cost2[34][23] = 4;
  198. cost2[34][33] = 1;
  199.  
  200. cost2[35][36] = 4;
  201. cost2[35][26] = 2;
  202. cost2[35][34] = 1;
  203.  
  204. cost2[36][35] = 3;
  205. end
  206.  
  207. initial begin
  208. /*for(i=0;i<V;i=i+1)
  209. begin
  210.     for(j=0;j<V;j=j+1) begin
  211.        
  212.         if(i==j) begin
  213.                 //cost2[i][j] = 0;
  214.                 cost[i][j] = 0;
  215.           end
  216.         else begin
  217.                 //cost2[i][j] = 999;
  218.                 cost[i][j] = 999;
  219.           end
  220.     end
  221. end */
  222. cost[0][1] = 100;               //A
  223. cost[0][2] = 15;
  224. cost[0][8] = 15;
  225.  
  226. cost[1][0] = 100;               //B
  227.  
  228. cost[2][0] = 15;                 //C
  229. cost[2][3] = 3;
  230. cost[2][4] = 15;
  231.  
  232. cost[3][2] = 3;                 //D
  233. cost[3][6] = 2;
  234. cost[3][17] = 4;
  235.  
  236. cost[4][2] = 15;            //E
  237. cost[4][5] = 100;
  238. cost[4][11] = 15;
  239.  
  240. cost[5][4] = 100;       //F
  241.  
  242. cost[6][3] = 2;         //G
  243. cost[6][7] = 100;
  244. cost[6][14] = 3;
  245.  
  246. cost[7][6] = 100;       //H
  247.  
  248. cost[8][0] = 15;            //I
  249. cost[8][10] = 15;
  250. cost[8][33] = 15;
  251.  
  252. cost[9][10] = 100;      //J
  253.  
  254. cost[10][8] = 2;        //K
  255. cost[10][9] = 100;
  256. cost[10][11] = 1;
  257.  
  258. cost[11][4] = 15;       //L
  259. cost[11][10] = 1;
  260. cost[11][12] = 3;
  261. cost[11][18] = 1;
  262.  
  263. cost[12][11] = 3;           //M
  264. cost[12][13] = 100;
  265. cost[12][14] = 1;
  266. cost[12][23] = 2;
  267.  
  268. cost[13][12] = 100;     //N
  269.  
  270. cost[14][6] = 3;            //O
  271. cost[14][12] = 1;
  272. cost[14][15] = 2;
  273.  
  274. cost[15][14] = 2;       //P
  275. cost[15][16] = 100;
  276. cost[15][17] = 1;
  277.  
  278. cost[16][15] = 100;         //Q
  279.  
  280. cost[17][15] = 1;       //R
  281. cost[17][3] = 4;
  282. cost[17][26] = 2;
  283.  
  284. cost[18][19] = 100;     //S
  285. cost[18][11] = 1;
  286. cost[18][21] = 1;      
  287.  
  288. cost[19][18] = 100;     //T
  289.  
  290. cost[20][21] = 100;         //U
  291.  
  292. cost[21][20] = 100;     //V
  293. cost[21][22] = 100;
  294. cost[21][28] = 1;
  295. cost[21][18] = 1;
  296.  
  297. cost[22][21] = 100;             //W
  298.  
  299. cost[23][24] = 100;     //X
  300. cost[23][12] = 2;
  301. cost[23][34] = 3;
  302.  
  303. cost[24][23] = 100;     //Y
  304.  
  305. cost[25][26] = 100;             //Z
  306.  
  307. cost[26][25] = 100;     //AA
  308. cost[26][17] = 2;
  309. cost[26][34] = 4;      
  310.  
  311. cost[27][28] = 100;     //AB
  312.  
  313. cost[28][27] = 100;     //AC
  314. cost[28][21] = 1;
  315. cost[28][29] = 100;
  316. cost[28][31] = 1;
  317.  
  318. cost[29][28] = 100;         //AD
  319.  
  320. cost[30][31] = 100;     //AE
  321.  
  322. cost[31][30] = 100;             //AF
  323. cost[31][28] = 1;
  324. cost[31][32] = 100;
  325. cost[31][33] = 1;
  326.  
  327. cost[32][31] = 100;             //AG
  328.  
  329. cost[33][31] = 1;       //AH
  330. cost[33][8] = 15;
  331. cost[33][34] = 3;
  332.  
  333. cost[34][35] = 2;       //AI
  334. cost[34][23] = 3;
  335. cost[34][33] = 3;
  336.  
  337. cost[35][36] = 100;     //AJ
  338. cost[35][26] = 4;
  339. cost[35][34] = 2;
  340.  
  341. cost[36][35] = 100;     //AK
  342.  
  343. end
  344.  
  345. reg [7:0]odc =50;     //optimum duty cycle
  346. reg [7:0]mo1 = 50;    // pwm to motor1, initially set to 50
  347. reg [7:0]mo2 = 50;    // pwm to motor2, initially set to 50
  348. reg [7:0]ml1 = 50;    // pwm to motor1 when it is on line
  349. reg [7:0]ml2 = 50;    // pwm to motor2 when it is on line
  350. reg [7:0]mn1 = 50;    // pwm to motor1 when it is on node
  351. reg [7:0]mn2 = 50;    // pwm to motor2 when it is on node
  352. reg [11:0]thr = 2000; //Condition to differentiate between white and black surface
  353. reg [7:0]r_COUNT = 0; //counter
  354. reg clk_1 = 0;        //1 MHz Clock
  355.  
  356. reg [2:0] id1 =0;        //to control uart
  357. reg hl;
  358.  
  359.  
  360. always @(posedge clk_50) begin   //Scaling down of 50MHz clock to 1 MHz
  361.  
  362.     if(reset == 0)
  363.      begin
  364.         r_COUNT <= 0;
  365.      end
  366.  
  367.    if (r_COUNT == 49 )begin             //Check if count reaches 49
  368.       r_COUNT <= 0;                     //Reset counter if it reaches 49
  369.    end else begin
  370.       r_COUNT <= r_COUNT + 1;           //increment counter by 1 till 49
  371.    end
  372.     clk_1 <= (r_COUNT < 25);
  373. end
  374. reg [6:0] start1 = 33;
  375. reg [6:0] end1 = 3;
  376. reg [6:0] s6 = 22;
  377. reg [6:0] dzn1 =7;
  378.  
  379. //dijkstra function
  380. function automatic dijkstra;
  381. input [6:0] start;
  382. input [6:0] enda;
  383. begin
  384.      $display("Enter dijkstra");
  385.     for (i = 0; i < V; i=i+1)
  386.     begin
  387.         dist[i] = 999;
  388.         parent[i] = i;
  389.           visited[i] = 0;
  390.           sp[i] = 0;
  391.           p_dc[i] = -1;
  392.     end
  393.     dist[start] = 0;
  394.         for (i = 0; i < V; i=i+1)
  395.         begin
  396.         near = minNode(1);
  397.         visited[near] = 1;
  398.  
  399.         for (adj = 0; adj < V; adj=adj+1)
  400.         begin
  401.             if (cost[near][adj] != 0 && dist[adj] > dist[near] + cost[near][adj])
  402.             begin
  403.                 dist[adj] = dist[near] + cost[near][adj];
  404.                 parent[adj] = near;
  405.             end
  406.         end
  407.         end
  408.       parnode = parent[enda];
  409.       sp[length] = enda;
  410.       for(i=0;i<V;i=i+1)
  411.            begin
  412.                 if(parnode != start) begin
  413.                
  414.                 length = length + 1;
  415.                 sp[length] = parnode;
  416.                      $display(" <- %6d ", sp[length]);
  417.                 parnode = parent[parnode];                   
  418.                     end
  419.             end
  420.         length= length + 1;
  421.         sp[length] = start;
  422.       //$display("%6d", length);
  423.         //direction
  424.         i=0;
  425.         for(j=35;j>0;j=j-1) begin
  426.             //$display("%6d", sp[j]);
  427.            
  428.             if(j<length && j>0) begin
  429.                 $display("%6d", sp[j]);
  430.                 if(((cost2[sp[j]][sp[j+1]]==1) && (cost2[sp[j]][sp[j-1]] == 2)) || ((cost2[sp[j]][sp[j+1]]==2) && (cost2[sp[j]][sp[j-1]] == 1)) || ((cost2[sp[j]][sp[j+1]]==4) && (cost2[sp[j]][sp[j-1]] == 3)) || ((cost2[sp[j]][sp[j+1]]==3) &&(cost2[sp[j]][sp[j-1]] == 4)))
  431.                     begin $display("Straight");  
  432.                         p_dc[i]=0;
  433.                        
  434.                         $display("%6d",p_dc[i]);
  435.                         i=i+1;
  436.                     end
  437.                 if(((cost2[sp[j]][sp[j+1]]==1) && (cost2[sp[j]][sp[j-1]] == 3)) || ((cost2[sp[j]][sp[j+1]]==3) && (cost2[sp[j]][sp[j-1]] == 2)) || ((cost2[sp[j]][sp[j+1]]==2) && (cost2[sp[j]][sp[j-1]] == 4)) || ((cost2[sp[j]][sp[j+1]]==4) && (cost2[sp[j]][sp[j-1]] == 1)))
  438.                     begin $display("Left");
  439.                         p_dc[i]=1;
  440.                        
  441.                         $display("%6d",p_dc[i]);
  442.                         i=i+1;
  443.                     end
  444.                 if(((cost2[sp[j]][sp[j+1]]==1) && (cost2[sp[j]][sp[j-1]] == 4)) || ((cost2[sp[j]][sp[j+1]]==4) && (cost2[sp[j]][sp[j-1]] == 2)) || ((cost2[sp[j]][sp[j+1]]==2) && (cost2[sp[j]][sp[j-1]] == 3)) || ((cost2[sp[j]][sp[j+1]]==3) && (cost2[sp[j]][sp[j-1]] == 1)))
  445.                     begin $display("Right");
  446.                         p_dc[i]=2;
  447.                         $display("%6d",p_dc[i]);
  448.                         i=i+1;
  449.                     end            
  450.             end
  451.            
  452.            
  453.         end
  454.          
  455.     dijkstra = 1;
  456. end
  457. endfunction
  458. //
  459.  
  460. reg flag_dijkstra = 0;
  461. reg [6:0] count_dijkstra =-1;
  462. always @(posedge clk_1) begin    
  463.  
  464. //Call dijkstra
  465.     if(flag_dijkstra == 0) begin
  466.         flag_dijkstra = dijkstra(start1, 3);
  467.        
  468.         end
  469.        
  470. // Line Following
  471.     if(reset == 0)
  472.      begin
  473.         nodecount =-4'd1 ;         //Initially node count set to -1
  474.      end
  475.    
  476.      led1 <= (s1>thr);               //Led lights up when s1 has a greater value than 2000
  477.      led2 <= (s2>thr);              //Led lights up when s2 has a greater value than 2000
  478.      led3 <= (s3>thr);              //Led lights up when s3 has a greater value than 2000
  479.  
  480.     error = (s1>thr) - (s3>thr);    //Relative error between sensors s1 and s3: values range from -1 to 1  P
  481.  
  482.     cumulative_error <= cumulative_error + error;  //Adds up the error to give a cumulative error  I
  483.      
  484.     if (cumulative_error > 10)      //Condition to reset the value of cumulative error to 10 if it crosses 10  
  485.     begin
  486.         cumulative_error <= 10;
  487.     end
  488.  
  489.      if (cumulative_error < -10)    //Condition to reset the value of cumulative error to -10 if it crosses -10  
  490.     begin
  491.         cumulative_error <= -10;
  492.     end
  493.      
  494.      if (s1<thr && s2>thr && s3<thr) //Cumulative error resets to zero when the bot is on line i.e WBW
  495.      begin
  496.             cumulative_error <= 0;  
  497.             hl=0;
  498.      end
  499.      
  500.      difference <= error-preverror;   //forms the differential part D
  501.      correction <= ((10*error) + cumulative_error + (2*difference)); // kp = 10, ki = 1, kd =2
  502.      
  503.       preverror <= error;  // Stores value of current error to previous error so that it can be used in next loop cycle
  504.      
  505.      
  506.      ml1 <= odc - correction;  // PID tuning for motor 1
  507.      ml2 <= odc + correction;  // PID tuning for motor 2
  508.  
  509.      if (ml1>70)      //Resetting value of ml1 to 70 if it crosses 70
  510.      begin
  511.          ml1 <= 70;
  512.      end
  513.      if (ml2>70)      //Resetting value of ml2 to 70 if it crosses 70
  514.      begin
  515.          ml2 <= 70;
  516.      end
  517.      if (ml1<30)       //Resetting value of ml1 to 30 if it becomes less than 30
  518.      begin
  519.          ml1 <= 30;
  520.      end
  521.      if (ml2<30)       //Resetting value of ml2 to 30 if it becomes less than 30
  522.      begin
  523.          ml2 <= 30;
  524.      end  
  525.     if (s1 < thr && s2 > thr && s3 < thr) //ready for next node, flag resets to zero on line : WBW
  526.     begin
  527.         flag <= 0;
  528.     end
  529.      /*else begin
  530.         flag <= 1;
  531.     end*/
  532.  
  533.     // Only detect node once.
  534.     if (s1>thr && s2>thr && s3>thr && flag == 0 && flag_dijkstra==1)  //detect node
  535.     begin        
  536.           hl = 1;
  537.           id1 = 4;
  538.           flag <= 1;
  539.           //$display("%7d " ,i);
  540.           //nodecount = p_dc[i];
  541.           count_dijkstra = count_dijkstra+1;   
  542.           $display("%6d, %6d, %6d",p_dc[0], count_dijkstra, p_dc[count_dijkstra]);
  543.            if(count_dijkstra==(length-1)) begin
  544.            
  545.             start1 = end1;
  546.             if(sp[0] == end1) begin
  547.                 end1=s6;
  548.             end
  549.             if(sp[0] == s6) begin
  550.                 end1=dzn1;
  551.             end
  552.             flag_dijkstra = 0;
  553.           end
  554.          
  555.          
  556.         if(p_dc[count_dijkstra] == 0)
  557.         begin  
  558.             //$display("straight");
  559.             mn1 <= odc;
  560.             mn2 <= odc;
  561.         end
  562.         if(p_dc[count_dijkstra] == 1)
  563.         begin
  564.             //$display("left");
  565.             mn1 <= 5;
  566.             mn2 <= 60;
  567.         end
  568.         if(p_dc[count_dijkstra] == 2)
  569.         begin    
  570.             //$display("right");   
  571.             mn1 <= 60;
  572.             mn2 <= 5;
  573.         end
  574.     end
  575.        
  576.            
  577.     /*if(flag == 1)    //Detection of node and applying pwm accordingly
  578.     begin
  579.    
  580.     if(p_dc[i] == 0)
  581.     begin  
  582.    $display("straight");   
  583.         mn1 <= odc;
  584.       mn2 <= odc;
  585.     end
  586.     if(p_dc[i] == 1)
  587.     begin
  588.     $display("left");  
  589.         mn1 <= 5;
  590.       mn2 <= 60;
  591.     end
  592.     if(p_dc[i] == 2)
  593.     begin    
  594.     $display("right"); 
  595.         mn1 <= 60;
  596.       mn2 <= 5;
  597.     end
  598.    
  599.     end*/
  600.    
  601.     if(flag == 0)    //assigning values of ml1 and ml2 (line condition) to mo1 and mo2 respectively
  602.     begin
  603.         mo1 <= ml1;
  604.         mo2 <= ml2;
  605.     end else
  606.     begin            //assigning values of mn1 and mn2 (node condition) to mo1 and mo2 respectively
  607.         mo1 <= mn1;
  608.         mo2 <= mn2;
  609.     end
  610. end
  611.        
  612. assign Led1 = led1;
  613. assign Led2 = led2;
  614. assign Led3 = led3;
  615.  
  616. assign id = id1;
  617. assign HL1 = hl;
  618. assign m1 = mo1;
  619. assign m2 = mo2;
  620.  
  621. endmodule
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement