benchmarks/JavaBenchmark.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Sat, 19 Jan 2013 23:54:47 +0000
branchrefactoring-vmdata
changeset 1986 9e63ab553922
parent 1818 2e5ed72e7dfd
child 2014 9fa66342102b
permissions -rw-r--r--
JavaNativeMethod & their implementation transformed to pass a reveiver. Java still does not boot at this point, some overloaded natives in sun,misc.Unsafe has to be fixed manually.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1761
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
     1
"
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
     2
 COPYRIGHT (c) 1996-2011 by Claus Gittinger
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
     3
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
     4
 New code and modifications done at SWING Research Group [1]:
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
     5
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
     6
 COPYRIGHT (c) 2010-2011 by Jan Vrany, Jan Kurs and Marcel Hlopko
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
     7
                            SWING Research Group, Czech Technical University in Prague
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
     8
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
     9
 This software is furnished under a license and may be used
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    10
 only in accordance with the terms of that license and with the
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    11
 inclusion of the above copyright notice.   This software may not
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    12
 be provided or otherwise made available to, or used by, any
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    13
 other person.  No title to or ownership of the software is
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    14
 hereby transferred.
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    15
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    16
 [1] Code written at SWING Research Group contains a signature
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    17
     of one of the above copright owners. For exact set of such code,
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    18
     see the differences between this version and version stx:libjava
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    19
     as of 1.9.2010
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    20
"
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    21
"{ Package: 'stx:libjava/benchmarks' }"
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    22
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    23
Object subclass:#JavaBenchmark
1788
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    24
	instanceVariableNames:'profiler'
1761
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    25
	classVariableNames:''
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    26
	poolDictionaries:''
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    27
	category:'Benchmarks-Java-Framework'
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    28
!
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    29
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    30
!JavaBenchmark class methodsFor:'documentation'!
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    31
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    32
copyright
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    33
"
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    34
 COPYRIGHT (c) 1996-2011 by Claus Gittinger
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    35
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    36
 New code and modifications done at SWING Research Group [1]:
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    37
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    38
 COPYRIGHT (c) 2010-2011 by Jan Vrany, Jan Kurs and Marcel Hlopko
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    39
                            SWING Research Group, Czech Technical University in Prague
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    40
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    41
 This software is furnished under a license and may be used
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    42
 only in accordance with the terms of that license and with the
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    43
 inclusion of the above copyright notice.   This software may not
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    44
 be provided or otherwise made available to, or used by, any
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    45
 other person.  No title to or ownership of the software is
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    46
 hereby transferred.
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    47
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    48
 [1] Code written at SWING Research Group contains a signature
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    49
     of one of the above copright owners. For exact set of such code,
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    50
     see the differences between this version and version stx:libjava
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    51
     as of 1.9.2010
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    52
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    53
"
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    54
! !
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    55
1788
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    56
!JavaBenchmark methodsFor:'accessing'!
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    57
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    58
profiler
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    59
    ^ profiler
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    60
!
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    61
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    62
profiler:something
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    63
    profiler := something.
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    64
! !
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    65
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    66
!JavaBenchmark methodsFor:'profiling'!
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    67
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    68
profileStart
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    69
    profiler == #callgrind ifTrue:[
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    70
        Profiler valgrind callgrindInstrumentationStart
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    71
    ].
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    72
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    73
    "Created: / 02-11-2012 / 02:28:33 / Jan Vrany <jan.vrany@fit.cvut.cz>"
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    74
!
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    75
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    76
profileStop
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    77
    profiler == #callgrind ifTrue:[
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    78
        Profiler valgrind callgrindInstrumentationStop
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    79
    ].
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    80
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    81
    "Created: / 02-11-2012 / 02:28:39 / Jan Vrany <jan.vrany@fit.cvut.cz>"
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    82
! !
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
    83
1761
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    84
!JavaBenchmark methodsFor:'running'!
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    85
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    86
runBenchmarkJ: n
1762
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
    87
    "Actually run a **Java** benchmark. Return time in milliseconds or
1761
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    88
     string 'N/A' if there is no Java equivalent of the benchmark"
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    89
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    90
    | bench |
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    91
1785
417582324c34 More refactoring, added warmup to JVM benchmarks
vranyj1
parents: 1783
diff changeset
    92
    bench := (Java classForName: 'stx.libjava.benchmarks.' , self class name).
