# Merge Sort

### 1 collaborator

Uri Wilensky (Author)

### Tags

computer science

Tagged by Reuven M. Lerner over 10 years ago

Model group CCL | Visible to everyone | Changeable by group members (CCL)
Model was written in NetLogo 5.0.4 • Viewed 596 times • Downloaded 55 times • Run 0 times

## WHAT IS IT?

This model is a visual demonstration of a standard sort algorithm called merge sort. The algorithm reorders, or permutes, n numbers into ascending order. This is accomplished by dividing the numbers into groups and then merging smaller groups to form larger groups. Order is maintained as the lists are merged so when the algorithm finishes there is only one sorted list containing all n items.

Note that it is possible to express merge sort in NetLogo much more concisely than is done in this model. Since this model aims to demonstrate the sort algorithm visually, the code is more complex than would be needed if the model only needed to sort the numbers.

## HOW IT WORKS

We start out with as many independent groups as we have elements. As the algorithm progresses through the list, it merges each adjacent pair of groups; thus, after each pass, the number of groups is halved.

To merge two groups:

1. Compare the first elements of the two groups to each other
2. Place the smallest/largest element (depending on the increasing-order? switch) of the two in a third group
3. Remove that element from its source group
4. Repeat until one of the source groups is empty
5. Place all of the remaining elements from the non-empty source group onto the end of the third group
6. Substitute, in place, the third group for the two source groups

We do this merge repeatedly for each set of two groups until there is only one group left. This final group is the original set of numbers in sorted order.

The number of steps required to sort n items using this algorithm is the ceiling of logarithm (base 2) of n. Each step requires at most n comparisons between the numbers. Therefore, the time it takes for the algorithm to run is about n log n. Computer scientists often write this as O(n log n) where n is how many numbers are to be sorted.

## HOW TO USE IT

Change the value of the NUMBER-OF-ELEMENTS slider to modify how many numbers to sort.

Pressing SETUP creates NUMBER-OF-ELEMENTS random values to be sorted.

STEP (1 ITEM) merges one number into its new group.

STEP (1 ROW) does one full round of group merges.

## THINGS TO NOTICE

Groups are represented by color. Numbers in the same group have the same color. When two groups merge, the numbers take the color of the smallest/largest element in the new group. Can you predict what would be the final color of all elements before starting?

Would merging more than two groups at a time lead to the elements getting sorted in fewer steps? Would this change make the algorithm any faster?

## THINGS TO TRY

We stated above that the algorithm will take at most a constant factor times n log n time to execute. Can you figure out why the constant factor is needed to make this statement accurate?

## EXTENDING THE MODEL

Can you make the elements draw their paths across the view?

There are many different sorting algorithms. You can find a few described at http://en.wikipedia.org/wiki/Sorting_algorithm. Try implementing the different sorts in NetLogo and use BehaviorSpace to compare them. Do different sorts perform better with different input sets (uniformly random, nearly sorted, reverse sorted, etc.)?

## NETLOGO FEATURES

This model uses lists extensively.

Note that NetLogo includes SORT and SORT-BY primitives; normally, you would just use one of these, rather than implementing a sort algorithm yourself. SORT arranges items in ascending order; SORT-BY lets you specify how items are to be ordered.

## HOW TO CITE

If you mention this model in a publication, we ask that you include these citations for the model itself and for the NetLogo software:

• Wilensky, U. (2005). NetLogo Merge Sort model. http://ccl.northwestern.edu/netlogo/models/MergeSort. Center for Connected Learning and Computer-Based Modeling, Northwestern Institute on Complex Systems, Northwestern University, Evanston, IL.
• Wilensky, U. (1999). NetLogo. http://ccl.northwestern.edu/netlogo/. Center for Connected Learning and Computer-Based Modeling, Northwestern Institute on Complex Systems, Northwestern University, Evanston, IL.

Click to Run Model

