Wedgies and multivals

From Xenharmonic Wiki
(Redirected from Wedgies and Multivals)
Jump to navigation Jump to search

[math] \def\hs{\hspace{-3px}} \def\vsp{{}\mkern-5.5mu}{} \def\llangle{\left\langle\vsp\left\langle} \def\lllangle{\left\langle\vsp\left\langle\vsp\left\langle} \def\llllangle{\left\langle\vsp\left\langle\vsp\left\langle\vsp\left\langle} \def\llbrack{\left[\left[} \def\lllbrack{\left[\left[\left[} \def\llllbrack{\left[\left[\left[\left[} \def\llvert{\left\vert\left\vert} \def\lllvert{\left\vert\left\vert\left\vert} \def\llllvert{\left\vert\left\vert\left\vert\left\vert} \def\rrangle{\right\rangle\vsp\right\rangle} \def\rrrangle{\right\rangle\vsp\right\rangle\vsp\right\rangle} \def\rrrrangle{\right\rangle\vsp\right\rangle\vsp\right\rangle\vsp\right\rangle} \def\rrbrack{\right]\right]} \def\rrrbrack{\right]\right]\right]} \def\rrrrbrack{\right]\right]\right]\right]} \def\rrvert{\right\vert\right\vert} \def\rrrvert{\right\vert\right\vert\right\vert} \def\rrrrvert{\right\vert\right\vert\right\vert\right\vert} [/math][math] \def\val#1{\left\langle\begin{matrix}#1\end{matrix}\right]} \def\tval#1{\left\langle\begin{matrix}#1\end{matrix}\right\vert} \def\bival#1{\llangle\begin{matrix}#1\end{matrix}\rrbrack} \def\bitval#1{\llangle\begin{matrix}#1\end{matrix}\rrvert} \def\trival#1{\lllangle\begin{matrix}#1\end{matrix}\rrrbrack} \def\tritval#1{\lllangle\begin{matrix}#1\end{matrix}\rrrvert} \def\quadval#1{\llllangle\begin{matrix}#1\end{matrix}\rrrrbrack} \def\quadtval#1{\llllangle\begin{matrix}#1\end{matrix}\rrrrvert} \def\monzo#1{\left[\begin{matrix}#1\end{matrix}\right\rangle} \def\tmonzo#1{\left\vert\begin{matrix}#1\end{matrix}\right\rangle} \def\bimonzo#1{\llbrack\begin{matrix}#1\end{matrix}\rrangle} \def\bitmonzo#1{\llvert\begin{matrix}#1\end{matrix}\rrangle} \def\trimonzo#1{\lllbrack\begin{matrix}#1\end{matrix}\rrrangle} \def\tritmonzo#1{\lllvert\begin{matrix}#1\end{matrix}\rrrangle} \def\quadmonzo#1{\llllbrack\begin{matrix}#1\end{matrix}\rrrrangle} \def\quadtmonzo#1{\llllvert\begin{matrix}#1\end{matrix}\rrrrangle} \def\rbra#1{\left\{\begin{matrix}#1\end{matrix}\right]} \def\rket#1{\left[\begin{matrix}#1\end{matrix}\right\}} \def\vmp#1#2{\left\langle\begin{matrix}#1\end{matrix}\,\vert\,\begin{matrix}#2\end{matrix}\right\rangle\vsp} \def\wmp#1#2{\llangle\begin{matrix}#1\end{matrix}\,\vert\vert\,\begin{matrix}#2\end{matrix}\rrangle} [/math]

This page may be difficult to understand to those unfamiliar with the mathematical concepts involved. A more accessible version will be worked on; in the meantime, feel free to ask questions in the Xenharmonic Alliance Discord server or Facebook group.

An alternating multilinear map which is a multilinear function taking a certain number n of monzos as arguments and returning an integer as a value we may call an n-map. This definition is quite a mouthful, and we will attempt to unpack it in more comprehensible language and explain why these things are valuable in tuning theory.

The simplest kind of n-map is the 1-map, or val. This takes p-limit rational numbers, which may be written as monzos, and returns an integer, and may be called both a group homomorphism and a module homomorphism. Vals are linear: If you take the product of two p-limit rationals (or equivalently, add the corresponding monzos) then the val applied to the product/sum is the sum of the val applied to each separately, and so forth. Next come the 2-maps. These are linear functions f(u, v), linear for u fixing v, and linear for v fixing u, and alternating. meaning that f(u, u) = 0 and f(u, v) = −f(v, u).

