summaryrefslogtreecommitdiffstats
path: root/src/electronics/components/addac.h
blob: 3d69e887f586a669c87ed9e2a6f950e0ca775fac (plain)
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
/***************************************************************************
 *   Copyright (C) 2005 by David Saxton                                    *
 *   david@bluehaze.org                                                    *
 *                                                                         *
 *   This program is free software; you can redistribute it and/or modify  *
 *   it under the terms of the GNU General Public License as published by  *
 *   the Free Software Foundation; either version 2 of the License, or     *
 *   (at your option) any later version.                                   *
 ***************************************************************************/

#ifndef ADDAC_H
#define ADDAC_H

#include "component.h"

const int max_ADDAC_bits = 32;

/**
@author David Saxton
*/
class ADDAC : public Component
{
public:
	public:
		ADDAC( ICNDocument *icnDocument, bool newItem, const char *id = 0L );
		~ADDAC();
		virtual bool canFlip() const { return true; }
		
	protected:
		void dataChanged();
		/**
		 * Add / remove pins according to the number of outputs the user has requested
		 */
		virtual void initPins() = 0;
		
		int m_numBits;
		double m_range;
};


/**
@author David Saxton
 */
class ADC : public ADDAC
{
	public:
		ADC( ICNDocument *icnDocument, bool newItem, const char *id = 0L );
		~ADC();
	
		static Item* construct( ItemDocument *itemDocument, bool newItem, const char *id );
		static LibraryItem *libraryItem();
	
		virtual void stepNonLogic();
		virtual bool doesStepNonLogic() const { return true; }
	
	protected:
		/**
		 * Add / remove pins according to the number of outputs the user has requested
		 */
		virtual void initPins();
	
		LogicOut *m_logic[max_ADDAC_bits];
		ECNode *m_realNode;
};


/**
@author David Saxton
 */
class DAC : public ADDAC
{
	public:
		DAC( ICNDocument *icnDocument, bool newItem, const char *id = 0L );
		~DAC();
	
		static Item* construct( ItemDocument *itemDocument, bool newItem, const char *id );
		static LibraryItem *libraryItem();
	
		virtual void stepNonLogic();
		virtual bool doesStepNonLogic() const { return true; }
	
	protected:
		/**
		 * Add / remove pins according to the number of outputs the user has requested
		 */
		virtual void initPins();
	
		LogicIn *m_logic[max_ADDAC_bits];
		VoltagePoint *m_voltagePoint;
};


#endif