<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Re: How to calculate a ratio by field value? in Splunk Search</title>
    <link>https://community.splunk.com/t5/Splunk-Search/How-to-calculate-a-ratio-by-field-value/m-p/571434#M199132</link>
    <description>&lt;P&gt;Once you have the 0 and 1 counts, all you need is an &lt;FONT face="courier new,courier"&gt;eval&lt;/FONT&gt; to calculate their ratio.&amp;nbsp; Because there are many sets of counts to evaluate, we'll use &lt;FONT face="courier new,courier"&gt;foreach&lt;/FONT&gt; to loop through them.&lt;/P&gt;&lt;LI-CODE lang="markup"&gt;index=SOME_INDEX sourcetype=SOME_SOURCETYPE code
| eval counterCode0{name} = if(code=0, 1, 0)
| eval counterCode1{name} = if(code=1, 1, 0)
| bin _time span=1m
| stats sum(counterCode0*), sum(counterCode1*) by _time
| foreach counterCode0* [ eval CounterRatio&amp;lt;&amp;lt;MATCHSTR&amp;gt;&amp;gt;=counterCode0&amp;lt;&amp;lt;MATCHSTR&amp;gt;&amp;gt;/counterCode1&amp;lt;&amp;lt;MATCHSTR&amp;gt;&amp;gt; ]&lt;/LI-CODE&gt;&lt;P&gt;Feel free to modify the logic to get the desired ratio and to handle possible division by zero.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
    <pubDate>Tue, 19 Oct 2021 00:26:14 GMT</pubDate>
    <dc:creator>richgalloway</dc:creator>
    <dc:date>2021-10-19T00:26:14Z</dc:date>
    <item>
      <title>How to calculate a ratio by field value?</title>
      <link>https://community.splunk.com/t5/Splunk-Search/How-to-calculate-a-ratio-by-field-value/m-p/571426#M199126</link>
      <description>&lt;P&gt;I have some data like the following:&lt;/P&gt;&lt;TABLE border="1" width="44.443129208754215%"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD width="33.333333333333336%"&gt;NAME&lt;/TD&gt;&lt;TD width="33.333333333333336%"&gt;Code&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD width="33.333333333333336%"&gt;Suzy&lt;/TD&gt;&lt;TD width="33.333333333333336%"&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD width="33.333333333333336%"&gt;John&lt;/TD&gt;&lt;TD width="33.333333333333336%"&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD width="33.333333333333336%"&gt;Adam&lt;/TD&gt;&lt;TD width="33.333333333333336%"&gt;1&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD width="33.333333333333336%"&gt;Suzy&lt;/TD&gt;&lt;TD width="33.333333333333336%"&gt;1&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD width="33.333333333333336%"&gt;John&lt;/TD&gt;&lt;TD width="33.333333333333336%"&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD width="33.333333333333336%"&gt;Adam&lt;/TD&gt;&lt;TD width="33.333333333333336%"&gt;1&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I am trying to calculate the ratio of code=1 to code=0, by Name, and display these ratios by hour. The name values are dynamic and unknown at query time.&lt;/P&gt;&lt;P&gt;I can get halfway there, using a dynamic eval field name, like this:&lt;/P&gt;&lt;PRE&gt;index=SOME_INDEX sourcetype=SOME_SOURCETYPE code&lt;BR /&gt;| eval counterCode0{name} = if(code=0, 1, 0)&lt;BR /&gt;| eval counterCode1{name} = if(code=1, 1, 0)&lt;BR /&gt;| bin _time span=1m&lt;BR /&gt;| stats sum(counterCode0*), sum(counterCode1*) by _time&lt;/PRE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;But I can't figure out how to get the ratios of counterCode1* to counterCode0*. Any ideas? Or do I need to approach this problem differently?&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Mon, 18 Oct 2021 22:58:38 GMT</pubDate>
      <guid>https://community.splunk.com/t5/Splunk-Search/How-to-calculate-a-ratio-by-field-value/m-p/571426#M199126</guid>
      <dc:creator>splunkuserCA1</dc:creator>
      <dc:date>2021-10-18T22:58:38Z</dc:date>
    </item>
    <item>
      <title>Re: How to calculate a ratio by field value?</title>
      <link>https://community.splunk.com/t5/Splunk-Search/How-to-calculate-a-ratio-by-field-value/m-p/571433#M199131</link>
      <description>&lt;P&gt;I think I found a solution:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;PRE&gt;index=SOME_INDEX sourcetype=SOME_SOURCETYPE code&lt;BR /&gt;| eval counterCode0 = if(code=0, 1, 0)&lt;BR /&gt;| eval counterCode1 = if(code=1, 1, 0)&lt;BR /&gt;| bin _time span=1m&lt;BR /&gt;| stats sum(counterCode0) as sumCode0, sum (counterCode1) as sumCode1 by _time, name&lt;BR /&gt;| eval ratio=sumCode1/sumCode0&lt;BR /&gt;| sort _time&amp;nbsp;&lt;/PRE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Perhaps using the &lt;STRONG&gt;eval counterCode0{name}=...&lt;/STRONG&gt; construct was making a solution too complicated. Still, if anyone knows how solve the problem using that method, please let me know!&lt;/P&gt;</description>
      <pubDate>Tue, 19 Oct 2021 00:17:03 GMT</pubDate>
      <guid>https://community.splunk.com/t5/Splunk-Search/How-to-calculate-a-ratio-by-field-value/m-p/571433#M199131</guid>
      <dc:creator>splunkuserCA1</dc:creator>
      <dc:date>2021-10-19T00:17:03Z</dc:date>
    </item>
    <item>
      <title>Re: How to calculate a ratio by field value?</title>
      <link>https://community.splunk.com/t5/Splunk-Search/How-to-calculate-a-ratio-by-field-value/m-p/571434#M199132</link>
      <description>&lt;P&gt;Once you have the 0 and 1 counts, all you need is an &lt;FONT face="courier new,courier"&gt;eval&lt;/FONT&gt; to calculate their ratio.&amp;nbsp; Because there are many sets of counts to evaluate, we'll use &lt;FONT face="courier new,courier"&gt;foreach&lt;/FONT&gt; to loop through them.&lt;/P&gt;&lt;LI-CODE lang="markup"&gt;index=SOME_INDEX sourcetype=SOME_SOURCETYPE code
