docs.javahelp.manual.boxes.graph.dag.html Maven / Gradle / Ivy
Graph
Directed Acyclic Graph
If you choose "Directed Acyclic Graph," (DAG) you will be limited to constructing directed acyclic graphs.
That is, you will only be allowed to constructed directed (-->) edges, and you will not be permitted to construct
cycles in your graph (X-->...-->X for some variable X in your graph).
To construct a DAG graph, place a Graph box on the workbench (see Graphs),
double click the Graph box, choose "Directed Acyclic Graph " from the menu, and click "OK." Once
you click "OK," you will be given a choice either to generate your own graph by hand or to have the
program generate a graph for you with a specified number of variables, variable values, and directed edges:
If you select "Created manually" and click "OK," a blank graph editor window is opened. If you
select "A random DAG," you will need to fill in parameters to generate a random DAG. See Generating
Random DAGs for more information.
You may at this point add variables and edges to the graph, or remove them if they're already there. To add a
measured variable to the graph, click "Add Variable" and then click in the white workbench area where you
want the measured variable to be located. To add a latent variable to the graph, click "Add Latent" and
then click in the white workbench area where you want the latent variable to be located. The names of an added
variable will be the first name in the sequence X1, X2, ..., that's not already in the graph. These names may be
changed; see Editing Node Properties for details.
To remove a variable from the graph, click on the variable you want to delete to select it and then press the delete
key. If you remove a node from the graph, all of the edges attached to it will be removed as well.
To add an edge to the graph, click the type of edge you want to add, click and hold the mouse button down over the
variable you want to edge to be from, and then drag the mouse to the variable you want the edge to be to. For a DAG,
you are limited to one type of edge--viz., a directed edge (-->). You are also prevented from forming cycles (X-->...-->X
for some variable X). If you attempt to add an edge that would form a cycle, the edge simply won't be added.
To remove an edge from the graph, click on the edge you want to remove to select it and then press the delete
key.
If all you want to do is change the directions of edges, there is a shortcut way to do this. Simply click on the
endpoint of the edge you want the arrow to be on, and the edge will change direction for you. See Edge Orientation Shortcuts.
A sample graph might look like this, after adding three variable and two edges:
Once you have made a graph, you may rearrange the nodes by clicking and dragging; the edges will follow along so taht
the structure of the graph remains the same. If you would like to move a whole section of nodes to another location,
draw a "rubberband" around them and click on any one to move them. See Selecting Groups of Nodes for details. If you
would like to change the name of a variable, or change whether the variable is latent or measured, double click the
variable, edit its properties, and click "OK." See Editing Node Properties for details.
When you click "Save," the graph editor window will close, and the contents will be saved in memory. If you
click "Cancel," the changes you made while editing will be disgarded, and the state of the graph before
editing will remain unchanged. You may change the graph you made at any time by reopening the Graph box and adding
or remove variables or edges or rearranging variables.
If you right click on the Graph box, a popup menu will appear with several options. See Popup Menus for more detail.
Important Points.
- If you create a model with a latent variable, if you later use the model to generate data, values for the latent
variables will not be shown. See Measured Vs. Latent Variables.
- If you have introduced any boxes that depend on a Graph box, changing the graph will alter the contents of all
boxes downstream in the flowchart from the Graph box. Often it is easier to simply create a new Graph box in the
same main workspace window--there is no limit to how many graph or other boxes you can have at the same time.
See Flowchart Dependencies.
Possible Parents for "Directed Acyclic Graph"
A "Directed Acyclic Graph" model can be self-standing, as described above. However, it can also be made a
child of a number of other models of a variety of different box types. Usually what this does is to make a copy in
the "Directed Acyclic Graph" box of a preexisting graph in the parent model, which is often a convenient
thing to be able to do. The following models all have graphs that, if they happen to be DAGs, can be copied into a
"Directed Acyclic Graph" model:
- All graph models.
- All search models.
- All parametric models.
- All instantiated models.
- All updater models.
In certain special cases, making a "Directed Acyclic Graph" model a child of another model has a
specialized behavior. If you make a "Directed Acyclic Graph" model a child of a Data box model, the effect
is to create a graph with all of the variables in the data set but no edges, as illustrated below.