Result.cc revision 10447
110447Snilay@cs.wisc.edu#include "util/Result.h"
210447Snilay@cs.wisc.edu
310447Snilay@cs.wisc.edu#include <iostream>
410447Snilay@cs.wisc.edu
510447Snilay@cs.wisc.edu#include "libutil/Log.h"
610447Snilay@cs.wisc.edu#include "libutil/Assert.h"
710447Snilay@cs.wisc.edu
810447Snilay@cs.wisc.edunamespace DSENT
910447Snilay@cs.wisc.edu{
1010447Snilay@cs.wisc.edu    using std::ostream;
1110447Snilay@cs.wisc.edu    using std::endl;
1210447Snilay@cs.wisc.edu
1310447Snilay@cs.wisc.edu    Result::SubResult::SubResult(const Result* sub_result_, const String& producer_, double num_results_)
1410447Snilay@cs.wisc.edu        : m_result_(sub_result_), m_producer_(producer_), m_num_results_(num_results_)
1510447Snilay@cs.wisc.edu    {
1610447Snilay@cs.wisc.edu        // Check if the result is not a null pointer
1710447Snilay@cs.wisc.edu        ASSERT((sub_result_ != NULL), "Internal error: sub_result_ is null");
1810447Snilay@cs.wisc.edu
1910447Snilay@cs.wisc.edu        // Check if the number of results greater than 0
2010447Snilay@cs.wisc.edu        ASSERT((num_results_ >= 0), "Internal error: num_results_ (" + String(num_results_) + ") is less than 0");
2110447Snilay@cs.wisc.edu    }
2210447Snilay@cs.wisc.edu
2310447Snilay@cs.wisc.edu    Result::SubResult::~SubResult()
2410447Snilay@cs.wisc.edu    {}
2510447Snilay@cs.wisc.edu
2610447Snilay@cs.wisc.edu    const Result* Result::SubResult::getResult() const
2710447Snilay@cs.wisc.edu    {
2810447Snilay@cs.wisc.edu        return m_result_;
2910447Snilay@cs.wisc.edu    }
3010447Snilay@cs.wisc.edu
3110447Snilay@cs.wisc.edu    const String& Result::SubResult::getProducer() const
3210447Snilay@cs.wisc.edu    {
3310447Snilay@cs.wisc.edu        return m_producer_;
3410447Snilay@cs.wisc.edu    }
3510447Snilay@cs.wisc.edu
3610447Snilay@cs.wisc.edu    double Result::SubResult::getNumResults() const
3710447Snilay@cs.wisc.edu    {
3810447Snilay@cs.wisc.edu        return m_num_results_;
3910447Snilay@cs.wisc.edu    }
4010447Snilay@cs.wisc.edu
4110447Snilay@cs.wisc.edu    Result::SubResult* Result::SubResult::clone() const
4210447Snilay@cs.wisc.edu    {
4310447Snilay@cs.wisc.edu        return new SubResult(*this);
4410447Snilay@cs.wisc.edu    }
4510447Snilay@cs.wisc.edu
4610447Snilay@cs.wisc.edu    Result::SubResult::SubResult(const SubResult& sub_result_)
4710447Snilay@cs.wisc.edu        : m_result_(sub_result_.m_result_), m_producer_(sub_result_.m_producer_), m_num_results_(sub_result_.m_num_results_)
4810447Snilay@cs.wisc.edu    {}
4910447Snilay@cs.wisc.edu
5010447Snilay@cs.wisc.edu    Result::Result()
5110447Snilay@cs.wisc.edu    {}
5210447Snilay@cs.wisc.edu
5310447Snilay@cs.wisc.edu    Result::Result(const String& result_name_)
5410447Snilay@cs.wisc.edu        : m_result_name_(result_name_)
5510447Snilay@cs.wisc.edu    {}
5610447Snilay@cs.wisc.edu
5710447Snilay@cs.wisc.edu    Result::~Result()
5810447Snilay@cs.wisc.edu    {
5910447Snilay@cs.wisc.edu        // Clear all sub results
6010447Snilay@cs.wisc.edu        for(vector<SubResult*>::iterator it = m_sub_results_.begin();
6110447Snilay@cs.wisc.edu            it != m_sub_results_.end(); ++it)
6210447Snilay@cs.wisc.edu        {
6310447Snilay@cs.wisc.edu            SubResult* sub_result = (*it);
6410447Snilay@cs.wisc.edu            delete sub_result;
6510447Snilay@cs.wisc.edu        }
6610447Snilay@cs.wisc.edu    }
6710447Snilay@cs.wisc.edu
6810447Snilay@cs.wisc.edu    const String& Result::getName() const
6910447Snilay@cs.wisc.edu    {
7010447Snilay@cs.wisc.edu        return m_result_name_;
7110447Snilay@cs.wisc.edu    }
7210447Snilay@cs.wisc.edu
7310447Snilay@cs.wisc.edu    void Result::setValue(double /* value_ */)
7410447Snilay@cs.wisc.edu    {
7510447Snilay@cs.wisc.edu        throw LibUtil::Exception("[Error] " + getName() + " -> Cannot set the value of a non-atomic result!");
7610447Snilay@cs.wisc.edu        return;
7710447Snilay@cs.wisc.edu    }
7810447Snilay@cs.wisc.edu
7910447Snilay@cs.wisc.edu    void Result::addValue(double /* value_ */)
8010447Snilay@cs.wisc.edu    {
8110447Snilay@cs.wisc.edu        throw LibUtil::Exception("[Error] " + getName() +
8210447Snilay@cs.wisc.edu                " -> Cannot add the value of a non-atomic result");
8310447Snilay@cs.wisc.edu        return;
8410447Snilay@cs.wisc.edu    }
8510447Snilay@cs.wisc.edu
8610447Snilay@cs.wisc.edu    double Result::getValue() const
8710447Snilay@cs.wisc.edu    {
8810447Snilay@cs.wisc.edu        throw LibUtil::Exception("[Error] " + getName() + " -> Cannot get the value of a non-atomic result!");
8910447Snilay@cs.wisc.edu        return 0.0;
9010447Snilay@cs.wisc.edu    }
9110447Snilay@cs.wisc.edu
9210447Snilay@cs.wisc.edu    void Result::addSubResult(const Result* sub_result_, const String& result_producer_, double num_results_)
9310447Snilay@cs.wisc.edu    {
9410447Snilay@cs.wisc.edu        SubResult* new_sub_result = new SubResult(sub_result_, result_producer_, num_results_);
9510447Snilay@cs.wisc.edu        m_sub_results_.push_back(new_sub_result);
9610447Snilay@cs.wisc.edu        return;
9710447Snilay@cs.wisc.edu    }
9810447Snilay@cs.wisc.edu
9910447Snilay@cs.wisc.edu    void Result::removeAllSubResults()
10010447Snilay@cs.wisc.edu    {
10110447Snilay@cs.wisc.edu        // Clear all sub results
10210447Snilay@cs.wisc.edu        for(vector<SubResult*>::iterator it = m_sub_results_.begin();
10310447Snilay@cs.wisc.edu            it != m_sub_results_.end(); ++it)
10410447Snilay@cs.wisc.edu        {
10510447Snilay@cs.wisc.edu            SubResult* sub_result = (*it);
10610447Snilay@cs.wisc.edu            delete sub_result;
10710447Snilay@cs.wisc.edu        }
10810447Snilay@cs.wisc.edu        m_sub_results_.clear();
10910447Snilay@cs.wisc.edu        return;
11010447Snilay@cs.wisc.edu    }
11110447Snilay@cs.wisc.edu
11210447Snilay@cs.wisc.edu    double Result::calculateSum() const
11310447Snilay@cs.wisc.edu    {
11410447Snilay@cs.wisc.edu        double sum = 0.0;
11510447Snilay@cs.wisc.edu
11610447Snilay@cs.wisc.edu        // Loop through all sub results and calculate the sum
11710447Snilay@cs.wisc.edu        for(vector<SubResult*>::const_iterator it = m_sub_results_.begin();
11810447Snilay@cs.wisc.edu            it != m_sub_results_.end(); ++it)
11910447Snilay@cs.wisc.edu        {
12010447Snilay@cs.wisc.edu            const SubResult* temp_sub_result = (*it);
12110447Snilay@cs.wisc.edu            const Result* temp_result = temp_sub_result->getResult();
12210447Snilay@cs.wisc.edu            double num_results = temp_sub_result->getNumResults();
12310447Snilay@cs.wisc.edu            sum += temp_result->calculateSum()*num_results;
12410447Snilay@cs.wisc.edu        }
12510447Snilay@cs.wisc.edu        return sum;
12610447Snilay@cs.wisc.edu    }
12710447Snilay@cs.wisc.edu
12810447Snilay@cs.wisc.edu    void Result::print(const String& prepend_str_, int detail_level_, ostream& ost_) const
12910447Snilay@cs.wisc.edu    {
13010447Snilay@cs.wisc.edu        print(prepend_str_, 1.0, detail_level_, ost_);
13110447Snilay@cs.wisc.edu        return;
13210447Snilay@cs.wisc.edu    }
13310447Snilay@cs.wisc.edu
13410447Snilay@cs.wisc.edu    Result* Result::clone() const
13510447Snilay@cs.wisc.edu    {
13610447Snilay@cs.wisc.edu        return new Result(*this);
13710447Snilay@cs.wisc.edu    }
13810447Snilay@cs.wisc.edu
13910447Snilay@cs.wisc.edu    Result::Result(const Result& result_)
14010447Snilay@cs.wisc.edu    {
14110447Snilay@cs.wisc.edu        // Copy the result name
14210447Snilay@cs.wisc.edu        m_result_name_ = result_.m_result_name_;
14310447Snilay@cs.wisc.edu
14410447Snilay@cs.wisc.edu        // Clone all sub results
14510447Snilay@cs.wisc.edu        for(vector<SubResult*>::const_iterator it = m_sub_results_.begin();
14610447Snilay@cs.wisc.edu            it != m_sub_results_.end(); ++it)
14710447Snilay@cs.wisc.edu        {
14810447Snilay@cs.wisc.edu            const SubResult* temp_sub_result = (*it);
14910447Snilay@cs.wisc.edu            SubResult* new_sub_result = temp_sub_result->clone();
15010447Snilay@cs.wisc.edu            m_sub_results_.push_back(new_sub_result);
15110447Snilay@cs.wisc.edu        }
15210447Snilay@cs.wisc.edu    }
15310447Snilay@cs.wisc.edu
15410447Snilay@cs.wisc.edu    void Result::print(const String& prepend_str_, double num_results_, int detail_level_, ostream& ost_) const
15510447Snilay@cs.wisc.edu    {
15610447Snilay@cs.wisc.edu        // Go down to lower level if detail_level_ > 0, else print the sthe sthe sthe sum
15710447Snilay@cs.wisc.edu        if(detail_level_ > 0)
15810447Snilay@cs.wisc.edu        {
15910447Snilay@cs.wisc.edu            for(vector<SubResult*>::const_iterator it = m_sub_results_.begin();
16010447Snilay@cs.wisc.edu                    it != m_sub_results_.end(); ++it)
16110447Snilay@cs.wisc.edu            {
16210447Snilay@cs.wisc.edu                const SubResult* temp_sub_result = (*it);
16310447Snilay@cs.wisc.edu                const Result* temp_result = temp_sub_result->getResult();
16410447Snilay@cs.wisc.edu                const String& temp_producer = temp_sub_result->getProducer();
16510447Snilay@cs.wisc.edu                const String& temp_result_name = temp_result->getName();
16610447Snilay@cs.wisc.edu                double temp_num_results = temp_sub_result->getNumResults();
16710447Snilay@cs.wisc.edu                String temp_prepend_str = prepend_str_ + "->" + temp_producer;
16810447Snilay@cs.wisc.edu
16910447Snilay@cs.wisc.edu                if(!temp_result_name.empty())
17010447Snilay@cs.wisc.edu                {
17110447Snilay@cs.wisc.edu                    temp_prepend_str += ":" + temp_result_name;
17210447Snilay@cs.wisc.edu                }
17310447Snilay@cs.wisc.edu                temp_result->print(temp_prepend_str, num_results_*temp_num_results, detail_level_ - 1, ost_);
17410447Snilay@cs.wisc.edu            }
17510447Snilay@cs.wisc.edu        }
17610447Snilay@cs.wisc.edu        else
17710447Snilay@cs.wisc.edu        {
17810447Snilay@cs.wisc.edu            ost_ << prepend_str_ << " = " << calculateSum()*num_results_;
17910447Snilay@cs.wisc.edu            ost_ << " (" << calculateSum() << " * " << num_results_ << ")" << endl;
18010447Snilay@cs.wisc.edu        }
18110447Snilay@cs.wisc.edu        return;
18210447Snilay@cs.wisc.edu    }
18310447Snilay@cs.wisc.edu
18410447Snilay@cs.wisc.edu    void Result::printHierarchy(const String& prepend_str_, int detail_level_, ostream& ost_) const
18510447Snilay@cs.wisc.edu    {
18610447Snilay@cs.wisc.edu        if(detail_level_ > 0)
18710447Snilay@cs.wisc.edu        {
18810447Snilay@cs.wisc.edu            for(vector<SubResult*>::const_iterator it = m_sub_results_.begin(); it != m_sub_results_.end(); ++it)
18910447Snilay@cs.wisc.edu            {
19010447Snilay@cs.wisc.edu                const SubResult* temp_sub_result = (*it);
19110447Snilay@cs.wisc.edu                const Result* temp_result = temp_sub_result->getResult();
19210447Snilay@cs.wisc.edu                const String& temp_producer = temp_sub_result->getProducer();
19310447Snilay@cs.wisc.edu                const String& temp_result_name = temp_result->getName();
19410447Snilay@cs.wisc.edu                String temp_prepend_str = prepend_str_ + "    ";
19510447Snilay@cs.wisc.edu
19610447Snilay@cs.wisc.edu                ost_ << prepend_str_ << " |--" << temp_producer << "->" << temp_result_name << endl;
19710447Snilay@cs.wisc.edu
19810447Snilay@cs.wisc.edu                temp_result->printHierarchy(temp_prepend_str, detail_level_ - 1, ost_);
19910447Snilay@cs.wisc.edu            }
20010447Snilay@cs.wisc.edu        }
20110447Snilay@cs.wisc.edu        return;
20210447Snilay@cs.wisc.edu    }
20310447Snilay@cs.wisc.edu
20410447Snilay@cs.wisc.edu    AtomicResult::AtomicResult(const String& result_name_, double value_)
20510447Snilay@cs.wisc.edu        : Result(result_name_), m_value_(value_)
20610447Snilay@cs.wisc.edu    {}
20710447Snilay@cs.wisc.edu
20810447Snilay@cs.wisc.edu    AtomicResult::~AtomicResult()
20910447Snilay@cs.wisc.edu    {}
21010447Snilay@cs.wisc.edu
21110447Snilay@cs.wisc.edu    void AtomicResult::setValue(double value_)
21210447Snilay@cs.wisc.edu    {
21310447Snilay@cs.wisc.edu        m_value_ = value_;
21410447Snilay@cs.wisc.edu        return;
21510447Snilay@cs.wisc.edu    }
21610447Snilay@cs.wisc.edu
21710447Snilay@cs.wisc.edu    void AtomicResult::addValue(double value_)
21810447Snilay@cs.wisc.edu    {
21910447Snilay@cs.wisc.edu        m_value_ += value_;
22010447Snilay@cs.wisc.edu        return;
22110447Snilay@cs.wisc.edu    }
22210447Snilay@cs.wisc.edu
22310447Snilay@cs.wisc.edu    double AtomicResult::getValue() const
22410447Snilay@cs.wisc.edu    {
22510447Snilay@cs.wisc.edu        return m_value_;
22610447Snilay@cs.wisc.edu    }
22710447Snilay@cs.wisc.edu
22810447Snilay@cs.wisc.edu    double AtomicResult::calculateSum() const
22910447Snilay@cs.wisc.edu    {
23010447Snilay@cs.wisc.edu        return m_value_;
23110447Snilay@cs.wisc.edu    }
23210447Snilay@cs.wisc.edu
23310447Snilay@cs.wisc.edu    AtomicResult* AtomicResult::clone() const
23410447Snilay@cs.wisc.edu    {
23510447Snilay@cs.wisc.edu        return new AtomicResult(*this);
23610447Snilay@cs.wisc.edu    }
23710447Snilay@cs.wisc.edu
23810447Snilay@cs.wisc.edu    AtomicResult::AtomicResult(const AtomicResult& atomic_result_)
23910447Snilay@cs.wisc.edu        : Result(atomic_result_), m_value_(atomic_result_.m_value_)
24010447Snilay@cs.wisc.edu    {}
24110447Snilay@cs.wisc.edu
24210447Snilay@cs.wisc.edu    void AtomicResult::print(const String& prepend_str_, double num_results_, int /* detail_level_ */, ostream& ost_) const
24310447Snilay@cs.wisc.edu    {
24410447Snilay@cs.wisc.edu        ost_ << prepend_str_ << " = " << m_value_*num_results_;
24510447Snilay@cs.wisc.edu        ost_ << " (" << m_value_ << " * " << num_results_ << ")" << endl;
24610447Snilay@cs.wisc.edu        return;
24710447Snilay@cs.wisc.edu    }
24810447Snilay@cs.wisc.edu} // namespace DSENT
24910447Snilay@cs.wisc.edu
250