One use for such things is as "machines" for measuring complexity. If we consider the 1-map which is the val for 11-limit 31et, we find we have [math]\tval{31 & 49 & 72 & 87 & 107}[/math]. This tells us that it takes 72 steps of 31 equal to get to the approximate 5, which therefore has a complexity of 72 in this system. Now consider a 2-map "meantone(u, v)" which tells us, roughly speaking, how many generator steps it takes to get to v assuming u is being used as a period in septimal meantone. Using 2 as a period we can take (the approximate) 3/2 as a generator, in which case we have meantone(2, 3) = 1, meantone(2, 5) = 4, meantone(2, 7) = 10. With 3 as a period and 3/2 as a generator, we get meantone(3, 5) = 4 and meantone(3, 7) = 13. Finally, with if we take 5 as a period we find that four 3/2s give 5, so 514 (or equivalently, 32) is the basic period. Using 32 as a period and 98 as a generator we get three generator steps to 7, and multiplying by four to be using 5 and not 514 gives us meantone(5, 7) = 12. This description does not make clear where the signs come from, which will emerge from the discussion of the wedge product, but it may help to elucidate how these things are connected to complexity.

Given an n-map f and an m-map g we may define a new (n + m)-map, the wedge product of f and g, written fg, as follows:

[math]\displaystyle f\wedge g = \sum_s \operatorname{sgn}\left(s\right)f\left(x_s(1), x_s(2), \ldots, x_s\left(n\right)\right)g\left(x_s\left(n +1\right), \ldots, x_s\left(n + m\right)\right)[/math]

where the sum is taken over S(n, m), the set of all permutations of the first n + m integers which are an (n, m) shuffle, and sgn(t) is the parity of the permutation t, which is +1 if t is even meaning an even number of transpositions of two numbers will get to t, and −1 if t is odd.

If f and g are both vals (1-maps) then this becomes especially easy: (fg)(u, v) = f(u)g(v) − f(v)g(u). Let's consider a specific example. Suppose [math]E_{19} = \val{19 & 30 & 44 & 53}[/math] is the equal temperament val for septimal 19et, and [math]E_{31} = \val{31 & 49 & 72 & 87}[/math] is the val for septimal 31et. Then writing intervals multiplicatively, we have

[math]\left(E_{19}\wedge E_{31}\right)\left(2,3\right) = E_{19}\left(2\right)E_{31}\left(3\right) - E_{19}\left(3\right)E_{31}\left(2\right) = 19*49 - 31*30 = 1.[/math]

We may continue in this way to consider (2,5), (2,7), (3,5), (3,7), and (5,7), and writing them in this alphabetical order yields [math]\bitval{1 & 4 & 10 & 4 & 13 & 12}[/math]. Here, the double angle braces are to indicate that the object is a 2-map. In fact, it is a special kind of 2-map in that it is the result of taking a wedge product rather than being, eg, the sum of two wedge products and is called a bival. In the same way, triple wedge products yield trivals which we depict with three angle braces, and so forth. Just as vals as associatd to rank one (equal) temperaments, bivals are associated to rank two temperaments such as meantone, trivals to rank three temperaments, and so forth. In tuning theory the necessity to look at any n-maps aside from vals, bivals and trivals seldom arises, so this notation, which is not standardly mathematical but which has been adopted for convenience by tuning theorists, is quite practical. As we can see by comparing the numbers, E19 ∧ E31 is the same object we were calling "meantone(u, v)" which gives us complexity measurements for meantone.

This particular bival has the properties that the first nonzero coordinate (1, in this case) is positive, and that the GCD of all of the coordinates is 1. An n-map with these properties we may call reduced, and reduced n-vals can be used to give unique names to regular temperaments.

These reduced n-vals, and particularly reduced bivals, are called wedgies (or Plücker coordinates), and the fact that they are reduced both makes the name unique and tells us that wedgies are projective, and hence the definition of regular temperaments in terms of them is projective. Thus, [math]E_{24} = \tval{24 & 38 & 56}[/math] is a perfectly valid val, but since it is not reduced, it does not define a 1-wedgie and hence there is no 5-limit 24et temperament to go with it. Sometimes such a temperament, where more than one set of notes exists in it each of which is unreachable from the others via intervals with defined prime mappings is called contorted. Wedgies do not name or signify contorted temperaments.

