- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在 R 或 C++ 中是否有一种快速填充(稀疏)矩阵的方法:
A, B, 0, 0, 0
C, A, B, 0, 0
0, C, A, B, 0
0, 0, C, A, B
0, 0, 0, C, A
TRONG MỘT
、B
、C
是 5x5 矩阵,0 是 5x5 零矩阵。
实际上,我使用的矩阵是成百上千行和列。在 R 中,我知道可以使用 rbind
Và cbind
但这是一个有点乏味且昂贵的解决方案。
更新:如何使用这个矩阵
令上述矩阵为H
。给定两个 vector x
Và S
,我需要计算 H %*% x + s = y
。
câu trả lời hay nhất
你如何使用这个矩阵其实更重要。在许多情况下,后续计算不需要显式矩阵构造。此问答可能与您无关:How to build & store this large lower triangular matrix for matrix-vector multiplication? , 但完美地说明了我的观点。
Let the above matrix be
H
. Given two vectorsx
VàS
, I need to computeH %*% x + s = y
.
矩阵仅用于矩阵 vector 乘法?我们绝对可以跳过形成这个矩阵,因为乘法只是 rbind(B, A, C)
Và x
之间的滚动矩阵 vector 乘法。
## `nA` is the number of `A`-blocks on the main diagonal of `H`
MatVecMul <- function (A, B, C, nA, x, s) {
## input validation
if (diff(dim(A))) stop("A is not a square matrix")
if (diff(dim(B))) stop("B is not a square matrix")
if (diff(dim(C))) stop("C is not a square matrix")
if (dim(A)[1] != dim(B)[1]) stop("A and B does not have the same dimension")
if (dim(A)[1] != dim(C)[1]) stop("A and C does not have the same dimension")
if (length(x) != nA * M) stop("dimension dismatch between matrix and vector")
if (length(x) %% length(s)) stop("length of 'x' does not divide length of 's'")
## initialization
y <- numeric(length(x))
##########################
# compute `y <- H %*% x` #
##########################
## first block column contains `rbind(A, C)`
M <- dim(A)[1]
ind_x <- 1:M
y[1:(2 * M)] <- rbind(A, C) %*% x[ind_x]
ind_x <- ind_x + M
## middle (nA - 2) block columns contain `rbind(B, A, C)`
BAC <- rbind(B, A, C)
ind_y <- 1:(3 * M)
i <- 0
while (i < (nA - 2)) {
y[ind_y] <- y[ind_y] + BAC %*% x[ind_x]
ind_x <- ind_x + M
ind_y <- ind_y + M
i <- i + 1
}
## final block column contains `rbind(A, C)`
ind_y <- ind_y[1:(2 * M)]
y[ind_y] <- y[ind_y] + rbind(B, A) %*% x[ind_x]
## compute `y + s` and return
y + s
}
这是一个可重现的例子。
set.seed(0)
M <- 5 ## dim of basic block
A <- matrix(runif(M * M), M)
B <- matrix(runif(M * M), M)
C <- matrix(runif(M * M), M)
nA <- 5
x <- runif(25)
s <- runif(25)
y <- MatVecMul(A, B, C, nA, x, s)
为了验证上面的Và
是否被正确计算,我们需要显式构造H
。构建方式有很多种。
方法一:使用分块对角(稀疏)矩阵
N <- nA * M ## dimension of the final square matrix
library(Matrix)
## construct 3 block diagonal matrices
H1 <- bdiag(rep.int(list(A), nA))
H2 <- bdiag(rep.int(list(B), nA - 1))
H3 <- bdiag(rep.int(list(C), nA - 1))
## augment H2 and H3, then add them together with H1
H <- H1 +
rbind(cbind(Matrix(0, nrow(H2), M), H2), Matrix(0, M, N)) +
cbind(rbind(Matrix(0, M, ncol(H3)), H3), Matrix(0, N, M))
## verification
range((H %*% x)@x + s - y)
#[1] -8.881784e-16 8.881784e-16
我们看到 MatVecMul
是正确的。
方法二:直接填写
此方法基于以下观察:
B
-------------
A B
C A B
C A B
C A B
C A
-------------
C
很容易先构造矩形矩阵,然后在中间对方阵进行子集。
BAC <- rbind(B, A, C)
nA <- 5 ## number of basic block
N <- nA * M ## dimension of the final square matrix
NR <- N + 2 * M ## leading dimension of the rectangular matrix
## 1D index for the leading B-A-C block
BAC_ind1D <- c(outer(1:nrow(BAC), seq(from = 0, by = NR, length = M), "+"))
## 1D index for none-zero elements in the rectangular matrix
fill_ind1D <- outer(BAC_ind1D, seq(from = 0, by = M * (NR + 1), length = nA), "+")
## 2D index for none-zero elements in the rectangular matrix
fill_ind2D <- arrayInd(fill_ind1D, c(NR, N))
## construct "dgCMatrix" sparse matrix
library(Matrix)
Hsparse <- sparseMatrix(i = fill_ind2D[, 1], j = fill_ind2D[, 2], x = BAC)
Hsparse <- Hsparse[(M+1):(N+M), ]
## construct dense matrix
Hdense <- matrix(0, NR, N)
Hdense[fill_ind2D] <- BAC
Hdense <- Hdense[(M+1):(N+M), ]
## verification
range((Hsparse %*% x)@x + s - y)
#[1] -8.881784e-16 8.881784e-16
range(base::c(Hdense %*% x) + s - y)
#[1] -8.881784e-16 8.881784e-16
我们再次看到 MatVecMul
是正确的。
使用 Rcpp 实现 MatVecMul
将 R 函数 MatVecMul
转换为 Rcpp 函数非常容易。我会把这个任务留给你,因为你已经使用了 c++ .
关于c++ - 如何构造这个分块三对角(稀疏)矩阵?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52452554/
#include sử dụng không gian tên std; lớp C{ riêng tư: int giá trị; công khai: C(){ giá trị = 0;
Câu hỏi này đã có câu trả lời: Sự khác biệt giữa char a[] = ?string?; và char *p = ?string?;? (8 câu trả lời) Đã đóng
đóng cửa. Câu hỏi này yêu cầu chi tiết hoặc rõ ràng. Câu trả lời không được chấp nhận vào thời điểm này. Bạn muốn cải thiện câu hỏi này? Thêm chi tiết và làm rõ câu hỏi bằng cách chỉnh sửa bài đăng này Đã đóng 7 năm trước. Bài đăng này đã được 8 tháng rồi
Ngoài việc gỡ lỗi, có công cụ kiểm tra nào cho c, c++ hoặc c# hoạt động giống như các hàm độc lập dán sao chép vào một số hộp văn bản rồi nhập tham số vào các hộp văn bản khác không? Câu trả lời hay nhất Có lẽ bạn sẽ xem xét thử nghiệm đơn vị. Tôi khuyên bạn nên kiểm tra google và google mô phỏng
Tôi muốn di chuyển một cửa sổ (HWND) trong màn hình thứ hai. Vấn đề là tôi đã thử rất nhiều cách như tăng gấp đôi độ phân giải hoặc nhập giá trị âm, nhưng nó không bao giờ đặt cửa sổ trên màn hình thứ hai của tôi. Mọi manh mối về cách thực hiện việc này trong C/C++/C# sẽ hữu ích nhất
Tôi đang tìm kiếm các triển khai hiện có của các loại DES khác nhau trong C/C++/C##. Nền tảng đang chạy của tôi là Windows XP/Vista/7. Tôi đang cố gắng viết chương trình C# sẽ sử dụng thuật toán DES để mã hóa và giải mã. Tôi cần một số thực tế
Thật khó để nói những gì để hỏi ở đây. Câu hỏi không rõ ràng, mơ hồ, không đầy đủ, quá rộng hoặc hùng biện và không thể trả lời hợp lý ở dạng hiện tại. Để được trợ giúp làm rõ vấn đề này để có thể mở lại, hãy truy cập trung tâm trợ giúp Đóng 1.
Có cách nào để buộc một cửa sổ khác ở trên cùng không? Không phải cửa sổ của ứng dụng mà là một cửa sổ khác đang chạy trên hệ thống. (Windows, C/C++/C#) Câu trả lời hay nhấtSetWindowPos(that_window_ha
Giả sử bạn có lựa chọn giữa C/C++ hoặc Csharp và bạn dự định chạy nhiều phiên bản của cùng một máy chủ trên máy chủ Windows và Linux, đâu là lựa chọn thông minh nhất để xây dựng một ứng dụng máy chủ socket? Câu trả lời tốt nhất là như
Bạn có thể cho tôi biết sự khác biệt giữa chúng? Nhân tiện, có thứ gì được gọi là thư viện C++ hay thư viện C không? Câu trả lời hay nhất Thư viện chuẩn C++ và thư viện chuẩn C là các thư viện được xác định theo tiêu chuẩn C++ và C và được cung cấp để các chương trình C++ và C sử dụng. Đó là điểm chung của những từ đó
Trong mã kiểm tra bên dưới, tôi đưa thông tin đầu ra vào phần bình luận. Tôi đang sử dụng gcc 4.8.5 và Centos 7.2. #include #include lớp C { công khai:
Thật khó để nói những gì đang được hỏi ở đây. Câu hỏi mơ hồ, mơ hồ, không đầy đủ, quá rộng hoặc hùng biện và không thể trả lời hợp lý ở dạng hiện tại. Để được trợ giúp làm rõ vấn đề này để bạn có thể mở lại, hãy truy cập trung tâm trợ giúp. Đã đóng
Khách hàng của tôi sẽ sử dụng cấu trúc/lớp được gọi là thông báo để liên lạc với khách hàng. Tôi nghĩ tôi sẽ viết máy chủ bằng C++. Sẽ có nhiều lớp khác nhau kế thừa thông báo. Vấn đề của tôi là gửi các lớp này qua mạng tới máy khách. Tôi nghĩ có lẽ tôi nên sử dụng
Tôi có hàm sau trong C#: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
Tôi có một dự án mà tôi phải viết một hàm để thực hiện một số thao tác nhất định trên một số dữ liệu. Tôi có thể viết mã bằng C/C++, nhưng tôi không muốn chia sẻ mã của chức năng này với chủ nhân của mình. Thay vào đó, tôi chỉ muốn anh ấy có quyền gọi hàm bằng mã của riêng mình. Có thể được không? Tôi đã nghĩ đến hai phương pháp này - trong
Tôi đang sử dụng API của bên thứ 3 (C/C++) được viết kém. Tôi đang sử dụng nó từ mã được quản lý (C++/CLI). Đôi khi xảy ra "Lỗi vi phạm quyền truy cập". Điều này làm hỏng toàn bộ ứng dụng. Tôi biết tôi không thể xử lý những lỗi này [nếu con trỏ truy cập vào vị trí bộ nhớ không hợp lệ, v.v.
đóng cửa. Câu hỏi này không tuân thủ các nguyên tắc của Stack Overflow. Hiện tại nó không chấp nhận câu trả lời. Chúng tôi không cho phép các câu hỏi tìm kiếm đề xuất về sách, công cụ, thư viện phần mềm, v.v. Bạn có thể chỉnh sửa câu hỏi của mình để trả lời bằng sự kiện và trích dẫn. Đóng cửa 7 năm trước
Đã đóng cửa. Câu hỏi này không tuân thủ nguyên tắc Stack Overflow. Câu trả lời không được chấp nhận vào thời điểm này. Các câu hỏi yêu cầu chúng tôi giới thiệu hoặc tìm các công cụ, thư viện hoặc tài nguyên bên ngoài trang web yêu thích đều không có chủ đề đối với Stack Overflow vì
Tôi có một số mã C sẽ được gọi từ C# bằng P/Invoke. Tôi đang cố gắng xác định tương đương C# cho hàm C này. SomeData* DoSomething(); struct SomeData {
Câu hỏi này đã có câu trả lời: Tại sao các cấu trúc này sử dụng hành vi không xác định trước và sau tăng? (14 câu trả lời) Đã đóng 6
Tôi là một lập trình viên xuất sắc, rất giỏi!