Talk:Geometric algebra: Difference between revisions

 
(39 intermediate revisions by 2 users not shown)
Line 85:
::::::It's not consistent if i, j and k are not orthogonal to each other, which is the case for the javascript implementation (and I do not have a working copy of perl6, so I can't test whether that implementation is invalid or not). It might be that i, j and k are not orthogonal for any implementation which satisfies the constraints in the task description - I suspect that that is the case, but I need to think a bit more to see if I can either (a) find an interpretation of the task description which is internally consistent, or (b) find a way of showing a contradiction. --[[User:Rdm|Rdm]] ([[User talk:Rdm|talk]]) 22:01, 17 October 2015 (UTC)
:::::::i, j and k are not vectors in geometric algebra. They are bivectors. Orthogonality does not apply to them. The formula I gave for the scalar product only stands for vectors (thus the boldface notation which often means "vectors"). Also I've never written they should be orthogonal. It's the e basis that is, not the i, j, k.--[[User:Grondilu|Grondilu]] ([[User talk:Grondilu|talk]]) 22:24, 17 October 2015 (UTC)
::::::::We might still have an issue here. I think I can agree that I, j, and k are not vectors from the orthogonal basis e. But claiming that they are "not vectors" without qualification seems both sloppy and misleading. Needs more exposition, I guess... --[[User:Rdm|Rdm]] ([[User talk:Rdm|talk]]) 18:02, 19 October 2015 (UTC)
:::::::::Strictly speaking, all elements of a geometric algebra are vectors, since the whole geometric algebra has a natural vector space structure. However, the word ''vector'' is usually reserved to the elements of <math>\mathcal{V}</math>. Other elements are ''multivectors''.--[[User:Grondilu|Grondilu]] ([[User talk:Grondilu|talk]]) 19:38, 19 October 2015 (UTC)
:::::::::The task description does expose this if you look carefully.--[[User:Grondilu|Grondilu]] ([[User talk:Grondilu|talk]]) 19:41, 19 October 2015 (UTC)
::::::::::Sure, but there's nothing in the task description which supports the idea that i, j and k are not vectors. The axioms of vector spaces hold for i, j and k -- you can add them, and you can scale them and that includes scaling them by -1 which we can think of as being an inverse. You referred to them as bivectors, but the relevant definition of that term was not included in the task description.
::::::::::If it's not in the task description, and it's relevant to the task, that's a defect of the task description. You can't just refer people to some unmanageably large external context and expect that people will be able to distinguish the parts of that context which you consider relevant from the parts you consider irrelevant.
::::::::::Put differently, I do not know whether the presence of a <math>\mathcal{V}</math> within a clifford algebra excludes the existence of a different <math>\mathcal{V'}</math> from the algebra. Maybe it does, and maybe the statement "It is a known fact that if the dimension of <math>\mathcal{V}</math> is <math>n</math>, then the dimension of the algebra is <math>2^n</math>." hints at the axioms or constraints or concepts which require that. Or maybe not. I've not studied the subject enough to say for sure. --[[User:Rdm|Rdm]] ([[User talk:Rdm|talk]]) 20:15, 19 October 2015 (UTC)
:::::::::::Notice that I did not mention bivectors in the task description, only in this discussion page. The task description hints that there are multivectors that are not vectors. Without any knowledge of the subject, that means that the reader can not assume anything about i, j and k because he does not know if the geometric product of two vectors is a vector or not. He should consider them as multivectors and as such the scalar product formula can not ''a priori'' be applied to them. I would also like to point at that you were the one who wanted to discuss the orthogonality of i, j and k (for which the concept does not apply), but there is no need to consider that for solving this task anyway.--[[User:Grondilu|Grondilu]] ([[User talk:Grondilu|talk]]) 20:39, 19 October 2015 (UTC)
::::::::::::But "geometric product" is not a part of the definition of "vector". You do not need a "geometric product" for a vector to be a vector, and in fact in the general case vectors exist without any geometric product being defined. Meanwhile, the axioms of the of the algebra require that a scalar product can be applied to i, j and k. So the reader should indeed be able to assume that the scalar product formula can be applied to them.
::::::::::::Still, yes, you are using a particular definition of "orthogonality" - it's not what I would have expected, and I can easily imagine other definitions which might serve in other contexts. So that means that that definition of orthogonality needs to be in the task description. --[[User:Rdm|Rdm]] ([[User talk:Rdm|talk]]) 20:48, 19 October 2015 (UTC)
:::::::::::::No, the axioms do not require that a scalar product can be applied to i, j and k. I think you're confusing things. The axioms imply that the ''geometric product'' can be applied to them, not the scalar product. In fact, the axioms do not mention a scalar product at all. Also I don't understand where you got the idea that I was suggesting that the geometric product is required for the definition of a vector.--[[User:Grondilu|Grondilu]] ([[User talk:Grondilu|talk]]) 20:57, 19 October 2015 (UTC)
:::::::::::::As far as the orthonormality is concerned, once a scalar product has been established, the definition of orthonormality is common knowledge enough that we don't have to remind it, imho.--[[User:Grondilu|Grondilu]] ([[User talk:Grondilu|talk]]) 20:59, 19 October 2015 (UTC)
::::::::::::::Specifically, the axioms include:
:<math>\begin{array}{c}
a(b+c) = ab+ac
\end{array}
</math>
::::::::::::::And as I understand it, a is a scalar or can be a scalar, and i, j and k are values which can be used in the context of b and/or c. Do you really disagree? If so, why?
::::::::::::::That said, scalar product itself has two relevant meanings in this discussion - a product between vectors which produces a scalar, and a product between a scalar and a vector which produces another vector. But even there, it's my understanding that a vector space only needs to support the ability to be scaled and added. Once you have that you have enough that you can easily define a mechanism which multiplies vectors and produces a scalar. That said, you have already defined product involving i, j and k which produces a scalar - that particular product doesn't make them orthonormal, but it would be easy enough to define another product which does. <code>-mul</code>, for example. --[[User:Rdm|Rdm]] ([[User talk:Rdm|talk]]) 02:49, 20 October 2015 (UTC)
::::::::::::::After thinking about this, I am going to ask you to change your "It is known" statements in the task description. You need to spell these out in more detail. You cannot expect these details to be known by typical contributors to Rosettacode. You cannot even expect these details to be known by typical mathematicians. Only people who are well versed in the geometri/clifford algebra arcana should be expected to have apriori understanding of those details. --[[User:Rdm|Rdm]] ([[User talk:Rdm|talk]]) 03:31, 20 October 2015 (UTC)
:::::::::::::::The axioms define a so-called geometric product. The fact that this geometric product can be applied to a scalar and something else does not make it a scalar product. The expression ''scalar product'' in math means something specific. IIRC it's a symmetric, bilinear, positive-definite form. The multiplication of a scalar by a vector in a vector space for instance is never called scalar product, as this would be a very unfortunate naming collision. IIRC it's called extern scalar multiplication or something like that.
:::::::::::::::The proof that the geometric product defines a scalar product is not too hard. First you define the inner product of two vectors <math>\mathbf{a}\cdot\mathbf{b} = (\mathbf{a}\mathbf{b} + \mathbf{b}\mathbf{a})/2</math>. It's straightforward to see that it is a symmetric and bilinear. What's not so obvious is that it is a form, that is that it returns a scalar. To see it you just notice the equality : <math>\mathbf{a}\mathbf{b} + \mathbf{b}\mathbf{a} = \mathbf{a}^2 - \mathbf{a}^2 + \mathbf{a}\mathbf{b} + \mathbf{b}\mathbf{a} + \mathbf{b}^2 - \mathbf{b}^2 = (\mathbf{a} + \mathbf{b})^2 -\mathbf{a}^2 - \mathbf{b}^2</math>, and this is a real number because it's a linear combination of real numbers.
:::::::::::::::It's not very complicated a proof, but it's quite irrelevant to the task and putting it in the description would spam it imho. I won't add it unless other people complain.--[[User:Grondilu|Grondilu]] ([[User talk:Grondilu|talk]]) 11:21, 20 October 2015 (UTC)
:::::::::::::::: The axioms themselves do not specify what kind of product they use - which means that the reader should be able to determine that. Of course, other statements will constrain this, but baring considerable familiarity with the topic, we are left with the sort of trial and error (or hypothesis and test) that leads to talk pages as large as this one. Put differently, a general problem with generality is that there's so many ways to do it, and so many of the underlying assumptions are just that: assumptions. --[[User:Rdm|Rdm]] ([[User talk:Rdm|talk]]) 11:47, 20 October 2015 (UTC)
::::::::::::::::: The axioms don't specify what kind of product they use because they ''define'' it. Any product that satisfy these axioms '''IS''' a geometric product. That's what axioms do.--[[User:Grondilu|Grondilu]] ([[User talk:Grondilu|talk]]) 12:01, 20 October 2015 (UTC)
::::::::::::::::::One difficulty here is that the definition uses the term "dimension". And, while we might reasonably assume that we know what a "[[Dimension_(vector_space)|dimension]]" is, you have also declared that multivectors are not vectors. This means that we should not be using the definition of dimension which applies to vectors. I hope you can see the difficulty... --[[User:Rdm|Rdm]] ([[User talk:Rdm|talk]]) 13:29, 20 October 2015 (UTC)
:::::::::::::::::::I've explained that already. Strictly speaking, multivectors are vectors, but the term ''vector'' is reserved to elements of <math>\mathcal{V}</math>. The task description also briefly mentions this.--[[User:Grondilu|Grondilu]] ([[User talk:Grondilu|talk]]) 14:22, 20 October 2015 (UTC)
 
== "Orthonormal basis" ==
Line 99 ⟶ 125:
 
:::No, I combine them with the geometric product. Let me remind you that quaternions here are used as a special case of a more general structure, the geometric algebra.--[[User:Grondilu|Grondilu]] ([[User talk:Grondilu|talk]]) 22:43, 17 October 2015 (UTC)
 
:::: I think you have enough specifics in the task page now to narrow the implementation down to the particular geometric algebra you are thinking of. Previously, there were an infinity of the things which satisfied the task description. (There still might be, but if so it's now a much more constrained infinity...). Thanks! --[[User:Rdm|Rdm]] ([[User talk:Rdm|talk]]) 17:58, 19 October 2015 (UTC)
 
== Task still needs something... ==
Line 126 ⟶ 154:
 
:::From a vector space of arbitrary dimension (but at least 3), you can use the geometric product, not the scalar product, to create three bivectors i, j, k such that the subalgebra generated by (1, i, j, k) is isomorphic to the quaternion field. I think that's basically what the task description says. Maybe I could be a bit more verbose, but I think that is not necessary.--[[User:Grondilu|Grondilu]] ([[User talk:Grondilu|talk]]) 23:07, 17 October 2015 (UTC)
 
:::: The trick, here, seems to be that in this context we use multiple conflicting concepts of the term "dimension" and, for related terms such as "scalar" and "vector". A thorough exposition would detail each of these uses and show - ideally through concrete examples - how each of them is relevant to the implementation, as well as how each of these uses is different from the other uses of the same word, and perhaps the phrasing conventions we should be using to distinguish between these cases. --[[User:Rdm|Rdm]] ([[User talk:Rdm|talk]]) 17:55, 19 October 2015 (UTC)
 
A current problem with this task is that it only tests for symmetric results.
 
In other words, the javascript implementation would work even if the multiply routine were changed from
 
<lang javascript>...
for (var i in a) {
if (a[i]) {
for (var j in b) {
if (b[j]) {
...</lang>
 
to
 
<lang javascript>...
for (var i in a) {
if (a[i]) {
var j= i;
if (b[j]) {
...</lang>
 
Obviously, "quaternions" which result from this kind of implementation would not be real quaternions. But, this is an easy mistake to make. And, to underline this, one of the J implementations currently features this mistake. Fixing it is trivial, but not necessary as the task is currently written.
 
But also display of asymmetric results seems both ugly and difficult to interpret, so I'll just mention that this is how the task is currently written. --[[User:Rdm|Rdm]] ([[User talk:Rdm|talk]]) 10:11, 21 October 2015 (UTC)
:The only way I can understand what you've just wrote here is by assuming you have again confused the geometric product and the inner product.--[[User:Grondilu|Grondilu]] ([[User talk:Grondilu|talk]]) 10:25, 21 October 2015 (UTC)
::Hmm... you are correct. Testing this, I see that the javascript implementation does indeed give different results with this change. But looking at that flawed J implementation, the deviation from the javascript implementation is real. To simulate it in the javascript implementation, you would need to consider the i and j values as members of a list and only combine values from a/b where the i list and the j list had the same index. Anyways,, I'll let you come up with a change to the task description to catch this issue - if it matters to you. --[[User:Rdm|Rdm]] ([[User talk:Rdm|talk]]) 12:43, 21 October 2015 (UTC)
 
== The J solution might be correct but too small ==
Line 149 ⟶ 205:
::::: To be correct, you should verify using .hasOwnProperty() that you are not dealing with something inherited (some javascript environments create situations where arrays inherit properties which are not indices). --[[User:Rdm|Rdm]] ([[User talk:Rdm|talk]]) 21:58, 18 October 2015 (UTC)
::::::I've changed add and multiply. I don't know about this hasOwnProperty stuff. I'll look into it later.--[[User:Grondilu|Grondilu]] ([[User talk:Grondilu|talk]]) 22:09, 18 October 2015 (UTC)
:::::::I've added a J implementation which supports (in a 64 bit J implementation) roughly 63 orthogonal dimensions (9223372036854775807 multivector dimensions). Not so many dimensions in a 32 bit J implementation, but of course most of those dimensions will be ignored in any context.
:::::::Meanwhile, here's the [https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/hasOwnProperty official doc on .hasOwnProperty()]. As for why you might want that, consider what happens if <code>Object.prototype.foo= function(){}</code> before the implementation ran...--[[User:Rdm|Rdm]] ([[User talk:Rdm|talk]]) 17:24, 19 October 2015 (UTC)
 
== Notation==
Line 160 ⟶ 218:
:--[[User:Grondilu|Grondilu]] ([[User talk:Grondilu|talk]]) 15:41, 19 October 2015 (UTC)
:Also, a scalar does not belong to <math>\mathcal{V}</math>, so there really is no reason to use a similar notation for it as for the basis of <math>\mathcal{V}</math>.--[[User:Grondilu|Grondilu]] ([[User talk:Grondilu|talk]]) 15:45, 19 October 2015 (UTC)
 
:Put differently: all of the implementations here which I have inspected use index 0 to represent the "scalar part" of the "multivector". However, the scalar part of the multivector is not orthogonal to the elements of the orthogonal basis. Specifically, in these implementations, e(0) here corresponds to index 1 of the multivector, e(1) corresponds to index 2 of the multivector, e(2) corresponds to index 4 of the multivector, e(3) corresponds to index 8 of the multivector and e(4) corresponds to index 16 of the multivector. --[[User:Rdm|Rdm]] ([[User talk:Rdm|talk]]) 17:14, 19 October 2015 (UTC)
 
== This task is a mess ==
 
I'm considering going back to verifying the axioms. I would add a verification that <math>\mathcal{V}</math> is of dimension at least 5, though. That should prevent implementations of trivial algebras and re-use of the quaternion.
In order to verify the contraction rule, I would require the test to be done on a large number of random vectors.
 
Possibly also displaying the multiplication table, as in the echolisp solution.
 
--[[User:Grondilu|Grondilu]] ([[User talk:Grondilu|talk]]) 14:54, 21 October 2015 (UTC)
 
I'm not sure what your issues are, but it seems to me that quaternions are an algebra containing a vector space \mathcal{V} and obeying these axioms:
 
:<math>\begin{array}{c}
(ab)c = a(bc)\\
a(b+c) = ab+ac\\
(a+b)c = ac+bc\\
\forall \mathbf{x}\in\mathcal{V},\,\mathbf{x}^2\in\R
\end{array}
</math>
 
You've added other constraints onto the task (such as the calculation that generates a 19, the orthonormal basis for \mathcal{V} and the requirement for two different embedded quaternion algebras), and I guess I can agree that that aspect is something of a mess. Mathematically speaking, I suppose that this hints at the need for further axioms... but computationally speaking, usually all we can ever provide is an implementation which approximates the math.
 
For example, no real computer implementation can satisfy the Peano postulates, so there will be cases where simple addition fails. And multiplication is even worse. Roughly half of the result domain for addition is typically missing, but for multiplication the size of the valid argument domain approximates the square root of the size of the result domain. So that sort of thing is going to be completely valid, mathematically...
 
Which I think has to do with why we get into concrete examples and/or concrete requirements - those might be "unnecessary" from a mathematical point of view, but they can be critically important from an implementation point of view. I think this also has something to do with why it's often a good idea to avoid an overly-general implementation...
 
So, anyways, from a mathematical purist point of view, I can't imagine many tasks can be anything but a "mess".
 
Though, I guess we could use Boolean addition and multiplication (greatest common divisor and least common multiple) or maybe modulo arithmetic - that would work around the overflow problems with regular addition and multiplication. This probably is not what you intend - might even violate the task purpose (whatever that is) - but these sorts of implementations would be a better fit if axiomatic correctness is what you are asking for.
 
Anyways... if you can figure out what it is that you want, I guess go for it... --[[User:Rdm|Rdm]] ([[User talk:Rdm|talk]]) 15:35, 21 October 2015 (UTC)
 
:There is always an othonormal basis in a vector space with a scalar product. And the inner product always defines a scalar product. So these are not additional constraints. The only additional constraints I added were the vector dimension of at least five and the euclidean metric.
:I'm not sure where you are going with your suggestion of boolean addition, multiplication or modular arithmetics. I'm pretty sure such operations would not allow the inclusion of a vector space.
:You seem to keep questioning the pertinence of the axioms but again, I did not invent them. They look fine to me.--[[User:Grondilu|Grondilu]] ([[User talk:Grondilu|talk]]) 15:55, 21 October 2015 (UTC)
::Nothing in the text I quoted requires the existence of a scalar product. You did mention scalar product elsewhere, but not in the quoted axioms. See also: http://mathworld.wolfram.com/VectorSpace.html --[[User:Rdm|Rdm]] ([[User talk:Rdm|talk]]) 17:37, 21 October 2015 (UTC)
:::I was referring to your mention of the orthonormal basis being a constraint to the task. The existence of a scalar product, and thus of an orthonormal basis, is a consequence of the axioms. It is thus not a constraint.--[[User:Grondilu|Grondilu]] ([[User talk:Grondilu|talk]]) 19:02, 21 October 2015 (UTC)
::::Sure, all vector spaces have a basis but there's nothing in those axioms that say anything about the dimension of that basis. --[[User:Rdm|Rdm]] ([[User talk:Rdm|talk]]) 20:46, 21 October 2015 (UTC)
6,951

edits