Computing the previous example in Maple

In fact one can directly do many computations in Maple. Let us associate to the i'th prime the variable [math] x_i [/math]. So for example 7 corresponds to [math] x_4 [/math]. Then we introduce a basis vector [math] dx_i [/math] associated to the variable [math] x_i [/math]. Then to a pair of primes, for example [math] (3,7) [/math], we associate a basis vector [math] dx_2 \wedge dx_4 [/math]. Similarly if we have 3 or more primes. Expressions where there are [math] dx_i [/math] can be called 1 forms, [math] dx_i \wedge dx_j [/math] 2 forms etc.

In this way let's write [math]E_{19} = \val{19 & 30 & 44 & 53}[/math] and [math]E_{31} = \val{31 & 49 & 72 & 87}[/math] as [math] e_{19}=19dx_1+30dx_2+44dx_3+53dx_4 [/math] and [math] e_{31}=31dx_1+49dx_2+72dx_3+87dx_4 [/math]. Then we simply compute the exterior product

[math] \displaystyle \alpha =e_{19} \wedge e_{31}=dx_1\wedge dx_2+4dx_1\wedge dx_3+10dx_1\wedge dx_4+4dx_2\wedge dx_3 +13dx_2\wedge dx_4+12dx_3\wedge dx_4[/math].

A form is said to be decomposable if it can be written as an exterior product of 1 forms. So given above [math] \alpha [/math] how do we know if it is decomposable or not? Let us introduce a linear map [math] L (b)=b\wedge \alpha [/math]. This is a map from 1 forms to 3 forms. Now a kernel or nullspace of this map are all 1 forms such that [math] L(b)=0 [/math]. A basis for this nullspace in the present case is

[math] \displaystyle b_1=dx_1-4dx_3-13dx_4 \quad, \quad b_2=dx_2+4dx_3+10dx_4 [/math].

Now one can check that [math] \alpha=b_1\wedge b_2 [/math]. All these computations can be done easily in Maple when the things are properly set up. But is this useful to anyone?

The original [math] (e_{19}, e_{31}) [/math] is a different basis of the nullspace. In matrix terms the connection between them is as follows. If

[math] \displaystyle A=\begin{pmatrix} 19 & 30 & 44 & 53 \\ 31 & 49 & 72 & 87 \end{pmatrix}[/math]

then its Hermite (normal) form is

[math] \displaystyle H=\begin{pmatrix} 1 & 0 & -4 & -13 \\ 0 & 1 & 4 & 10 \end{pmatrix}[/math]

Let us take another example. Suppose we have [math] \alpha_0=dx_1\wedge dx_2\wedge dx_3+2dx_1\wedge dx_2\wedge dx_4-2dx_1\wedge dx_3\wedge dx_4 -5dx_2\wedge dx_3\wedge dx_4[/math]. Now we have [math] L_0 (b)=b\wedge \alpha_0 [/math] and the basis for nullspace is

[math] \displaystyle b_1=dx_1+5dx_4 \quad, \quad b_2=dx_2+2dx_4 \quad, \quad b_3=dx_3+2dx_4 [/math].

and one can check that [math] \alpha=b_1\wedge b_2 \wedge b_3[/math]. Note by the way that n − 1 forms are always decomposable (here n=4 and we computed the decomposition of 3 form).

Truncation of wedgies

A useful operation to perform on any multivector, including wedgies, is truncation of the wedgie to a lower prime limit. This in effect sets all the basis vectors of a p-limit wedgie which are greater than q, the prime limit being truncated to zero. An algorithm to produce the truncation is to list the r-subsets of the primes to p in alphabetical order, and add the corresponding coefficient to the list of the q-limit truncation if and only if the maximum prime in the r-subet is less than or equal to q. Truncating a wedgie can lead to a non-wedgie if the GCD of the coefficients is greater than one; this means that in the lower limit, contortion has appeared.

Conditions on being a wedgie

If we take any three integers [math]\bitval{a & b & c}[/math] such that GCD(a, b, c) = 1 and a ≥ 1 the result is always a wedgie, the wedgie tempering out the dual monzo [math]\tmonzo{c & -b & a}[/math]. Since three such integers chosen at random are unlikely to produce a suitably small comma, the temperament will probably not be worth much, but at least it can be defined.

