2.4.3 Defining Arbitrary Curves

Arbitrary curves are curves defined by a vector expression of voltages and/or currents or from an expression of existing graph waveforms. The input vectors to the expression can come from a number of sources, including interactive selection of schematic nodes or waveforms. As the easiest way to generate these curves is with a fixed schematic probe, this method is be presented first.

To download the examples for Module 2, click Module_2_Examples.zip

What You Will Learn

  • How to use fixed schematic probes to plot arbitrary expressions.
  • You can plot the power in any device with the Probe > Power In Device... menu item.
  • How to generate curves which are expressions of existing graph curves.
  • How to generate curves which are arbitrary expressions containing multiple vectors selected from the schematic.

Getting Started

Creating Arbitrary Curves From Fixed Schematic Probes

The Arbitrary Probe is a very powerful fixed schematic probe with an automatically created symbol. To use this probe, you enter a expression of voltages and currents in the dialog box, and the program creates a symbol which has a pin for each voltage, and a pair of pins connected by a 0-volt DC source for each current. Voltages are entered in the expression as V(nnn), and currents as I(nnn), where nnn is a unique string identifier. After entering the expression and closing the dialog box, the program creates a symbol with the correct pins and with the graphing statements which implement the arbitrary expression.

Exercise #1: Create and Place Arbitrary Probe

In this exercise you will place and configure an arbitrary probe to generate the expression: P=(VDRAINVSOURCE)×IDRAIN This probe will output the power curve on a new grid above the drain current and drain-to-source voltage curves.
  1. Open the 2.4_SelfOscillatingConverter_POP_Tran.sxsch schematic.
  2. From the schematic menu, select Probe > Create and Place Arbitrary Probe .
    Result: The arbitrary probe dialog opens.
  3. In the Probe expression box, enter the expression: V(D,S)*I(D). This is a shorter expression than the full expression: P=(VDRAINVSOURCE)×IDRAIN The syntax: V(D,S) is equivalent to V(D)-V(S). You will see that this shorter expression creates a smaller probe symbol than you would see with the full expression. In this case, the smaller probe is easier to place and wire on the schematic. The configured dialog should appear as:
  4. In the Curve label box, enter Power in Q1.
  5. In the Axis type box, select the Use dedicated grid radio button.
  6. To the right of the Axis type box is the Graph box. In the Graph box, select Use named graph and in the Graph name box, enter Switching. The configured dialog now appears as:
  7. Click Ok.
    Result: The program parses the Probe expression, and creates a schematic probe which has the correct pins and enters into a place mode:
  8. Place the probe in the approximate location shown above. Next, you will wire the probe into the existing schematic components.
  9. Wire the arbitrary probe to the schematic:
    1. First, select the 1-grid square length wire which connects the IQ1 Drain probe to the transformer network. To accomplish this, you will need to press and hold the Shift key while dragging a box around the wire. This tells the program to only select wires, not the default which is wires and symbols.
      Result: Just one grid square of wire is selected.
    2. Press the Delete key to delete this wire.
    3. Now wire the probe into the existing circuit. The final wiring should appear equivilent to:
  10. Press F9 to run the simulation.
    Result: The power expression is plotted as a green curve above the drain voltage and drain current waveforms.

Creating Arbitrary Curves Interactively

In the first exercise, you created an arbitrary probe symbol, wired it to the schematic and ran a simulation, producing a curve which approximates the power dissipated in the MOSFET. In this case we knew the expression we wanted to plot, and this is not always the case. There are occasions where you will want to generate curve interactively after the simulation completes. In the next example, you will generate the same arbitrary curve using the Define Curve Dialog.

Using the Define Curve Dialog, you can enter expressions defining the Y and X axis of the curve. By default the dialog assumes that the X axis is time (or frequency) and that the user must enter the expression for the Y axis. You can enable the X-Y plot by selecting the X-Y Plot check box. The expressions can contain vector names and a set of built-in functions. The results of the X and Y expressions are expected to be vectors and are plotted on the graph and axis you specify in the dialog.

