Hướng dẫn how do you plot a 3d numpy array in python? - làm thế nào để bạn vẽ một mảng numpy 3d trong python?

Tôi muốn vẽ kết quả của một phương pháp số cho một hệ thống ODE ba chiều. Đầu ra của tôi ở dạng (giả sử chúng ta đã tính toán ba bước):

import numpy as np
v= np.array([[1,2,3], [4,5,6], [7,8,9]])

Trong đó giá trị đầu tiên trong mỗi 3-Tuple là tọa độ x, thứ hai là tọa độ y và thứ ba là tọa độ z.

Tôi muốn cách đơn giản và hiệu quả nhất để vẽ các điểm này trên lưới 3D. Vấn đề dường như là dữ liệu nên được định hình như

from mpl_toolkits import mplot3d
6.

Matplotlib ban đầu được thiết kế chỉ với âm mưu hai chiều trong tâm trí. Trong khoảng thời gian phát hành 1.0, một số tiện ích âm mưu ba chiều được xây dựng trên màn hình hai chiều của Matplotlib và kết quả là một bộ công cụ thuận tiện (nếu hơi hạn chế) để trực quan hóa dữ liệu ba chiều. Các sơ đồ ba chiều được bật bằng cách nhập bộ công cụ

from mpl_toolkits import mplot3d
7, đi kèm với cài đặt matplotlib chính:

In [1]:

from mpl_toolkits import mplot3d

Khi mô hình con này được nhập, một trục ba chiều có thể được tạo bằng cách chuyển từ khóa

from mpl_toolkits import mplot3d
8 cho bất kỳ thói quen tạo trục thông thường nào:

In [2]:

%matplotlib inline
import numpy as np
import matplotlib.pyplot as plt

In [3]:

fig = plt.figure()
ax = plt.axes(projection='3d')

Với các trục ba chiều này được kích hoạt, giờ đây chúng ta có thể vẽ một loạt các loại lô ba chiều. Cấu trúc ba chiều là một trong những chức năng có lợi rất cao từ việc xem các số liệu tương tác thay vì tĩnh trong sổ ghi chép; Hãy nhớ lại rằng để sử dụng các số liệu tương tác, bạn có thể sử dụng

from mpl_toolkits import mplot3d
9 thay vì
%matplotlib inline
import numpy as np
import matplotlib.pyplot as plt
0 khi chạy mã này.

Điểm và dòng ba chiều

Biểu đồ ba chiều cơ bản nhất là một dòng hoặc bộ sưu tập các biểu đồ phân tán được tạo ra từ các bộ ba (x, y, z). Tương tự với các ô hai chiều phổ biến hơn được thảo luận trước đó, chúng có thể được tạo bằng các hàm

%matplotlib inline
import numpy as np
import matplotlib.pyplot as plt
1 và
%matplotlib inline
import numpy as np
import matplotlib.pyplot as plt
2. Chữ ký cuộc gọi cho những thứ này gần giống với các đối tác hai chiều của chúng, vì vậy bạn có thể tham khảo các sơ đồ dòng đơn giản và các sơ đồ phân tán đơn giản để biết thêm thông tin về việc kiểm soát đầu ra. Ở đây chúng ta sẽ vẽ một vòng xoáy lượng giác, cùng với một số điểm được vẽ ngẫu nhiên gần dòng:

In [4]:

ax = plt.axes(projection='3d')

# Data for a three-dimensional line
zline = np.linspace(0, 15, 1000)
xline = np.sin(zline)
yline = np.cos(zline)
ax.plot3D(xline, yline, zline, 'gray')

# Data for three-dimensional scattered points
zdata = 15 * np.random.random(100)
xdata = np.sin(zdata) + 0.1 * np.random.randn(100)
ydata = np.cos(zdata) + 0.1 * np.random.randn(100)
ax.scatter3D(xdata, ydata, zdata, c=zdata, cmap='Greens');

Lưu ý rằng theo mặc định, các điểm phân tán có tính minh bạch của chúng được điều chỉnh để mang lại cảm giác về độ sâu trên trang. Mặc dù hiệu ứng ba chiều đôi khi rất khó nhìn thấy trong một hình ảnh tĩnh, một chế độ xem tương tác có thể dẫn đến một số trực giác đẹp về bố cục của các điểm.

Lô đường viền ba chiều

Tương tự như các ô đường viền mà chúng tôi đã khám phá về mật độ và sơ đồ đường viền,

from mpl_toolkits import mplot3d
7 chứa các công cụ để tạo ra các ô cứu trợ ba chiều bằng cách sử dụng các đầu vào tương tự. Giống như các sơ đồ
%matplotlib inline
import numpy as np
import matplotlib.pyplot as plt
4 hai chiều,
%matplotlib inline
import numpy as np
import matplotlib.pyplot as plt
5 yêu cầu tất cả các dữ liệu đầu vào phải ở dạng các lưới chính quy hai chiều, với dữ liệu Z được đánh giá tại mỗi điểm. Ở đây chúng tôi sẽ hiển thị sơ đồ đường viền ba chiều của chức năng hình sin ba chiều:

