adjacency_matrix

1-0 matrix defining which categorical variable levels are related.

Specification

  • Alias: None

  • Arguments: INTEGERLIST

Description

The adjacency_matrix keyword is associated with discrete_design_set variables that are specified to be categorical. Each such variable is associated with one \(k \times k\) symmetric matrix, where \(k\) is the number of values (or levels) of the variable. Entry \(i,j\) of a matrix should be 1 if level \(i\) and level \(j\) are related by some subjective criteria or if \(i=j\) ; it should be 0 otherwise. The matrices for all variables of the same type ( string, real, or integer) are entered sequentially as a list of integers as shown in the examples below.

Default Behavior

The adjacency_matrix keyword is only relevant for discrete_design_set real and discrete_design_set integer variables if one or more of them have been specified to be categorical. It is always relevant for discrete_design_set string variables. If the user does not define an adjacency matrix, the default is method dependent. Currently, the only method that makes use of the adjacency matrix is method-mesh_adaptive_search, which uses a tri-diagonal adjacency matrix by default.

Expected Output

The expected output is method dependent.

Usage Tips

If an adjacency matrix is defined for one type of (categorical) discrete_design_set variable, if must be defined for all variables of that type, even for those not defined to be categorical. Those for the non-categorical set variables will be ignored.

Examples

The following example shows a variables specification where some real and some integer discrete_design_set variables are categorical.

variables
  continuous_design = 3
    initial_point  -1.0    1.5   2.0
    lower_bounds  -10.0  -10.0 -10.0
    upper_bounds   10.0   10.0  10.0
    descriptors    'x1'   'x2'  'x3'
  discrete_design_range = 2
    initial_point  2     2
    lower_bounds   1     1
    upper_bounds   4     9
    descriptors   'y1'  'y2'
  discrete_design_set
    real = 2
      elements_per_variable = 4 5
      elements  =  1.2 2.3 3.4 4.5 1.2 3.3 4.4 5.5 7.7
      descriptors  'y3'            'y4'
      categorical  'no'            'yes'
      adjacency_matrix 1 1 0 0  # Begin entry of 4x4 matrix for y3
                       1 1 1 0
                       0 1 1 1
                       0 0 1 1
                       1 0 1 0 1 # Begin entry of 5x5 matrix for y4
                       0 1 0 1 0
                       1 0 1 0 1
                       0 1 0 1 0
                       1 0 1 0 1
    integer = 2
      elements_per_variable = 2 3
      elements  =  4  7  8  9  12
      descriptors  'z1'  'z2'
      categorical  'yes' 'yes'

Note that for the real case, the user wants to define an adjacency matrix for the categorical variable, so adjacency matrices for both variables must be specified. The matrix for the first one will be ignored. Note that no adjacency matrix is specified for either integer categorical variable. The default will be used in both cases. Currently the only method taking advantage of adjacency matrices is mesh_adaptive_search, which uses a tri-diagonal adjacency matrix by default. Thus, the matrices used would be

z1: 1 1
    1 1
z2: 1 1 0
    1 1 1
    0 1 1

The following example shows a variables specification for string variables. Note that string variables are always considered to be categorical. If an adjacency matrix is not specified, a method-dependent default matrix will be used.

variables,
  continuous_design = 2
    initial_point  0.5  0.5
    lower_bounds   0.   0.
    upper_bounds   1.   1.
    descriptors =  'x'  'y'
  discrete_design_set string = 1
    elements = 'aniso1' 'aniso2' 'iso1' 'iso2' 'iso3'
    descriptors = 'ancomp'
    adjacency_matrix 1 1 0 0 0
                     1 1 0 0 0
                     0 0 1 1 1
                     0 0 1 1 1
                     0 0 1 1 1