```breed [ mergers merger ]
breed [ elements element ]

elements-own [ value ]
mergers-own [ merge-group ]
globals
[
group-count     ;; Number of groups (lists) of elements
group-list      ;; List of lists of elements
step-number     ;; Number of complete merge steps finished
current-loc     ;; Group position of next element to be drawn, used by single-sort
current-group   ;; Group number of next element to be drawn, used by single-sort
current-count   ;; Element number of next element to be drawn, used by single-sort
]

;;;;;;;;;;;;;;;;;;;;;;
;; Setup Procedures ;;
;;;;;;;;;;;;;;;;;;;;;;

to setup
ca
set current-count 1
set current-loc 0
set current-group 0
set step-number 0
set group-list []
set group-count number-of-elements
setup-elements
end

to setup-elements
set-default-shape turtles "circle"
create-elements number-of-elements
[
set size 5
set value (random (4 * number-of-elements))
;; (list self) creates a list with its sole item being the turtle itself
set group-list lput (list self) group-list
]
draw
end

;;;;;;;;;;;;;;;;;;;;;;;;
;; Runtime Procedures ;;
;;;;;;;;;;;;;;;;;;;;;;;;

;; Do one set of group merges.  That is, have each pair of neighboring groups merge.

to step-row
;; Finish displaying current step if need be
if (current-count > 1)
[
draw
set current-count 1
set current-loc 0
set current-group 0
stop
]
;; Stop if the first group contains all elements which means all elements
;; have been sorted.
if (length (item 0 group-list) = number-of-elements)
[ stop ]
set step-number (step-number + 1)
combine-groups
draw
end

;;;;;;;;;;;;;;;;;;;;;;;;
;; Merging Procedures ;;
;;;;;;;;;;;;;;;;;;;;;;;;

to combine-groups
let num 0
;; Create a merger for every two groups
;; Each merger will combine two groups
create-mergers (group-count / 2)
[
set merge-group num
set num (num + 2)
]
[
merge (item merge-group group-list) (item (merge-group + 1) group-list) merge-group
die
]
;; Remove empty groups (-1's) from our list
set group-list remove -1 group-list
set group-count length group-list
end

;; Merge lists 1 and 2 into one list, maintaining order

to merge [ list1 list2 location ] ;; mergers procedure
let new-list []
;; Sort the lists into new-list until either list1 or list2 is empty.
;; The groups are merged into increasing/decreasing order depending on
;; whether the increasing-order switch in on/off.
let item1 0
let item2 0
while [(not empty? list1) and (not empty? list2)]
[
set item1 item 0 list1
set item2 item 0 list2
ifelse ( [value] of item1 < [value] of item2 )
[
set new-list lput item1 new-list
set list1 but-first list1
]
[
set new-list lput item2 new-list
set list2 but-first list2
]
]
;; One of the lists is always going to be non-empty after the above loop.
;; Put the remainder of the non-empty list into new-list.
ifelse (empty? list1)
[ set new-list sentence new-list list2 ]
[ set new-list sentence new-list list1 ]
;; Copy the new-list into the appropriate location in group-list.
;; [(a+b) b c d] becomes [(a+b) -1 c d]
;; The -1's will be removed once the entire step is complete.
;; We do this instead of removing it here to keep order and length intact.
set group-list (replace-item location group-list new-list)
set group-list (replace-item (location + 1) group-list -1)
end

;;;;;;;;;;;;;;;;;;;;;;;;
;; Display Procedures ;;
;;;;;;;;;;;;;;;;;;;;;;;;

to step-item
;; If we have finished this round of sorting, reset our values
if (current-count > number-of-elements)
[
set current-count 1
set current-loc 0
set current-group 0
]
;; Do a round of sorting before we display if necessary
if (current-count = 1)
[
;; Stop if the first group contains all elements which means all elements
;; have been sorted.
if (length (item 0 group-list) = number-of-elements)  [stop]
set step-number (step-number + 1)
combine-groups
;; To display the step number.
ask patch (min-pxcor + 2) (max-pycor - 5 - (step-number * 10))
[set plabel-color green set plabel step-number]
]
;; Display the current element with its new position and color.
let tcolor [color] of first (item current-group group-list)
ask (item current-loc (item current-group group-list))
[
set pcolor color
set color tcolor
set ycor (max-pycor - 5 - (10 * step-number))
set xcor (min-pxcor + (current-count * ((2 * max-pxcor) / (number-of-elements + 1))))
ask patch-at 0 4 [set plabel-color white set plabel [value] of myself]
]
;; Update information about which turtle to display next
set current-count (current-count + 1)
ifelse(length (item current-group group-list) = (current-loc + 1))
[
set current-loc 0
set current-group (current-group + 1)
]
[ set current-loc (current-loc + 1) ]
end

;; Move the turtles to their appropriate locations

to draw
let list-loc 0
let element-num 1
;; Evenly space the elements across the view
let separation ((2 * max-pxcor) / (number-of-elements + 1))
;; To display the step number.
ask patch (min-pxcor + 2) (max-pycor - 5 - (step-number * 10))
[set plabel-color green set plabel step-number]
while [list-loc < group-count]
[
let current-list item list-loc group-list
let tcolor [color] of first current-list
while [not empty? current-list]
[
[
;; To keep track of what group an element belonged to before the current step,
;; we leave the color and display the value at it's previous place.
if (step-number != 0) [ set pcolor color]
set color tcolor
set ycor (max-pycor - 5 - (10 * step-number))
set xcor (min-pxcor + (element-num * separation))
ask patch-at 0 4 [set plabel-color white set plabel [value] of myself]
]
set element-num (element-num + 1)
set current-list but-first current-list
]
set list-loc (list-loc + 1)
]
end

```

There are 10 versions of this model.

Uri Wilensky almost 11 years ago Updated to NetLogo 5.0.4 Download this version
Uri Wilensky over 11 years ago Updated version tag Download this version
Uri Wilensky over 11 years ago Updated to version from NetLogo 5.0.3 distribution Download this version
Uri Wilensky over 13 years ago Updated from NetLogo 4.1 Download this version
Uri Wilensky over 13 years ago Updated from NetLogo 4.1 Download this version
Uri Wilensky over 13 years ago Updated from NetLogo 4.1 Download this version
Uri Wilensky over 13 years ago Updated from NetLogo 4.1 Download this version
Uri Wilensky over 13 years ago Model from NetLogo distribution Download this version