mirror of
https://github.com/jankae/LibreVNA.git
synced 2026-04-07 15:33:51 +00:00
Custom math expressions + bugfix harmonic mixing
This commit is contained in:
parent
49e0b901fd
commit
9614c9d850
97 changed files with 18173 additions and 11 deletions
395
Software/PC_Application/Traces/Math/parser/mpVariable.cpp
Normal file
395
Software/PC_Application/Traces/Math/parser/mpVariable.cpp
Normal file
|
|
@ -0,0 +1,395 @@
|
|||
/** \file
|
||||
\brief Implementation of the muParserX variable class.
|
||||
|
||||
<pre>
|
||||
__________ ____ ___
|
||||
_____ __ _\______ \_____ _______ ______ __________\ \/ /
|
||||
/ \| | \ ___/\__ \\_ __ \/ ___// __ \_ __ \ /
|
||||
| Y Y \ | / | / __ \| | \/\___ \\ ___/| | \/ \
|
||||
|__|_| /____/|____| (____ /__| /____ >\___ >__| /___/\ \
|
||||
\/ \/ \/ \/ \_/
|
||||
Copyright (C) 2016, Ingo Berg
|
||||
All rights reserved.
|
||||
|
||||
Redistribution and use in source and binary forms, with or without
|
||||
modification, are permitted provided that the following conditions are met:
|
||||
|
||||
* Redistributions of source code must retain the above copyright notice,
|
||||
this list of conditions and the following disclaimer.
|
||||
* Redistributions in binary form must reproduce the above copyright notice,
|
||||
this list of conditions and the following disclaimer in the documentation
|
||||
and/or other materials provided with the distribution.
|
||||
|
||||
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
||||
IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
|
||||
INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
||||
NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
||||
WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
POSSIBILITY OF SUCH DAMAGE.
|
||||
</pre>
|
||||
*/
|
||||
#include "mpVariable.h"
|
||||
#include "mpError.h"
|
||||
|
||||
#include "mpValue.h"
|
||||
|
||||
|
||||
MUP_NAMESPACE_START
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
/** \brief Create a variable and bind a value to it.
|
||||
\param pVal Pointer of the value to bind to this variable.
|
||||
|
||||
It is possible to create an empty variable object by setting pVal to nullptr.
|
||||
Such variable objects must be bound later in order to be of any use. The parser
|
||||
does NOT assume ownership over the pointer!
|
||||
*/
|
||||
Variable::Variable(IValue *pVal)
|
||||
:IValue(cmVAL)
|
||||
,m_pVal(pVal)
|
||||
{
|
||||
AddFlags(IToken::flVOLATILE);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
Variable::Variable(const Variable &obj)
|
||||
:IValue(cmVAL)
|
||||
{
|
||||
Assign(obj);
|
||||
AddFlags(IToken::flVOLATILE);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
Variable& Variable::operator=(const Variable &obj)
|
||||
{
|
||||
Assign(obj);
|
||||
return *this;
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
/** \brief Assign a value to the variable.
|
||||
\param ref Reference to the value to be assigned
|
||||
*/
|
||||
IValue& Variable::operator=(const Value &ref)
|
||||
{
|
||||
assert(m_pVal);
|
||||
*m_pVal = ref;
|
||||
return *this;
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
IValue& Variable::operator=(int_type val)
|
||||
{
|
||||
assert(m_pVal);
|
||||
return m_pVal->operator=(val);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
IValue& Variable::operator=(float_type val)
|
||||
{
|
||||
assert(m_pVal);
|
||||
return m_pVal->operator=(val);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
IValue& Variable::operator=(string_type val)
|
||||
{
|
||||
assert(m_pVal);
|
||||
return m_pVal->operator=(val);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
IValue& Variable::operator=(bool_type val)
|
||||
{
|
||||
assert(m_pVal);
|
||||
return m_pVal->operator=(val);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
IValue& Variable::operator=(const matrix_type &val)
|
||||
{
|
||||
assert(m_pVal);
|
||||
return m_pVal->operator=(val);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
IValue& Variable::operator=(const cmplx_type &val)
|
||||
{
|
||||
assert(m_pVal);
|
||||
return m_pVal->operator=(val);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
IValue& Variable::operator+=(const IValue &val)
|
||||
{
|
||||
assert(m_pVal);
|
||||
return m_pVal->operator+=(val);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
IValue& Variable::operator-=(const IValue &val)
|
||||
{
|
||||
assert(m_pVal);
|
||||
return m_pVal->operator-=(val);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
IValue& Variable::operator*=(const IValue &val)
|
||||
{
|
||||
assert(m_pVal);
|
||||
return m_pVal->operator*=(val);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
IValue& Variable::At(int nRow, int nCol)
|
||||
{
|
||||
return m_pVal->At(nRow, nCol);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
IValue& Variable::At(const IValue &row, const IValue &col)
|
||||
{
|
||||
try
|
||||
{
|
||||
return m_pVal->At(row, col);
|
||||
}
|
||||
catch(ParserError &exc)
|
||||
{
|
||||
// add the identifier to the error context
|
||||
exc.GetContext().Ident = GetIdent();
|
||||
throw exc;
|
||||
}
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
Variable::~Variable()
|
||||
{}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
void Variable::Assign(const Variable &ref)
|
||||
{
|
||||
if (this==&ref)
|
||||
return;
|
||||
|
||||
m_pVal = ref.m_pVal;
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
/** \brief Returns a character representing the type of the variable.
|
||||
\throw nothrow
|
||||
*/
|
||||
char_type Variable::GetType() const
|
||||
{
|
||||
return (m_pVal) ? m_pVal->GetType() : 'v';
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
/** \brief Returns the Value pointer bound to this variable.
|
||||
\throw nothrow
|
||||
*/
|
||||
IValue* Variable::GetPtr() const
|
||||
{
|
||||
return m_pVal;
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
int_type Variable::GetInteger() const
|
||||
{
|
||||
try
|
||||
{
|
||||
return m_pVal->GetInteger();
|
||||
}
|
||||
catch (ParserError &exc)
|
||||
{
|
||||
exc.GetContext().Ident = GetIdent();
|
||||
throw;
|
||||
}
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
float_type Variable::GetFloat() const
|
||||
{
|
||||
try
|
||||
{
|
||||
return m_pVal->GetFloat();
|
||||
}
|
||||
catch (ParserError &exc)
|
||||
{
|
||||
exc.GetContext().Ident = GetIdent();
|
||||
throw;
|
||||
}
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
float_type Variable::GetImag() const
|
||||
{
|
||||
try
|
||||
{
|
||||
return m_pVal->GetImag();
|
||||
}
|
||||
catch (ParserError &exc)
|
||||
{
|
||||
exc.GetContext().Ident = GetIdent();
|
||||
throw;
|
||||
}
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
const cmplx_type& Variable::GetComplex() const
|
||||
{
|
||||
try
|
||||
{
|
||||
return m_pVal->GetComplex();
|
||||
}
|
||||
catch (ParserError &exc)
|
||||
{
|
||||
exc.GetContext().Ident = GetIdent();
|
||||
throw;
|
||||
}
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
const string_type& Variable::GetString() const
|
||||
{
|
||||
try
|
||||
{
|
||||
return m_pVal->GetString();
|
||||
}
|
||||
catch (ParserError &exc)
|
||||
{
|
||||
exc.GetContext().Ident = GetIdent();
|
||||
throw;
|
||||
}
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
bool Variable::GetBool() const
|
||||
{
|
||||
try
|
||||
{
|
||||
return m_pVal->GetBool();
|
||||
}
|
||||
catch (ParserError &exc)
|
||||
{
|
||||
exc.GetContext().Ident = GetIdent();
|
||||
throw;
|
||||
}
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
const matrix_type& Variable::GetArray() const
|
||||
{
|
||||
try
|
||||
{
|
||||
return m_pVal->GetArray();
|
||||
}
|
||||
catch (ParserError &exc)
|
||||
{
|
||||
exc.GetContext().Ident = GetIdent();
|
||||
throw;
|
||||
}
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
int Variable::GetRows() const
|
||||
{
|
||||
try
|
||||
{
|
||||
return m_pVal->GetRows();
|
||||
}
|
||||
catch (ParserError &exc)
|
||||
{
|
||||
exc.GetContext().Ident = GetIdent();
|
||||
throw;
|
||||
}
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
int Variable::GetCols() const
|
||||
{
|
||||
try
|
||||
{
|
||||
return m_pVal->GetCols();
|
||||
}
|
||||
catch (ParserError &exc)
|
||||
{
|
||||
exc.GetContext().Ident = GetIdent();
|
||||
throw;
|
||||
}
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
void Variable::SetFloat(float_type a_fVal)
|
||||
{
|
||||
assert(m_pVal);
|
||||
*m_pVal = a_fVal;
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
void Variable::SetString(const string_type &a_sVal)
|
||||
{
|
||||
assert(m_pVal);
|
||||
*m_pVal = a_sVal;
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
void Variable::SetBool(bool a_bVal)
|
||||
{
|
||||
assert(m_pVal);
|
||||
*m_pVal = a_bVal;
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
void Variable::Bind(IValue *pValue)
|
||||
{
|
||||
m_pVal = pValue;
|
||||
}
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
bool Variable::IsVariable() const
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
IToken* Variable::Clone() const
|
||||
{
|
||||
return new Variable(*this);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
Value* Variable::AsValue()
|
||||
{
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------------------------
|
||||
string_type Variable::AsciiDump() const
|
||||
{
|
||||
stringstream_type ss;
|
||||
|
||||
ss << g_sCmdCode[ GetCode() ];
|
||||
ss << _T(" [addr=0x") << std::hex << this << std::dec;
|
||||
ss << _T("; pos=") << GetExprPos();
|
||||
ss << _T("; id=\"") << GetIdent() << _T("\"");
|
||||
ss << _T("; type=\"") << GetType() << _T("\"");
|
||||
ss << _T("; val=");
|
||||
|
||||
switch(GetType())
|
||||
{
|
||||
case 'i': ss << (int_type)GetFloat(); break;
|
||||
case 'f': ss << GetFloat(); break;
|
||||
case 'm': ss << _T("(array)"); break;
|
||||
case 's': ss << _T("\"") << GetString() << _T("\""); break;
|
||||
}
|
||||
|
||||
ss << ((IsFlagSet(IToken::flVOLATILE)) ? _T("; ") : _T("; not ")) << _T("vol");
|
||||
ss << _T("]");
|
||||
|
||||
return ss.str();
|
||||
}
|
||||
MUP_NAMESPACE_END
|
||||
Loading…
Add table
Add a link
Reference in a new issue