-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLinearPieceWise.h
executable file
·113 lines (89 loc) · 3.44 KB
/
LinearPieceWise.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
// LinearPieceWise.h: interface for the CLinearPieceWise class.
//
//////////////////////////////////////////////////////////////////////
#if !defined(AFX_LINEARPIECEWISE_H__A3456E43_595E_11D2_BB29_F5D419D58836__INCLUDED_)
#define AFX_LINEARPIECEWISE_H__A3456E43_595E_11D2_BB29_F5D419D58836__INCLUDED_
#if _MSC_VER >= 1000
#pragma once
#endif // _MSC_VER >= 1000
#include <list>
//#include <vector>
#include "Standard.h"
#include "Value.h"
class CLinearPieceWiseTemplate;
/**********************************************************************
* Class: CSegment
* Implenetation class for CLinearPieceWise which holds a fixed
* point coordinate and a slope
**********************************************************************/
class CSegment
{
public:
CValue x;
CValue y;
CValue m; // gradient
bool operator ==(const CSegment& rhs) const {return x == rhs.x;}
bool operator !=(const CSegment& rhs) const {return x != rhs.x;}
bool operator <(const CSegment& rhs) const {return x < rhs.x;}
bool operator >(const CSegment& rhs) const {return x > rhs.x;}
};
/**********************************************************************
* Class: CLinearPieceWise
* Primative widget class to implement a linear piece wise approximation
* to arbitrary transfer functions
**********************************************************************/
class CLinearPieceWise : public CStandardWidget
{
public:
typedef std::list<CSegment> SegmentList;
private:
class CLinearPieceWiseOutput : public CAnalogueOutput
{
public:
CLinearPieceWiseOutput(CStandardWidget* pWidget);
virtual CValue Value() const;
};
CAnalogueInput m_input;
CLinearPieceWiseOutput m_output;
SegmentList m_segments;
bool m_blEditable;
friend class CLinearPieceWiseTemplate;
CLinearPieceWise(const CWidgetTemplate* pTemplate, const std::string& strName);
public:
virtual ~CLinearPieceWise();
virtual COutput* Output(int idx);
virtual const COutput& Output(int idx) const;
virtual CInput* Input(int idx);
virtual const CInput& Input(int idx) const;
virtual CWidget* Clone(const std::string& strName) const;
virtual bool CanEdit() const;
virtual void Edit(const CEditContext* pContext);
virtual void Freeze(); // make not editable
CValue Value() const;
// Editing interface
int PointCount() const;
SegmentList::iterator Points();
bool NextPoint(SegmentList::const_iterator& iter, CValue& x, CValue& y) const;
void AddPoint(CValue x, CValue y);
void DeletePoint(SegmentList::iterator& iter);
void Clear();
void Update();
};
/**********************************************************************
* Class: CLinearPieceWiseTemplate
* Template class to produce CLinearPieceWise widgets
**********************************************************************/
class CLinearPieceWiseTemplate : public CStandardWidgetTemplate
{
CAnalogueConnectorDescription m_inputDesc;
CAnalogueConnectorDescription m_outputDesc;
public:
CLinearPieceWiseTemplate();
virtual ~CLinearPieceWiseTemplate();
virtual CWidget* Create(const std::string& strName) const;
virtual const CConnectorDescription& Output(int idx) const;
virtual int OutputCount() const;
virtual const CConnectorDescription& Input(int idx) const;
virtual int InputCount() const;
};
#endif // !defined(AFX_LINEARPIECEWISE_H__A3456E43_595E_11D2_BB29_F5D419D58836__INCLUDED_)