Categories
  • Studies of Boolean functions
  •   Encyclosphere.org ENCYCLOREADER
      supported by EncyclosphereKSF

    3-ary Boolean functions

    From Wikiversity - Reading time: 13 min

    Studies of Boolean functions
    The 3-ary Boolean function represented as a Venn diagram
    sec 53 containing 8 functions, including the one shown above (shown in the top right position)
    bec 27 containing 3 secs, including the one shown above (shown in orange)
    The 22 becs ordered by weight, including the one shown above (shown second on the left in box 4)
    Compare A039754

    There are = 256 3-ary Boolean functions, like set operations or logical connectives.

    This Venn diagram 0000 0001, representing the intersection of 3 sets, or the conjunction of 3 statements respectively, gives an example of a 3-ary Boolean function.


    Equivalence classes

    [edit | edit source]
    See: Equivalence classes of Boolean functions

    The set of 256 functions can be parted into various equivalence classes.
    The most basic way to do that are the 46 small equivalence classes (secs). Functions belong to the same sec, when they can be expressed by each other by negating arguments. There are 3 arguments that can be negated, so there can be up to = 8 different functions in a sec.

    When binarily colored cubes can be transformed into each other by mirroring and rotation, they are essentially the same.
    The corresponding Boolean functions are often called equivalent and belong to the same big equivalence class (bec).


    Numbers of equivalence classes
    wec: 5
    sec: A000231(3) = 46 bec: A000616(3) = 22
    gsec: 30 gbec: 14
    ggsec: 18 ggbec: 8


    The following sequences show the number of secs and becs by weight:

                    weight   =   0   1   2   3   4   5   6   7   8
    secs: A054724(3, 0..8)   =   1   1   7   7  14   7   7   1   1
    becs: A039754(3, 0..8)   =   1   1   3   3   6   3   3   1   1
    

    The following sequences show the number of secs and becs by number of functions in each sec:

                                 1    2    4    8
    secs: A227725(3, 0..3)   =   2    7   14   23
    becs:                        2    3    6   11
    


    Permutations of functions in a bec

    [edit | edit source]

    Theoretically a bec could have 3! * 23 = 6 * 8 = 48 functions, but the largest becs have only 24. (There are some becs of 4-ary functions with the highest possible number of functions, e.g. this one.)

    Nonlinearity

    [edit | edit source]

    The nonlinearity of a function is the smallest Hamming distance it has from one of the 16 linear functions, i.e. from a row of the binary Walsh matrix or its complement.
    The functions in wec E0 are the linear functions, i.e. those with nonlinearity 0. The functions in wec O have nonlinearity 1, and all others have nonlinearity 2.
    There are no 3-ary bent functions.

    Walsh spectrum

    [edit | edit source]
    The Boolean function
    has the Walsh spectrum [1]
    and the binary Walsh spectrum . The latter is row 1 of the Walsh matrix.

    The Walsh spectrum of a Boolean function is the product of its binary string (as a row vector) with a Walsh matrix.
    The first entry of the Walsh spectrum is the functions digit sum, and all entries have the same parity.

    In the following chapter Walsh spectra are shown in the "by ggbec" sections.
    Walsh spectra of the same sec (which differ only in the signs of their entries) are always shown in the same file.

    The Walsh spectra of complements sum up to . [2]


    Walsh matrix with row numbers

    Further the binary Walsh spectra are always shown by the red squares in the background. They are always rows of a binary Walsh matrix - or, in other terms, exclusive disjunctions of unnegated arguments.

    The functions with odd digit sum, which make up wec O, have each binary Walsh spectrum one time in every sec.

    The functions with even digit sum, which make up the other four wecs, have always the same binary Walsh spectrum in the same sec:

    = 0000 0000 in wec E0
    = 0101 0101     or     = 0011 0011     or     = 0000 1111        in wec E1
    = 0110 0110     or     = 0101 1010     or     = 0011 1100        in wec E2
    = 0110 1001 in wec E3


    Functions with the same binary Walsh spectrum

    [edit | edit source]

    In the diagrams in this section the even functions are shown in red, and the odd ones (i.e. those in wec O) in yellow. Each odd function differs in the lowest bit (numerically: by 1) from an even function with the same binary Walsh spectrum. So in the octeract graphs each red vertex is connected to a yellow vertex by an edge of the direction corresponding to the lowest bit (like the edge connecting vertices 0 and 1). The pattern of the red vertices is always symmetrical to the main axes. Surprisingly the yellow vertices are also symmetrical, but to axes tilted to the left or to the right (indicated by \ or / in the table).

    Nested equivalence classes

    [edit | edit source]

    Overview

    [edit | edit source]

    The matrix on the right shows the 256 functions arranged in a way similar to the Hasse diagram, which is an octeract graph.
    The colors indicate the five wecs, as shown in the table below.

    The two following matrices are examples of a gbec and a ggsec. Both contain the sec 26. Files like these are in the collapsible boxes below in boxes labeled Positions.

    These matrices are symmetric to the main diagonal, because they contain complete secs. They are also symmetric to the antidiagonal, because they contain all the complements, and complements are symmetric about the center of the matrix. The ggsec matrices are also symmetric about the central axes, because they contain all the half-complements. Left half-complements are vertically, and right ones are horizontally symmetric to each other.

    gbec 25 with 6 secs (sec 26 is light green)
    ggsec 21 with 4 secs (sec 26 is light red)


    O
    nonlinearity 1
      E0  
    nonlinearity 0
      E1  
    nonlinearity 2
      E2  
    nonlinearity 2
      E3  
    nonlinearity 2
    by ggbec

          
    ggbec 1 with 64 functions

          
    ggbec 22 with 64 functions
    by ggbec


    ggbec 0 with 2 functions


    ggbec 15 with 6 functions

          
    ggbec 60 with 8 functions
    by ggbec

          
    ggbec 3 with 48 functions
    by ggbec

          
    ggbec 6 with 48 functions
          
    ggbec 23 with 16 functions
    by ggsec by ggsec by ggsec by ggsec
    122
    172225
    1127731221072561
    1118
    1278
    778
    318
    1919198
    558
    28288
    618
    2121218
    878
    26268
    918
    2222228
    1078
    25258
    1038
    01560
    01560105
    02551560105
    0001
    2551
    15152
    5151512
    60602
    8585852
    90902
    1021021022
    1051052
    3
    330
    36330
    3334
    634
    5554
    954
    1717174
    1194
    30308
    5454548
    8686868
    6
    627
    611127
    6664
    1114
    1818184
    1234
    29298
    2020204
    1254
    27278
    5353538
    23
    2324
    2324126
    2323238
    24244
    1264

    The tables above show how the equivalence classes are nested in each other. Each table shows the equivalence classes in a wec.
    The vertical axes show ggsecs, gsecs and secs, and the horizontal ones show ggbecs, gbecs and becs.
    The entries in the matrices show which secs belong to which becs.
    The numbers in these fields show how many functions are in each sec. A dark red background tells that the sec contains a monotonic function.

    wec O with 128 functions

    [edit | edit source]

    wec O ordered by ggbec

    [edit | edit source]

    wec O ordered by ggsec

    [edit | edit source]

    wec E0 with 16 functions

    [edit | edit source]

    wec E0 ordered by ggbec

    [edit | edit source]

    wec E0 ordered by ggsec

    [edit | edit source]

    wec E1 with 48 functions

    [edit | edit source]

    wec E1 ordered by ggbec

    [edit | edit source]

    wec E1 ordered by ggsec

    [edit | edit source]

    wec E2 with 48 functions

    [edit | edit source]

    wec E2 ordered by ggbec

    [edit | edit source]

    wec E2 ordered by ggsec

    [edit | edit source]

    wec E3 with 16 functions

    [edit | edit source]

    Monotonic functions

    [edit | edit source]
    contradictionA and B and CA and BA and CB and C(A and B) or (A and C)(A and B) or (B and C)(A and C) or (B and C)ABC(A or B) and (A or C) and (B or C) <====> (A and B) or (A and C) or (B and C)(A or B) and (A or C)(A or B) and (B or C)(A or C) and (B or C)A or BA or CB or CA or B or Ctautology
    Formulas appear when the mouse is moved over the diagram, and the sec files are linked from them. In the sec files the monotonic functions are always in the top right position.


    The right Hasse diagram in the file on the right shows the 20 monotonic 3-ary Boolean functions.

    If a sec has a monotonic function, all the secs in the gbec and gsec it belongs to also have one. So one can call secs, gbecs and gsecs monotonic, when they contain monotonic functions. There are 6 gbecs and 12 gsecs that are monotonic in this sense. Their collapsible boxes are marked with Tudor roses .

    In the above tables that show the nesting of the equivalence classes the monotonic secs have a dark red instead of a black background.

    gbec weight gsec
    0 0, 8 0
    1 1, 7 1
    3 2, 6 3, 5, 17
    7 3, 5 7, 19, 21
    15, 23 4 15, 23, 51, 85

    All wecs except E2 contain monotonic functions.


    Subgroups of nimber addition

    [edit | edit source]
    See: Subgroups of nimber addition#Z23

    16 secs with in all 8 + 7*4 + 7*2 + 1 = 51 functions are related to subgroups of nimber addition:

    These matrices describe equivalence relations.
          
    1000 00001100 00001010 00001000 10001000 00101000 01001001 00001000 00011010 10101100 11001111 00001100 00111010 01011001 10011001 01101111 1111
    These cubes correspond to the matrices' top lines. In the linked files they are always in the bottom left position.


    In each sec matrix its leading function appears in a sona pattern. This pattern is 0 in N(0) iff the sec contains 8 different functions. All the other different sona patterns appear only in the sec matrices of the actual sonas between 1 and 15 and their Boolean complements. Each gbec is marked in green with its sona-bec, and each gsec is marked with its sona-sec.

    Complements in secs

    [edit | edit source]

    There are two kinds of secs that are their own complements (i.e. complete gsecs): Those with sona rank 2, marked as N(2, ...), and the following seven secs containing 8 functions each:

    Gbecs by similarity to 4-ary sec matrix

    [edit | edit source]

    In the octeract matrices of the gbecs it can be seen, that they belong together in a way that is independent of ggbecs and wecs. Their pattern is part of a sec matrix of one of the five 4-ary exact-value functions. On the left the functions in these gbecs are shown in the Hasse diagram.



    0

    gbec 0 wec E0

    gbec 60 wec E0

    gbec 24 wec E3

    1, 2, 4, 8

    gbec 1 wec O

    gbec 25 wec O



    3, 5, 6, 9, 10, 12

    gbec 3 wec E1

    gbec 30 wec E1

    gbec 6 wec E2

    gbec 27 wec E2

    7, 11, 13, 14

    gbec 7 wec O

    gbec 22 wec O



    15

    gbec 15 wec E0

    gbec 105 wec E0

    gbec 23 wec E3

    References

    [edit | edit source]
    1. Compare Figure 1 in Walsh Spectrum Computations Using Cayley Graphs, by W. J. Townsend and M. A. Thornton
    2. Compare Property 1 (page 3 of the PDF) in The spectral test of the Boolean function linearity by P. Porwik
    This article is licensed under CC BY-SA 3.0.
    Original source: https://en.wikiversity.org/wiki/3-ary Boolean functions
    Status: article is cached
    Encyclosphere.org EncycloReader is supported by the EncyclosphereKSF