$(instance)TriangularTest Icon

TriangularTest

Usage

TriangularTest()

Behavior

\[ \begin{align} \mathtt{signal.y}\left( t \right) &= \mathtt{integrator.u}\left( t \right) \\ \frac{\mathrm{d} \mathtt{integrator.x}\left( t \right)}{\mathrm{d}t} &= \mathtt{integrator.k} \mathtt{integrator.u}\left( t \right) \\ \mathtt{integrator.y}\left( t \right) &= \mathtt{integrator.x}\left( t \right) \\ \mathtt{signal.y}\left( t \right) &= ifelse\left( \mathtt{signal.start\_time} < t, - \mathtt{signal.amplitude} + 4 \mathtt{signal.amplitude} \mathtt{signal.frequency} \left| - \frac{1}{2} \mathtt{signal.period} + \left|mod\left( - \frac{1}{4} \mathtt{signal.period} - \mathtt{signal.start\_time} + t, \mathtt{signal.period} \right)\right|\right|, \mathtt{signal.offset} \right) \end{align} \]

Source

component TriangularTest
  integrator = Integrator()
  signal = Triangular(amplitude=1, frequency=2, start_time=0.5, offset=0.7)
relations
  connect(signal.y, integrator.u)
metadata {
  "JuliaSim": {
    "tests": {
      "case1": {
        "stop": 5,
        "atol": {"integrator.x": 0.001},
        "expect": {
          "initial": {"signal.y": 0.7},
          "signals": ["signal.y", "integrator.x"],
          "final": {"signal.y": 0, "integrator.x": 0.37555}
        }
      }
    }
  }
}
end
Flattened Source
component TriangularTest
  integrator = Integrator()
  signal = Triangular(amplitude=1, frequency=2, start_time=0.5, offset=0.7)
relations
  connect(signal.y, integrator.u)
metadata {
  "JuliaSim": {
    "tests": {
      "case1": {
        "stop": 5,
        "atol": {"integrator.x": 0.001},
        "expect": {
          "initial": {"signal.y": 0.7},
          "signals": ["signal.y", "integrator.x"],
          "final": {"signal.y": 0, "integrator.x": 0.37555}
        }
      }
    }
  }
}
end

Test Cases

Test Case case1

Signal `signal.y` for test `case1` of `TriangularTest`

Signal `integrator.x` for test `case1` of `TriangularTest`

  • Examples
  • Experiments
  • Analyses