Differences
This shows you the differences between two versions of the page.
Next revision | Previous revision | ||
documentation:language_reference:objects:matrix:functions:touserdata [2018/09/25 13:26] – created Simon Heinze | documentation:language_reference:objects:matrix:functions:touserdata [2019/04/12 10:22] (current) – Corrected my grammar Simon Heinze | ||
---|---|---|---|
Line 5: | Line 5: | ||
Matrices are, per default, tables of tables in Lua. When algebraic operations are performed on them, they are repeatedly copied and moved, which can lead to severe performance issues if the matrices are large objects. | Matrices are, per default, tables of tables in Lua. When algebraic operations are performed on them, they are repeatedly copied and moved, which can lead to severe performance issues if the matrices are large objects. | ||
- | A call of Matrix.ToUserdata($M$) takes a matrix and transforms it, from Lua's point of view, from a table of tables to a mere pointer. This means that the object still has all functionalities Quanty defines on it with increased performance. The downside is that any functionalities Lua defines on tables | + | A call of Matrix.ToUserdata($M$) takes a matrix and transforms it, from Lua's point of view, from a table of tables to a mere pointer, which it returns. This means that the object still has all functionalities Quanty defines on it, but with increased performance. The downside is that any functionalities Lua defines on tables |
The inverse operation of Matrix.ToUserdata() is // | The inverse operation of Matrix.ToUserdata() is // | ||
Line 11: | Line 11: | ||
===== Example ===== | ===== Example ===== | ||
- | |||
- | ### | ||
- | Will follow. | ||
- | ### | ||
==== Input ==== | ==== Input ==== | ||
<code Quanty Example.Quanty> | <code Quanty Example.Quanty> | ||
- | -- some example code | + | --This creates a table of tables |
+ | A = Matrix.Random({-2, | ||
+ | setmetatable(A, | ||
+ | |||
+ | TimeStart(" | ||
+ | B = Matrix.Transpose(A) | ||
+ | B = Matrix.Conjugate(B) | ||
+ | B = Matrix.ConjugateTranspose(B) | ||
+ | B = B - A | ||
+ | print(B[1][1]) | ||
+ | TimeEnd(" | ||
+ | |||
+ | AUData = Matrix.ToUserdata(A) | ||
+ | --A is, after this point, no longer needed. | ||
+ | A = nil | ||
+ | B = nil | ||
+ | collectgarbage() | ||
+ | |||
+ | TimeStart(" | ||
+ | B = Matrix.Transpose(AUData) | ||
+ | B = Matrix.Conjugate(B) | ||
+ | B = Matrix.ConjugateTranspose(B) | ||
+ | B = B - AUData | ||
+ | --In case we want to access the first element. | ||
+ | B = Matrix.ToTable(B) | ||
+ | print(B[1][1]) | ||
+ | TimeEnd(" | ||
+ | |||
+ | TimePrint() | ||
</ | </ | ||
==== Result ==== | ==== Result ==== | ||
<file Quanty_Output> | <file Quanty_Output> | ||
- | text produced as output | + | 0 |
+ | 0 | ||
+ | Timing results | ||
+ | | ||
+ | 0:00:13 | 1 | 0 | Table of Tables | ||
+ | 0:00:02 | 1 | 0 | Userdata | ||
</ | </ | ||