MultiSensor
IconMultiSensor
Provides combined voltage and current measurements from an electrical circuit.
This component extends a PowerSensor
to offer voltage, current and power readings as real-valued outputs. The output v
represents the measured voltage, the output i
represents the measured current and the output power
represents power. v
and i
outputs are directly sourced from internal voltage_sensor
and current_sensor
subcomponents, which are part of the inherited PowerSensor
. The defining equations from the relations
block are:
\[v = \text{voltage_sensor.v}\]
\[i = \text{current_sensor.i}\]
\[power = \text{voltage_sensor.v*current_sensor.i} This component extends from [`PowerSensor`](https://help.juliahub.com/dyad/dev/stdlib/ElectricalComponents/components/PowerSensor.html) ## Usage `MultiSensor()` ## Connectors * `pc` - This connector represents an electrical pin with voltage and current as the potential and flow variables, respectively. ([`Pin`](@ref)) * `nc` - This connector represents an electrical pin with voltage and current as the potential and flow variables, respectively. ([`Pin`](@ref)) * `pv` - This connector represents an electrical pin with voltage and current as the potential and flow variables, respectively. ([`Pin`](@ref)) * `nv` - This connector represents an electrical pin with voltage and current as the potential and flow variables, respectively. ([`Pin`](@ref)) * `power` - This connector represents a real signal as an output from a component ([`RealOutput`](@ref)) * `i` - This connector represents a real signal as an output from a component ([`RealOutput`](@ref)) * `v` - This connector represents a real signal as an output from a component ([`RealOutput`](@ref)) ## Behavior \]
@example behavior using ElectricalComponents #hide using ModelingToolkit #hide @named sys = MultiSensor() #hide full_equations(sys) #hide
## Source
@raw html <pre><code class="language-dyad hljs"><span class="hljs-comment"># Provides combined voltage and current measurements from an electrical circuit.
This component extends a PowerSensor
to offer voltage, current and power
readings as real-valued outputs. The output v
represents the measured
voltage, the output i
represents the measured current and the output power
represents power. v
and i
outputs are directly sourced from internal
voltage_sensor
and current_sensor
subcomponents, which are part of the
inherited PowerSensor
. The defining equations from the relations
block are:
```math
v = \text{voltage_sensor.v}
```
```math
i = \text{current_sensor.i}
```
```math
power = \text{voltagesensor.v*currentsensor.i}</span>
<span class="hljs-keyword">component</span> MultiSensor <span class="hljs-keyword">extends</span> <span class="hljs-link"><a href="https://help.juliahub.com/dyad/dev/stdlib/ElectricalComponents/components/PowerSensor.html">PowerSensor</a></span> <span class="hljs-comment"># Output signal representing the measured current</span> <span class="hljs-symbol">i</span> = <span class="hljs-link"><a href="https://help.juliahub.com/dyad/dev/stdlib/Dyad/connectors/RealOutput.html">RealOutput</a></span>() [{ "Dyad": { "placement": {"icon": {"x1": 650, "y1": 950, "x2": 750, "y2": 1050, "rot": 90}} } }] <span class="hljs-comment"># Output signal representing the measured voltage</span> <span class="hljs-symbol">v</span> = <span class="hljs-link"><a href="https://help.juliahub.com/dyad/dev/stdlib/Dyad/connectors/RealOutput.html">RealOutput</a></span>() [{ "Dyad": { "placement": {"icon": {"x1": 850, "y1": 950, "x2": 950, "y2": 1050, "rot": 90}} } }] <span class="hljs-keyword">relations</span> i = currentsensor.i v = voltagesensor.v <span class="hljs-keyword">metadata</span> { "Dyad": { "labels": [ {"label": "instance", "x": 500, "y": 1100, "rot": 0}, {"label": "M", "x": 500, "y": 713, "rot": 0} ], "icons": {"default": "dyad://ElectricalComponents/FourPinSensor.svg"} } } <span class="hljs-keyword">end</span></code></pre>
@raw html
<details> <summary>Flattened Source</summary>
@raw html <pre><code class="language-dyad hljs"><span class="hljs-comment"># Provides combined voltage and current measurements from an electrical circuit.
This component extends a PowerSensor
to offer voltage, current and power
readings as real-valued outputs. The output v
represents the measured
voltage, the output i
represents the measured current and the output power
represents power. v
and i
outputs are directly sourced from internal
voltage_sensor
and current_sensor
subcomponents, which are part of the
inherited PowerSensor
. The defining equations from the relations
block are:
```math
v = \text{voltage_sensor.v}
```
```math
i = \text{current_sensor.i}
```
```math
power = \text{voltagesensor.v*currentsensor.i}</span>
<span class="hljs-keyword">component</span> MultiSensor <span class="hljs-comment"># Positive pin for current measurement path</span> <span class="hljs-symbol">pc</span> = <span>Pin</span>() [{ "Dyad": { "placement": {"icon": {"iconName": "pos", "x1": -50, "y1": 450, "x2": 50, "y2": 550}} } }] <span class="hljs-comment"># Negative pin for current measurement path</span> <span class="hljs-symbol">nc</span> = <span>Pin</span>() [{ "Dyad": { "placement": {"icon": {"iconName": "neg", "x1": 950, "y1": 450, "x2": 1050, "y2": 550}} } }] <span class="hljs-comment"># Positive pin for voltage measurement</span> <span class="hljs-symbol">pv</span> = <span>Pin</span>() [{ "Dyad": { "placement": {"icon": {"iconName": "pos", "x1": 450, "y1": -50, "x2": 550, "y2": 50}} } }] <span class="hljs-comment"># Negative pin for voltage measurement</span> <span class="hljs-symbol">nv</span> = <span>Pin</span>() [{ "Dyad": { "placement": {"icon": {"iconName": "neg", "x1": 450, "y1": 950, "x2": 550, "y2": 1050}} } }] <span class="hljs-comment"># Internal subcomponent to measure voltage</span> <span class="hljs-symbol">voltagesensor</span> = <span>VoltageSensor</span>() <span class="hljs-comment"># Internal subcomponent to measure current</span> <span class="hljs-symbol">currentsensor</span> = <span>CurrentSensor</span>() <span class="hljs-comment"># Output signal representing the calculated instantaneous power</span> <span class="hljs-symbol">power</span> = <span>RealOutput</span>() [{ "Dyad": { "placement": {"icon": {"x1": 150, "y1": 950, "x2": 250, "y2": 1050, "rot": 90}} } }] <span class="hljs-comment"># Output signal representing the measured current</span> <span class="hljs-symbol">i</span> = <span>RealOutput</span>() [{ "Dyad": { "placement": {"icon": {"x1": 650, "y1": 950, "x2": 750, "y2": 1050, "rot": 90}} } }] <span class="hljs-comment"># Output signal representing the measured voltage</span> <span class="hljs-symbol">v</span> = <span>RealOutput</span>() [{ "Dyad": { "placement": {"icon": {"x1": 850, "y1": 950, "x2": 950, "y2": 1050, "rot": 90}} } }] <span class="hljs-keyword">relations</span> <span class="hljs-builtin">connect</span>(pv, voltagesensor.p) <span class="hljs-builtin">connect</span>(voltagesensor.n, nv) <span class="hljs-builtin">connect</span>(pc, currentsensor.p) <span class="hljs-builtin">connect</span>(currentsensor.n, nc) power = voltagesensor.v * currentsensor.i i = currentsensor.i v = voltagesensor.v <span class="hljs-keyword">metadata</span> { "Dyad": { "labels": [ {"label": "instance", "x": 500, "y": 1100, "rot": 0}, {"label": "M", "x": 500, "y": 713, "rot": 0} ], "icons": {"default": "dyad://ElectricalComponents/FourPinSensor.svg"} } } <span class="hljs-keyword">end</span></code></pre>
@raw html </details>
@raw html
<br></br>
```
Test Cases
No test cases defined.
Related
- Examples
- Experiments
- Analyses
- Tests