blob: 6484eb9889716f02e508d23a05a85ab4a87d2d4b [file] [log] [blame]
Kevin Rocard93250d12012-07-19 17:48:30 +02001/*
David Wagnerb76c9d62014-02-05 18:30:24 +01002 * Copyright (c) 2011-2014, Intel Corporation
3 * All rights reserved.
Patrick Benavoliee65e6d2011-11-20 18:52:24 +01004 *
David Wagnerb76c9d62014-02-05 18:30:24 +01005 * Redistribution and use in source and binary forms, with or without modification,
6 * are permitted provided that the following conditions are met:
Patrick Benavoliee65e6d2011-11-20 18:52:24 +01007 *
David Wagnerb76c9d62014-02-05 18:30:24 +01008 * 1. Redistributions of source code must retain the above copyright notice, this
9 * list of conditions and the following disclaimer.
Patrick Benavoliee65e6d2011-11-20 18:52:24 +010010 *
David Wagnerb76c9d62014-02-05 18:30:24 +010011 * 2. Redistributions in binary form must reproduce the above copyright notice,
12 * this list of conditions and the following disclaimer in the documentation and/or
13 * other materials provided with the distribution.
14 *
15 * 3. Neither the name of the copyright holder nor the names of its contributors
16 * may be used to endorse or promote products derived from this software without
17 * specific prior written permission.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
21 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
22 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
23 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
24 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
25 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
26 * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
28 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Patrick Benavoliee65e6d2011-11-20 18:52:24 +010029 */
30#include "LinearParameterAdaptation.h"
31
32#define base CParameterAdaptation
33
34CLinearParameterAdaptation::CLinearParameterAdaptation() : base("Linear"), _dSlopeNumerator(1), _dSlopeDenominator(1)
35{
36}
37
38// Element properties
39void CLinearParameterAdaptation::showProperties(string& strResult) const
40{
41 base::showProperties(strResult);
42
43 // SlopeNumerator
44 strResult += " - SlopeNumerator: ";
45 strResult += toString(_dSlopeNumerator);
46 strResult += "\n";
47
48 // SlopeDenominator
49 strResult += " - SlopeDenominator: ";
50 strResult += toString(_dSlopeDenominator);
51 strResult += "\n";
52}
53
54// From IXmlSink
55bool CLinearParameterAdaptation::fromXml(const CXmlElement& xmlElement, CXmlSerializingContext& serializingContext)
56{
57 // Get SlopeNumerator
58 if (xmlElement.hasAttribute("SlopeNumerator")) {
59
60 _dSlopeNumerator = xmlElement.getAttributeDouble("SlopeNumerator");
61
62 } else {
63 // Default
64 _dSlopeNumerator = 1;
65 }
66 // Get SlopeDenominator
67 if (xmlElement.hasAttribute("SlopeDenominator")) {
68
69 _dSlopeDenominator = xmlElement.getAttributeDouble("SlopeDenominator");
70
71 // Avoid by 0 division errors
72 if (_dSlopeDenominator == 0) {
73
74 serializingContext.setError("SlopeDenominator attribute can't be 0 on element" + xmlElement.getPath());
75
76 return false;
77 }
78
79 } else {
80 // Default
81 _dSlopeDenominator = 1;
82 }
83
84 // Base
85 return base::fromXml(xmlElement, serializingContext);
86}
87
88// Conversions
89int64_t CLinearParameterAdaptation::fromUserValue(double dValue) const
90{
91 return base::fromUserValue(dValue * _dSlopeNumerator / _dSlopeDenominator);
92}
93
94double CLinearParameterAdaptation::toUserValue(int64_t iValue) const
95{
96 return base::toUserValue(iValue) * _dSlopeDenominator / _dSlopeNumerator;
97}