Truck routing
Model was written in NetLogo 5.0
•
Viewed 628 times
•
Downloaded 34 times
•
Run 0 times
Do you have questions or comments about this model? Ask them here! (You'll first need to log in.)
Info tab cannot be displayed because of an encoding error
Comments and Questions
Please start the discussion about this model!
(You'll first need to log in.)
Click to Run Model
extensions [ gis table] globals [ cities-dataset countries-dataset arr_e] breed [cities city] breed [trucks truck] patches-own [population country-name] cities-own [key name pop] to setup file-close-all ca set arr_e [] set-default-shape trucks "truck" ; Load all of our datasets set cities-dataset gis:load-dataset "USCAN/cities.shp" set countries-dataset gis:load-dataset "USCAN/countries.shp" gis:set-world-envelope (gis:envelope-union-of (gis:envelope-of cities-dataset) (gis:envelope-of countries-dataset)) display-countries create-towns end to create-towns foreach gis:feature-list-of cities-dataset [ let location gis:location-of (first (first (gis:vertex-lists-of ?))) if not empty? location [ create-cities 1 [ set xcor item 0 location set ycor item 1 location set size 2 set shape "pentagon" set color black if label-cities [set label gis:property-value ? "NAME"] set key gis:property-value ? "KEY" set name gis:property-value ? "NAME" set pop gis:property-value ? "POPULATION" ] ] ] end to create-electric-network ask turtles [create-links-with other turtles] set arr_e [] ask links [set hidden? true] let l [] foreach [self] of links [ set l lput ([link-length] of ?) l] set l sort l ;first pair ask first([self] of links with [link-length = first(l)]) [set color 25 set hidden? false set thickness 0.3 let e1 [who] of end1 let e2 [who] of end2 let tempar [] set tempar lput e1 tempar set tempar lput e2 tempar set arr_e lput tempar arr_e] set l remove-item 0 l while [length(l) > 0] [ let li first([self] of links with [link-length = first(l)]) let e1 [who] of [end1] of li let e2 [who] of [end2] of li let i 0 let flag 0 let p1 -1 let p2 -1 while [i < length(arr_e)] [ if (member? e1 item i arr_e) [set p1 i] if (member? e2 item i arr_e) [set p2 i] set i i + 1] let case 0 while [flag = 0] [ let tempar [] if p1 != -1 and p1 = p2 [ ;Case1: Both belong to the same array set case 1 set flag 2] if p1 = -1 and p1 = p2 [ ;Case2: Nobody belongs set tempar lput e1 tempar set tempar lput e2 tempar set arr_e lput tempar arr_e set case 2 set flag 1] if p1 != -1 and p2 = -1 [ ;Case 3: Only e1 exists in one group set tempar item p1 arr_e set arr_e remove tempar arr_e set tempar lput e2 tempar set arr_e lput tempar arr_e set case 3 set flag 1] if p1 = -1 and p2 != -1 [ ;Case 4: Only e2 exists in one group set tempar item p2 arr_e set arr_e remove tempar arr_e set tempar lput e1 tempar set arr_e lput tempar arr_e set case 4 set flag 1] if p1 != -1 and p2 != -1 and flag = 0 [ ;Case 5: Both already belong to different groups let g1 item p1 arr_e let g2 item p2 arr_e set tempar sentence g1 g2 set arr_e remove g1 arr_e set arr_e remove g2 arr_e set arr_e lput tempar arr_e set case 5 set flag 1] ] if flag = 1 [ask li [ set color 25 set hidden? false set thickness 0.3 ] ;print (word "ADD link" li ". Case " case) ;show arr_e ] set l remove-item 0 l ] set arr_e remove-duplicates arr_e ;show arr_e ask links with [hidden? = true] [die] end ; Drawing polygon data from a shapefile, and optionally loading some ; of the data into turtles, if label-countries is true to display-countries gis:set-drawing-color white gis:draw countries-dataset 1 gis:apply-coverage countries-dataset "CNTRY_NAME" country-name ask patches [ ifelse country-name = "United States" [set pcolor 135] [ifelse country-name = "Canada" [set pcolor 64] [set pcolor 88]] ] end to import-road-network let dest [] file-open "Road.txt" let l file-read-characters 1 let i 1 while [i <= count(turtles)] [ set dest lput(file-read) dest set i i + 1] set i 1 let j 1 while [i <= length(dest)] [ set j 1 while [j <= length(dest)] [ if j = 1 [set l file-read] let value file-read let fro item (i - 1) dest let too item (j - 1) dest if value != 0 [;print (word "From " fro " to " too) ask cities with [key = fro] [create-link-with one-of (cities with [key = too])] ] set j j + 1] set i i + 1] file-close end to-report dijkstra let tempar [] ask turtle Origin [ let r [] let distan [] let l sort([who] of other turtles) let from_array l let index table:make let t 0 while [t < length(l)] [ set r lput([]) r set distan lput 999999 distan table:put index (item t l) (position (item t l) l) set t t + 1] ;First turn let next_index [] let j 0 while [j < length(l)] [ let de item j l if is-link? link who de [let dd 0 set next_index lput(de) next_index ask link who de [set dd link-length] let temproute item j r set temproute lput de temproute set r replace-item j r temproute set distan replace-item j distan dd] set j j + 1] while [length(from_array) > 0] [ foreach next_index [ let temp_from ? let posic_orig table:get index temp_from let k 0 while [k < length(from_array)] [ let temp_dest item k from_array if temp_dest != temp_from [ if is-link? link temp_dest temp_from [ let dd 0 ask link temp_dest temp_from [set dd link-length] let posic_dest table:get index temp_dest if item posic_dest distan > (dd + item posic_orig distan) [ set distan replace-item posic_dest distan (dd + item posic_orig distan) let temp_route (item posic_orig r) set temp_route lput(temp_dest) temp_route set r replace-item posic_dest r temp_route] ]] set k k + 1] set from_array remove temp_from from_array] set next_index [] let i 0 while [i < length(r)] [ if item i r != [] and member? (item i l) from_array [set next_index lput(item i l) next_index] set i i + 1]] let final_route item (table:get index Destin) r set final_route fput(Origin) final_route let total_distance item (table:get index Destin) distan set tempar lput final_route tempar set tempar lput total_distance tempar] report tempar end to create-shortest-path ask turtles [set color 85] ask links [ set color gray set thickness 0] if Origin = Destin [user-message "Please select two different nodes" stop] ask turtle Origin [set color Red] ask turtle Destin [set color Red] let tempar dijkstra let final_route item 0 dijkstra let total_distance item 1 dijkstra print (word "The shortest path between Origin and Destination nodes is " final_route " for " total_distance) let i 0 while [i < length(final_route) - 1] [ if (item (i + 1) final_route) != Destin [ask turtle (item (i + 1) final_route) [set color 27]] ask link (item i final_route) (item (i + 1) final_route) [ set color red set thickness 0.3] set i i + 1] end to send-truck ask trucks [die] ask turtles [set color black set size 2 set label ""] ask links [ set color gray set thickness 0] if Origin = Destin [user-message "Please select two different nodes" stop] ask turtle Origin [set color Red set size 3 set label Name] ask turtle Destin [set color Red set size 3 set label Name] let tempar dijkstra let final_route item 0 dijkstra let total_distance item 1 dijkstra let fr_name [] foreach final_route [set fr_name lput([Name] of turtle ?) fr_name] print "The shortest path between Origin and Destination nodes is " print fr_name print (word "with a total distance of " (total_distance * 86.5671974577573) " km") let i 0 while [i < length(final_route) - 1] [ if (item (i + 1) final_route) != Destin [ask turtle (item (i + 1) final_route) [set color 27 set label Name]] ask link (item i final_route) (item (i + 1) final_route) [ set color red set thickness 0.3] set i i + 1] create-trucks 1 [ set xcor [xcor] of city Origin set ycor [ycor] of city Origin set size 3 set color blue set label (word "Truck " who) set label-color 25] let c0 first([who] of trucks) watch truck c0 set i 0 while [i < length(final_route) - 1] [ let c1 item (i + 1) final_route move-from-to c0 c1 speed set i i + 1] reset-perspective end to reset-labels ask cities [set color black set size 2 set label Name] ask links [set color gray] end to move-from-to [a b c] ; from turtle a ==> to turtle b, with speed c ask turtle a [set heading towards turtle b] let coordfrom [] let coordto [] set coordfrom lput([xcor] of turtle a) coordfrom set coordfrom lput([ycor] of turtle a) coordfrom set coordto lput([xcor] of turtle b) coordto set coordto lput([ycor] of turtle b) coordto let stepx ((item 0 coordfrom) - (item 0 coordto)) / 20 let stepy ((item 1 coordfrom) - (item 1 coordto)) / 20 while [(abs((item 0 coordfrom) - (item 0 coordto)) > 0.5) or (abs((item 1 coordfrom) - (item 1 coordto)) > 0.5)] [ask turtle a [set xcor (xcor - stepx) set ycor (ycor - stepy) wait (1 / c)] set coordfrom replace-item 0 coordfrom ([xcor] of turtle a) set coordfrom replace-item 1 coordfrom ([ycor] of turtle a) ] end
There is only one version of this model, created over 10 years ago by Alvaro Gil.
Attached files
File | Type | Description | Last updated | |
---|---|---|---|---|
Mod5-6-GIS.zip | extension | Model, extensions and data | over 10 years ago, by Alvaro Gil | Download |
Truck routing.png | preview | Preview for 'Truck routing' | over 10 years ago, by Alvaro Gil | Download |
This model does not have any ancestors.
This model does not have any descendants.