However, this is no longer the case in higher limits. There, not everything which looks like a wedgie will be one; for instance the wedgies must also satisfy the condition, for any wedgie W, that W ∧ W = 0, where the "0" means the multival of rank 2r obtained by wedging W with W. For prime limits 7 and 11 this condition suffices for rank two, but in general we need to check, for every prime qp and every basis val v sending q to 1 and everything else to 0, that (W ∨ q) ∧ W = 0 and (W ∧ v)º ∧ Wº = 0, where "∨" denotes the interior product. These conditions, the complete set along with the basic reduction conditions for being a wedgie, are known as the Plücker relations. Note that the Plücker relations must be satisfied, since for a rank-r multival, W ∨ q is a rank-(r − 1) multival corresponding to tempering out all the commas of W, as well as q.

In the 7-limit case, if we wedge a prospective rank two multival [math]W = \bitval{a & b & c & d & e & f}[/math] with itself, we obtain [math]W \wedge W = 2\left(af - be + cd\right)[/math]. The quantity afbe + cd is the Pfaffian of the wedgie, and that the Pfaffian is zero tells us that in the five-dimensional projective space P⁵ in which wedgies live, the wedgie lies on a (four-dimensional) hypersurface, known as the Grassmannian Gr(2, 4). For an 11-limit rank-two wedgie [math]W = \bitval{w_1 & w_2 & w_3 & w_4 & w_5 & w_6 & w_7 & w_8 & w_9 & w_{10}}[/math] we have that [math]W \wedge W = 2\quadtval{w_1 w_8 - w_2 w_6 + w_3 w_5 & w_1 w_9 - w_2 w_7 + w_4 w_5 & w_1 w_{10} - w_3 w_7 + w_4 w_6 & w_2 w_{10} - w_3 w_9 + w_4 w_8 & w_5 w_{10} - w_6 w_9 + w_7 w_8}[/math] is zero. These conditions allow us to solve for three of the coefficients in terms of the other seven, and so that Gr(2, 5), the Grassmannian of rank-two 11-limit temperaments, is a six-dimensional projective algebraic variety in nine-dimensional projective space P⁹. Wedgies correspond to rational points on this variety. For 11-limit rank three temperaments, we have w6w1w5w2 + w4w3 = w9w1w8w2 + w7w3 = w10w1w8w4 + w7w5 = w10w2w9w4 + w7w6 = w10w3w9w5 + w8w6 = 0; again, this leads to a six-dimensional variety, this time Gr(3, 5).

Constrained wedgies

Most of the wedgies which are legitimate according to the previous section do not represent temperaments which are in any way reasonable. To get temperaments which are, we need to constrain the relevant metrics--complexity should not be too high, error should not be too high, and badness should not be so high that competing temperaments are much better. Let us consider how bounding relative error E, aka simple badness, constrains a 7-limit rank-w wedgie [math]W = \bitval{a & b & c & d & e & f}[/math].

By definition, [math]E = \left\|J \wedge Z\right\|[/math], where Z is the weighted version of W; if q3, q5, and q7 are the logarithms base two of 3, 5, and 7, then [math]Z = \bival{\frac{a}{q_3} & \frac{b}{q_5} & \frac{c}{q_7} & \frac{d}{q_3 q_5} & \frac{e}{q_3 q_7} & \frac{f}{q_5 q_7}}[/math]. We now have

[math]\left(\frac{d}{q_3q_5}-\frac{b}{q_5}+\frac{a}{q_3}\right)^2+\left(\frac{e}{q_3q_7}-\frac{c}{q_7}+\frac{a}{q_3}\right)^2+\left(\frac{f}{q_5q_7}-\frac{c}{q_7}+\frac{b}{q_5}\right)^2+\left(\frac{f}{q_5q_7}-\frac{e}{q_3q_7}+\frac{d}{q_3q_5}\right)^2 = 4 E^2[/math]