In [5]:

def f(x, y):
    return np.sin(np.sqrt(x ** 2 + y ** 2))

x = np.linspace(-6, 6, 30)
y = np.linspace(-6, 6, 30)

X, Y = np.meshgrid(x, y)
Z = f(X, Y)

In [6]:

fig = plt.figure()
ax = plt.axes(projection='3d')
ax.contour3D(X, Y, Z, 50, cmap='binary')
ax.set_xlabel('x')
ax.set_ylabel('y')
ax.set_zlabel('z');

Đôi khi góc xem mặc định không tối ưu, trong trường hợp đó chúng ta có thể sử dụng phương pháp

%matplotlib inline
import numpy as np
import matplotlib.pyplot as plt
6 để đặt góc độ cao và góc phương vị. Trong ví dụ sau, chúng ta sẽ sử dụng độ cao 60 độ (nghĩa là 60 độ so với mặt phẳng X-Y) và góc phương vị 35 độ (nghĩa là xoay 35 độ ngược chiều kim đồng hồ về trục z):

Một lần nữa, lưu ý rằng loại xoay này có thể được thực hiện tương tác bằng cách nhấp và kéo khi sử dụng một trong các phụ trợ tương tác của Matplotlib.

Khung dây và lô bề mặt

Hai loại sơ đồ ba chiều khác hoạt động trên dữ liệu có lưới là khung dây và các ô bề mặt. Chúng lấy một lưới các giá trị và chiếu nó lên bề mặt ba chiều được chỉ định và có thể làm cho các dạng ba chiều kết quả khá dễ dàng để hình dung. Đây là một ví dụ về việc sử dụng khung dây:

In [8]:

fig = plt.figure()
ax = plt.axes(projection='3d')
ax.plot_wireframe(X, Y, Z, color='black')
ax.set_title('wireframe');

Một âm mưu bề mặt giống như một âm mưu khung dây, nhưng mỗi mặt của khung dây là một đa giác đầy. Thêm một colormap vào các đa giác đầy có thể hỗ trợ nhận thức về cấu trúc liên kết của bề mặt được hình dung:

In [9]:

ax = plt.axes(projection='3d')
ax.plot_surface(X, Y, Z, rstride=1, cstride=1,
                cmap='viridis', edgecolor='none')
ax.set_title('surface');

Lưu ý rằng mặc dù lưới các giá trị cho một biểu đồ bề mặt cần phải là hai chiều, nhưng nó không cần phải là trực tràng. Dưới đây là một ví dụ về việc tạo ra một lưới cực một phần, khi được sử dụng với biểu đồ ____27 có thể cho chúng ta một lát cắt vào chức năng mà chúng ta đang hình dung:

In [10]:

r = np.linspace(0, 6, 20)
theta = np.linspace(-0.9 * np.pi, 0.8 * np.pi, 40)
r, theta = np.meshgrid(r, theta)

X = r * np.sin(theta)
Y = r * np.cos(theta)
Z = f(X, Y)

ax = plt.axes(projection='3d')
ax.plot_surface(X, Y, Z, rstride=1, cstride=1,
                cmap='viridis', edgecolor='none');

Tam giác bề mặt

Đối với một số ứng dụng, các lưới được lấy mẫu đồng đều theo yêu cầu của các thói quen trên là quá hạn chế và bất tiện. Trong những tình huống này, các lô dựa trên tam giác có thể rất hữu ích. Điều gì sẽ xảy ra nếu thay vì một trận hòa thậm chí từ một cartesian hoặc lưới cực, thay vào đó chúng ta có một tập hợp các trận hòa ngẫu nhiên?

In [11]:

from mpl_toolkits import mplot3d
0

Chúng ta có thể tạo ra một biểu đồ phân tán của các điểm để có được ý tưởng về bề mặt mà chúng ta đang lấy mẫu từ:

In [12]:

from mpl_toolkits import mplot3d
1

Điều này để lại rất nhiều điều mong muốn. Chức năng sẽ giúp chúng ta trong trường hợp này là

%matplotlib inline
import numpy as np
import matplotlib.pyplot as plt
8, tạo ra một bề mặt bằng cách đầu tiên tìm một bộ hình tam giác được hình thành giữa các điểm liền kề (hãy nhớ rằng X, Y và Z Đây là các mảng một chiều):

In [13]:

from mpl_toolkits import mplot3d
2

Kết quả chắc chắn không sạch sẽ như khi nó được vẽ với một lưới, nhưng tính linh hoạt của một tam giác như vậy cho phép một số lô ba chiều thực sự thú vị. Ví dụ, thực sự có thể vẽ một dải Möbius ba chiều bằng cách sử dụng điều này, như chúng ta sẽ thấy tiếp theo.

