diff --git a/main.c b/main.c
index e83ba658bb6c014eb5cac34951416c0b8c6c9981..a86789a69be35328a11eadf44da1eb41bc7d7286 100644
--- a/main.c
+++ b/main.c
@@ -11,24 +11,33 @@
 #include "matrix.h"
 
 int main() {
-    matrix mat, cloned;
+    matrix mat, cloned, transposed;
     int32_t m = 3;
     int32_t n = 4;
     int32_t s = m * n;
     int32_t val = 0;
     int32_t data[12] = { 2, 1, -1, -2, 3, 1, 1, 3, 1, 4, -1, -1 };
+    // Init
     matrix_init(&mat, m, n, val);
     printf("Empty matrix %dx%d\n", m, n);
     matrix_print(mat);
+    // Init from array
     matrix_init_from_array(&mat, m, n, data, s);
     printf("Matrix %dx%d from array\n", m, n);
     matrix_print(mat);
+    // Clone
     matrix_clone(&cloned, mat);
     printf("Cloned matrix :\n");
     matrix_print(cloned);
+    // Transpose
+    matrix_transpose(&transposed, mat);
+    printf("Transposed matrix :\n");
+    matrix_print(transposed);
     // Free the memory
     matrix_destroy(&mat);
     matrix_destroy(&cloned);
+    matrix_destroy(&transposed);
+
     
     return EXIT_SUCCESS;
 }
diff --git a/matrix.c b/matrix.c
index af26f76afc8e2ab4914ed2663bbb70bf0bc9083f..fb71f567634e33886e08f8581a866dacc1fe90ac 100644
--- a/matrix.c
+++ b/matrix.c
@@ -106,3 +106,19 @@ error_code matrix_destroy(matrix *mat) {
 
     return ok;
 }
+
+error_code matrix_transpose(matrix *transposed, const matrix mat) {
+    error_code code = matrix_alloc(transposed, mat.n, mat.m);
+    if (code == err) {
+        return err;
+    }
+
+    for (int i = 0; i < mat.m; i++) {
+        for (int k = 0; k < mat.n; k++) {
+            transposed->data[k][i] = mat.data[i][k];
+        }
+    }
+
+    return ok;
+}
+