Quá trình Gram–Schmidt

Từ testwiki
Phiên bản vào lúc 22:28, ngày 18 tháng 11 năm 2024 của imported>Plantaest (Đã lùi lại sửa đổi của 14.226.245.213 (thảo luận) quay về phiên bản cuối của Seventhsister23)
(khác) ← Phiên bản cũ | Phiên bản mới nhất (khác) | Phiên bản mới → (khác)
Bước tới điều hướng Bước tới tìm kiếm
Hai bước đầu tiên của quá trình Gram–Schmidt

Trong toán học, đặc biệt là trong lĩnh vực đại số tuyến tínhgiải tích số, quá trình Gram–Schmidt là một phương pháp trực chuẩn hóa một tập hợp các vectơ trong một không gian tích trong, thường là không gian Euclid Rn được trang bị tích trong tiêu chuẩn. Quá trình Gram–Schmidt xử lý một tập hợp vectơ hữu hạn và độc lập tuyến tính S = {v1,..., vk} với Bản mẫu:Nowrap và tạo ra từ tập đã cho một tập vectơ trực giao Bản mẫu:Nowrap} sinh ra không gian con k chiều của Rn tương tự không gian sinh bởi tập S.

Phương pháp này được đặt tên theo Jørgen Pedersen GramErhard Schmidt, nhưng Pierre-Simon Laplace đã quen thuộc với nó trước Gram và Schmidt.[1] Trong lý thuyết phân rã nhóm Lie nó được tổng quát hóa bởi phân rã Iwasawa.

Áp dụng quá trình Gram–Schmidt vào các vectơ cột của một ma trận với hạng cột đầy đủ, ta có phép phân rã QR (ma trận đó được phân rã thành một ma trận trực giaotam giác).

Quá trình Gram–Schmidt

Quá trình Gram-Schmidt (có cải tiến) được thực hiện trên ba vectơ độc lập tuyến tính không trực giao của một cơ sở cho không gian R3. Nhấp vào ảnh để xem chi tiết.

Ta định nghĩa toán tử chiếu vectơ bởi

proj𝐮(𝐯)=𝐮,𝐯𝐮,𝐮𝐮,

trong đó 𝐮,𝐯 ký hiệu tích trong của hai vectơ uv. Toán tử chiếu trực giao vectơ v vào đường thẳng span bởi vectơ u. Nếu u = 0, ta định nghĩa proj0(𝐯):=0, tức là ánh xạ chiếu proj0ánh xạ không, nó biến mọi vectơ thành vectơ không.

Quá trình Gram–Schmidt sau đó được tiến hành như sau:

𝐮1=𝐯1,𝐞1=𝐮1𝐮1𝐮2=𝐯2proj𝐮1(𝐯2),𝐞2=𝐮2𝐮2𝐮3=𝐯3proj𝐮1(𝐯3)proj𝐮2(𝐯3),𝐞3=𝐮3𝐮3𝐮4=𝐯4proj𝐮1(𝐯4)proj𝐮2(𝐯4)proj𝐮3(𝐯4),𝐞4=𝐮4𝐮4    𝐮k=𝐯kj=1k1proj𝐮j(𝐯k),𝐞k=𝐮k𝐮k.

Dãy u1,..., uk là dãy vectơ trực giao cần tìm, và các vectơ được chuẩn hóa e1,..., ek tạo thành một tập hợp trực chuẩn. Việc tính toán dãy u1,..., uk được gọi là trực giao hóa Gram–Schmidt, còn việc tính toán dãy e1,..., ek được gọi là trực chuẩn hóa Gram–Schmidt bởi vì các vectơ đã được chuẩn hóa.

Để kiểm tra xem các công thức trên liệu có cho một dãy trực giao, đầu tiên ta tính 𝐮1,𝐮2 bằng cách thế vào công thức ở trên cho u2: ta được 0. Sau đó sử dụng điều này để tính 𝐮1,𝐮3 bằng cách lại thế vào công thức ở trên cho u3: ta tiếp tục được 0. Chứng minh tổng quát sau đó được tiếp tục nhờ phép quy nạp toán học.

Nói một cách hình học, phương pháp này được tiếp tục như sau: để tính ui nó chiếu trực giao vectơ vi vào không gian con U sinh bởi u1,..., ui−1, mà đó cũng là không gian con sinh bởi v1,..., vi−1. Vectơ ui sau đó được định nghĩa là hiệu giữa vi và hình chiếu này và đảm bảo là trực giao với tất cả các vectơ trong không gian con U.

Quá trình Gram–Schmidt cũng áp dụng cho một dãy độc lập tuyến tính và vô hạn đếm được {vi}i. Kết quả là một dãy trực giao (hay trực chuẩn) {ui}i sao cho với một số tự nhiên n: span đại số của v1,..., vn cũng chính là span của u1,..., un.

Nếu quá trình Gram–Schmidt được áp dụng cho một dãy phụ thuộc tuyến tính, nó sẽ cho ra vectơ 0 ở bước thứ i, giả sử vi là một tổ hợp tuyến tính của Bản mẫu:Nowrap. Nếu cần phải có một hệ cơ sở trực chuẩn thì thuật toán nên tìm ra các vectơ không trong các kết quả và loại bỏ chúng vì không có một bội nào của vectơ không mà có độ dài bằng 1. Số vectơ đầu ra của thuật toán sẽ bằng số chiều của không gian được span bởi các vectơ đầu vào.

Ví dụ

Không gian Euclide

Xét hệ vectơ sau trong R2 (với tích trong quy ước chính là tích vô hướng)

S={𝐯1=(31),𝐯2=(22)}.

Bây giờ, thực hiện Gram–Schmidt để có được hệ các vectơ trực giao:

𝐮1=𝐯1=(31)
𝐮2=𝐯2proj𝐮1(𝐯2)=(22)proj(31)((22))=(22)810(31)=(2/56/5).

Ta kiểm tra rằng các vectơ u1u2 chắc chắn là trực giao:

𝐮1,𝐮2=(31),(2/56/5)=65+65=0,

lưu ý rằng nếu tích vô hướng của hai vectơ bằng 0 thì chúng trực giao.

Đối với các vectơ khác vectơ không, ta có thể chuẩn hóa các vectơ đó bằng cách chia cho độ dài của chúng như dưới đây:

𝐞1=110(31)
𝐞2=14025(2/56/5)=110(13).

Tham khảo

Bản mẫu:Tham khảo

Tham khảo sách

Liên kết ngoài

Bản mẫu:Portal

Bản mẫu:Đại số tuyến tínhBản mẫu:Sơ khai toán học