-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathsort.tcl
54 lines (41 loc) · 1.11 KB
/
sort.tcl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
# Timing of the view sort operation
package require Mk4tcl
proc timedRun {tag count args} {
set usec [lindex [time $args $count] 0]
append ::stats($tag) [format {%9.2f} [expr {$count*$usec/1000.0}]]
}
proc fill {seq} {
global warray
foreach {k v} [array get warray] {
mk::row append db.words text $k$seq
}
}
set step 40000
set mult 7
#set fd [open /usr/share/dict/words]
set fd [open words]
for {set i 0} {$i < $step && [gets $fd line] >= 0} {incr i} {
set warray($line) $i
}
close $fd
puts [clock format [clock seconds]]
file delete _large.mk
mk::file open db _large.mk -nocommit
mk::view layout db.words text
for {set i 0} {$i < $mult} {incr i} {
append stats(count) [format {%9d} [expr {($i+1)*$step}]]
timedRun fill 1 fill $i
timedRun sort 1 mk::select db.words -sort text
puts -nonewline stderr .
}
timedRun commit 1 mk::file commit db
puts stderr " [mk::view size db.words] rows, [file size _large.mk] b"
for {set i 0} {$i < 3} {incr i} {
puts " $i: [mk::get db.words!$i]"
}
mk::file close db
puts [clock format [clock seconds]]
puts ""
parray stats
puts ""
puts [clock format [clock seconds]]