mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-19 19:09:36 +00:00
Extend scope of transpose
Includes an arg to allow transposing in respecto to the secondary "diagonal"
This commit is contained in:
parent
9a5724aebd
commit
5ebf1c80b9
2 changed files with 24 additions and 3 deletions
24
arrays.scad
24
arrays.scad
|
@ -1287,6 +1287,10 @@ function array_dim(v, depth=undef) =
|
||||||
|
|
||||||
// Function: transpose()
|
// Function: transpose()
|
||||||
// Description: Returns the transposition of the given array.
|
// Description: Returns the transposition of the given array.
|
||||||
|
// When reverse=true, the transposition is done in respect to the secondary diagonal, that is:
|
||||||
|
// .
|
||||||
|
// reverse(transpose(reverse(arr))) == transpose(arr, reverse=true)
|
||||||
|
// By default, reverse=false.
|
||||||
// Example:
|
// Example:
|
||||||
// arr = [
|
// arr = [
|
||||||
// ["a", "b", "c"],
|
// ["a", "b", "c"],
|
||||||
|
@ -1313,13 +1317,29 @@ function array_dim(v, depth=undef) =
|
||||||
// // ["c", "f"],
|
// // ["c", "f"],
|
||||||
// // ]
|
// // ]
|
||||||
// Example:
|
// Example:
|
||||||
|
// arr = [
|
||||||
|
// ["a", "b", "c"],
|
||||||
|
// ["d", "e", "f"],
|
||||||
|
// ["g", "h", "i"]
|
||||||
|
// ];
|
||||||
|
// t = transpose(arr, reverse=true);
|
||||||
|
// // Returns:
|
||||||
|
// // [
|
||||||
|
// // ["i", "f", "c"],
|
||||||
|
// // ["h", "e", "b"],
|
||||||
|
// // ["g", "d", "a"]
|
||||||
|
// // ]
|
||||||
|
// Example:
|
||||||
// transpose([3,4,5]); // Returns: [3,4,5]
|
// transpose([3,4,5]); // Returns: [3,4,5]
|
||||||
function transpose(arr) =
|
function transpose(arr, reverse=false) =
|
||||||
assert( is_list(arr) && len(arr)>0, "The array is not a vector neither a matrix." )
|
assert( is_list(arr) && len(arr)>0, "The array is not a vector neither a matrix." )
|
||||||
is_list(arr[0])
|
is_list(arr[0])
|
||||||
? let( l0 = len(arr[0]) )
|
? let( l0 = len(arr[0]) )
|
||||||
assert([for(a=arr) if(!is_list(a) || len(a)!=l0) 1 ]==[], "The array is not a vector neither a matrix." )
|
assert([for(a=arr) if(!is_list(a) || len(a)!=l0) 1 ]==[], "The array is not a vector neither a matrix." )
|
||||||
[for (i=[0:1:l0-1])
|
reverse
|
||||||
|
? [for (i=[0:1:l0-1])
|
||||||
|
[ for (j=[0:1:len(arr)-1]) arr[len(arr)-1-j][l0-1-i] ] ]
|
||||||
|
: [for (i=[0:1:l0-1])
|
||||||
[ for (j=[0:1:len(arr)-1]) arr[j][i] ] ]
|
[ for (j=[0:1:len(arr)-1]) arr[j][i] ] ]
|
||||||
: assert( is_vector(arr), "The array is not a vector neither a matrix." )
|
: assert( is_vector(arr), "The array is not a vector neither a matrix." )
|
||||||
arr;
|
arr;
|
||||||
|
|
|
@ -480,6 +480,7 @@ test_array_dim();
|
||||||
module test_transpose() {
|
module test_transpose() {
|
||||||
assert(transpose([[1,2,3],[4,5,6],[7,8,9]]) == [[1,4,7],[2,5,8],[3,6,9]]);
|
assert(transpose([[1,2,3],[4,5,6],[7,8,9]]) == [[1,4,7],[2,5,8],[3,6,9]]);
|
||||||
assert(transpose([[1,2,3],[4,5,6]]) == [[1,4],[2,5],[3,6]]);
|
assert(transpose([[1,2,3],[4,5,6]]) == [[1,4],[2,5],[3,6]]);
|
||||||
|
assert(transpose([[1,2,3],[4,5,6]], reverse=true) == [[6,3],[5,2],[4,1]]);
|
||||||
assert(transpose([3,4,5]) == [3,4,5]);
|
assert(transpose([3,4,5]) == [3,4,5]);
|
||||||
}
|
}
|
||||||
test_transpose();
|
test_transpose();
|
||||||
|
|
Loading…
Reference in a new issue