| eval counterCode0{name} = if(code=0, 1, 0)
| eval counterCode1{name} = if(code=1, 1, 0)
| bin _time span=1m
| stats sum(counterCode0*), sum(counterCode1*) by _time
| foreach counterCode0* [ eval CounterRatio&amp;lt;&amp;lt;MATCHSTR&amp;gt;&amp;gt;=counterCode0&amp;lt;&amp;lt;MATCHSTR&amp;gt;&amp;gt;/counterCode1&amp;lt;&amp;lt;MATCHSTR&amp;gt;&amp;gt; ]&lt;/LI-CODE&gt;&lt;P&gt;Feel free to modify the logic to get the desired ratio and to handle possible division by zero.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Tue, 19 Oct 2021 00:26:14 GMT</pubDate>
      <guid>https://community.splunk.com/t5/Splunk-Search/How-to-calculate-a-ratio-by-field-value/m-p/571434#M199132</guid>
      <dc:creator>richgalloway</dc:creator>
      <dc:date>2021-10-19T00:26:14Z</dc:date>
    </item>
    <item>
      <title>Re: How to calculate a ratio by field value?</title>
      <link>https://community.splunk.com/t5/Splunk-Search/How-to-calculate-a-ratio-by-field-value/m-p/571546#M199164</link>
      <description>&lt;P&gt;That led me to the solution! Thanks. Ultimately, I had to do some more syntactical gymnastics:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;1) My "name" field had some special chars that I had to remove. Otherwise, I'd get an error message like "&lt;SPAN&gt;Failed to parse templatized search for field...":&lt;/SPAN&gt;&lt;/P&gt;&lt;PRE&gt;&lt;SPAN&gt;| eval newName=replace(name,"[']","")&lt;/SPAN&gt;&lt;/PRE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;2) For whatever reason, the "foreach" syntax provided did not work in the inner "eval" when trying to include the "counterCode1" values. Instead, I had to use this garish syntax - MATCHSEG2 worked better for me:&lt;/P&gt;&lt;PRE&gt;| foreach sum*counterCode0* [ eval CounterRatio&amp;lt;&amp;lt;MATCHSTR&amp;gt;&amp;gt;='&amp;lt;&amp;lt;FIELD&amp;gt;&amp;gt;' / 'sum(counterCode1&amp;lt;&amp;lt;MATCHSEG2&amp;gt;&amp;gt;' ]&lt;/PRE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Tue, 19 Oct 2021 19:00:12 GMT</pubDate>
      <guid>https://community.splunk.com/t5/Splunk-Search/How-to-calculate-a-ratio-by-field-value/m-p/571546#M199164</guid>
      <dc:creator>splunkuserCA1</dc:creator>
      <dc:date>2021-10-19T19:00:12Z</dc:date>
    </item>
  </channel>
</rss>

