Temperature = Init Temp; (Init Temp=10000)

Temperature = Init Temp; (Init Temp=10000)

<p>PROJECT # 3</p><p>Submitted By:</p><p>Priyank Tiwari Problem statement</p><p>A traveling salesman must travel to 20 cities (at least once each) of a country whose boarders form a rectangle of length (east-west) 3000 miles and width 1500 (south- north) miles. First, generate 20 such cities (randomly, uniformly) and then start traveling from the most northeast city (defined as the city closest to the northeast corner of the country) to the remaining 19 cities. Find a path that has the shortest total distance. You may use a brute force method to do it but you are encouraged to use one of the stochastic optimization methods such as simulated annealing. Please do the following:</p><p>(1) Compute the CPU time necessary to find such shortest path by one processor. (2) Use P processors to compute the same path or a different path with the same distance (accurate to machine precision if the new distance is different.) a P = 2 b. P = 4 c P = 8 (3) Plot the speedup curve and discuss your timing results.</p><p>ALGORITHM TEMPERATURE = INIT_TEMP; (INIT TEMP=10000) CITY=INIT CONFIG OF CITIES(set the initial config) CITY(0)=Northernmost city(sort out the northern most city and put as 1’st element) While (TEMPERATURE > 0.1) { While ( INNER_LOOP_CRITERION = TRUE) (run for 100 times) { mindistance(OLD COST) = CALC PATH( ); RANDOMOIZE ; ( not to randomize position of cities but their arrangement in City array) Distancecalc(NEW COST)= CALC PATH( ); If ( Distancecalc< mindistance) { mindistance= Distancecalc; [OldCost = NewCost;] SaveCity=City (DistCalc); [Save the configuration at the least distance] } ------Accept the good move</p><p>ELSE </p><p>{ r = RANDOM(0,1); Delta Cost=NEW COST-OLD COST; y = exp( -DeltaCost / TEMPERATURE); if(r < y) { mindistance= Distancecalc; [OldCost = NewCost;] SaveCity=City (DistCalc); [Save the configuration at the least distance] } ------Accept the bad move</p><p>}</p><p>ELSE { reject bad move</p><p>( don’t change mindistance)</p><p>}</p><p>} ------INNER LOOP boundary Mindistnace1Proc=mindistance for(J=0;J<P;J++) ------for all the processors do this { if myrank !=0; SEND( myrank,Mindistance1Proc) } for(J=0;J<P;J++) ------for all the processors do this { RECIEVE ( myrank,Mindistance1Proc) ------Sort least min distance and get corresponding rank SEND(sortedmyrank )</p><p>} for(J=0;J<P;J++)</p><p>{</p><p>IF myrank !=0</p><p>RECIEVE (sortedmyrank ) </p><p>IF myrank = sortedmyrank ------( means the rank sent from 0) SEND( savecity config) } for(J=0;J<P;J++) { CITY =SaveCity }</p><p>TEMP= TEMP * ALPHA (TEMP= TEMP* .8) }------OUTER LOOP BOUNDARY PROJECT CODE: //Declaration of Header Files #include <stdio.h> #include <stdlib.h> #include <mpi.h> #include <math.h> #define MAX 20</p><p>//declaring the function prototypes double calc_shortestpath(); double calc_path(); void randomize(); void calc_parallel();</p><p>//defining the city struct city_structure { int x,y; }; struct city_structure city[MAX],saved_city[MAX]; //definition of global variables int t=10000; double alpha=0.8; double min_distance=100000000000; int p,my_rank,rankfrom0; long int smallest; int flag=0;</p><p>MPI_Status status;</p><p>//START of Main Function int main(int argc, char *argv[]) { int i,j,tag,temp_x,temp_y; double temp,distance[MAX]; double minimum; double starttime=0, endtime=0;</p><p>//variables usedfor calculating execution time</p><p> double time_taken=0,timeelapsed=0,totaltime=0; //variables used for calculating execution time</p><p>//MPI code MPI_Init(&argc, &argv); //Initiate MPI MPI_Comm_rank(MPI_COMM_WORLD, &my_rank); //Set COMM and my_rank MPI_Comm_size(MPI_COMM_WORLD, &p); //find COMM's size</p><p>//Assigning the locations of the cities</p><p> for(i=0;i<MAX;i++) { city[i].x=rand()%3000; city[i].y=rand()%1500; }</p><p>//Doing this to find the north east city</p><p> temp=3354; for(i=0;i<20;i++)</p><p>{ distance[i]= sqrt(pow(city[i].x -3000,2)+ pow(city[i].y - 1500,2)); if(distance[i]<temp) { temp=distance[i]; tag=i; } }</p><p>//1st city swapped with most northeast city temp_x=city[0].x; temp_y=city[0].y;</p><p> city[0].x=city[tag].x; city[0].y=city[tag].y;</p><p> city[tag].x= temp_x; city[tag].y= temp_y;</p><p> starttime = MPI_Wtime(); //starting timer</p><p> calc_parallel();// This is the crux of the project</p><p> endtime = MPI_Wtime();//stopping the timer time_taken=endtime-starttime;//computing time taken</p><p>//Calculating the time taken by each processor and then sending //it to processor with Rank 0 for(j=0;j<p;j++) { if(my_rank==j) MPI_Send(&time_taken,1,MPI_DOUBLE,0,j*3,MPI_COMM_WORLD); }</p><p> if(my_rank==0) { totaltime=time_taken; for(j=1;j<p;j++) {</p><p>MPI_Recv(&timeelapsed,1,MPI_DOUBLE,j,j*3,MPI_COMM_WORLD,&status); totaltime+=timeelapsed; }</p><p> minimum=smallest; printf("The Travelling Salesman problem for calculating the shortest path between 20 cities using Simulated Annealing\n"); printf("\n\nminimum distance calculated is %lf",minimum); printf("\n\nYou get the shorterst path by traversing thru the following cities back to the first city\n"); for(i=0;i<20;i++) printf(" (%d,%d)\n-",city[i].x,city[i].y);</p><p> printf(" (%d,%d)\n-",city[0].x,city[0].y); printf("\n\nTime taken for execution of the program is %f seconds\n",totaltime/p); }</p><p>MPI_Finalize(); return 0; }</p><p>//Function for calculating the shortest path by each processor double calc_shortestpath() { int count,i; double dist=0,distance_calc,minimum,delta,c,a;</p><p> for(count=0;count<100;count++) { randomize(); distance_calc=calc_path(); if(distance_calc<min_distance) { min_distance=distance_calc; for(i=0;i<20;i++) { saved_city[i].x=city[i].x; saved_city[i].y=city[i].y; } } else { //Simulated Annealing being used to chose the minimum distance delta=distance_calc-min_distance; c=((rand()%1)+1)/(sqrt(rand()%5)); a=delta/t; if(c<exp(-a)) min_distance=distance_calc; for(i=0;i<20;i++) { saved_city[i].x=city[i].x; saved_city[i].y=city[i].y; } } }</p><p> return(min_distance); }</p><p>//Function for calculating the path for 1 iteration double calc_path() { int i; double dist=0; for(i=1;i<19;i++) dist+=sqrt(pow(city[i].x -city[i+1].x,2)+ pow(city[i].y - city[i+1].y,2));</p><p> dist+=sqrt(pow(city[0].x -city[1].x,2)+ pow(city[0].y - city[1].y,2)); dist+=sqrt(pow(city[0].x -city[19].x,2)+ pow(city[0].y - city[19].y,2)); return(dist); }</p><p>//Function for changing the cities selected for calculating the path void randomize() { int i,number,temp_x,temp_y; for(i=1;i<20;i++) { number=rand()%19+1; temp_x=city[i].x; temp_y=city[i].y;</p><p> city[i].x=city[number].x; city[i].y=city[number].y;</p><p> city[number].x= temp_x; city[number].y= temp_y; } }</p><p>/*This is a function which each processor will execute for finding the shortest path,then send it to rank 0 processor for determining which processor calculated the shortest path and then broadcast this information to all other processors so that it can improve upon this path using the</p><p>Simulated Annealing Technique */ void calc_parallel() { int i,j,k,count,ranking,min_rank;</p><p> double min_dist1proc=100000000,minimumbyprocs[8];</p><p> while (t>0.1) { min_dist1proc=calc_shortestpath();</p><p>//Send smallest distance calculated by each processor to rank 0 processor for(j=0;j<p;j++) if((my_rank==j)&&(my_rank!=0)) {</p><p>MPI_Send(&min_dist1proc,1,MPI_DOUBLE,0,j*10,MPI_COMM_WORLD);</p><p>MPI_Send(&j,1,MPI_INT,0,j*10,MPI_COMM_WORLD); }</p><p>/*Rank 0 processor determines which processor calculated the shortest distance and then sends this information to other processors*/ if(my_rank==0) { minimumbyprocs[0]=min_dist1proc; for(j=1;j<p;j++) {</p><p>MPI_Recv(&minimumbyprocs[j],1,MPI_DOUBLE,j,j*10,MPI_COMM_WORLD,&stat us);</p><p>MPI_Recv(&ranking,1,MPI_INT,j,j*10,MPI_COMM_WORLD,&status); }</p><p> smallest=1000000; for(count=0;count<p;count++) { if(minimumbyprocs[count]<smallest) { smallest=minimumbyprocs[count]; min_rank=count; } }</p><p> for(j=1;j<p;j++) {</p><p>MPI_Send(&min_rank,1,MPI_INT,j,j*20,MPI_COMM_WORLD); } rankfrom0=min_rank; }</p><p>/*Each processor checks the rank sent by rank 0 processor to check whether it itself is the one which calculated the shortest distance*/ for(j=1;j<p;j++) { if(my_rank==j) {</p><p>MPI_Recv(&rankfrom0,1,MPI_INT,0,j*20,MPI_COMM_WORLD,&status); // printf("\nminimum rank=%d",rankfrom0); } }</p><p> for(j=0;j<p;j++) { if(my_rank==rankfrom0) // printf("\nBroadcasting my info"); for(k=0;k<p;k++) { if(my_rank!=k) for(i=0;i<20;i++) { //Sending the best path to all processors</p><p>MPI_Send(&saved_city[i].x,1,MPI_INT,k,k*30,MPI_COMM_WORLD);</p><p>MPI_Send(&saved_city[i].y,1,MPI_INT,k,k*30,MPI_COMM_WORLD); } } } /*All processors receive the best path computed during 1 iteration by 1 processor and then improves upon this path*/ if(p>1) for(k=0;k<p;k++) if((my_rank==k)&&(my_rank!=rankfrom0)) { for(i=0;i<20;i++) {</p><p>MPI_Recv(&city[i].x,1,MPI_INT,rankfrom0,k*30,MPI_COMM_WORLD,&status );</p><p>MPI_Recv(&city[i].y,1,MPI_INT,rankfrom0,k*30,MPI_COMM_WORLD,&status ); } } t=0.8*t;</p><p>} }</p><p>Project CODE for Brute force:</p><p>//Declaration of Header Files #include <stdio.h> #include <stdlib.h> #include <mpi.h> #include <math.h> #define MAX 20</p><p>//declaring the function prototypes double calc_shortestpath(); double calc_path(); void randomize(); void calc_parallel();</p><p>//defining the city struct city_structure { int x,y; }; struct city_structure city[MAX],saved_city[MAX]; //definition of global variables int t=10000; double alpha=0.8; double min_distance=100000000000; int p,my_rank,rankfrom0; long int smallest; int flag=0;</p><p>MPI_Status status;</p><p>//START of Main Function int main(int argc, char *argv[]) { int i,j,tag,temp_x,temp_y; double temp,distance[MAX]; double minimum; double starttime=0, endtime=0; //variables used for calculating execution time double time_taken=0,timeelapsed=0,totaltime=0; //variables used for calculating execution time</p><p>//MPI code MPI_Init(&argc, &argv); //Initiate MPI MPI_Comm_rank(MPI_COMM_WORLD, &my_rank); //Set COMM and my_rank MPI_Comm_size(MPI_COMM_WORLD, &p); //find COMM's size</p><p>//Assigning the locations of the cities for(i=0;i<MAX;i++) { city[i].x=rand()%3000; city[i].y=rand()%1500; }</p><p>//Doing this to find the north east city temp=3354; for(i=0;i<20;i++) { distance[i]= sqrt(pow(city[i].x -3000,2)+ pow(city[i].y - 1500,2)); if(distance[i]<temp) { temp=distance[i]; tag=i; } }</p><p>//1st city swapped with most northeast city temp_x=city[0].x; temp_y=city[0].y;</p><p> city[0].x=city[tag].x; city[0].y=city[tag].y; city[tag].x= temp_x; city[tag].y= temp_y;</p><p> starttime = MPI_Wtime(); //starting timer</p><p> calc_parallel();// This is the crux of the project</p><p> endtime = MPI_Wtime();//stopping the timer time_taken=endtime-starttime;//computing time taken</p><p>//Calculating the time taken by each processor and then sending it to processor with Rank 0 for(j=0;j<p;j++) { if(my_rank==j) MPI_Send(&time_taken,1,MPI_DOUBLE,0,j*3,MPI_COMM_WORLD); }</p><p> if(my_rank==0) { totaltime=time_taken; for(j=1;j<p;j++) {</p><p>MPI_Recv(&timeelapsed,1,MPI_DOUBLE,j,j*3,MPI_COMM_WORLD,&status); totaltime+=timeelapsed; }</p><p> minimum=smallest; printf("The Travelling Salesman problem for calculating the shortest path between 20 cities using Simulated Annealing\n"); printf("\n\nminimum distance calculated is %lf",minimum); printf("\n\nYou get the shorterst path by traversing thru the following cities back to the first city\n"); for(i=0;i<20;i++) printf(" (%d,%d)\n-",city[i].x,city[i].y);</p><p> printf(" (%d,%d)\n-",city[0].x,city[0].y); printf("\n\nTime taken for execution of the program is %f seconds\n",totaltime/p); }</p><p>MPI_Finalize(); return 0; }</p><p>//Function for calculating the shortest path by each processor double calc_shortestpath() { int count,i; double dist=0,distance_calc,minimum,delta,c,a;</p><p> for(count=0;count<100;count++) { randomize(); distance_calc=calc_path(); if(distance_calc<min_distance) { min_distance=distance_calc; for(i=0;i<20;i++) { saved_city[i].x=city[i].x; saved_city[i].y=city[i].y; } }</p><p>}</p><p> return(min_distance); }</p><p>//Function for calculating the path for 1 iteration double calc_path() { int i; double dist=0; for(i=1;i<19;i++) dist+=sqrt(pow(city[i].x -city[i+1].x,2)+ pow(city[i].y - city[i+1].y,2));</p><p> dist+=sqrt(pow(city[0].x -city[1].x,2)+ pow(city[0].y - city[1].y,2)); dist+=sqrt(pow(city[0].x -city[19].x,2)+ pow(city[0].y - city[19].y,2)); return(dist); }</p><p>//Function for changing the cities selected for calculating the path void randomize() { int i,number,temp_x,temp_y; srand(my_rank*1000); for(i=1;i<20;i++) { number=rand()%19+1; temp_x=city[i].x; temp_y=city[i].y;</p><p> city[i].x=city[number].x; city[i].y=city[number].y;</p><p> city[number].x= temp_x; city[number].y= temp_y; } }</p><p>/*This is a function which each processor will execute for finding the shortest path,then send it to rank 0 processor for determining which processor calculated the shortest path and then broadcast this information to all other processors so that it can improve upon this path using the</p><p>Simulated Annealing Technique */ void calc_parallel() { int i,j,k,count,ranking,min_rank; double min_dist1proc=100000000,minimumbyprocs[8];</p><p> while (t>0.1)//&&(flag==0)) { min_dist1proc=calc_shortestpath();</p><p>//Send smallest distance calculated by each processor to rank 0 processor for(j=0;j<p;j++) if((my_rank==j)&&(my_rank!=0)) {</p><p>MPI_Send(&min_dist1proc,1,MPI_DOUBLE,0,j*10,MPI_COMM_WORLD);</p><p>MPI_Send(&j,1,MPI_INT,0,j*10,MPI_COMM_WORLD); }</p><p>/*Rank 0 processor determines which processor calculated the shortest distance and then sends this information to other processors*/ if(my_rank==0) { minimumbyprocs[0]=min_dist1proc; for(j=1;j<p;j++) {</p><p>MPI_Recv(&minimumbyprocs[j],1,MPI_DOUBLE,j,j*10,MPI_COMM_WORLD,&stat us);</p><p>MPI_Recv(&ranking,1,MPI_INT,j,j*10,MPI_COMM_WORLD,&status); }</p><p> smallest=1000000; for(count=0;count<p;count++) { if(minimumbyprocs[count]<smallest) { smallest=minimumbyprocs[count]; min_rank=count; } }</p><p> rankfrom0=min_rank;</p><p>/* if(smallest<13984) { flag=1; for(j=1;j<p;j++) {</p><p>MPI_Send(&flag,1,MPI_INT,j,j*50,MPI_COMM_WORLD); } }*/ }</p><p>/*for(j=1;j<p;j++) { if(my_rank==j) {</p><p>MPI_Recv(&flag,1,MPI_INT,0,j*50,MPI_COMM_WORLD,&status); // if(flag==1) return; } }*/</p><p> t=0.8*t; } }</p><p>RESULTS FOR SIMULATED ANNEALING:</p><p>TIMING(Simulated annealing)</p><p>0.19</p><p>0.17 0.1649 s</p><p> d 0.15 n o</p><p> c 0.13 e s</p><p>Series1 n</p><p> i 0.11</p><p> e 0.0976</p><p> m 0.09 i</p><p>T 0.079321 0.07 0.06417 0.05 1 2 4 8 Number of procs speed up (Simulated annealing)</p><p>1.7 1.5 1.5209 1.3 1.23 p u</p><p>1.1 d 1 Series1 e</p><p> e 0.9 p s 0.7 0.5918 0.5 0.3 1 2 4 8 time in secs</p><p>RESULTS FOR BRUTE FORCE TIMING(brute force)</p><p>0.19 0.18375 0.18 s d</p><p> n 0.17 0.1702 o c</p><p> e 0.16 s</p><p>0.155195 Series1</p><p> n 0.15 0.15012 i</p><p> e 0.14 m i T 0.13 0.12 1 2 4 8 Number of procs</p><p> speed up (brute force)</p><p>1.25 1.224 1.2 1.18 1.15</p><p> p 1.1 1.08 u 1.05 d Series1 e</p><p> e 1 1 p</p><p> s 0.95 0.9 0.85 0.8 1 2 4 8 time in secs</p><p>ANALYSIS: The method employed here for finding a optimum solution for the traveling salesman problem is SIMULATED ANNEALING.The methodology we have used here for calculating the speed up is that what distance we found out in the case of 1 processor ,using that as a reference we have evaluated the performance in case of more processors. Generally this method involves a lot of message passing, so it is useful mostly for the problems with large computation parameters .Since our algorithm is based on the calculation for the distances between the cities and then adding them up for getting the total path length, which involves a very less time for 20 cities. So computation time is very less as compared to that of the message passing involved.</p><p>Moreover the results reveal that since all the processors are running the whole process individually on each of them separately, so it might be the case that 2 or more processors may not be able to generate the minimum distance in less time as compared to that of 1 processor case. Because the results for more processors depends on just the random distribution for the cities, so this scenario is possible. This case is observed in case of 2 processors ,where the same distance path (13,984 miles)as that of 1 processor case was found by 2 processor case in more time. But fortunately when 4 or more processors are used, the random combinations for the path selected are more and thereafter the same distance path can be discovered in a relatively less time. But since down the line each of the processor is calculating the whole algorithm on it’s own so a very large speed up should not be expected as is evident from the result. </p><p>Where as the results obtained in case of brute force are as expected and the speed up curve is also obtained as is expected. In this all the possible combinations are tried for all the city paths.</p><p>------</p>

View Full Text

Details

  • File Type
    pdf
  • Upload Time
    -
  • Content Languages
    English
  • Upload User
    Anonymous/Not logged-in
  • File Pages
    18 Page
  • File Size
    -

Download

Channel Download Status
Express Download Enable

Copyright

We respect the copyrights and intellectual property rights of all users. All uploaded documents are either original works of the uploader or authorized works of the rightful owners.

  • Not to be reproduced or distributed without explicit permission.
  • Not used for commercial purposes outside of approved use cases.
  • Not used to infringe on the rights of the original creators.
  • If you believe any content infringes your copyright, please contact us immediately.

Support

For help with questions, suggestions, or problems, please contact us