From this we can conclude that d, e, and f satisfy [math]\left|d - q_3b + q_5a\right| \leqslant 2Eq_3q_5[/math], [math]\left|e - q_3c + q_7a\right| \leqslant 2Eq_3q_7[/math], and [math]\left|f - q_5c + q_7d\right| \leqslant 2Eq_5q_7[/math]. This has an interesting interpretation: since [math]\tval{1 & q_3 & q_5 & q_7} \wedge \tval{0 & a & b & c} =[/math] [math]\bitval{a & b & c & q_3b - q_5a & q_3c - q_7a & q_5c - q_7b}[/math], if E ≤ 14q5q7, then the full wedgie can be recovered from the octave equivalent (OE) portion of the wedgie simply by wedging it with [math]\tval{1 & q_3 & q_5 & q_7}[/math] and rounding to the nearest integer. This is not a very serious constraint to place on relative error; it seems unlikely anyone would be interested in a temperament which did not fall well under this low standard. Hence we may compile lists of reasonable temperaments by presuming "reasonable" requires this bound to be met, searching through triples [math]\bitval{a & b & c & \ldots}[/math] (note that if all of these are zero, 2 is being tempered out) up to some complexity bound, wedging with [math]\tmonzo{1 & q_3 & q_5 & q_7}[/math], and rounding, then checking if the GCD is one and the Pfaffian is zero (i.e. afbe + cd = 0). Then we may toss everthing which does not meet the bound on relative error; however, for a reasonable list we will want a tighter bound.

If C = ||W|| is the TE complexity, then the formula for the logflat badness B in the 7-limit rank-two case is particularly simple: B = CE. If complexity is bounded by, for example, 20 (which allows for some quite complex temperaments) then since E ≤ 14q5q7, B ≤ 204q5q7 = 0.767. This badness figure is easily met. While simply bounding complexity will lead to a finite list, the list would be enormous. An alternative is also to bound badness; for instance, we might produce a list of 7-limit rank-two temperaments with complexity less than 20 and a more reasonable badness limit, such as 0.05 or 0.06.

Reconstituting wedgies in general

Essentially the same situation obtains for rank two temperaments in higher limits. The rule then is that if [math]E \leqslant \frac{1}{\binom{n}{3}\log_2\left(q\right)\log_2\left(p\right)}[/math] then wedging [math]K = \tval{1 & \log_2\left(3\right) & \log_2\left(5\right) & \ldots & \log_2\left(p\right)}[/math] with the val consisting of 0 followed by the first n − 1 coefficients of the wedgie and rounding will give the wedgie, where p and q are the largest and second largest primes in the prime limit.

More generally, we can reconstitute W by rounding Y = (W ∨ 2) ∧ K to the nearest integer coefficients, where K is the JI point [math]\tval{1 & \log_2\left(3\right) & \log_2\left(5\right) & \ldots & \log_2\left(p\right)}[/math] in unweighted coordinates. Then we have [math]\left\|\left(W - Y\right) + Y\right\| \leqslant \left\|W-Y\right\| + \left\|Y\right\|[/math] by the triangle inequality, and since ||W − Y|| is bounded by the fact that W has been obtained by rounding, complexity, which is ||(W − Y) + Y|| = ||W||, can be bounded by ||Y||; which means it can be bounded by the coefficients of Y, which are those coefficients of W which can be found in W∨2 and over which we could be conducting a search. Moreover, we have from Y ∧ K = ((W ∨ 2) ∧ K) ∧ K = 0 that relative error, which is ||W ∧ K||, is ||((W − Y) + Y) ∧ K|| = ||(W − Y) ∧ K||, hence relative error is also bounded by the fact that ||W − Y|| is bounded. This means that unless relative error is large, W can be recovered by rounding Y, and hence all wedgies within such a bound, which we may call recoverable, can be found by a search on only some prospective coefficients. Temperaments which are not recoverable seem of little interest and may be ruled out of consideration. Search spaces for complexity measures such as TE complexity which are defined in terms of the wedgie can be obtained by assuming all wedgie coefficients which are not being used to recover a wedgie are zero, which gives a minimum value for the complexity. In the case of rank two temperaments, an especially efficient complexity measure for such searches, and one with some other desirable properties, is generator complexity.

In the particular case of the 11-limit in rank three, we have that (W ∨ 2) ∧ K gives the full wedgie, which has ten coefficents, in terms of the first six upon rounding off. Using this for a search is less difficult than it sounds, since the complexity numbers for rank three are so much lower. If the relative error E satisifes E ≤ 12√(5)q5q7q11, then the rounding off is guaranteed to lead to the correct result. This amount, 0.0099, is again easily met.

See also

Notes