mirror of
				https://github.com/ruby/ruby.git
				synced 2022-11-09 12:17:21 -05:00 
			
		
		
		
	mesurement time makes less accuracy. * benchmark/bm_app_factorial.rb: ditto. * benchmark/bm_app_mandelbrot.rb: ditto. * benchmark/bm_app_strconcat.rb: ditto. * benchmark/bm_io_file_create.rb: ditto. * benchmark/bm_io_file_read.rb: ditto. * benchmark/bm_io_file_write.rb: ditto. * benchmark/bm_so_concatenate.rb: ditto. * benchmark/bm_so_lists.rb: ditto. * benchmark/bm_so_matrix.rb: ditto. * benchmark/bm_so_random.rb: ditto. * benchmark/bm_so_sieve.rb: ditto. * benchmark/bm_vm_thread_mutex1.rb: ditto. * benchmark/bm_vm_thread_mutex2.rb: ditto. * benchmark/bm_vm_thread_mutex3.rb: ditto. * benchmark/bm_vm1_block.rb: cleanup. * benchmark/bm_vm1_const.rb: cleanup. * benchmark/bm_vm1_ensure.rb: cleanup. * benchmark/bm_vm1_ivar.rb: cleanup. * benchmark/bm_vm1_length.rb: cleanup. * benchmark/bm_vm1_neq.rb: cleanup. * benchmark/bm_vm1_not.rb: cleanup. * benchmark/bm_vm1_rescue.rb: cleanup. * benchmark/bm_vm1_simplereturn.rb: cleanup. * benchmark/bm_vm1_swap.rb: cleanup. * benchmark/bm_vm2_array.rb: cleanup. * benchmark/bm_vm2_case.rb: cleanup. * benchmark/bm_vm2_defined_method.rb: cleanup. * benchmark/bm_vm2_eval.rb: cleanup. * benchmark/bm_vm2_method.rb: cleanup. * benchmark/bm_vm2_mutex.rb: cleanup. * benchmark/bm_vm2_poly_method.rb: cleanup. * benchmark/bm_vm2_poly_method_ov.rb: cleanup. * benchmark/bm_vm2_proc.rb: cleanup. * benchmark/bm_vm2_regexp.rb: cleanup. * benchmark/bm_vm2_send.rb: cleanup. * benchmark/bm_vm2_super.rb: cleanup. * benchmark/bm_vm2_unif1.rb: cleanup. * benchmark/bm_vm2_zsuper.rb: cleanup. * benchmark/bm_vm_thread_alive_check1.rb: cleanup. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@32356 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
		
			
				
	
	
		
			47 lines
		
	
	
	
		
			999 B
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
	
		
			999 B
		
	
	
	
		
			Ruby
		
	
	
	
	
	
#from http://www.bagley.org/~doug/shootout/bench/lists/lists.ruby
 | 
						|
 | 
						|
NUM = 300
 | 
						|
SIZE = 10000
 | 
						|
 | 
						|
def test_lists()
 | 
						|
  # create a list of integers (Li1) from 1 to SIZE
 | 
						|
  li1 = (1..SIZE).to_a
 | 
						|
  # copy the list to li2 (not by individual items)
 | 
						|
  li2 = li1.dup
 | 
						|
  # remove each individual item from left side of li2 and
 | 
						|
  # append to right side of li3 (preserving order)
 | 
						|
  li3 = Array.new
 | 
						|
  while (not li2.empty?)
 | 
						|
    li3.push(li2.shift)
 | 
						|
  end
 | 
						|
  # li2 must now be empty
 | 
						|
  # remove each individual item from right side of li3 and
 | 
						|
  # append to right side of li2 (reversing list)
 | 
						|
  while (not li3.empty?)
 | 
						|
    li2.push(li3.pop)
 | 
						|
  end
 | 
						|
  # li3 must now be empty
 | 
						|
  # reverse li1 in place
 | 
						|
  li1.reverse!
 | 
						|
  # check that first item is now SIZE
 | 
						|
  if li1[0] != SIZE then
 | 
						|
    p "not SIZE"
 | 
						|
    0
 | 
						|
  else
 | 
						|
    # compare li1 and li2 for equality
 | 
						|
    if li1 != li2 then
 | 
						|
      return(0)
 | 
						|
    else
 | 
						|
      # return the length of the list
 | 
						|
      li1.length
 | 
						|
    end
 | 
						|
  end
 | 
						|
end
 | 
						|
 | 
						|
i = 0
 | 
						|
while i<NUM
 | 
						|
  i+=1
 | 
						|
  result = test_lists()
 | 
						|
end
 | 
						|
 | 
						|
result
 |