Exercise #2: Using The Define Curve Dialog to Plot the Power in a Device

  1. This exercise starts with the schematic 2.4_SelfOscillatingConverter_POP_Tran.sxsch opened, and with the simulation data from the last step of the first exercise.
  2. From the menu bar, select Plot > Add Curve... .
    Result: The Define Curve Dialog opens:
    Note: The Define Curve dialog is interactive, that is, you can click on the waveform viewer or the schematic to automatically populate the dialog X and Y fields with vectors. This is different than other dialogs which steal focus and therefore prevent you from interacting with the other SIMetrix/SIMPLIS windows while the dialog is open.
  3. Click in the Y field at to top of the dialog and press ( to start the expression.
  4. On the schematic, left-click on the drain connection of the MOSFET Q1:
    Result: The dialog is populated with the drain voltage node, :33.
    Note: Your node numbers might be different, depending on how you re-wired the arbitrary probe in the first exercise.
  5. Next, type a minus character, - so that the Y expression is (:33-.
  6. On the schematic, left-click on the source connection of the MOSFET Q1:
    Result: The dialog is populated with the source voltage node, :32.
  7. Type )*, making the Y expression (:33-:32)*
  8. Press and hold the shift key while left-clicking on the positive side of the IQ1 Drain current probe:
    Result: The dialog is populated with the probe current, IPROBE3#P, the final Y expression is (:33-:32)*IPROBE3#P. The dialog should now appear as shown below:
  9. To put the curve on a new grid above the existing grid before you accept the dialog and plot the curve, select the Use new grid radio button as shown below:
  10. Click Ok.
    Result: The power in Q1 is plotted on a new grid above the arbitrary probe you created in the first exercise. Because you didn't specify a curve name, the program labeled the curve with the expression which created it.

The above procedure used the bare minimum of steps. At any point in the process, you can hand type into the expression box. The Define Curve Dialog allows you to specify much more than just the curve expression, as you will see with the next example.

Exercise #3: Expression History and Curve Annotation

One useful feature of the Define Curve Dialog is that the system remembers the previously plotted expressions. In this example, you will delete the curve you just created and add it with a more useful name than the actual vector expression, which is (:33-:32)*IPROBE3#P.

  1. Select the curve you just created with the curve label (:33-:32)*IPROBE3#P. You can select curves by clicking on the curve in the waveform viewer.
  2. Press the Delete key.
    Result: The curve and axis are deleted.
  3. From the waveform viewer menu bar, select Plot > Add Curve...
    Result: The Define Curve Dialog opens.
  4. Select the Y expression combo box pull down as shown below:

    Notice that the curve expression you defined in the first example is remembered and is available to be plotted.

  5. Select the previously used curve expression.
  6. In the Curve label field, type an appropriate curve label, such as Power in Q1 (new). The resulting dialog is shown below:
  7. , To put the curve on a new grid above the existing grid as you did with the first example, select the Axis/Graph Options tab and select the Use new grid radio button as shown below:
  8. Click Ok.
    Result: The Power in Q1 (new) curve is added to a new grid on the waveform viewer. While the vector information is identical to the previous curve, the curve label is much shorter and its intuitive that the curve represents the power dissipated in Q1.

In the first three exercises, you plotted the power in Q1 taking into account only the power from the drain current and drain-to-source voltage product. SIMetrix/SIMPLIS has a very powerful probe feature which automatically plots the power in a device, taking into account all pin currents and voltages. In the next exercise, you will compare the power dissipation generated using this method vs. the Define Curve method.

Exercise #4: Compare with the Power In Device Function

The schematic menu Probe > Power In Device... automatically generates the power in a single device. This includes any device implemented as a subcircuit, such as a hierarchical schematic component. To probe the power in the MOSFET Q1,

  1. With the graph open from the last example, select Probe > Power In Device... from the schematic menu.
  2. Move the mouse over to the MOSFET Q1:
  3. Left-click the mouse.
    Result: A curve with label Power(Q1) is added to the waveform viewer. This curve is added to the selected grid, which is the upper grid on the waveform viewer.

Exercise #5: Difference of Two Graph Curves

At this point the waveform viewer has the drain voltage and draing current curves, and the three curves you added, one created with the Arbitrary Fixed Schematic Probe, one created with the Define Curve Dialog, and one created with the Power In Device random probe. Because of the large magnitudes of these curves, comparing the difference between them is quite difficult. In this example, you will plot the difference of the two power curves.

  1. Select the power curve in the middle grid.
  2. Press delete to remove this curve and it's grid.
  3. Zoom in on the power curves in the upper grid using the box select:
    1. Press and hold the left mouse button while dragging the mouse to create a box selection.
    2. Repeat until the two curves separate on the waveform viewer:
      Result: Your curves will appear differently than the image below depending on which portion of the curve you zoomed in on.
  4. Once you can distinctly see the two curves, you can add the difference curve. From the menu bar, select Plot > Add Curve...
  5. In the waveform viewer, left-click on the curve with the label Power(Q1)
    Result: The Y expression is updated with cv(n), where n is an integer. The integer value is not important.
  6. Type a minus character (-) so that the expression is now cv(n)-.
  7. In the waveform viewer, left click on the curve with the label Power in Q1 (new)
    Result: The Y expression is updated with cv(m), where m is an integer. The dialog should be configured as below:
  8. Add a descriptive curve label, such as Delta Power
  9. As with the first two exercises, you should put the curve on a new grid above the existing grid. Select the Axis/Graph Options tab and select the Use new grid radio button as shown below:
  10. Click Ok.
    Result: A new curve is added to a new grid above the existing grids. This curve represents the difference in power dissipation between the two methods, and is calculated from the two existing power curves, which were themselves calculated from the raw voltage and current vectors.
  11. You can press the Home key to zoom to the full extent of the waveform viewer.

You can now zoom on the waveform viewer and easily see that the power difference is the power coming into and out of the gate terminal.

Conclusions and Key Points to Remember

  • The arbitrary fixed probe allows you to automatically plot an expression of voltages and currents after each simulation run.
  • The Define Curve dialog allows you to interactively plot mathematical expressions of different vectors.
  • When creating curves interactively, the curve to be plotted can be made up of existing graph curves, schematic nodes, or a combination of both.