OROperator Class
(Automation::OROperator)The OROperator does a bitwise OR between all the arguments and the input to produce an output. More...
Header: | #include <OROperator.h> |
Inherits: | CDPOperator<T> |
Public Functions
OROperator(const CDPPropertyBase &in) |
Reimplemented Public Functions
virtual unsigned int | Process() override |
- 18 public functions inherited from CDPOperator
- 17 public functions inherited from CDPOperatorBase
- 46 public functions inherited from CDPBaseObject
- 26 public functions inherited from CDP::StudioAPI::CDPNode
- 22 public functions inherited from CDP::StudioAPI::ICDPNode
Additional Inherited Members
- 1 public variable inherited from CDPOperatorBase
- 1 static public member inherited from CDPBaseObject
- 1 protected function inherited from CDP::StudioAPI::CDPNode
- 8 protected variables inherited from CDPOperator
- 5 protected variables inherited from CDPOperatorBase
- 11 protected variables inherited from CDPBaseObject
Detailed Description
The OROperator does a bitwise OR between all the arguments and the input to produce an output.
OR has the following truth table:
Input A | Input B | Output (A OR B) |
---|---|---|
0 | 0 | 0 |
0 | 1 | 1 |
1 | 0 | 1 |
1 | 1 | 1 |
When operator is used inside a signal its default input is automatically tied to signal's InternalValue or previous operator's output. Its default output is automatically tied to next operator's input or to signal's Value. See also CDP Operator Usage In CDP Signals.
Example
To OR a signal value with value 0x0001, add an OROperator<unsigned short> into a Signal<unsigned short> in Configure mode. Then go into the OROperator that was added, and add an Argument<unsigned short>. Set its Value to 0x0001 (1).
How to Run the Example
To run the example from CDP Studio, open Welcome mode and find it under Examples. Next, in Configure mode right-click on the system project and select Run & Connect. See the Running the Example Project tutorial for more information.
Set the signal Value containing the OR operator to 2, and verify that the value after the operator has been applied becomes 3.
Actual Processing Code of the OROperator
unsigned int OROperator<T>::Process() { T outputValue = static_cast<T>(m_input); for (auto arg : this->m_arguments) outputValue |= static_cast<T>(*arg); m_output = outputValue; return STATUS_OK; }
See also Argument.
Member Function Documentation
OROperator::OROperator(const CDPPropertyBase &in)
Default constructs an instance of OROperator.
[override virtual]
unsigned int OROperator::Process()
Get started with CDP Studio today
Let us help you take your great ideas and turn them into the products your customer will love.