This document is an automatically generated cross reference for the ergm model terms from the stanet project.  The source for this data and additional descriptions are in the ?ergm.terms help file or the ergm manual. 
For convenience, this table lists a subset of the most commonly-used ergm terms and categories.
This table lists the complete set of terms available in the ergm package. In HTML versions, clicking on a term name will jump to its definition. 
This table lists full definitions for all of the terms along with their tags.  Note that some terms may have multiple versions (e.g. valued vs. binary) with slightly different arguments and will be listed more than once with the same definition. 
>| Description | Categories | 
| absdiff(attrname, pow=1) 
 Absolute difference: The attrnameargument is a character string giving the name of a quantitative attribute in the network’s vertex attribute list. This term adds one network statistic to the model equaling the sum ofabs(attrname[i]-attrname[j])^powfor all edges (i,j) in the network. | binary, dyad-independent, frequently-used, directed, undirected, quantitative nodal attribute | 
| absdiff(attrname, pow=1, form =“sum”) 
 Absolute difference: The attrnameargument is a character string giving the name of a quantitative attribute in the network’s vertex attribute list. This term adds one network statistic to the model equaling the sum ofabs(attrname[i]-attrname[j])^powfor all edges (i,j) in the network. | valued, dyad-independent, directed, undirected, quantitative nodal attribute | 
| absdiffcat(attrname, base=NULL) 
 Categorical absolute difference:  The attrnameargument is a character string giving the name of a quantitative attribute in the network’s vertex attribute list. This term adds one statistic for every possible nonzero distinct value ofabs(attrname[i]-attrname[j])in the network; the value of each such statistic is the number of edges in the network with the corresponding absolute difference. The optionalbaseargument is a vector indicating which nonzero differences, in order from smallest to largest, should be omitted from the model (i.e., treated like the zero-difference category). Thebaseargument, if used, should contain indices, not differences themselves. For instance, if the possible values ofabs(attrname[i]-attrname[j])are 0, 0.5, 3, 3.5, and 10, then to omit 0.5 and 10 one should setbase=c(1, 4). Note that this term should generally be used only when the quantitative attribute has a limited number of possible values; an example is the"Grade"attribute of thefaux.mesa.highorfaux.magnolia.highdatasets. | binary, dyad-independent, directed, undirected, categorical nodal attribute | 
| absdiffcat(attrname, base=NULL, form=“sum”) 
 Categorical absolute difference:  The attrnameargument is a character string giving the name of a quantitative attribute in the network’s vertex attribute list. This term adds one statistic for every possible nonzero distinct value ofabs(attrname[i]-attrname[j])in the network; the value of each such statistic is the number of edges in the network with the corresponding absolute difference. The optionalbaseargument is a vector indicating which nonzero differences, in order from smallest to largest, should be omitted from the model (i.e., treated like the zero-difference category). Thebaseargument, if used, should contain indices, not differences themselves. For instance, if the possible values ofabs(attrname[i]-attrname[j])are 0, 0.5, 3, 3.5, and 10, then to omit 0.5 and 10 one should setbase=c(1, 4). Note that this term should generally be used only when the quantitative attribute has a limited number of possible values; an example is the"Grade"attribute of thefaux.mesa.highorfaux.magnolia.highdatasets. | valued, dyad-independent, directed, undirected, categorical nodal attribute | 
| altkstar(lambda, fixed=FALSE) 
 Alternating k-star:  This term adds one network statistic to the model equal to a weighted alternating sequence of k-star statistics with weight parameter lambda. This is the version given in Snijders et al. (2006). Thegwdegreeandaltkstarproduce mathematically equivalent models, as long as they are used together with theedges(orkstar(1)) term, yet the interpretation of thegwdegreeparameters is slightly more straightforward than the interpretation of thealtkstarparameters. For this reason, we recommend the use of thegwdegreeinstead ofaltkstar. See Section 3 and especially equation (13) of Hunter (2007) for details. The optional argumentfixedindicates whether thedecayparameter is fixed at the given value, or is to be fit as a curved exponential family model (see Hunter and Handcock, 2006). The default isFALSE, which means the scale parameter is not fixed and thus the model is a CEF model. This term can only be used with undirected networks. | binary, undirected, curved, categorical nodal attribute | 
| asymmetric(attrname=NULL, diff=FALSE, keep=NULL) 
 Asymmetric dyads: This term adds one network statistic to the model equal to the number of pairs of actors for which exactly one of (i,j) or (j,i) exists. This term can only be used with directed networks. If the optional attrnameargument is used, only asymmetric pairs that match on the named vertex attribute are counted. The optional modifiersdiffandkeepare used in the same way as for thenodematchterm; refer to this term for details and an example. | binary, directed, dyad-independent, triad-related | 
| atleast(threshold=0) 
 Number of dyads with values greater than or equal to a threshold Adds one statistic equaling to the number of dyads whose values equal or exceed threshold. | valued, directed, undirected, dyad-independent | 
| atmost(threshold=0) 
 Number of dyads with values less than or equal to a threshold Adds one statistic equaling to the number of dyads whose values equal or are exceeded by threshold. | valued, directed, undirected, dyad-independent | 
| b1concurrent(by=NULL, levels=NULL) 
 Concurrent node count for the first mode in a bipartite (aka two-mode) network: This term adds one network statistic to the model, equal to the number of nodes in the first mode of the network with degree 2 or higher. The first mode of a bipartite network object is sometimes known as the “actor” mode. The optional argument byis a character string giving the name of an attribute in the network’s vertex attribute list; it functions just like thebyargument of theb1degreeterm. Without the optional argument, this statistic is equivalent tob1mindegree(2). This term can only be used with undirected bipartite networks. | binary, bipartite, undirected, categorical nodal attribute | 
| b1cov(attrname, transform, transformname) 
 Main effect of a covariate for the first mode in a bipartite (aka two-mode) network:  The attrnameargument is a character string giving the name of a numeric (not categorical) attribute in the network’s vertex attribute list. This term adds a single network statistic to the model equaling the total value ofattrname(i)for all edges (i,j) in the network. This term may only be used with bipartite networks. For categorical attributes, seeb1factor. | binary, undirected, bipartite, dyad-independent, quantitative nodalattribute, frequently-used | 
| b1cov(attrname, transform, transformname, form=“sum”) 
 Main effect of a covariate for the first mode in a bipartite (aka two-mode) network:  The attrnameargument is a character string giving the name of a numeric (not categorical) attribute in the network’s vertex attribute list. This term adds a single network statistic to the model equaling the total value ofattrname(i)for all edges (i,j) in the network. This term may only be used with bipartite networks. For categorical attributes, seeb1factor. | valued, undirected, bipartite, dyad-independent, quantitative nodal attribute, frequently-used | 
| b1degrange(from, to=+Inf, by=NULL, homophily=FALSE, levels=NULL) 
 Degree range for the first mode in a bipartite (a.k.a. two-mode) network:  The fromandtoarguments are vectors of distinct integers (or+Inf, forto(its default)). If one of the vectors has length 1, it is recycled to the length of the other. Otherwise, they must have the same length. This term adds one network statistic to the model for each element offrom(orto); the ith such statistic equals the number of nodes of the first mode (“actors”) in the network of degree greater than or equal tofrom[i]but strictly less thanto[i], i.e. with edge count in semiopen interval[from,to). The optional argumentbyis a character string giving the name of an attribute in the network’s vertex attribute list.  If this is specified andhomophilyisTRUE, then degrees are calculated using the subnetwork consisting of only edges whose endpoints have the same value of thebyattribute. Ifbyis specified andhomophilyisFALSE(the default), then separate degree range statistics are calculated for nodes having each separate value of the attribute. This term can only be used with bipartite networks; for directed networks see idegrangeandodegrange. For undirected networks, seedegrange, and seeb2degrangefor degrees of the second mode (“events”). | binary, bipartite, undirected | 
| b1degree(d, by=NULL, levels=NULL) 
 Degree for the first mode in a bipartite (aka two-mode) network: The dargument is a vector of distinct integers. This term adds one network statistic to the model for each element ind; the ith such statistic equals the number of nodes of degreed[i]in the first mode of a bipartite network, i.e. with exactlyd[i]edges. The first mode of a bipartite network object is sometimes known as the “actor” mode. The optional argumentbyis a character string giving the name of an attribute in the network’s vertex attribute list. If this is specified  then each node’s degree is tabulated only with other nodes having the same value of thebyattribute. This term can only be used with undirected bipartite networks. | binary, bipartite, undirected, categorical nodal attribute, frequently-used | 
| b1factor(attrname, base=1, levels=NULL) 
 Factor attribute effect for the first mode in a bipartite (aka two-mode) network:  The attrnameargument is a character string giving the name of a categorical attribute in the network’s vertex attribute list. This term adds multiple network statistics to the model, one for each of (a subset of) the unique values of theattrnameattribute. Each of these statistics gives the number of times a node with that attribute in the first mode of the network appears in an edge. The first mode of a bipartite network object is sometimes known as the “actor” mode. To include all attribute values is usually not a good idea, because the sum of all such statistics equals the number of edges and hence a linear dependency would arise in any model also includingedges. Thus, thebaseargument tells which value(s) (numbered in order according to thesortfunction) should be omitted. The default value,base=1, means that the smallest (i.e., first in sorted order) attribute value is omitted. For example, if the “fruit” factor has levels “orange”, “apple”, “banana”, and “pear”, then to add just two terms, one for “apple” and one for “pear”, then set “banana” and “orange” to the base (remember to sort the values first) by usingnodefactor("fruit",     base=2:3). This term can only be used with undirected bipartite networks. | binary, bipartite, undirected, dyad-independent, frequently-used, categorical nodal attribute | 
| b1factor(attrname, base=1, levels=NULL, form=“sum”) 
 Factor attribute effect for the first mode in a bipartite (aka two-mode) network:  The attrnameargument is a character string giving the name of a categorical attribute in the network’s vertex attribute list. This term adds multiple network statistics to the model, one for each of (a subset of) the unique values of theattrnameattribute. Each of these statistics gives the number of times a node with that attribute in the first mode of the network appears in an edge. The first mode of a bipartite network object is sometimes known as the “actor” mode. To include all attribute values is usually not a good idea, because the sum of all such statistics equals the number of edges and hence a linear dependency would arise in any model also includingedges. Thus, thebaseargument tells which value(s) (numbered in order according to thesortfunction) should be omitted. The default value,base=1, means that the smallest (i.e., first in sorted order) attribute value is omitted. For example, if the “fruit” factor has levels “orange”, “apple”, “banana”, and “pear”, then to add just two terms, one for “apple” and one for “pear”, then set “banana” and “orange” to the base (remember to sort the values first) by usingnodefactor("fruit",     base=2:3). This term can only be used with undirected bipartite networks. | valued, bipartite, undirected, dyad-independent, frequently-used, categorical nodal attribute | 
| b1mindegree(d) 
 Minimum degree for the first mode in a bipartite (aka two-mode) network: The dargument is a vector of distinct integers. This term adds one network statistic to the model for each element ind; the ith such statistic equals the number of nodes in the first mode of a bipartite network with at least degreed[i].  The first mode of a bipartite network object is sometimes known as the “actor” mode. This term can only be used with undirected bipartite networks. | binary, bipartite, undirected | 
| b1nodematch(attrname, diff=FALSE, keep=NULL, by=NULL, alpha=1, beta=1, ) 
 Nodal attribute-based homophily effect for the first mode in a bipartite (aka two-mode) network:  This term is introduced in Bomiriya et al (2014). The attrnameargument is a character string giving the name of a categorical attribute in the network’s vertex attribute list. Out of the two arguments (discount parameters)alphaandbeta, both which takes values from [0,1],  only one should be set at a time. If none is set to a value other than 1, this term will  simply be a homophily based two-star statistic. This term adds one statistic to the model  unlessdiffis set toTRUE, in which case the term adds multiple network  statistics to the model, one for each of (a subset of) the unique values of theattrnameattribute. To include only the attribute values you wish, use thekeepargument.  If analphadiscount parameter is used, each of these statistics gives the sum of  the number of common second-mode nodes raised to the poweralphafor each pair of  first-mode nodes with that attribute. If abetadiscount parameter is used, each  of these statistics gives half the sum of the number of two-paths with two first-mode nodes  with that attribute as the two ends of the two path raised to the powerbetafor each  edge in the network. Thebyb2attrargument is a character string giving the name of a second mode categorical attribute in the network’s attribute list. Setting this argument will separate the orginal statistics based on the values of the set second mode attribute— i.e. for example, ifdiffisFALSE, then the sum of all the statistics for  each level of this second-mode attribute will be equal to the originalb1nodematchstatistic wherebyb2attrset toNULL. This term can only be used with  undirected bipartite networks. | binary, bipartite, undirected, dyad-independent, categorical nodal attribute, frequently-used | 
