<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DZone Snippets: average code</title>
    <link>http://snippets.dzone.com/posts</link>
    <pubDate>Sat, 26 Jul 2008 20:25:05 GMT</pubDate>
    <description>DZone Snippets: average code</description>
    <item>
      <title>Weighted Mean</title>
      <link>http://snippets.dzone.com/posts/show/4613</link>
      <description>Weighted mean ( http://en.wikipedia.org/wiki/Mean#Weighted_arithmetic_mean )&lt;br /&gt;&lt;br /&gt;&lt;code&gt;&lt;br /&gt;class Array&lt;br /&gt;  #sum (and mean) found on http://snippets.dzone.com/posts/show/2161&lt;br /&gt;  def sum&lt;br /&gt;    inject( nil ) { |sum,x| sum ? sum + x.to_f : x.to_f }&lt;br /&gt;  end&lt;br /&gt;  &lt;br /&gt;  def mean&lt;br /&gt;    sum.to_f / size&lt;br /&gt;  end&lt;br /&gt;  &lt;br /&gt;  #http://en.wikipedia.org/wiki/Mean#Weighted_arithmetic_mean&lt;br /&gt;  def weighted_mean(weights_array)&lt;br /&gt;    raise "Each element of the array must have an accompanying weight.  Array length = #{self.size} versus Weights length = #{weights_array.size}" if weights_array.size != self.size&lt;br /&gt;    w_sum = weights_array.sum&lt;br /&gt;    w_prod = 0&lt;br /&gt;    self.each_index {|i| w_prod += self[i] * weights_array[i].to_f}&lt;br /&gt;    w_prod.to_f / w_sum.to_f&lt;br /&gt;  end&lt;br /&gt;end&lt;br /&gt;&lt;/code&gt;&lt;br /&gt;&lt;br /&gt;Example&lt;br /&gt;&lt;code&gt;&lt;br /&gt;&gt;&gt; a = [1,2,3]&lt;br /&gt;=&gt; [1, 2, 3]&lt;br /&gt;&gt;&gt; w = [1,1,1]&lt;br /&gt;=&gt; [1, 1, 1]&lt;br /&gt;&gt;&gt; a.weighted_arithmetic_mean(w)&lt;br /&gt;=&gt; 2.0&lt;br /&gt;&gt;&gt; a.mean&lt;br /&gt;=&gt; 2.0&lt;br /&gt;&gt;&gt; w = [5,2,1]&lt;br /&gt;=&gt; [5, 2, 1]&lt;br /&gt;&gt;&gt; a.weighted_arithmetic_mean(w)&lt;br /&gt;=&gt; 1.5&lt;br /&gt;&lt;/code&gt;</description>
      <pubDate>Wed, 03 Oct 2007 21:29:12 GMT</pubDate>
      <guid>http://snippets.dzone.com/posts/show/4613</guid>
      <author>wiseleyb (ben)</author>
    </item>
    <item>
      <title>Split String into roughly equal-sized chunks.</title>
      <link>http://snippets.dzone.com/posts/show/2631</link>
      <description>Split a string into an array of roughly equal sized chunks based on a string or regular expression delimiter.&lt;br /&gt;Delimiter is preserved in output.&lt;br /&gt;&lt;br /&gt;&lt;code&gt;&lt;br /&gt;class String&lt;br /&gt;  def chunk_string(average_segment_size = 40, sclice_on = /\s+/)&lt;br /&gt;    out = []&lt;br /&gt;    slices_estimate = self.size.divmod(average_segment_size)&lt;br /&gt;    slice_count = (slices_estimate[1] &gt; 0 ? slices_estimate[0] + 1 : slices_estimate[0])&lt;br /&gt;    slice_guess = self.size / slice_count&lt;br /&gt;    previous_slice_location = 0&lt;br /&gt;    (1..slice_count - 1).each do&lt;br /&gt;      |i|&lt;br /&gt;      slice_location = self.nearest_split(slice_guess * i, sclice_on)&lt;br /&gt;      out &lt;&lt; self.slice(previous_slice_location..slice_location)&lt;br /&gt;      previous_slice_location = slice_location + 1&lt;br /&gt;    end&lt;br /&gt;    out &lt;&lt; self.slice(previous_slice_location..self.size)&lt;br /&gt;    out&lt;br /&gt;  end&lt;br /&gt;&lt;br /&gt;  def nearest_split(slice_start, slice_on)&lt;br /&gt;    left_scan_location  = (self.slice(0..slice_start).rindex(slice_on)).to_i&lt;br /&gt;    right_scan_location = (self.slice((slice_start+1)..self.size).index(slice_on)).to_i + slice_start&lt;br /&gt;    ((slice_start - left_scan_location) &lt; (right_scan_location - slice_start) ? left_scan_location : right_scan_location)&lt;br /&gt;  end&lt;br /&gt;end&lt;br /&gt;&lt;/code&gt;</description>
      <pubDate>Thu, 21 Sep 2006 00:29:28 GMT</pubDate>
      <guid>http://snippets.dzone.com/posts/show/2631</guid>
      <author>duncanbeevers (Duncan Beevers)</author>
    </item>
  </channel>
</rss>