1775
ce199ac67100 - PrimitiveArguments
vranyj1
parents: 1774
diff changeset
    93
ce199ac67100 - PrimitiveArguments
vranyj1
parents: 1774
diff changeset
    94
    ^(bench >> #'runBenchmarkJ(I)J')
1774
bacb7b00a664 - JavaBenchmark
vranyj1
parents: 1766
diff changeset
    95
        valueWithReceiver: bench arguments: (Array with: n)
1761
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    96
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
    97
    "Created: / 31-10-2012 / 10:31:03 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1774
bacb7b00a664 - JavaBenchmark
vranyj1
parents: 1766
diff changeset
    98
    "Modified: / 31-10-2012 / 21:42:34 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1775
ce199ac67100 - PrimitiveArguments
vranyj1
parents: 1774
diff changeset
    99
    "Modified (format): / 31-10-2012 / 22:52:15 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1762
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   100
!
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   101
1780
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   102
runBenchmarkS2J: n
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   103
    "Actually run a cross-language call variant of the benchmark
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   104
     (i.e., Smalltalk calling Java or vice versa). Return time in milliseconds or
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   105
     string 'N/A' if there is no cross-call equivalent of the benchmark"
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   106
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   107
    ^'N/A'
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   108
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   109
    "Created: / 31-10-2012 / 23:39:59 / Jan Vrany <jan.vrany@fit.cvut.cz>"
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   110
!
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   111
1762
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   112
runBenchmarkS:n 
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   113
    "Actually run a **Smalltalk** benchmark. Return time in milliseconds or
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   114
     string 'N/A' if there is no Smalltalk equivalent of the benchmark"
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   115
    
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   116
    ^ self subclassResponsibility
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   117
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   118
    "Created: / 31-10-2012 / 10:26:33 / Jan Vrany <jan.vrany@fit.cvut.cz>"
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   119
! !
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   120
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   121
!JavaBenchmark methodsFor:'running-API'!
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   122
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   123
runJ: passes
1783
a4fc9f4d958e Print statistics when after running Java code
vranyj1
parents: 1782
diff changeset
   124
    "Run **Java** version of the benchmark. Do the warmup"
a4fc9f4d958e Print statistics when after running Java code
vranyj1
parents: 1782
diff changeset
   125
a4fc9f4d958e Print statistics when after running Java code
vranyj1
parents: 1782
diff changeset
   126
    | time |
1762
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   127
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   128
    "Here, we have to do the warmup twice. First, to
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   129
     load all the Java code and an make sure methods
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   130
     are in oldspace (for ILCs), second to force resolve
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   131
     and machine-compile Java code"
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   132
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   133
    JavaVM booted ifFalse:[
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   134
        Java flushAllJavaResources.
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   135
        Java initialize.
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   136
        JavaVM initializeVM.
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   137
    ].
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   138
1781
feb3223a8ccd Warmup fixes
vranyj1
parents: 1780
diff changeset
   139
    self runBenchmarkJ: 2.
1762
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   140
    ObjectMemory scavenge.
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   141
    ObjectMemory tenure.
1782
d605b775f1f5 Warmup fixes
vranyj1
parents: 1781
diff changeset
   142
    self runBenchmarkJ: 2.
d605b775f1f5 Warmup fixes
vranyj1
parents: 1781
diff changeset
   143
1788
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
   144
    self profileStart.
1806
4468ee811835 More debugging support & comments
vranyj1
parents: 1790
diff changeset
   145
    ObjectMemory debugBreakPoint3.
1783
a4fc9f4d958e Print statistics when after running Java code
vranyj1
parents: 1782
diff changeset
   146
    time := self runBenchmarkJ: passes.
1788
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
   147
    self profileStop.
1783
a4fc9f4d958e Print statistics when after running Java code
vranyj1
parents: 1782
diff changeset
   148
    JavaVM performance printCountersOn: Stdout.
a4fc9f4d958e Print statistics when after running Java code
vranyj1
parents: 1782
diff changeset
   149
    ^time.
1762
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   150
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   151
    "Created: / 31-10-2012 / 11:15:41 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1811
e97e02d47e1e - JavaBenchmark
vranyj1
parents: 1806
diff changeset
   152
    "Modified: / 07-11-2012 / 20:41:01 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1762
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   153
!
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   154
1780
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   155
runS2J: passes
1783
a4fc9f4d958e Print statistics when after running Java code
vranyj1
parents: 1782
diff changeset
   156
    "Run **cross-language** version of the benchmark. Do the warmup"
a4fc9f4d958e Print statistics when after running Java code
vranyj1
parents: 1782
diff changeset
   157
a4fc9f4d958e Print statistics when after running Java code
vranyj1
parents: 1782
diff changeset
   158
    | time |
1780
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   159
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   160
    "Here, we have to do the warmup twice. First, to
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   161
     load all the Java code and an make sure methods
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   162
     are in oldspace (for ILCs), second to force resolve
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   163
     and machine-compile Java code"
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   164
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   165
    JavaVM booted ifFalse:[
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   166
        Java flushAllJavaResources.
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   167
        Java initialize.
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   168
        JavaVM initializeVM.
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   169
    ].
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   170
1781
feb3223a8ccd Warmup fixes
vranyj1
parents: 1780
diff changeset
   171
    self runBenchmarkS2J: 2.
1780
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   172
    ObjectMemory scavenge.
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   173
    ObjectMemory tenure.
1781
feb3223a8ccd Warmup fixes
vranyj1
parents: 1780
diff changeset
   174
    self runBenchmarkS2J: 2.
feb3223a8ccd Warmup fixes
vranyj1
parents: 1780
diff changeset
   175
1788
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
   176
    self profileStart.
1785
417582324c34 More refactoring, added warmup to JVM benchmarks
vranyj1
parents: 1783
diff changeset
   177
    time := self runBenchmarkS2J: passes.
1788
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
   178
    self profileStop.
1783
a4fc9f4d958e Print statistics when after running Java code
vranyj1
parents: 1782
diff changeset
   179
    JavaVM performance printCountersOn: Stdout.
a4fc9f4d958e Print statistics when after running Java code
vranyj1
parents: 1782
diff changeset
   180
    ^time.
a4fc9f4d958e Print statistics when after running Java code
vranyj1
parents: 1782
diff changeset
   181
1780
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   182
    "Created: / 31-10-2012 / 23:40:17 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1811
e97e02d47e1e - JavaBenchmark
vranyj1
parents: 1806
diff changeset
   183
    "Modified: / 07-11-2012 / 20:41:11 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1780
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   184
!
0539eae51568 - PrimitiveArguments
vranyj1
parents: 1775
diff changeset
   185
1762
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   186
runS: passes
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   187
    "Run **Smalltalk** version of the benchmark. Do the warmup"
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   188
1788
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
   189
    | time |
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
   190
1790
7415875de93d More results + fix for running Smalltalk benchmarks (JIT enabled)
vranyj1
parents: 1788
diff changeset
   191
    ObjectMemory justInTimeCompilation: true.
7415875de93d More results + fix for running Smalltalk benchmarks (JIT enabled)
vranyj1
parents: 1788
diff changeset
   192
    
1781
feb3223a8ccd Warmup fixes
vranyj1
parents: 1780
diff changeset
   193
    self runBenchmarkS: 2.
1762
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   194
    ObjectMemory scavenge.
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   195
    ObjectMemory tenure.
1781
feb3223a8ccd Warmup fixes
vranyj1
parents: 1780
diff changeset
   196
    self runBenchmarkS: 2.
1788
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
   197
    self profileStart.
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
   198
    time := self runBenchmarkS: passes.
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
   199
    self profileStop.
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
   200
    ^time
1762
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   201
d67be8cbec02 - JavaBenchmark
vranyj1
parents: 1761
diff changeset
   202
    "Created: / 31-10-2012 / 11:12:48 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1788
8ac0e8cdcb62 - JavaBenchmarkRunner
vranyj1
parents: 1785
diff changeset
   203
    "Modified: / 02-11-2012 / 02:31:10 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1761
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
   204
! !
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
   205
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
   206
!JavaBenchmark class methodsFor:'documentation'!
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
   207
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
   208
version_SVN
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
   209
    ^ '$Id::                                                                                                                        $'
dba3db31ea2a Initial port of benchmarks
vranyj1
parents:
diff changeset
   210
! !