Ví dụ: Hình dung một dải Möbius

Một dải Möbius tương tự như một dải giấy dán vào một vòng lặp với một nửa twist. Về mặt cấu trúc, nó khá thú vị bởi vì mặc dù xuất hiện nó chỉ có một mặt duy nhất! Ở đây chúng tôi sẽ trực quan hóa một đối tượng như vậy bằng cách sử dụng các công cụ ba chiều của Matplotlib. Chìa khóa để tạo dải Möbius là suy nghĩ về tham số hóa của nó: đó là một dải hai chiều, vì vậy chúng ta cần hai kích thước nội tại. Hãy gọi chúng là $ \ theta $, dao động từ $ 0 $ đến $ 2 \ pi $ xung quanh vòng lặp và $ w $ dao động từ -1 đến 1 trên chiều rộng của dải:

In [14]:

from mpl_toolkits import mplot3d
3

Bây giờ từ tham số này, chúng ta phải xác định vị trí (x, y, z) của dải nhúng.

Suy nghĩ về nó, chúng ta có thể nhận ra rằng có hai vòng quay xảy ra: một là vị trí của vòng lặp về trung tâm của nó (cái mà chúng ta gọi là $ \ theta $), trong khi cái còn lại là sự xoắn của dải về trục của nó (chúng ta 'll gọi đây là $ \ Phi $). Đối với một dải Möbius, chúng ta phải có dải tạo ra một nửa trong vòng lặp đầy đủ hoặc $ \ Delta \ Phi = \ Delta \ theta/2 $.

Bây giờ chúng tôi sử dụng hồi ức về lượng giác để rút ra sự nhúng ba chiều. Chúng tôi sẽ xác định $ r $, khoảng cách của mỗi điểm từ trung tâm và sử dụng điều này để tìm tọa độ $ (x, y, z) $: tọa độ:

Trong & nbsp; [16]:

from mpl_toolkits import mplot3d
4

Cuối cùng, để vẽ biểu đồ đối tượng, chúng ta phải đảm bảo rằng tam giác là chính xác. Cách tốt nhất để làm điều này là xác định phép tam giác trong các tham số cơ bản, và sau đó để cho matplotlib dự án tam giác này vào không gian ba chiều của dải Möbius. Điều này có thể được thực hiện như sau:

In [17]:

from mpl_toolkits import mplot3d
5

Kết hợp tất cả các kỹ thuật này, có thể tạo và hiển thị một loạt các đối tượng và mẫu ba chiều trong matplotlib.

Làm thế nào để bạn vẽ một hàm 3 chiều trong Python?

Các ô ba chiều được bật bằng cách nhập bộ công cụ mplot3d, đi kèm với cài đặt matplotlib chính:..
Từ mpl_toolkits nhập mplot3d ..
%matplotlib inline nhập khẩu numpy khi nhập np matplotlib.pyplot như plt ..
FIG = plt. Hình () ax = plt. ....
FIG = plt. Hình () ax = plt. ....
cây rìu. ....
FIG = plt. ....
AX = PLT. ....
theta = 2 * np ..

Làm thế nào để bạn tạo ra một mảng 3D trong Python?

Mã sau đây tạo ra một mảng 3 chiều:..
# Một mảng 3D, hình dạng- (2, 2, 2) >>> d3_array = np.....
# Lấy một phần tử duy nhất từ một marray 3D >>> d3_array [0, 1, 0] 2 ..
# Lấy một mảng con 1D từ một mảng 3D >>> d3_array [:, 0, 0] mảng ([0, 4]).

Bạn có thể vẽ một mảng numpy trong Python không?

Để vẽ đồ thị trong Python, chúng tôi sẽ sử dụng thư viện matplotlib.Matplotlib được sử dụng cùng với dữ liệu numpy để vẽ bất kỳ loại đồ thị nào.Từ matplotlib, chúng tôi sử dụng hàm cụ thể, tức là pyplot (), được sử dụng để vẽ dữ liệu hai chiều.. Matplotlib is used along with NumPy data to plot any type of graph. From matplotlib we use the specific function i.e. pyplot(), which is used to plot two-dimensional data.

Làm thế nào để bạn vẽ đường viền 3D trong Python?

Hàm ax.contour3d () tạo ra biểu đồ đường viền ba chiều.Nó đòi hỏi tất cả các dữ liệu đầu vào phải ở dạng lưới chính quy hai chiều, với dữ liệu Z được đánh giá tại mỗi điểm.Ở đây, chúng tôi sẽ hiển thị một sơ đồ đường viền ba chiều của chức năng hình sin ba chiều. contour3D() function creates three-dimensional contour plot. It requires all the input data to be in the form of two-dimensional regular grids, with the Z-data evaluated at each point. Here, we will show a three-dimensional contour diagram of a three-dimensional sinusoidal function.