Hướng dẫn dùng python ravel python
The numpy.ravel() functions returns contiguous flattened array(1D array with all the input-array elements and with the same type as it). A copy is made only if needed. Show numpy.ravel(array, order = 'C') Parameters : array : [array_like]Input array. order : [C-contiguous, F-contiguous, A-contiguous; optional] C-contiguous order in memory(last index varies the fastest) C order means that operating row-rise on the array will be slightly quicker FORTRAN-contiguous order in memory (first index varies the fastest). F order means that column-wise operations will be faster. ‘A’ means to read / write the elements in Fortran-like index order if, array is Fortran contiguous in memory, C-like order otherwise Return : Flattened array having same type as the Input array and and order as per choice. Code 1 : Shows that array.ravel is equivalent to reshape(-1, order=order) Python
Output : Original array : [[ 0 1 2 3 4] [ 5 6 7 8 9] [10 11 12 13 14]] ravel() : [ 0 1 2 ..., 12 13 14] numpy.ravel() == numpy.reshape(-1) Reshaping array : [ 0 1 2 ..., 12 13 14] Code 2 :Showing ordering manipulation Python
Output : Original array : [[ 0 1 2 3 4] [ 5 6 7 8 9] [10 11 12 13 14]] About numpy.ravel() : numpy.ravel() : [ 0 1 2 ..., 12 13 14] Maintains A Order : [ 0 1 2 ..., 12 13 14] array2 [[[ 0 2 4] [ 1 3 5]] [[ 6 8 10] [ 7 9 11]]] Maintains A Order : [ 0 1 2 ..., 9 10 11] References : Trong Python, đối với một số trường hợp, chúng ta cần mảng một chiều hơn là mảng 2-D hoặc đa chiều. Với mục đích này, mô-đun numpy cung cấp một hàm được gọi là numpy.ndarray.flatten (), trả về bản sao của mảng trong một chiều chứ không phải trong mảng 2-D hoặc nhiều chiều. Các bài viết liên quan: Cú pháp ndarray.flatten (order = 'C') Tham sốorder: {‘C’, ‘F’, ‘A’, ‘K’} (tùy chọn) Nếu chúng ta đặt tham số thứ tự thành ‘C’, điều đó có nghĩa là mảng sẽ được làm phẳng theo thứ tự chính của hàng. Nếu ‘F’ được đặt, mảng sẽ được làm phẳng theo thứ tự cột-chính. Mảng được làm phẳng theo thứ tự cột-chính chỉ khi ‘a’ là Fortran liền kề trong bộ nhớ và khi chúng tôi đặt tham số thứ tự thành ‘A’. Thứ tự cuối cùng là ‘K’, làm phẳng mảng theo cùng thứ tự mà các phần tử xuất hiện trong bộ nhớ. Theo mặc định, tham số này được đặt thành ‘C’. Returns:y: ndarray Hàm này trả về một bản sao của mảng nguồn, được làm phẳng thành một chiều. Ví dụ 1: import numpy as np a = np.array([[1,4,7], [2,5,8],[3,6,9]]) b=a.flatten() b Đầu ra: Trong đoạn code trên
Ví dụ 2: import numpy as np a = np.array([[1,4,7], [2,5,8],[3,6,9]]) b=a.flatten('C') b Output: Trong đoạn code trên
Ví dụ 3: import numpy as np a = np.array([[1,4,7], [2,5,8],[3,6,9]]) b=a.flatten('F') b Output: Ví dụ 4: import numpy as np a = np.array([[1,4,7], [2,5,8],[3,6,9]]) b=a.flatten('A') b Output: Ví dụ 5: import numpy as np a = np.array([[1,4,7], [2,5,8],[3,6,9]]) b=a.flatten('K') b Output: Flattening Trong phần này tôi xin giới thiệu cách chuyển một mảng nhiều chiều về mảng chỉ có môt chiều mà tôi gọi đó là làm phẳng (flatten) mảng hoặc mảng có shape mong muốn khác. Thư viện numpy cung cấp ta hai phương thức giúp ta làm việc này dễ dàng: flatten() và ravel(). Phưng thức flatten() sử dụng một tham số từ khoá tùy chọn "order". Ý nghĩa của “order” được miêu tả dưới đây. Giá trị mặc định là "C". Ý nghĩa “order” cho cả flatten() và ravel(): với mảng a[i1][i2][i3]…[in] 'F': trật tự Fortran-like, với chỉ số đầu tiên (i1) thay đổi nhanh nhất, và chỉ số cuối cùng thay đổi chậm nhất (in). 'A': trật tự sẽ là Fortran-like nếu mảng "a" là “Fortran contiguous” trong bộ nhớ, tương tự trật tự sẽ là c-like nếu ngược lại. 'K': đọc các phần tử theo thứ tự chúng xuất hiện trong bộ nhớ, ngoại trừ việc đảo chiều dữ liệu khi chỉ số là âm. Ví dụ:
Sử dụng ravel(), thứ tự của các phần tử trong mảng trả về bởi ravel () thường là kiểu "C-style". Cú pháp: ravel (a, order = 'C') Ravel trả về một mảng một chiều. Bản sao được thực hiện chỉ khi cần thiết. Thông số từ khóa tùy chọn "order" có thể là 'C', 'F', 'A', hoặc 'K'
Qua 2 ví dụ trên có thể thấy cả hai phương thức ravel() hay flatten() đều trả về list kết quả như nhau. Vậy tại sao cần sinh ra 2 phương thức để thực hiện cùng một công việc ? Hãy cùng theo dõi ví dụ bên dưới:
Như vậy flatten() luôn trả về một copy của mảng gốc trong khi ravel() là trả về một view của mảng gốc. Dẫn đến kết quả là nếu ta thay đổi giá trị mảng được trả về bởi ravel() thì mảng gốc cũng sẽ thay đổi theo. Bù lại thì ravel sẽ thường xử lý nhanh hơn bởi không cần memory để thực hiện copy. Nhưng các bạn cần cẩn thận với việc chỉnh sửa mảng được trả về bởi ravel(). Reshape Làm phẳng một mảng chỉ là một cách để thay đổi chiều của mảng. Một mảng có thể thay đổi thành bất kỳ chiều nào miễn là không thay đổi số lượng phần tử trong mảng. Việc này có thể thực hiện qua hàm reshape(). Phương thức reshape() đã được chúng tôi nhắc đến trong “bài 24: numpy slicing indexing”. Trong phần này tôi sẽ nêu chi tiết hơn về ý nghĩa cũng như cú pháp của nó. Reshape() trả về mảng mới có shape mới mà không thay đổi dữ liệu của nó. Cú pháp là reshape(a, newshape, order = 'C'), ý nghĩa của thông số: a là mảng cần reshape, newshape là một tuple sẽ nêu rõ kích thước các chiều muốn chuyển về, “order” sẽ nhận một trong các giá trị sau 'C', 'F', 'A' với ý nghĩa giống trong flatten() hay ravel(). Quan sát ví dụ sau để rõ hơn cách sử dụng reshape().
Ghép các mảng (Concatenating Arrays) Trong quá trình xử lý dữ liệu, rất nhiều bài toán đòi hỏi cần ghép nối nhiều mảng với nhau để mở rộng hàng hay cột thì khĩ thuật “Concatenating Arrays” tỏ ra rất hiệu quả. Cú pháp: numpy.concatenate((a1,a2,…), axis=0) Trong đó: (a1,a2,…) là list các mảng cần ghép. Trong ví dụ sau, chúng ta nối ba mảng một chiều vào một mảng qua phương thức concatenate()
Khi ghép các mảng đa chiều, chúng ta có thể ghép các mảng theo trục. Điều kiện là mảng phải có cùng một size tương ứng với trục muốn ghép khi dùng concatenate(). Giá trị mặc định là axis = 0: Dưới đây là ví dụ cho cả hai trường hợp axis=0 và axis = 1, các bạn chú ý kết quả để có thể hiểu được cách ghép.
Adding New Dimensions Các tham số mới có thể được thêm vào mảng bằng cách sử dụng kết hợp slicing và np.newaxis. Chúng tôi minh họa kỹ thuật này bằng một ví dụ:
Xếp chồng các mảng: Ta có thể xếp chồng các mảng theo hàng hoặc theo cột qua hai phương thức sau: row_stack() và column_stack(). Bạn có thể xếp chồng nhiều vectors tùy ý bạn, trong ví dụ dưới đây tôi lấy ví dụ cho 2 mảng. Chú ý kích thước chiều xếp chồng của các mảng phải giống nhau.
Phương thức tile() Đôi khi, bạn muốn hoặc phải tạo một ma trận mới bằng cách lặp lại một ma trận hiện có nhiều lần để tạo một ma trận mới với một hình dạng khác hoặc thậm chí là kích thước. Ví dụ lập lại ma trận được bôi đỏ để tạo thành ma trận như mảng dưới đây. Theo hàng 4 lần, cột lập 5 lần.
Cú pháp tile(x,reps), trong đó x là mảng cần lập, và reps là một tuple chỉ rõ hàng và cột cần lập bao nhiêu lần. Ví dụ:
Kết luận Qua bài này chúng tôi đã giới thiệu với các bạn thêm nhiều thao tác mới trên mảng, mà qua đó ảnh hưởng trực tiếp đến chiều của mảng. Sử dụng các phương thức flatten() hoặc ravel() khi bạn muốn chuyển mảng nhiều chiều về mảng chỉ có một chiều (hay làm phẳng mảng). Chú ý là flatten() trả về một copy của mảng gốc trong khi ravel() là trả về một view của mảng gốc. Reshape() đem đến nhiều tùy chọn hơn cho phép bạn tạo ra mảng mới có shape mới mà không thay đổi dữ liệu của nó. Ghép các mảng với phương thức concatenate(). Tăng chiều cho mảng đang tồn tại với numpy.newaxis. Xếp chồng các mảng theo hàng với row_stack() và theo cột với column_stack() hay tạo một ma trận mới bằng cách lặp lại ma trận hiện có nhiều lần với tile(). Trong bài tiếp theo chúng tôi sẽ trình bày chi tiết hơn về đối tượng kiểu dữ liệu ‘dtype’ – đối tượng này đã được sử dụng nhiều trong những bài học vừa qua. |