| b1star(k, attrname=NULL, levels=NULL) 
 k-Stars for the first mode in a bipartite (aka two-mode) network:  The kargument is a vector of distinct integers. This term adds one network statistic to the model for each element ink. The ith such statistic counts the number of distinctk[i]-stars whose center node is in the first mode of the network. The first mode of a bipartite network object is sometimes known as the “actor” mode. A k-star is defined to be a center node N and a set of k different nodes \{O_1, …, O_k\} such that the ties \{N, O_i\} exist for i=1, …, k. The optional argumentattrnameis a character string giving the name of an attribute in the network’s vertex attribute list. If this is specified then the count is over the number of k-stars (with center node in the first mode) where all nodes have the same value of the attribute. This term can only be used for undirected bipartite networks. Note thatb1star(1)is equal tob2star(1)and toedges. | binary, bipartite, undirected, categorical nodal attribute | 
| b1starmix(k, attrname, base=NULL, diff=TRUE, levels=NULL) 
  Mixing matrix for k-stars centered on the first mode of a bipartite network: Only a single value of k is allowed. This term counts all k-stars in which the b2 nodes (called events in some contexts) are homophilous in the sense that they all share the same value of attrname. However, the b1 node (in some contexts, the actor) at the center of the k-star does NOT have to have the same value as the b2 nodes; indeed, the values taken by the b1 nodes may be completely distinct from those of the b2 nodes, which allows for the use of this term in cases where there are two separate nodal attributes, one for the b1 nodes and another for the b2 nodes (in this case, however, these two attributes should be combined to form a single nodal attribute calledattrname. A different statistic is created for each value ofattrnameseen in a b1 node, even if no k-stars are observed with this value. Whether a different statistic is created for each value seen in a b2 node depends on the value of thediffargument: Whendiff=TRUE, the default, a different statistic is created for each value and thus the behavior of this term is reminiscent of thenodemixterm, from which it takes its name; whendiff=FALSE, all homophilous k-stars are counted together, though these k-stars are still categorized according to the value of the central b1 node. Thebaseterm may be used to control which of the possible terms are left out of the model: By default, all terms are included, but ifbaseis set to a vector of indices then the corresponding terms (in the order they would be created whenbase=NULL) are left out. | binary, bipartite, undirected, categorical nodal attribute | 
| b1twostar(b1attrname, b2attrname, base=NULL, b1levels=NULL, b2levels=NULL) 
  Two-star census for central nodes centered on the first mode of a bipartite network: This term takes two nodal attribute names, one for b1 nodes (actors in some contexts) and one for b2 nodes (events in some contexts). Only b1attrnameis required; ifb2attrnameis not passed, it is assumed to be the same asb1attrname. Assuming that there are n_1 values ofb1attrnameamong the b1 nodes and n_2 values ofb2attrnameamong the b2 nodes, then the total number of distinct categories of two stars according to these two attributes is n_1(n_2)(n_2+1)/2. This model term creates a distinct statistic counting each of these categories. Thebaseterm may be used to leave some of these categories out; when passed as a vector of integer indices (in the order the statistics would be created whenbase=NULL), the corresponding terms will be left out. | binary, bipartite, undirected, categorical nodal attribute | 
| b2concurrent(by=NULL) 
 Concurrent node count for the second mode in a bipartite (aka two-mode) network: This term adds one network statistic to the model, equal to the number of nodes in the second mode of the network with degree 2 or higher. The second mode of a bipartite network object is sometimes known as the “event” mode. The optional argument byis a character string giving the name of an attribute in the network’s vertex attribute list; it functions just like thebyargument of theb2degreeterm. Without the optional argument, this statistic is equivalent tob2mindegree(2). This term can only be used with undirected bipartite networks. | binary, bipartite, undirected, frequently-used | 
| b2cov(attrname, transform, transformname) 
 Main effect of a covariate for the second mode in a bipartite (aka two-mode) network:  The attrnameargument is a character string giving the name of a numeric (not categorical) attribute in the network’s vertex attribute list. This term adds a single network statistic to the model equaling the total value ofattrname(j)for all edges (i,j) in the network. This term may only be used with bipartite networks. For categorical attributes, seeb2factor. | binary, undirected, bipartite, dyad-independent, quantitative nodal attribute, frequently-used | 
| b2cov(attrname, transform, transformname, form=“sum”) 
 Main effect of a covariate for the second mode in a bipartite (aka two-mode) network:  The attrnameargument is a character string giving the name of a numeric (not categorical) attribute in the network’s vertex attribute list. This term adds a single network statistic to the model equaling the total value ofattrname(j)for all edges (i,j) in the network. This term may only be used with bipartite networks. For categorical attributes, seeb2factor. | valued, undirected, bipartite, dyad-independent, quantitative nodal attribute, frequently-used | 
| b2degrange(from, to=+Inf, by=NULL, homophily=FALSE, levels=NULL) 
 Degree range for the second mode in a bipartite (a.k.a. two-mode) network:  The fromandtoarguments are vectors of distinct integers (or+Inf, forto(its default)). If one of the vectors has length 1, it is recycled to the length of the other. Otherwise, they must have the same length. This term adds one network statistic to the model for each element offrom(orto); the ith such statistic equals the number of nodes of the second mode (“events”) in the network of degree greater than or equal tofrom[i]but strictly less thanto[i], i.e. with edge count in semiopen interval[from,to). The optional argumentbyis a character string giving the name of an attribute in the network’s vertex attribute list.  If this is specified andhomophilyisTRUE, then degrees are calculated using the subnetwork consisting of only edges whose endpoints have the same value of thebyattribute. Ifbyis specified andhomophilyisFALSE(the default), then separate degree range statistics are calculated for nodes having each separate value of the attribute. This term can only be used with bipartite networks; for directed networks see idegrangeandodegrange. For undirected networks, seedegrange, and seeb1degrangefor degrees of the first mode (“actors”). | binary, bipartite, undirected | 
| b2degree(d, by=NULL) 
 Degree for the second mode in a bipartite (aka two-mode) network: The dargument is a vector of distinct integers. This term adds one network statistic to the model for each element ind; the ith such statistic equals the number of nodes of degreed[i]in the second mode of a bipartite network, i.e. with exactlyd[i]edges. The second mode of a bipartite network object is sometimes known as the “event” mode. The optional termbyis a character string giving the name of an attribute in the network’s vertex attribute list. If this is specified  then each node’s degree is tabulated only with other nodes having the same value of thebyattribute. This term can only be used with undirected bipartite networks. | binary, bipartite, undirected, categorical nodal attribute, frequently-used | 
| b2factor(attrname, base=1, levels=NULL) 
 Factor attribute effect for the second mode in a bipartite (aka two-mode) network :  The attrnameargument is a character string giving the name of a categorical attribute in the network’s vertex attribute list. This term adds multiple network statistics to the model, one for each of (a subset of) the unique values of theattrnameattribute. Each of these statistics gives the number of times a node with that attribute in the second mode of the network appears in an edge. The second mode of a bipartite network object is sometimes known as the “event” mode. To include all attribute values is usually not a good idea, because the sum of all such statistics equals the number of edges and hence a linear dependency would arise in any model also includingedges. Thus, thebaseargument tells which value(s) (numbered in order according to thesortfunction) should be omitted. The default value,base=1, means that the smallest (i.e., first in sorted order) attribute value is omitted. For example, if the “fruit” factor has levels “orange”, “apple”, “banana”, and “pear”, then to add just two terms, one for “apple” and one for “pear”, then set “banana” and “orange” to the base (remember to sort the values first) by usingnodefactor("fruit", base=2:3). This term can only be used with undirected bipartite networks. | binary, bipartite, undirected, dyad-independent, categorical nodal attribute, frequently-used | 
| b2factor(attrname, base=1, levels=NULL, form=“sum”) 
 Factor attribute effect for the second mode in a bipartite (aka two-mode) network :  The attrnameargument is a character string giving the name of a categorical attribute in the network’s vertex attribute list. This term adds multiple network statistics to the model, one for each of (a subset of) the unique values of theattrnameattribute. Each of these statistics gives the number of times a node with that attribute in the second mode of the network appears in an edge. The second mode of a bipartite network object is sometimes known as the “event” mode. To include all attribute values is usually not a good idea, because the sum of all such statistics equals the number of edges and hence a linear dependency would arise in any model also includingedges. Thus, thebaseargument tells which value(s) (numbered in order according to thesortfunction) should be omitted. The default value,base=1, means that the smallest (i.e., first in sorted order) attribute value is omitted. For example, if the “fruit” factor has levels “orange”, “apple”, “banana”, and “pear”, then to add just two terms, one for “apple” and one for “pear”, then set “banana” and “orange” to the base (remember to sort the values first) by usingnodefactor("fruit", base=2:3). This term can only be used with undirected bipartite networks. | valued, bipartite, undirected, dyad-independent, categorical nodal attribute, frequently-used | 
| b2mindegree(d) 
 Minimum degree for the second mode in a bipartite (aka two-mode) network: The dargument is a vector of distinct integers. This term adds one network statistic to the model for each element ind; the ith such statistic equals the number of nodes  in the second mode of a bipartite network with at least degreed[i].  The second mode of a bipartite network object is sometimes known as the “event” mode. This term can only be used with undirected bipartite networks. | binary, bipartite, undirected | 
| b2nodematch(attrname, diff=FALSE, keep=NULL, by=NULL, alpha=1, beta=1, ) 
 Nodal attribute-based homophily effect for the second mode in a bipartite (aka two-mode) network: This term is introduced in Bomiriya et al (2014). The attrnameargument is a character string giving the name of a categorical attribute in the network’s vertex attribute list. Out of the two arguments (discount parameters)alphaandbeta, both which takes values from [0,1],  only one should be set at a time. If none is set to a value other than 1, this term will  simply be a homophily based two-star statistic. This term adds one statistic to the model  unlessdiffis set toTRUE, in which case the term adds multiple network  statistics to the model, one for each of (a subset of) the unique values of theattrnameattribute. To include only the attribute values you wish, use thekeepargument.  If analphadiscount parameter is used, each of these statistics gives the sum of  the number of common first-mode nodes raised to the poweralphafor each pair of  second-mode nodes with that attribute. If abetadiscount parameter is used, each  of these statistics gives half the sum of the number of two-paths with two second-mode nodes  with that attribute as the two ends of the two path raised to the powerbetafor each  edge in the network. Thebyb1attrargument is a character string giving the name of a first mode categorical attribute in the network’s attribute list. Setting this argument will separate the orginal statistics based on the values of the set first mode attribute— i.e. for example, ifdiffisFALSE, then the sum of all the statistics for  each level of this first-mode attribute will be equal to the originalb2nodematchstatistic wherebyb1attrset toNULL. This term can only be used with  undirected bipartite networks. | binary, bipartite, undirected, dyad-independent, categorical nodal attribute, frequently-used | 
| b2star(k, attrname=NULL, levels=NULL) 
 k-Stars for the second mode in a bipartite (aka two-mode) network:  The kargument is a vector of distinct integers. This term adds one network statistic to the model for each element ink. The ith such statistic counts the number of distinctk[i]-stars whose center node is in the second mode of the network. The second mode of a bipartite network object is sometimes known as the “event” mode. A k-star is defined to be a center node N and a set of k different nodes \{O_1, …, O_k\} such that the ties \{N, O_i\} exist for i=1, …, k. The optional argumentattrnameis a character string giving the name of an attribute in the network’s vertex attribute list. If this is specified then the count is over the number of k-stars (with center node in the second mode) where all nodes have the same value of the attribute. This term can only be used for undirected bipartite networks. Note thatb2star(1)is equal tob1star(1)and toedges. | binary, bipartite, undirected, categorical nodal attribute | 
| b2starmix(k, attrname, base=NULL, diff=TRUE, levels=NULL) 
  Mixing matrix for k-stars centered on the second mode of a bipartite network:  This term is exactly the same as b1starmixexcept that the roles of b1 and b2 are reversed. | binary, bipartite, undirected, categorical nodal attribute | 
| b2twostar(b1attrname, b2attrname, base=NULL, b1levels=NULL, b2levels=NULL) 
  Two-star census for central nodes centered on the second mode of a bipartite network: This term is exactly the same as b1twostarexcept that the roles of b1 and b2 are reversed. | binary, bipartite, undirected, categorical nodal attribute | 
| balance() 
 Balanced triads:  This term adds one network statistic to the model equal to the number of triads in the network that are balanced. The balanced triads are those of type 102or300in the categorization of Davis and Leinhardt (1972). For details on the 16 possible triad types, see?triad.classifyin the{sna}package. For an undirected network, the balanced triads are those with an even number of ties (i.e., 0 and 2). | binary, triad-related, directed, undirected | 
| coincidence(d=NULL,active=0) 
 Coincident node count for the second mode in a bipartite (aka two-mode) network: By default this term adds one network statistic to the model for each pair of nodes of mode two. It is equal to the number of (first mode) mutual partners of that pair. The first mode of a bipartite network object is sometimes known as the “actor” mode and the seconds as the “event” mode. So this is the number of actors going to both events in the pair. The optional argument dis a two-column matrix of (row-wise) pairs indices where the first row is less than the second row. The second optional argument,active, selects pairs for which the observed count is at leastactive. This term can only be used with undirected bipartite networks. | binary, bipartite, undirected | 
| concurrent(by=NULL, levels=NULL) 
 Concurrent node count:  This term adds one network statistic to the model, equal to the number of nodes in the network with degree 2 or higher. The optional argument byis a character string giving the name of an attribute in the network’s vertex attribute list; it functions just like thebyargument of thedegreeterm. This term can only be used with undirected networks. | binary, undirected, categorical nodal attribute | 
| concurrentties(by=NULL, levels=NULL) 
 Concurrent tie count:  This term adds one network statistic to the model, equal to the number of ties incident on each actor beyond the first. The optional argument byis a character string giving the name of an attribute in the network’s vertex attribute list; it functions just like thebyargument of thedegreeterm. This term can only be used with undirected networks. | binary, undirected, categorical nodal attribute | 
| ctriple(attrname=NULL, levels=NULL) 
 Cyclic triples: This term adds one statistic to the model, equal to the number of cyclic triples in the network, defined as a set of edges of the form {(i,j), (j,k), (k,i)}. Note that for all directed networks, triangleis equal tottriple+ctriple, so at most two of these three terms can be in a model. The optional argumentattrnameis a character string giving the name of an attribute in the network’s vertex attribute list. If this is specified then the count is over the number of cyclic triples where all three nodes have the same value of the attribute. This term can only be used with directed networks. | binary, directed, triad-related, categorical nodal attribute | 
| ctriad() 
 Cyclic triples: This term adds one statistic to the model, equal to the number of cyclic triples in the network, defined as a set of edges of the form {(i,j), (j,k), (k,i)}. Note that for all directed networks, triangleis equal tottriple+ctriple, so at most two of these three terms can be in a model. The optional argumentattrnameis a character string giving the name of an attribute in the network’s vertex attribute list. If this is specified then the count is over the number of cyclic triples where all three nodes have the same value of the attribute. This term can only be used with directed networks. | binary, directed, triad-related, categorical nodal attribute | 
| cycle(k) 
 Cycles:  The kargument is a vector of distinct integers. This term adds one network statistic to the model for each element ink; the ith such statistic equals the number of cycles in the network with length exactlyk[i]. The cycle statistic applies to both directed and undirected networks. For directed networks, it counts directed cycles of length k, as opposed to undirected cycles in the undirected case. The directed cycle terms of lengths 2 and 3 are equivalent tomutualandctriple(respectively). The undirected cycle term of length 3 is equivalent totriangle, and there is no undirected cycle term of length 2. | binary, directed, undirected | 
| cyclicalties(attrname=NULL, levels=NULL) 
 Cyclical ties:  This term adds one statistic, equal to the number of ties  i–>j such that there exists a two-path from i to j.  (Related to the ttripleterm.) The binary version takes a nodal attributeattrname, and, if given, all three nodes involved (i, j, and the node on the two-path) must match on this attribute in order for i–>j to be counted. The binary version of this term can only be used with directed networks. The valued version can be used with both directed and undirected. | binary, directed | 
| cyclicalties(threshold=0) 
 Cyclical ties:  This term adds one statistic, equal to the number of ties  i–>j such that there exists a two-path from i to j.  (Related to the ttripleterm.) The binary version takes a nodal attributeattrname, and, if given, all three nodes involved (i, j, and the node on the two-path) must match on this attribute in order for i–>j to be counted. The binary version of this term can only be used with directed networks. The valued version can be used with both directed and undirected. | valued, directed, undirected | 
| cyclicalweights(twopath=“min”,combine=“max”,affect=“min”) 
 Cyclical weights: This statistic implements the cyclical weights statistic, like that defined by Krivitsky (2012), Equation 13, but with the focus dyad being y_{j,i} rather than y_{i,j}. The currently implemented options for twopathis the minimum of the constituent dyads ("min") or their geometric mean ("geomean"); forcombine, the maximum of the 2-path strengths ("max") or their sum ("sum"); and foraffect, the minimum of the focus dyad and the combined strength of the two paths ("min") or their geometric mean ("geomean"). For each of these options, the first (and the default) is more stable but also more conservative, while the second is more sensitive but more likely to induce a multimodal distribution of networks. | valued, directed, undirected | 
| ddsp(d, type=“OTP”) 
 Directed dyadwise shared partners: This term adds one network statistic to the model for each element in dwhere the ith such statistic equals the number of dyads in the network with exactlyd[i]shared partners. This term can only be used with directed networks.  Multiple shared partner definitions are possible; thetypeargument may be used to select the type of shared partner to be counted (see below for type codes).  By default, outgoing two-paths are employed. While there is only one shared partner configuration in the undirected case, nine distinct configurations are possible for directed graphs.  Currently, edgewise shared partner terms may be defined with respect to five of these configurations; they are defined here as follows (using terminology from Butts (2008) and the releventpackage):  Outgoing Two-path (OTP)vertex k is an OTP shared partner of ordered pair (i,j) iff i->k->j. Also known as “transitive shared partner”.Incoming Two-path (ITP)vertex k is an ITP shared partner of ordered pair (i,j) iff j->k->i. Also known as “cyclical shared partner”Outgoing Shared Partner (OSP)vertex k is an OSP shared partner of ordered pair (i,j) iff i->k, j->k.Incoming Shared Partner (ISP)vertex k is an ISP shared partner of ordered pair (i,j) iff k->i, k->j. Note that Robins et al. (2009) define closely related statistics to several of the above, using slightly different terminology.  | binary, directed | 
| degrange(from, to=+Inf, by=NULL, homophily=FALSE, levels=NULL) 
 Degree range:  The fromandtoarguments are vectors of distinct integers (or+Inf, forto(its default)). If one of the vectors has length 1, it is recycled to the length of the other. Otherwise, they must have the same length. This term adds one network statistic to the model for each element offrom(orto); the ith such statistic equals the number of nodes in the network of degree greater than or equal tofrom[i]but strictly less thanto[i], i.e. with edges in semiopen interval[from,to). The optional argumentbyis a character string giving the name of an attribute in the network’s vertex attribute list.  If this is specified andhomophilyisTRUE, then degrees are calculated using the subnetwork consisting of only edges whose endpoints have the same value of thebyattribute. Ifbyis specified andhomophilyisFALSE(the default), then separate degree range statistics are calculated for nodes having each separate value of the attribute. This term can only be used with undirected networks; for directed networks see idegrangeandodegrange. This term can be used with bipartite networks, and will count nodes of both first and second mode in the specified degree range. To count only nodes of the first mode (“actors”), useb1degrangeand to count only those fo the second mode (“events”), useb2degrange. | binary, undirected, categorical nodal attribute | 
| degree(d, by=NULL, homophily=FALSE, levels=NULL) 
 Degree:  The dargument is a vector of distinct integers. This term adds one network statistic to the model for each element ind; the ith such statistic equals the number of nodes in the network of degreed[i], i.e. with exactlyd[i]edges. The optional argumentbyis a character string giving the name of an attribute in the network’s vertex attribute list.  If this is specified andhomophilyisTRUE, then degrees are calculated using the subnetwork consisting of only edges whose endpoints have the same value of thebyattribute. Ifbyis specified andhomophilyisFALSE(the default), then separate degree  statistics are calculated for nodes having each separate value of the attribute. This term can only be used with undirected networks; for directed networks seeidegreeandodegree. | binary, undirected, categorical nodal attribute, frequently-used | 
| degree1.5() 
 Degree to the 3/2 power: This term adds one network statistic to the model equaling the sum over the actors of each actor’s degree taken to the 3/2 power (or, equivalently, multiplied by its square root). This term is an undirected analog to the terms of Snijders et al. (2010), equations (11) and (12). This term can only be used with undirected networks.  | binary, undirected | 
| degreepopularity() 
 Degree popularity (deprecated): see degree1.5. | binary, undirected, deprecated | 
| degcrossprod() 
 Degree Cross-Product:  This term adds one network statistic equal to the mean of the cross-products of the degrees of all pairs of nodes in the network which are tied. Only coded for undirected networks.  | binary, undirected | 
| degcor() 
 Degree Correlation:  This term adds one network statistic equal to the correlation  of the degrees of all pairs of nodes in the network which are tied. Only coded for undirected networks.  | binary, undirected | 
| density() 
 Density:  This term adds one network statistic equal to the density of the network. For undirected networks, densityequalskstar(1)oredgesdivided by n(n-1)/2; for directed networks,densityequalsedgesoristar(1)orostar(1)divided by n(n-1). | binary, dyad-independent, directed, undirected | 
| diff(attrname, pow=1, dir=“t-h”, sign.action=“identity”) 
 Difference: The attrnameargument is a character string giving the name of a quantitative attribute in the network’s vertex attribute list. For values ofpowother than0, this term adds one network statistic to the model, equaling the sum, over directed edges (i,j), ofsign.action(attrname[i]-attrname[j])^powifdiris"t-h"(the default),"tail-head", or"b1-b2"and ofsign.action(attrname[j]-attrname[i])^powif"h-t","head-tail", or"b2-b1". That is, the argumentdirdetermines which vertex’s attribute is subtracted from which, with tail being the origin of a directed edge and head being its destination, and bipartite networks' edges being treated as going from the first part (b1) to the second (b2). If pow==0, the exponentiation is replaced by the signum function:+1if the difference is positive,0if there is no difference, and-1if the difference is negative. Note that this function is applied after thesign.action. The comparison is exact, so when using calculated values ofattrname, ensure that values that you want to be considered equal are, in fact, equal. The following sign.actionsare possible:  "identity"(the default)no transformation of the difference regardless of sign"abs"absolute value of the difference: equivalent to the absdiffterm"posonly"positive differences are kept, negative differences are replaced by 0"negonly"negative differences are kept, positive differences are replaced by 0 Note that this term may not be meaningful for unipartite undirected networks unless sign.action=="abs". When used on such a network, it behaves as if all edges were directed, going from the lower-indexed vertex to the higher-indexed vertex. | binary, dyad-independent, frequently-used, directed, undirected, quantitative nodal attribute | 
| diff(attrname, pow=1, dir=“t-h”, sign.action=“identity”, form =“sum”) 
 Difference: The attrnameargument is a character string giving the name of a quantitative attribute in the network’s vertex attribute list. For values ofpowother than0, this term adds one network statistic to the model, equaling the sum, over directed edges (i,j), ofsign.action(attrname[i]-attrname[j])^powifdiris"t-h"(the default),"tail-head", or"b1-b2"and ofsign.action(attrname[j]-attrname[i])^powif"h-t","head-tail", or"b2-b1". That is, the argumentdirdetermines which vertex’s attribute is subtracted from which, with tail being the origin of a directed edge and head being its destination, and bipartite networks' edges being treated as going from the first part (b1) to the second (b2). If pow==0, the exponentiation is replaced by the signum function:+1if the difference is positive,0if there is no difference, and-1if the difference is negative. Note that this function is applied after thesign.action. The comparison is exact, so when using calculated values ofattrname, ensure that values that you want to be considered equal are, in fact, equal. The following sign.actionsare possible:  "identity"(the default)no transformation of the difference regardless of sign"abs"absolute value of the difference: equivalent to the absdiffterm"posonly"positive differences are kept, negative differences are replaced by 0"negonly"negative differences are kept, positive differences are replaced by 0 Note that this term may not be meaningful for unipartite undirected networks unless sign.action=="abs". When used on such a network, it behaves as if all edges were directed, going from the lower-indexed vertex to the higher-indexed vertex. | valued, dyad-independent, directed, undirected, quantitative nodal attribute | 
| desp(d, type=“OTP”) 
 Directed edgewise shared partners: This term adds one network statistic to the model for each element in dwhere the ith such statistic equals the number of edges in the network with exactlyd[i]shared partners. This term can only be used with directed networks.  Multiple shared partner definitions are possible; thetypeargument may be used to select the type of shared partner to be counted (seeddspfor type codes).  By default, outgoing two-paths are employed. | binary, directed | 
| dgwdsp(decay=0, fixed=FALSE, cutoff=30, type=“OTP”) 
 Geometrically weighted dyadwise shared partner distribution: This term adds one network statistic to the model equal to the geometrically weighted dyadwise shared partner distribution with decay parameter decayparameter, which should be non-negative. (this parameter was calledalphaprior toergm 3.7). The value supplied for this parameter may be fixed (iffixed=TRUE), or it may be used instead as the starting value for the estimation ofdecayin a curved exponential family model (whenfixed=FALSE, the default) (see Hunter and Handcock, 2006).  Note that the GWDSP statistic is equal to the sum of GWNSP plus GWESP. For a directed network, multiple shared partner definitions are possible; thetypeargument may be used to select the type of shared partner to employ (seeddspfor definitions).  By default, outgoing two-paths are employed.  The optional argumentcutoffsets the number of underlying DSP terms to use in computing the statistics to reduce the computational burden. | binary, directed | 
| dgwesp(decay=0, fixed=FALSE, cutoff=30, type=“OTP”) 
 Geometrically weighted edgewise shared partner distribution: This term adds a statistic equal to the geometrically weighted edgewise (not dyadwise) shared partner distribution with decay parameter decayparameter, which should be non-negative. (this parameter was calledalphaprior toergm 3.7). The value supplied for this parameter may be fixed (iffixed=TRUE), or it may be used instead as the starting value for the estimation ofdecayin a curved exponential family model (whenfixed=FALSE, the default) (see Hunter and Handcock, 2006). For a directed network, multiple shared partner definitions are possible; thetypeargument may be used to select the type of shared partner to employ (seeddspfor definitions).  By default, outgoing two-paths are employed.  The optional argumentcutoffsets the number of underlying ESP terms to use in computing the statistics to reduce the computational burden. | binary, directed | 
| dgwnsp(decay=0, fixed=FALSE, cutoff=30, type=“OTP”) 
 Geometrically weighted non-edgewise shared partner distribution: This term is just like gwesp and gwdsp except it adds a statistic equal to the geometrically weighted nonedgewise (that is, over dyads that do not have an edge) shared partner distribution with decay parameter decayparameter, which should be non-negative. (this parameter was calledalphaprior toergm 3.7). The value supplied for this parameter may be fixed (iffixed=TRUE), or it may be used instead as the starting value for the estimation ofdecayin a curved exponential family model (whenfixed=FALSE, the default) (see Hunter and Handcock, 2006). For a directed network, multiple shared partner definitions are possible; thetypeargument may be used to select the type of shared partner to employ (seeddspfor definitions).  By default, outgoing two-paths are employed.  The optional argumentcutoffsets the number of underlying NSP terms to use in computing the statistics to reduce the computational burden. | binary, directed | 
| dnsp(d, type=“OTP”) 
 Directed non-edgewise shared partners: This term adds one network statistic to the model for each element in dwhere the ith such statistic equals the number of non-edges in the network with exactlyd[i]shared partners. This term can only be used with directed networks.  Multiple shared partner definitions are possible; thetypeargument may be used to select the type of shared partner to be counted (seeddspfor type codes).  By default, outgoing two-paths are employed. | binary, directed | 
| dsp(d) 
 Dyadwise shared partners:  The dargument is a vector of distinct integers. This term adds one network statistic to the model for each element ind; the ith such statistic equals the number of dyads in the network with exactlyd[i]shared partners. This term can be used with directed and undirected networks. For directed networks the count is over homogeneous shared partners only (i.e., only partners on a directed two-path connecting the nodes in the dyad). | binary, directed, undirected | 
| dyadcov(x, attrname=NULL) 
 Dyadic covariate: The xargument is either a square matrix of covariates, one for each possible edge in the network, the name of a network attribute of covariates, or a network; if the latter, optional argumentattrnameprovides the name of the quantitative edge attribute to use for covariate values (in this case, missing edges inxare assigned a covariate value of zero). This term adds three statistics to the model, each equal to the sum of the covariate values for all dyads occupying one of the three possible non-empty dyad states (mutual, upper-triangular asymmetric, and lower-triangular asymmetric dyads, respectively), with the empty or null state serving as a reference category. If the network is undirected,xis either a matrix of edgewise covariates, or a network; if the latter, optional argumentattrnameprovides the name of the edge attribute to use for edge values. This term adds one statistic to the model, equal to the sum of the covariate values for each edge appearing in the network. Theedgecovanddyadcovterms are equivalent for undirected networks. | binary, dyad-independent, directed, undirected, categorical nodal attribute | 
| edgecov(x, attrname=NULL) 
 Edge covariate: The xargument is either a square matrix of covariates, one for each possible edge in the network, the name of a network attribute of covariates, or a network; if the latter, optional argumentattrnameprovides the name of the quantitative edge attribute to use for covariate values (in this case, missing edges inxare assigned a covariate value of zero). This term adds one statistic to the model, equal to the sum of the covariate values for each edge appearing in the network. Theedgecovterm applies to both directed and undirected networks. For undirected networks the covariates are also assumed to be undirected. Theedgecovanddyadcovterms are equivalent for undirected networks. | binary, dyad-independent, directed, undirected, frequently-used | 
| edgecov(x,) 
 Edge covariate: The xargument is either a square matrix of covariates, one for each possible edge in the network, the name of a network attribute of covariates, or a network; if the latter, optional argumentattrnameprovides the name of the quantitative edge attribute to use for covariate values (in this case, missing edges inxare assigned a covariate value of zero). This term adds one statistic to the model, equal to the sum of the covariate values for each edge appearing in the network. Theedgecovterm applies to both directed and undirected networks. For undirected networks the covariates are also assumed to be undirected. Theedgecovanddyadcovterms are equivalent for undirected networks. | valued, directed, undirected, dyad-independent | 
| edges() 
 Edges: This term adds one network statistic equal to the number of edges (i.e. nonzero values) in the network. For undirected networks, edgesis equal tokstar(1); for directed networks,edgesis equal to bothostar(1)andistar(1). | binary, valued, dyad-independent, directed, undirected, frequently-used | 
| nonzero() 
 Edges: This term adds one network statistic equal to the number of edges (i.e. nonzero values) in the network. For undirected networks, edgesis equal tokstar(1); for directed networks,edgesis equal to bothostar(1)andistar(1). | valued, directed, undirected, dyad-independent | 
| esp(d) 
 Edgewise shared partners:  This is just like the dspterm, except this term adds one network statistic to the model for each element indwhere the ith such statistic equals the number of edges (rather than dyads) in the network with exactlyd[i]shared partners. This term can be used with directed and undirected networks. For directed networks the count is over homogeneous shared partners only (i.e., only partners on a directed two-path connecting the nodes in the edge and in the same direction). | binary, directed, undirected | 
| equalto(value=0, tolerance=0) 
 Number of dyads with values equal to a specific value (within tolerance): Adds one statistic equal to the number of dyads whose values are within toleranceofvalue, i.e., betweenvalue-toleranceandvalue+tolerance, inclusive. | valued, directed, undirected, dyad-independent | 
| greaterthan(threshold=0) 
 Number of dyads with values strictly greater than a threshold: Adds one statistic equal to the number of dyads whose values exceed threshold. | valued, directed, undirected, dyad-independent | 
| gwb1degree(decay, fixed=FALSE, attrname=NULL, cutoff=30, levels=NULL) 
 Geometrically weighted degree distribution for the first mode in a bipartite (aka two-mode) network:  This term adds one network statistic to the model equal to the weighted degree distribution with decay controlled by the decayparameter, which should be non-negative, for nodes in the first mode of a bipartite network. The first mode of a bipartite network object is sometimes known as the “actor” mode.  Thedecayparameter is the same as theta_s in equation (14) in Hunter (2007).  The value supplied for this parameter may be fixed (iffixed=TRUE), or it may be used as merely the starting value for the estimation in a curved exponential family model (the default). The optional argumentcutoffis only relevant iffixed=FALSE. In that case it only uses this  number of terms in computing the statistics to reduce the computational burden. Ifattrnameis specified then separate degree statistics are calculated for nodes having each separate value of the attribute. This term can only be used with undirected bipartite networks. | binary, bipartite, undirected, curved | 
| gwb2degree(decay, fixed=FALSE, attrname=NULL, cutoff=30, levels=NULL) 
 Geometrically weighted degree distribution for the second mode in a bipartite (aka two-mode) network:  This term adds one network statistic to the model equal to the weighted degree distribution with decay controlled by the which should be non-negative, for nodes in the second mode of a bipartite network. The second mode of a bipartite network object is sometimes known as the “event” mode.  The decayparameter is the same as theta_s in equation (14) in Hunter (2007).  The value supplied for this parameter may be fixed (iffixed=TRUE), or it may be used as merely the starting value for the estimation in a curved exponential family model (the default). The optional argumentcutoffis only relevant iffixed=FALSE. In that case it only uses this  number of terms in computing the statistics to reduce the computational burden. Ifattrnameis specified then separate degree statistics are calculated for nodes having each separate value of the attribute. This term can only be used with undirected bipartite networks. | binary, bipartite, undirected, curved | 
| gwdegree(decay, fixed=FALSE, attrname=NULL, cutoff=30, levels=NULL) 
 Geometrically weighted degree distribution:  This term adds one network statistic to the model equal to the weighted degree distribution with decay controlled by the decayparameter. Thedecayparameter is the same as theta_s in equation (14) in Hunter (2007).  The value supplied for this parameter may be fixed (iffixed=TRUE), or it may be used instead as the starting value for the estimation ofdecayin a curved exponential family model (whenfixed=FALSE, the default) (see Hunter and Handcock, 2006). The optional argumentcutoffis only relevant iffixed=FALSE. In that case it only uses this  number of terms in computing the statistics to reduce the computational burden.  Ifattrnameis specified then separate degree statistics are calculated for nodes having each separate value of the attribute.  This term can only be used with undirected networks. | binary, undirected, curved, frequently-used | 
| gwdsp(decay=0, fixed=FALSE, cutoff=30) 
 Geometrically weighted dyadwise shared partner distribution:  This term adds one network statistic to the model equal to the geometrically weighted dyadwise shared partner distribution with decay parameter decayparameter, which should be non-negative. The value supplied for this parameter may be fixed (iffixed=TRUE), or it may be used instead as the starting value for the estimation ofdecayin a curved exponential family model (whenfixed=FALSE, the default) (see Hunter and Handcock, 2006). For directed networks the count is over homogeneous shared partners only (i.e., only partners on a directed two-path connecting the nodes in the dyad). The optional argumentcutoffis only relevant iffixed=FALSE. In that case it only uses this  number of terms in computing the statistics to reduce the computational burden. | binary, directed, undirected, curved | 
| gwesp(decay=0, fixed=FALSE, cutoff=30) 
 Geometrically weighted edgewise shared partner distribution:  This term is just like gwdspexcept it adds a statistic equal to the geometrically weighted edgewise (not dyadwise) shared partner distribution with decay parameterdecayparameter, which should be non-negative. The value supplied for this parameter may be fixed (iffixed=TRUE), or it may be used instead as the starting value for the estimation ofdecayin a curved exponential family model (whenfixed=FALSE, the default) (see Hunter and Handcock, 2006). This term can be used with directed and undirected networks. For directed networks the geometric weighting is over homogeneous shared partners only (i.e., only partners on a directed two-path connecting the nodes in the edge and in the same direction). The optional argumentcutoffis only relevant iffixed=FALSE. In that case it only uses this  number of terms in computing the statistics to reduce the computational burden. | binary, frequently-used, directed, undirected, curved | 
| gwidegree(decay, fixed=FALSE, attrname=NULL, cutoff=30, levels=NULL) 
 Geometrically weighted in-degree distribution: This term adds one network statistic to the model equal to the weighted in-degree distribution with decay parameter decayparameter, which should be non-negative. (this parameter was calledalphaprior toergm 3.7). The value supplied for this parameter may be fixed (iffixed=TRUE), or it may be used instead as the starting value for the estimation ofdecayin a curved exponential family model (whenfixed=FALSE, the default) (see Hunter and Handcock, 2006). This term can only be used with directed networks. The optional argumentcutoffis only relevant iffixed=FALSE. In that case it only uses this  number of terms in computing the statistics to reduce the computational burden. Ifattrnameis specified then separate degree statistics are calculated for nodes having each separate value of the attribute. | binary, directed, curved | 
| gwnsp(decay=0, fixed=FALSE, cutoff=30) 
 Geometrically weighted nonedgewise shared partner distribution: This term is just like gwespandgwdspexcept it adds a statistic equal to the geometrically weighted nonedgewise (that is, over dyads that do not have an edge) shared partner distribution with weight parameterdecayparameter, which should be non-negative. (this parameter was calledalphaprior toergm 3.7). The optional argumentfixedindicates whether thedecayparameter is fixed at the given value, or is to be fit as a curved exponential-family model (see Hunter and Handcock, 2006).  The default isFALSE, which means the scale parameter is not fixed and thus the model is a CEF model. This term can be used with directed and undirected networks. For directed networks the geometric weighting is over homogeneous shared partners only (i.e., only partners on a directed two-path connecting the nodes in the non-edge and in the same direction). The optional argumentcutoffis only relevant iffixed=FALSE. In that case it only uses this  number of terms in computing the statistics to reduce the computational burden. | binary, directed, undirected, curved | 
| gwodegree(decay, fixed=FALSE, attrname=NULL, cutoff=30, levels=NULL) 
 Geometrically weighted out-degree distribution: This term adds one network statistic to the model equal to the weighted out-degree distribution with decay parameter decayparameter, which should be non-negative. (this parameter was calledalphaprior toergm 3.7). The value supplied for this parameter may be fixed (iffixed=TRUE), or it may be used instead as the starting value for the estimation ofdecayin a curved exponential family model (whenfixed=FALSE, the default) (see Hunter and Handcock, 2006). This term can only be used with directed networks. The optional argumentcutoffis only relevant iffixed=FALSE. In that case it only uses this  number of terms in computing the statistics to reduce the computational burden. Ifattrnameis specified then separate degree statistics are calculated for nodes having each separate value of the attribute. | binary, directed, curved | 
| hamming(x, cov, attrname=NULL) 
 Hamming distance:  This term adds one statistic to the model equal to the weighted or unweighted Hamming distance of the network from the network specified by x. (If no argument is given,xis taken to be the observed network, i.e., the network on the left side of the ~ in the formula that defines the ERGM.) Unweighted Hamming distance is defined as the total number of pairs (i,j) (ordered or unordered, depending on whether the network is directed or undirected) on which the two networks differ. If the optional argumentcovis specified, then the weighted Hamming distance is computed instead, where each pair (i,j) contributes a pre-specified weight toward the distance when the two networks differ on that pair. The argumentcovis either a matrix of edgewise weights or a network; if the latter, the optional argumentattrnameprovides the name of the edge attribute to use for weight values. | binary, dyad-independent, directed, undirected | 
| hammingmix(attrname, x, base=0) 
 Hamming  distance within mixing:  This term adds one statistic to the model for every possible pairing of   attribute values of the network for the vertex attribute named attrname.  Each such statistic is the Hamming distance (i.e., the number of differences)  between the appropriate subset of dyads in the network and the corresponding subset inx. The ordering of the attribute values is alphabetical.  The optionbasegives the index of statistics to be omitted from the tabulation. For examplebase=2will omit the second statistic, making it the de facto reference category. This term can only be used with directed networks. | binary, directed, dyad-independent | 
| idegrange(from, to=+Inf, by=NULL, homophily=FALSE, levels=NULL) 
 In-degree range:  The fromandtoarguments are vectors of distinct integers (or+Inf, forto(its default)). If one of the vectors has length 1, it is recycled to the length of the other. Otherwise, they must have the same length. This term adds one network statistic to the model for each element offrom(orto); the ith such statistic equals the number of nodes in the network of in-degree greater than or equal tofrom[i]but strictly less thanto[i], i.e. with in-edge count in semiopen interval[from,to). The optional argumentbyis a character string giving the name of an attribute in the network’s vertex attribute list.  If this is specified andhomophilyisTRUE, then degrees are calculated using the subnetwork consisting of only edges whose endpoints have the same value of thebyattribute. Ifbyis specified andhomophilyisFALSE(the default), then separate degree range statistics are calculated for nodes having each separate value of the attribute. This term can only be used with directed networks; for undirected networks (bipartite and not) see degrange. For degrees of specific modes of bipartite networks, seeb1degrangeandb2degrange. For in-degrees, seeidegrange. | binary, directed, categorical nodal attribute | 
| idegree(d, by=NULL, homophily=FALSE, levels=NULL) 
 In-degree: The dargument is a vector of distinct integers. This term adds one network statistic to the model for each element ind; the ith such statistic equals the number of nodes in the network of in-degreed[i], i.e. the number of nodes with exactlyd[i]in-edges. The optional termbyis a character string giving the name of an attribute in the network’s vertex attribute list.  If this is specified andhomophilyisTRUE, then degrees are calculated using the subnetwork consisting of only edges whose endpoints have the same value of thebyattribute. Ifbyis specified andhomophilyisFALSE(the default), then separate degree  statistics are calculated for nodes having each separate value of the attribute. This term can only be used with directed networks; for undirected networks seedegree. | binary, directed, categorical nodal attribute, frequently-used | 
| idegree1.5() 
 In-degree to the 3/2 power: This term adds one network statistic to the model equaling the sum over the actors of each actor’s indegree taken to the 3/2 power (or, equivalently, multiplied by its square root). This term is analogous to the term of Snijders et al. (2010), equation (12). This term can only be used with directed networks.  | binary, directed | 
| idegreepopularity() 
 In-degree popularity (deprecated): see idegree1.5. | binary, directed, deprecated | 
| ininterval(lower=-Inf, upper=+Inf, open=) 
 Number of dyads whose values are in an interval Adds one statistic equaling to the number of dyads whose values are between lowerandupper. Argumentopenis alogicalvector of length 2 that controls whether the interval is open (exclusive) on the lower and on the upper end, respectively.opencan also be specified as one of"[]","(]","[)", and"()". | valued, directed, undirected, dyad-independent | 
| intransitive() 
 Intransitive triads:  This term adds one statistic to the model, equal to the number of triads in the network that are intransitive. The intransitive triads are those of type 111D,201,111U,021C, or030Cin the categorization of Davis and Leinhardt (1972). For details on the 16 possible triad types, seetriad.classifyin thesnapackage. Note the distinction from thectripleterm. This term can only be used with directed networks. | binary, directed, triad-related | 
| isolates() 
 Isolates: This term adds one statistic to the model equal to the number of isolates in the network. For an undirected network, an isolate is defined to be any node with degree zero. For a  directed network, an isolate is any node with both in-degree and out-degree equal to zero.  | binary, directed, undirected, frequently-used | 
| istar(k, attrname=NULL, levels=NULL) 
 In-stars:  The kargument is a vector of distinct integers. This term adds one network statistic to the model for each element ink. The ith such statistic counts the number of distinctk[i]-instars in the network, where a k-instar is defined to be a node N and a set of k different nodes \{O_1, …, O_k\} such that the ties (O_j, N) exist for j=1, …, k. The optional argumentattrnameis a character string giving the name of an attribute in the network’s vertex attribute list. If this is specified then the count is over the number of k-instars where all nodes have the same value of the attribute. This term can only be used for directed networks; for undirected networks seekstar. Note thatistar(1)is equal to bothostar(1)andedges. | binary, directed, categorical nodal attribute | 
| kstar(k, attrname=NULL, levels=NULL) 
 k-Stars:   The kargument is a vector of distinct integers. This term adds one network statistic to the model for each element ink. The ith such statistic counts the number of distinctk[i]-stars in the network, where a k-star is defined to be a node N and a set of k different nodes \{O_1, …, O_k\} such that the ties \{N, O_i\} exist for i=1, …, k. The optional argumentattrnameis a character string giving the name of an attribute in the network’s vertex attribute list. If this is specified then the count is over the number of k-stars where all nodes have the same value of the attribute. This term can only be used for undirected networks; for directed networks, seeistar,ostar,twopathandm2star. Note thatkstar(1)is equal toedges. | binary, undirected, categorical nodal attribute | 
| smallerthan(threshold=0) 
 Number of dyads with values strictly smaller than a threshold: Adds one statistic equaling to the number of dyads whose values exceeded by threshold. | valued, directed, undirected, dyad-independent | 
| localtriangle(x) 
 Triangles within neighborhoods:   This term adds one statistic to the model equal to the number of triangles in the network between nodes “close to” each other. For an undirected network, a local triangle is defined to be any set of three edges between nodal pairs \{(i,j), (j,k), (k,i)\} that are in the same neighborhood. For a directed network, a triangle is defined as any set of three edges (i,j), (j,k) and either (k{\rightarrow}i) or (k{≤ftarrow}i) where again all nodes are within the same neighborhood. The argument xis an undirected network or an symmetric adjacency matrix that specifies whether the two nodes  are in the same neighborhood. Note thattriangle, with or without an argument, is a special case oflocaltriangle. | binary, triad-related, directed, undirected | 
| m2star() 
 Mixed 2-stars, a.k.a 2-paths:  This term adds one statistic to the model, equal to the number of mixed 2-stars in the network, where a mixed 2-star is a pair of distinct edges (i,j), (j,k). A mixed 2-star is sometimes called a 2-path because it is a directed path of length 2 from i to k via j. However, in the case of a 2-path the focus is usually on the endpoints i and k, whereas for a mixed 2-star the focus is usually on the midpoint j. This term can only be used with directed networks; for undirected networks see kstar(2). See alsotwopath. | binary, directed | 
| meandeg() 
 Mean vertex degree: This term adds one network statistic to the model equal to the average degree of a node.  Note that this term is a constant multiple of both edgesanddensity. | binary, dyad-independent, directed, undirected | 
| mm(attrs, levels=NULL, levels2=NULL) 
 Mixing matrix cells and margins: attrsis a two-sided formula whose LHS gives the attribute or attribute function (see Specifying Vertex Attributes and Levels) for the rows of the mixing matrix and whose RHS gives that for its columns. A one-sided formula (e.g.,~A) is symmetrized (e.g.,A~A).levelssimilarly specifies the subset of rows and columns to be used.levels2can then be used to filter which specific cells of the matrix to include. A two-sided formula with a dot on one side calculates the margins of the mixing matrix, analogously tonodefactor, withA~.calculating the row/sender/b1 margins and.~Acalculating the column/receiver/b2 margins. | binary, dyad-independent, frequently-used, directed, undirected, categorical nodal attribute | 
| mm(attrs, levels=NULL, levels2=NULL, form=“sum”) 
 Mixing matrix cells and margins: attrsis a two-sided formula whose LHS gives the attribute or attribute function (see Specifying Vertex Attributes and Levels) for the rows of the mixing matrix and whose RHS gives that for its columns. A one-sided formula (e.g.,~A) is symmetrized (e.g.,A~A).levelssimilarly specifies the subset of rows and columns to be used.levels2can then be used to filter which specific cells of the matrix to include. A two-sided formula with a dot on one side calculates the margins of the mixing matrix, analogously tonodefactor, withA~.calculating the row/sender/b1 margins and.~Acalculating the column/receiver/b2 margins. | valued, dyad-independent, frequently-used, directed, undirected, categorical nodal attribute | 
| mutual(same=NULL, diff=FALSE, by=NULL, keep=NULL) 
 Mutuality:  In binary ERGMs, equal to the number of pairs of actors i and j for which (i,j) and (j,i) both exist. For valued ERGMs, equal to ∑_{i<j} m(y_{i,j},y_{j,i}), where m is determined by formargument:"min"for \min(y_{i,j},y_{j,i}),"nabsdiff"for -|y_{i,j},y_{j,i}|,"product"for y_{i,j}y_{j,i}, and"geometric"for √{y_{i,j}}√{y_{j,i}}. See Krivitsky (2012) for a discussion of these statistics.form="threshold"simply computes the binarymutualityafter thresholding atthreshold. This term can only be used with directed networks. The binary version also has the following capabilities: if the optional sameargument is passed the name of a vertex attribute, only mutual pairs that match on the attribute are counted; separate counts for each unique matching value can be obtained by usingdiff=TRUEwithsame; and ifbyis passed the name of a vertex attribute, then each node is counted separately for each mutual pair in which it  occurs and the counts are tabulated by unique values of the attribute. This means that the sum of the mutual statistics whenbyis used will equal twice the standard mutual statistic.  Only one ofsameorbymay be used, and only the former is affected bydiff; if bothsameandbyare passed,byis ignored. Finally, ifkeepis passed a numerical vector, this vector of integers tells which statistics should be kept whenever themutualterm would ordinarily result in multiple statistics. | binary, directed, frequently-used | 
| mutual(form=“min”,threshold=0) 
 Mutuality:  In binary ERGMs, equal to the number of pairs of actors i and j for which (i,j) and (j,i) both exist. For valued ERGMs, equal to ∑_{i<j} m(y_{i,j},y_{j,i}), where m is determined by formargument:"min"for \min(y_{i,j},y_{j,i}),"nabsdiff"for -|y_{i,j},y_{j,i}|,"product"for y_{i,j}y_{j,i}, and"geometric"for √{y_{i,j}}√{y_{j,i}}. See Krivitsky (2012) for a discussion of these statistics.form="threshold"simply computes the binarymutualityafter thresholding atthreshold. This term can only be used with directed networks. The binary version also has the following capabilities: if the optional sameargument is passed the name of a vertex attribute, only mutual pairs that match on the attribute are counted; separate counts for each unique matching value can be obtained by usingdiff=TRUEwithsame; and ifbyis passed the name of a vertex attribute, then each node is counted separately for each mutual pair in which it  occurs and the counts are tabulated by unique values of the attribute. This means that the sum of the mutual statistics whenbyis used will equal twice the standard mutual statistic.  Only one ofsameorbymay be used, and only the former is affected bydiff; if bothsameandbyare passed,byis ignored. Finally, ifkeepis passed a numerical vector, this vector of integers tells which statistics should be kept whenever themutualterm would ordinarily result in multiple statistics. | valued, directed | 
| nearsimmelian() 
 Near simmelian triads:  This term adds one statistic to the model equal to the number of near Simmelian triads, as defined by Krackhardt and Handcock (2007). This is a sub-graph of size three which is exactly one tie short of being complete. This term can only be used with directed networks.  | binary, directed, triad-related | 
| nodecov(attrname, transform, transformname) 
 Main effect of a covariate:  The attrnameargument is a character string giving the name of a numeric (not categorical) attribute in the network’s vertex attribute list. This term adds a single network statistic to the model equaling the sum ofattrname(i)andattrname(j)for all edges (i,j) in the network. For categorical attributes, seenodefactor. Note that for directed networks,nodecovequalsnodeicovplusnodeocov. | binary, dyad-independent, frequently-used, directed, undirected, quantitative nodal attribute | 
| nodecov(attrname, transform, transformname,) 
 Main effect of a covariate:  The attrnameargument is a character string giving the name of a numeric (not categorical) attribute in the network’s vertex attribute list. This term adds a single network statistic to the model equaling the sum ofattrname(i)andattrname(j)for all edges (i,j) in the network. For categorical attributes, seenodefactor. Note that for directed networks,nodecovequalsnodeicovplusnodeocov. | valued, dyad-independent, directed, undirected, quantitative nodal attribute | 
| nodemain() 
 Main effect of a covariate:  The attrnameargument is a character string giving the name of a numeric (not categorical) attribute in the network’s vertex attribute list. This term adds a single network statistic to the model equaling the sum ofattrname(i)andattrname(j)for all edges (i,j) in the network. For categorical attributes, seenodefactor. Note that for directed networks,nodecovequalsnodeicovplusnodeocov. | binary, directed, undirected | 
| nodecovar() 
 Uncentered covariance of dyad values incident on each actor: This term adds one statistic equal to ∑_{i,j,k} (y_{i,j}y_{i,k}+y_{k,j}y_{k,j}). This can be viewed as a valued analog of the kstar(2)statistic. | valued, directed, undirected, quantitative nodal attribute | 
| nodefactor(attrname, base=1, levels=NULL) 
 Factor attribute effect: The attrnameargument is a character vector giving one or more names of categorical attributes in the network’s vertex attribute list. This term adds multiple network statistics to the model, one for each of (a subset of) the unique values of theattrnameattribute (or each combination of the attributes given). Each of these statistics gives the number of times a node with that attribute or those attributes appears in an edge in the network. In particular, for edges whose endpoints both have the same attribute values, this value is counted twice. To include all attribute values is usually not a good idea – though this may be  accomplished if desired by settingbase=0– because the sum of all such statistics equals twice the number of edges and hence a  linear dependency would arise in any model also includingedges. Thus, thebaseargument tells which value(s)  (numbered in order according to thesortfunction) should be omitted. The default value,base=1, means that the smallest  (i.e., first in sorted order) attribute value is omitted. For example, if the “fruit” factor has levels “orange”, “apple”, “banana”, and “pear”, then to add just two terms, one for “apple” and one for “pear”, then set “banana” and “orange” to the base (remember to sort the values first) by usingnodefactor("fruit",     base=2:3). For an analogous term for quantitative vertex attributes, seenodecov. | binary, dyad-independent, directed, undirected, categorical nodal attribute, frequently-used | 
| nodefactor(attrname, base=1, levels=NULL, form=“sum”) 
 Factor attribute effect: The attrnameargument is a character vector giving one or more names of categorical attributes in the network’s vertex attribute list. This term adds multiple network statistics to the model, one for each of (a subset of) the unique values of theattrnameattribute (or each combination of the attributes given). Each of these statistics gives the number of times a node with that attribute or those attributes appears in an edge in the network. In particular, for edges whose endpoints both have the same attribute values, this value is counted twice. To include all attribute values is usually not a good idea – though this may be  accomplished if desired by settingbase=0– because the sum of all such statistics equals twice the number of edges and hence a  linear dependency would arise in any model also includingedges. Thus, thebaseargument tells which value(s)  (numbered in order according to thesortfunction) should be omitted. The default value,base=1, means that the smallest  (i.e., first in sorted order) attribute value is omitted. For example, if the “fruit” factor has levels “orange”, “apple”, “banana”, and “pear”, then to add just two terms, one for “apple” and one for “pear”, then set “banana” and “orange” to the base (remember to sort the values first) by usingnodefactor("fruit",     base=2:3). For an analogous term for quantitative vertex attributes, seenodecov. | dyad-independent, valued, directed, undirected, categorical nodal attribute | 
| nodeicov(attrname, transform, transformname) 
 Main effect of a covariate for in-edges:  The attrnameargument is a character string giving the name of a numeric (not categorical) attribute in the network’s vertex attribute list. This term adds a single network statistic to the model equaling the total value ofattrname(j)for all edges (i,j) in the network. This term may only be used with directed networks. For categorical attributes, seenodeifactor. | binary, directed, quantitative nodal attribute, frequently-used | 
| nodeicov(attrname, transform, transformname, form=“sum”) 
 Main effect of a covariate for in-edges:  The attrnameargument is a character string giving the name of a numeric (not categorical) attribute in the network’s vertex attribute list. This term adds a single network statistic to the model equaling the total value ofattrname(j)for all edges (i,j) in the network. This term may only be used with directed networks. For categorical attributes, seenodeifactor. | valued, directed, quantitative nodal attribute | 
| nodeicovar() 
 Uncentered covariance of in-dyad values incident on each actor: This term adds one statistic equal to ∑_{i,j,k} y_{k,j}y_{k,j}. This can be viewed as a valued analog of the istar(2)statistic. | valued, directed, quantitative nodal attribute | 
| nodeifactor(attrname, base=1, levels=NULL) 
 Factor attribute effect for in-edges: The attrnameargument is a character vector giving one or more names of a categorical attribute in the network’s vertex attribute list. This term adds multiple network statistics to the model, one for each of (a subset of) the unique values of theattrnameattribute (or each combination of the attributes given). Each of these statistics gives the number of times a node with that attribute or those attributes appears as the terminal node of a directed tie. To include all attribute values is usually not a good idea – though this may be accomplished if desired by settingbase=0– because the sum of all such statistics equals the number of edges and hence a linear dependency would arise in any model also includingedges. Thus, thebaseargument tells which value(s) (numbered in order according to thesortfunction) should be omitted. The default value,base=1, means that the smallest (i.e., first in sorted order) attribute value is omitted. For example, if the “fruit” factor has levels “orange”, “apple”, “banana”, and “pear”, then to add just two terms, one for “apple” and one for “pear”, then set “banana” and “orange” to the base (remember to sort the values first) by usingnodefactor("fruit", base=2:3). For an analogous term for quantitative vertex attributes, seenodeicov. | binary, dyad-independent, directed, categorical nodal attribute, frequently-used | 
| nodeifactor(attrname, base=1, levels=NULL, form=“sum”) 
 Factor attribute effect for in-edges: The attrnameargument is a character vector giving one or more names of a categorical attribute in the network’s vertex attribute list. This term adds multiple network statistics to the model, one for each of (a subset of) the unique values of theattrnameattribute (or each combination of the attributes given). Each of these statistics gives the number of times a node with that attribute or those attributes appears as the terminal node of a directed tie. To include all attribute values is usually not a good idea – though this may be accomplished if desired by settingbase=0– because the sum of all such statistics equals the number of edges and hence a linear dependency would arise in any model also includingedges. Thus, thebaseargument tells which value(s) (numbered in order according to thesortfunction) should be omitted. The default value,base=1, means that the smallest (i.e., first in sorted order) attribute value is omitted. For example, if the “fruit” factor has levels “orange”, “apple”, “banana”, and “pear”, then to add just two terms, one for “apple” and one for “pear”, then set “banana” and “orange” to the base (remember to sort the values first) by usingnodefactor("fruit", base=2:3). For an analogous term for quantitative vertex attributes, seenodeicov. | valued, dyad-independent, directed, categorical nodal attribute | 
| nodeisqrtcovar() 
 Uncentered covariance of square roots of in-dyad values incident on each actor: This term adds one statistic equal to ∑_{i,j,k}  √{y_{i,j}}√{y_{k,j}}. This can be viewed as a valued analog of the istar(2)statistic. | valued, directed, non-negative, quantitative nodal attribute | 
| nodematch(attrname, diff=FALSE, keep=NULL, levels=NULL) 
 Uniform homophily and differential homophily: The attrnameargument is a character vector giving one or more names of attributes in the network’s vertex attribute list. Whendiff=FALSE, this term adds one network statistic to the model, which counts the number of edges (i,j) for whichattrname(i)==attrname(j). This is also called ”uniform homophily,” because each group is assumed to have the same propensity for within-group ties.  When multiple attribute names are given, the statistic counts only ties for which all of the attributes match. Whendiff=TRUE, p network statistics are added to the model, where p is the number of unique values of theattrnameattribute. The kth such statistic counts the number of edges (i,j) for whichattrname(i) ==     attrname(j) == value(k), wherevalue(k)is the kth smallest unique value of the attrname attribute. This is also called ”differential homophily,” because each group is allowed to have a unique propensity for within-group ties.  Note that a statistical test of uniform vs. differential homophily should be conducted using the ANOVA function. If set to non-NULL, the optional keepargument should be a vector of integers giving the values ofkthat should be considered for matches; other values are ignored (this works for bothdiff=FALSEanddiff=TRUE). For instance, to add two statistics, counting the matches for just the 2nd and 4th categories, usenodematchwithdiff=TRUEandkeep=c(2,4). | binary, dyad-independent, frequently-used, directed, undirected, categorical nodal attribute | 
| nodematch(attrname, diff=FALSE, keep=NULL, levels=NULL, form=“sum”) 
 Uniform homophily and differential homophily: The attrnameargument is a character vector giving one or more names of attributes in the network’s vertex attribute list. Whendiff=FALSE, this term adds one network statistic to the model, which counts the number of edges (i,j) for whichattrname(i)==attrname(j). This is also called ”uniform homophily,” because each group is assumed to have the same propensity for within-group ties.  When multiple attribute names are given, the statistic counts only ties for which all of the attributes match. Whendiff=TRUE, p network statistics are added to the model, where p is the number of unique values of theattrnameattribute. The kth such statistic counts the number of edges (i,j) for whichattrname(i) ==     attrname(j) == value(k), wherevalue(k)is the kth smallest unique value of the attrname attribute. This is also called ”differential homophily,” because each group is allowed to have a unique propensity for within-group ties.  Note that a statistical test of uniform vs. differential homophily should be conducted using the ANOVA function. If set to non-NULL, the optional keepargument should be a vector of integers giving the values ofkthat should be considered for matches; other values are ignored (this works for bothdiff=FALSEanddiff=TRUE). For instance, to add two statistics, counting the matches for just the 2nd and 4th categories, usenodematchwithdiff=TRUEandkeep=c(2,4). | valued, dyad-independent, directed, undirected, categorical nodal attribute | 
| match() 
 Uniform homophily and differential homophily: The attrnameargument is a character vector giving one or more names of attributes in the network’s vertex attribute list. Whendiff=FALSE, this term adds one network statistic to the model, which counts the number of edges (i,j) for whichattrname(i)==attrname(j). This is also called ”uniform homophily,” because each group is assumed to have the same propensity for within-group ties.  When multiple attribute names are given, the statistic counts only ties for which all of the attributes match. Whendiff=TRUE, p network statistics are added to the model, where p is the number of unique values of theattrnameattribute. The kth such statistic counts the number of edges (i,j) for whichattrname(i) ==     attrname(j) == value(k), wherevalue(k)is the kth smallest unique value of the attrname attribute. This is also called ”differential homophily,” because each group is allowed to have a unique propensity for within-group ties.  Note that a statistical test of uniform vs. differential homophily should be conducted using the ANOVA function. If set to non-NULL, the optional keepargument should be a vector of integers giving the values ofkthat should be considered for matches; other values are ignored (this works for bothdiff=FALSEanddiff=TRUE). For instance, to add two statistics, counting the matches for just the 2nd and 4th categories, usenodematchwithdiff=TRUEandkeep=c(2,4). | binary, directed, dyad-independent, undirected, categorical nodal attribute | 
| nodemix(attrname, base=NULL, levels=NULL) 
 Nodal attribute mixing: The attrnameargument is a character vector giving the names of categorical attributes in the network’s vertex attribute list. By default, this term adds one network statistic to the model for each possible pairing of attribute values. The statistic equals the number of edges in the network in which the nodes have that pairing of values. (When multiple names are given, a statistic is added for each combination of attribute values for those names.) In other words, this term produces one statistic for every entry in the mixing matrix for the attribute(s). The ordering of the attribute values is alphabetical (for nominal categories) or numerical (for ordered categories). The optionalbaseargument is a vector of integers corresponding to the pairings that should not be included. Ifbasecontains only negative integers, then these integers correspond to the only pairings that should be included. By default (i.e., withbase=NULLorbase=0), all pairings are included. | binary, dyad-independent, frequently-used, directed, undirected, categorical nodal attribute | 
| nodemix(attrname, base=NULL, levels=NULL, form=“sum”) 
 Nodal attribute mixing: The attrnameargument is a character vector giving the names of categorical attributes in the network’s vertex attribute list. By default, this term adds one network statistic to the model for each possible pairing of attribute values. The statistic equals the number of edges in the network in which the nodes have that pairing of values. (When multiple names are given, a statistic is added for each combination of attribute values for those names.) In other words, this term produces one statistic for every entry in the mixing matrix for the attribute(s). The ordering of the attribute values is alphabetical (for nominal categories) or numerical (for ordered categories). The optionalbaseargument is a vector of integers corresponding to the pairings that should not be included. Ifbasecontains only negative integers, then these integers correspond to the only pairings that should be included. By default (i.e., withbase=NULLorbase=0), all pairings are included. | valued, dyad-independent, directed, undirected, categorical nodal attribute | 
| nodeocov(attrname, transform, transformname) 
 Main effect of a covariate for out-edges:  The attrnameargument is a character string giving the name of a numeric (not categorical) attribute in the network’s vertex attribute list. This term adds a single network statistic to the model equaling the total value ofattrname(i)for all edges (i,j) in the network. This term may only be used with directed networks. For categorical attributes, seenodeofactor. | binary, directed, dyad-independent, quantitative nodal attribute | 
| nodeocov(attrname, transform, transformname, form=“sum”) 
 Main effect of a covariate for out-edges:  The attrnameargument is a character string giving the name of a numeric (not categorical) attribute in the network’s vertex attribute list. This term adds a single network statistic to the model equaling the total value ofattrname(i)for all edges (i,j) in the network. This term may only be used with directed networks. For categorical attributes, seenodeofactor. | valued, directed, dyad-independent | 
| nodeocovar() 
 Uncentered covariance of out-dyad values incident on each actor: This term adds one statistic equal to ∑_{i,j,k} y_{i,j}y_{i,k}. This can be viewed as a valued analog of the ostar(2)statistic. | valued, directed, quantitative nodal attribute | 
| nodeofactor(attrname, base=1, levels=NULL) 
 Factor attribute effect for out-edges: The attrnameargument is a character string giving one or more names of categorical attributes in the network’s vertex attribute list. This term adds multiple network statistics to the model, one for each of (a subset of) the unique values of theattrnameattribute (or each combination of the attributes given). Each of these statistics gives the number of times a node with that attribute or those attributes appears as the node of origin of a directed tie. To include all attribute values is usually not a good idea – though this may be accomplished if desired by settingbase=0– because the sum of all such statistics equals the number of edges and hence a linear dependency would arise in any model also includingedges. Thus, thebaseargument tells which value(s) (numbered in order according to thesortfunction) should be omitted. The default value,base=1, means that the smallest (i.e., first in sorted order) attribute value is omitted. For example, if the “fruit” factor has levels “orange”, “apple”, “banana”, and “pear”, then to add just two terms, one for “apple” and one for “pear”, then set “banana” and “orange” to the base (remember to sort the values first) by usingnodefactor("fruit", base=2:3). For an analogous term for quantitative vertex attributes, seenodeocov. | binary, dyad-independent, directed, categorical nodal attribute | 
| nodeofactor(attrname, base=1, levels=NULL, form=“sum”) 
 Factor attribute effect for out-edges: The attrnameargument is a character string giving one or more names of categorical attributes in the network’s vertex attribute list. This term adds multiple network statistics to the model, one for each of (a subset of) the unique values of theattrnameattribute (or each combination of the attributes given). Each of these statistics gives the number of times a node with that attribute or those attributes appears as the node of origin of a directed tie. To include all attribute values is usually not a good idea – though this may be accomplished if desired by settingbase=0– because the sum of all such statistics equals the number of edges and hence a linear dependency would arise in any model also includingedges. Thus, thebaseargument tells which value(s) (numbered in order according to thesortfunction) should be omitted. The default value,base=1, means that the smallest (i.e., first in sorted order) attribute value is omitted. For example, if the “fruit” factor has levels “orange”, “apple”, “banana”, and “pear”, then to add just two terms, one for “apple” and one for “pear”, then set “banana” and “orange” to the base (remember to sort the values first) by usingnodefactor("fruit", base=2:3). For an analogous term for quantitative vertex attributes, seenodeocov. | valued, dyad-independent, categorical nodal attribute, directed | 
| nodeosqrtcovar() 
 Uncentered covariance of square roots of out-dyad values incident on each actor: This term adds one statistic equal to ∑_{i,j,k}  √{y_{i,j}}√{y_{i,k}}. This can be viewed as a valued analog of the ostar(2)statistic. | valued, directed, non-negative | 
| nodesqrtcovar(center=TRUE) 
 Covariance of square roots of dyad values incident on each actor: This term adds one statistic equal to ∑_{i,j,k}  (√{y_{i,j}}√{y_{i,k}}+√{y_{k,j}}√{y_{k,j}}) if center=FALSE. This can be viewed as a valued analog of thekstar(2)statistic. Ifcenter=FALSE(the default), the statistic is instead ∑_{i,j,k}   ((√{y_{i,j}}-\bar{√{y}})(√{y_{i,k}}-\bar{√{y}})+(√{y_{k,j}}-\bar{√{y}})(√{y_{k,j}}-\bar{√{y}})), where \bar{√{y}} is the mean of the square root of dyad values. | valued, non-negative, directed, undirected, quantitative nodal attribute | 
| nsp(d) 
 Nonedgewise shared partners: This is just like the dspandespterms, except this term adds one network statistic to the model for each element indwhere the ith such statistic equals the number of  non-edges (that is, dyads that do not have an edge) in the network with exactlyd[i]shared partners. This term can be used with directed and undirected networks. For directed networks the count is over homogeneous shared partners only (i.e., only partners on a directed two-path connecting the nodes in the non-edge and in the same direction). | binary, directed, undirected | 
| odegrange(from, to=+Inf, by=NULL, homophily=FALSE, levels=NULL) 
 Out-degree range:  The fromandtoarguments are vectors of distinct integers (or+Inf, forto(its default)). If one of the vectors has length 1, it is recycled to the length of the other. Otherwise, they must have the same length. This term adds one network statistic to the model for each element offrom(orto); the ith such statistic equals the number of nodes in the network of out-degree greater than or equal tofrom[i]but strictly less thanto[i], i.e. with out-edge count in semiopen interval[from,to). The optional argumentbyis a character string giving the name of an attribute in the network’s vertex attribute list.  If this is specified andhomophilyisTRUE, then degrees are calculated using the subnetwork consisting of only edges whose endpoints have the same value of thebyattribute. Ifbyis specified andhomophilyisFALSE(the default), then separate degree range statistics are calculated for nodes having each separate value of the attribute. This term can only be used with directed networks; for undirected networks (bipartite and not) see degrange. For degrees of specific modes of bipartite networks, seeb1degrangeandb2degrange. For in-degrees, seeidegrange. | binary, directed, categorical nodal attribute | 
| odegree(d, by=NULL, homophily=FALSE, levels=NULL) 
 Out-degree: The dargument is a vector of distinct integers. This term adds one network statistic to the model for each element ind; the ith such statistic equals the number of nodes in the network of out-degreed[i], i.e. the number of nodes with exactlyd[i]out-edges. The optional argumentbyis a character string giving the name of an attribute in the network’s vertex attribute list.  If this is specified andhomophilyisTRUE, then degrees are calculated using the subnetwork consisting of only edges whose endpoints have the same value of thebyattribute. Ifbyis specified andhomophilyisFALSE(the default), then separate degree  statistics are calculated for nodes having each separate value of the attribute. This term can only be used with directed networks; for undirected networks seedegree. | binary, directed, categorical nodal attribute, frequently-used | 
| odegree1.5() 
 Out-degree to the 3/2 power: This term adds one network statistic to the model equaling the sum over the actors of each actor’s outdegree taken to the 3/2 power (or, equivalently, multiplied by its square root). This term is analogous to the term of Snijders et al. (2010), equation (12). This term can only be used with directed networks.  | binary, directed | 
| odegreepopularity() 
 Out-degree popularity (deprecated): see odegree1.5. | binary, directed, deprecated | 
| opentriad() 
 Open triads: This term adds one statistic to the model equal to the number of 2-stars minus three times the number of triangles in the network. It is currently only implemented for undirected networks.   | binary, undirected, triad-related | 
| ostar(k, attrname=NULL, levels=NULL) 
 k-Outstars: The kargument is a vector of distinct integers. This term adds one network statistic to the model for each element ink. The ith such statistic counts the number of distinctk[i]-outstars in the network, where a k-outstar is defined to be a node N and a set of k different nodes \{O_1, …, O_k\} such that the ties (N,O_j) exist for j=1, …, k. The optional argumentattrnameis a character string giving the name of an attribute in the network’s vertex attribute list. If this is specified then the count is the number of k-outstars where all nodes have the same value of the attribute. This term can only be used with directed networks; for undirected networks seekstar. Note thatostar(1)is equal to bothistar(1)andedges. | binary, directed, categorical nodal attribute | 
| receiver(base=1) 
 Receiver effect:  This term adds one network statistic for each node equal to the number of in-ties for that node. This measures the popularity of the node. The term for the first node is omitted by default because of linear dependence that arises if this term is used together with edges, but its coefficient can be computed as the negative of the sum of the coefficients of all the other actors. That is, the average coefficient is zero, following the Holland-Leinhardt parametrization of the $p_1$ model (Holland and Leinhardt, 1981). Thebaseargument allows the user to determine which nodes' statistics should be omitted. Thebaseargument can also be a vector of negative indices, to specify which should be added instead of deleted, andbase=0specifies that all statistics should be included. This term can only be used with directed networks. For undirected networks, seesociality. | binary, directed, dyad-independent | 
| receiver(base=1, form=“sum”) 
 Receiver effect:  This term adds one network statistic for each node equal to the number of in-ties for that node. This measures the popularity of the node. The term for the first node is omitted by default because of linear dependence that arises if this term is used together with edges, but its coefficient can be computed as the negative of the sum of the coefficients of all the other actors. That is, the average coefficient is zero, following the Holland-Leinhardt parametrization of the $p_1$ model (Holland and Leinhardt, 1981). Thebaseargument allows the user to determine which nodes' statistics should be omitted. Thebaseargument can also be a vector of negative indices, to specify which should be added instead of deleted, andbase=0specifies that all statistics should be included. This term can only be used with directed networks. For undirected networks, seesociality. | valued, directed, dyad-independent | 
| sender(base=1) 
 Sender effect:  This term adds one network statistic for each node equal to the number of out-ties for that node. This measures the activity of the node. The term for the first node is omitted by default because of linear dependence that arises if this term is used together with edges, but its coefficient can be computed as the negative of the sum of the coefficients of all the other actors. That is, the average coefficient is zero, following the Holland-Leinhardt parametrization of the $p_1$ model (Holland and Leinhardt, 1981). Thebaseargument allows the user to determine which nodes' statistics should be omitted. Thebaseargument can also be a vector of negative indices, to specify which should be added instead of deleted, andbase=0specifies that all statistics should be included. This term can only be used with directed networks. For undirected networks, seesociality. | binary, directed, dyad-independent | 
| sender(base=1, form=“sum”) 
 Sender effect:  This term adds one network statistic for each node equal to the number of out-ties for that node. This measures the activity of the node. The term for the first node is omitted by default because of linear dependence that arises if this term is used together with edges, but its coefficient can be computed as the negative of the sum of the coefficients of all the other actors. That is, the average coefficient is zero, following the Holland-Leinhardt parametrization of the $p_1$ model (Holland and Leinhardt, 1981). Thebaseargument allows the user to determine which nodes' statistics should be omitted. Thebaseargument can also be a vector of negative indices, to specify which should be added instead of deleted, andbase=0specifies that all statistics should be included. This term can only be used with directed networks. For undirected networks, seesociality. | valued, directed, dyad-independent | 
| simmelian() 
 Simmelian triads: This term adds one statistic to the model equal to the number of Simmelian triads, as defined by Krackhardt and Handcock (2007). This is a complete sub-graph of size three. This term can only be used with directed networks.  | binary, directed, triad-related | 
| simmelianties() 
 Ties in simmelian triads: This term adds one statistic to the model equal to the number of ties in the network that are associated with Simmelian triads, as defined by Krackhardt and Handcock (2007). Each Simmelian has six ties in it but, because Simmelians can overlap in terms of nodes (and associated ties), the total number of ties in these Simmelians is less than six times the number of Simmelians. Hence this is a measure of the clustering of Simmelians (given the number of Simmelians). This term can only be used with directed networks.  | binary, triad-related, directed | 
| smalldiff(attrname, cutoff) 
 Number of ties between actors with similar (but not necessarily identical) attribute values: The attrnameargument is a character string giving the name of a quantitative attribute in the network’s vertex attribute list. This term adds one statistic, having as its value the number of edges in the network for which the incident actors' attribute values differ less thancotoff; that is, number of edges betweenitojsuch thatabs(attrname[i]-attrname[j])<cutoff. | binary, dyad-independent, directed, undirected, quantitative nodal attribute | 
| sociality(attrname=NULL, base=1, levels=NULL) 
 Undirected degree:  This term adds one network statistic for each node equal to the number of ties of that node. The optional attrnameargument is a character string giving the name of an attribute in the network’s vertex attribute list that takes categorical values. If provided, this term only counts ties between nodes with the same value of the attribute (an actor-specific version of thenodematchterm). This term can only be used with undirected networks.  For directed networks, seesenderandreceiver. By default,base=1means that the statistic for the first node will be omitted, but this argument may be changed to control which statistics are included just as for thesenderandreceiverterms. | binary, undirected, dyad-independent, categorical nodal attribute | 
| sociality(attrname=NULL, base=1, levels=NULL, form=“sum”) 
 Undirected degree:  This term adds one network statistic for each node equal to the number of ties of that node. The optional attrnameargument is a character string giving the name of an attribute in the network’s vertex attribute list that takes categorical values. If provided, this term only counts ties between nodes with the same value of the attribute (an actor-specific version of thenodematchterm). This term can only be used with undirected networks.  For directed networks, seesenderandreceiver. By default,base=1means that the statistic for the first node will be omitted, but this argument may be changed to control which statistics are included just as for thesenderandreceiverterms. | valued, undirected, dyad-independent, categorical nodal attribute | 
| sum(pow=1) 
 Sum of dyad values (optionally taken to a power): This term adds one statistic equal to the sum of dyad values taken to the power pow, which defaults to 1. | valued, directed, undirected | 
| threetrail(keep=1:4) 
  Three-trails: a.k.a. threepath. For an undirected network, this term adds one statistic equal to the number of 3-trails, where a 3-trail is defined as a “trail” of length three that traverses three distinct edges. Note that a 3-trail need not include four distinct nodes; in particular, a triangle counts as three 3-trails.  For a directed network, this term adds four statistics  (or some subset of these four specified by thekeepargument), one for each of the four distinct types of directed three-paths.  If the  nodes of the path are written from left to right such that the middle edge points to the right ®, then the four types are RRR, RRL, LRR, and LRL. That is, an RRR 3-trail is of the form  i–>j–>k–>l, and RRL 3-trail is of the form i–>j–>k<–l, etc. Like in the undirected case, there is no requirement that the nodes be distinct in a directed 3-trail.  However, the three edges must all be  distinct.  Thus, a mutual tie i<–>j does not count as a 3-trail of the form i–>j–>i<–j; however, in the subnetwork i<–>j–>k, there are two directed 3-trails, one LRR (k<–j–>i–>j) and one RRR (k<–j–>i–>j). This term used to be (inaccurately) called threepath. That name has been deprecated and may be removed in a future version. | binary, directed, undirected | 
| transitive() 
 Transitive triads:  This term adds one statistic to the model, equal to the number of triads in the network that are transitive. The transitive triads are those of type 120D,030T,120U, or300in the categorization of Davis and Leinhardt (1972). For details on the 16 possible triad types, seetriad.classifyin thesnapackage. Note the distinction from thettripleterm. This term can only be used with directed networks. | binary, directed, triad-related | 
| transitiveties(attrname=NULL, levels=NULL) 
 Transitive ties:  This term adds one statistic, equal to the number of ties  i–>j such that there exists a two-path from i to j.  (Related to the ttripleterm.) The binary version takes a nodal attributeattrname, and, if given, all three nodes involved (i, j, and the node on the two-path) must match on this attribute in order for i–>j to be counted. The binary version of this term can only be used with directed networks. The valued version can be used with both directed and undirected. | binary, directed, triad-related, categorical nodal attribute | 
| transitiveties(threshold=0) 
 Transitive ties:  This term adds one statistic, equal to the number of ties  i–>j such that there exists a two-path from i to j.  (Related to the ttripleterm.) The binary version takes a nodal attributeattrname, and, if given, all three nodes involved (i, j, and the node on the two-path) must match on this attribute in order for i–>j to be counted. The binary version of this term can only be used with directed networks. The valued version can be used with both directed and undirected. | valued, directed, undirected, triad-related | 
| transitiveweights(twopath=“min”,combine=“max”,affect=“min”) 
 Transitive weights: This statistic implements the transitive weights statistic defined by Krivitsky (2012), Equation 13. The currently implemented options for twopathis the minimum of the constituent dyads ("min") or their geometric mean ("geomean"); forcombine, the maximum of the 2-path strengths ("max") or their sum ("sum"); and foraffect, the minimum of the focus dyad and the combined strength of the two paths ("min") or their geometric mean ("geomean"). For each of these options, the first (and the default) is more stable but also more conservative, while the second is more sensitive but more likely to induce a multimodal distribution of networks. | valued, directed, undirected, non-negative, triad-related | 
| triadcensus(d) 
 Triad census:  For a directed network, this term adds one network statistic for each of an arbitrary subset of the 16 possible types of triads categorized by Davis and Leinhardt (1972) as 003, 012, 102, 021D, 021U, 021C, 111D,     111U, 030T, 030C, 201, 120D, 120U, 120C, 210,and300. Note that at least one category should be dropped; otherwise a linear dependency will exist among the 16 statistics, since they must sum to the total number of three-node sets. By default, the category003, which is the category of completely empty three-node sets, is dropped. This is considered category zero, and the others are numbered 1 through 15 in the order given above. By specifying a numeric vector of integers from 0 to 15 as thedargument, the user may specify a set of terms to add other than the default value of1:15. Each statistic is the count of the corresponding triad type in the network. For details on the 16 types, see?triad.classifyin the{sna}package, on which this code is based. For an undirected network, the triad census is over the four types defined by the number of ties (i.e., 0, 1, 2, and 3), and the default is to add1:3, which is to say that the 0 is dropped; however, this too may be controlled by changing thedargument to a numeric vector giving a subset of \{0, 1, 2, 3\}. | binary, triad-related, directed, undirected | 
| triangle(attrname=NULL, levels=NULL) 
 Triangles: This term adds one statistic to the model equal to the number of triangles in the network. For an undirected network, a triangle is defined to be any set \{(i,j), (j,k), (k,i)\} of three edges. For a directed network, a triangle is defined as any set of three edges (i,j) and (j,k) and either (k,i) or (i,k). The former case is called a “transitive triple” and the latter is called a “cyclic triple”, so in the case of a directed network, triangleequalsttripleplusctriple— thus at most two of these three terms can be in a model. The optional argumentattrnamerestricts the count to those triples of nodes with equal values of the vertex attribute specified byattrname. | binary, frequently-used, triad-related, directed, undirected, categorical nodal attribute | 
| tripercent(attrname=NULL, levels=NULL) 
 Triangle percentage:  This term adds one statistic to the model equal to 100 times the ratio of the number of triangles in the network to the sum of the number of triangles and the number of 2-stars not in triangles (the latter is considered a potential but incomplete triangle).  In case the denominator equals zero, the statistic is defined to be zero. For the definition of triangle, see triangle. The optional argumentattrnamerestricts the counts (both numerator and denominator) to those triples of nodes with equal values of the vertex attribute specified byattrname. This is often called the mean correlation coefficient. This term can only be used with undirected networks; for directed networks, it is difficult to define the numerator and denominator in a consistent and meaningful way. | binary, undirected, triad-related, categorical nodal attribute | 
| ttriple(attrname=NULL, levels=NULL) 
 Transitive triples:  This term adds one statistic to the model, equal to the number of transitive triples in the network, defined as a set of edges {(i,j), (j,k), (i,k)}. Note that triangleequalsttriple+ctriplefor a directed network, so at most two of the three terms can be in a model. The optional argumentattrnameis a character string giving the name of an attribute in the network’s vertex attribute list. If this is specified then the count is over the number of transitive triples where all three nodes have the same value of the attribute. This term can only be used with directed networks. | binary, directed, triad-related, categorical nodal attribute | 
| ttriad() 
 Transitive triples:  This term adds one statistic to the model, equal to the number of transitive triples in the network, defined as a set of edges {(i,j), (j,k), (i,k)}. Note that triangleequalsttriple+ctriplefor a directed network, so at most two of the three terms can be in a model. The optional argumentattrnameis a character string giving the name of an attribute in the network’s vertex attribute list. If this is specified then the count is over the number of transitive triples where all three nodes have the same value of the attribute. This term can only be used with directed networks. | binary, directed, triad-related, categorical nodal attribute | 
| twopath() 
 2-Paths:  This term adds one statistic to the model, equal to the number of 2-paths in the network. For a directed network this is defined as a pair of edges (i,j), (j,k), where i and j must be distinct. That is, it is a directed path of length 2 from i to k via j. For directed networks a 2-path is also a mixed 2-star but the interpretation is usually different; see m2star. For undirected networks a twopath is defined as a pair of edges \{i,j\}, \{j,k\}. That is, it is an undirected path of length 2 from i to k via j, also known as a 2-star. | binary, directed, undirected | 
Note that currently the categories are somewhat ambiguous in their exclusivity.  For example, a term marked as 'directed' can not be used with an undirected network, but a term not marked with either 'directed' or 'undirected' can be used with both. (rename to 'directed-only' ?)
This documentation was built with..