nashorn/test/lib/benchmark.js
author bpittore
Fri, 07 Feb 2014 14:47:04 -0500
changeset 23477 6c2348280d09
parent 16151 97c1e756ae1e
child 24778 2ff5d7041566
permissions -rw-r--r--
Merge
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     1
/*
16151
97c1e756ae1e 8005663: Update copyright year to 2013
jlaskey
parents: 16147
diff changeset
     2
 * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved.
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     4
 * 
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     7
 * published by the Free Software Foundation.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     8
 * 
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    13
 * accompanied this code).
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    14
 * 
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    18
 * 
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    21
 * questions.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    22
 */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    23
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    24
/**
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    25
 * A simple benchmark module that can be loaded
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    26
 * in order to time how many times a method executes
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    27
 * in a fixed number of seconds
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    28
 */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    29
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    30
var benchmark = function(method, timeInMillis, args) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    31
    var hz,
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    32
    period,
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    33
    startTime = new Date,
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    34
    runs = 0;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    35
    do {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    36
	method.apply(args);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    37
	runs++;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    38
	totalTime = new Date - startTime;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    39
    } while (totalTime < timeInMillis);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    40
    
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    41
    // convert ms to seconds
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    42
    totalTime /= 1000;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    43
    
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    44
    // period → how long per operation
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    45
    period = totalTime / runs;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    46
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    47
    // hz → the number of operations per second
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    48
    hz = 1 / period;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    49
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    50
    return hz;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    51
};
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    52