From 5ebf1c80b956d04b79b6b45372948e5267fa27d1 Mon Sep 17 00:00:00 2001 From: RonaldoCMP Date: Tue, 11 Aug 2020 14:32:25 +0100 Subject: [PATCH] Extend scope of transpose Includes an arg to allow transposing in respecto to the secondary "diagonal" --- arrays.scad | 26 +++++++++++++++++++++++--- tests/test_arrays.scad | 1 + 2 files changed, 24 insertions(+), 3 deletions(-) diff --git a/arrays.scad b/arrays.scad index 6124e89..835fd65 100644 --- a/arrays.scad +++ b/arrays.scad @@ -1287,6 +1287,10 @@ function array_dim(v, depth=undef) = // Function: transpose() // 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: // arr = [ // ["a", "b", "c"], @@ -1313,14 +1317,30 @@ function array_dim(v, depth=undef) = // // ["c", "f"], // // ] // 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] -function transpose(arr) = +function transpose(arr, reverse=false) = assert( is_list(arr) && len(arr)>0, "The array is not a vector neither a matrix." ) is_list(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." ) - [for (i=[0:1:l0-1]) - [ for (j=[0:1:len(arr)-1]) arr[j][i] ] ] + 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] ] ] : assert( is_vector(arr), "The array is not a vector neither a matrix." ) arr; diff --git a/tests/test_arrays.scad b/tests/test_arrays.scad index 64a7fbb..f121266 100644 --- a/tests/test_arrays.scad +++ b/tests/test_arrays.scad @@ -480,6 +480,7 @@ test_array_dim(); 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]]) == [[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]); } test_transpose();