AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / coding / 问题 / 78993707
Accepted
Paolo Lorenzini
Paolo Lorenzini
Asked: 2024-09-17 18:51:40 +0800 CST2024-09-17 18:51:40 +0800 CST 2024-09-17 18:51:40 +0800 CST

按行填充矩阵

  • 772

我想根据一个函数按行填充矩阵,该函数给出数字 seq(1) 1 seq(2) 1 2 等等的 seq()

    matrixinp = matrix(data=NA, nrow=6, ncol=6) 

> print(matrixinp) 
     [,1] [,2] [,3] [,4] [,5] [,6]
[1,]   NA   NA   NA   NA   NA   NA
[2,]   NA   NA   NA   NA   NA   NA
[3,]   NA   NA   NA   NA   NA   NA
[4,]   NA   NA   NA   NA   NA   NA
[5,]   NA   NA   NA   NA   NA   NA
[6,]   NA   NA   NA   NA   NA   NA
    
    # display matrix 
    print(matrixinp) 
    
    # fill the elements with some  
    # 90 in a matrix 
    for (i in 1:6){
      aaa<-seq(i)
      print(aaa)
      for(j in 1:6){ 
        matrixinp[j,] = aaa
      } 
    }

这给了我这个:

> print(matrixinp)
     [,1] [,2] [,3] [,4] [,5] [,6]
[1,]    1    2    3    1    2    3
[2,]    1    2    3    1    2    3
[3,]    1    2    3    1    2    3
[4,]    1    2    3    1    2    3
[5,]    1    2    3    1    2    3
[6,]    1    2    3    1    2    3

但我想要这个:

> print(matrixinp)
     [,1] [,2] [,3] [,4] [,5] [,6]
[1,]    1    NA   NA   NA   NA   NA
[2,]    1    2    NA   NA   NA   NA
[3,]    1    2    3    NA   NA   NA
[4,]    1    2    3    4    NA   NA
[5,]    1    2    3    4    5    NA
[6,]    1    2    3    4    5    6
  • 7 7 个回答
  • 80 Views

7 个回答

  • Voted
  1. Best Answer
    Rui Barradas
    2024-09-17T19:00:26+08:002024-09-17T19:00:26+08:00

    我敢打赌一行代码就能解决这个问题,R 是一种矢量化语言。

    matrixinp <- matrix(data=NA, nrow=6, ncol=6)
    matrixinp[lower.tri(matrixinp, diag = TRUE)] <- rep(1:6, 6:1)
    
    matrixinp
    #>      [,1] [,2] [,3] [,4] [,5] [,6]
    #> [1,]    1   NA   NA   NA   NA   NA
    #> [2,]    1    2   NA   NA   NA   NA
    #> [3,]    1    2    3   NA   NA   NA
    #> [4,]    1    2    3    4   NA   NA
    #> [5,]    1    2    3    4    5   NA
    #> [6,]    1    2    3    4    5    6
    

    创建于 2024-09-17,使用reprex v2.1.0

    等一下,我打赌赢了。
    诀窍是要知道 R 的矩阵是列主序的,因此使用索引矩阵,lower.tri值将放在正确的位置。

    • 6
  2. jblood94
    2024-09-17T19:53:25+08:002024-09-17T19:53:25+08:00

    作为函数:

    f <- function(n) `dim<-`(rep(rbind(NA, 1:n), rbind(0:(n - 1), n:1)), c(n, n))
    f(6)
    #>      [,1] [,2] [,3] [,4] [,5] [,6]
    #> [1,]    1   NA   NA   NA   NA   NA
    #> [2,]    1    2   NA   NA   NA   NA
    #> [3,]    1    2    3   NA   NA   NA
    #> [4,]    1    2    3    4   NA   NA
    #> [5,]    1    2    3    4    5   NA
    #> [6,]    1    2    3    4    5    6
    f(10)
    #>       [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10]
    #>  [1,]    1   NA   NA   NA   NA   NA   NA   NA   NA    NA
    #>  [2,]    1    2   NA   NA   NA   NA   NA   NA   NA    NA
    #>  [3,]    1    2    3   NA   NA   NA   NA   NA   NA    NA
    #>  [4,]    1    2    3    4   NA   NA   NA   NA   NA    NA
    #>  [5,]    1    2    3    4    5   NA   NA   NA   NA    NA
    #>  [6,]    1    2    3    4    5    6   NA   NA   NA    NA
    #>  [7,]    1    2    3    4    5    6    7   NA   NA    NA
    #>  [8,]    1    2    3    4    5    6    7    8   NA    NA
    #>  [9,]    1    2    3    4    5    6    7    8    9    NA
    #> [10,]    1    2    3    4    5    6    7    8    9    10
    
    • 4
  3. ThomasIsCoding
    2024-09-17T19:16:37+08:002024-09-17T19:16:37+08:00

    你可以尝试

    > replace(m <- diag(1:6) * NA, lower.tri(m, TRUE), rep(1:6, 6:1))
         [,1] [,2] [,3] [,4] [,5] [,6]
    [1,]    1   NA   NA   NA   NA   NA
    [2,]    1    2   NA   NA   NA   NA
    [3,]    1    2    3   NA   NA   NA
    [4,]    1    2    3    4   NA   NA
    [5,]    1    2    3    4    5   NA
    [6,]    1    2    3    4    5    6
    

    在哪里

    • diag(1:6)*NA产生一个6-by-6矩阵NA
    • lower.tri检索下三角部分m
    • replacem根据掩码指标替换值

    或者,如果你想要按行进行操作

    > do.call(rbind, lapply(1:6, \(k) `length<-`(seq.int(k), 6)))
         [,1] [,2] [,3] [,4] [,5] [,6]
    [1,]    1   NA   NA   NA   NA   NA
    [2,]    1    2   NA   NA   NA   NA
    [3,]    1    2    3   NA   NA   NA
    [4,]    1    2    3    4   NA   NA
    [5,]    1    2    3    4    5   NA
    [6,]    1    2    3    4    5    6
    

    在哪里

    • `length<-`将长度设置为给定的向量
    • do.call(rbind, ...)按行将向量堆叠在列表中
    • 3
  4. G. Grothendieck
    2024-09-17T20:06:04+08:002024-09-17T20:06:04+08:00

    1)创建一个 6x6 的对角矩阵,用列号填充它,然后 NA 出上三角。

    library(magrittr)
    diag(6) %>% col() %>% { ifelse(row(.) < ., NA, .) }
    

    给予

         [,1] [,2] [,3] [,4] [,5] [,6]
    [1,]    1   NA   NA   NA   NA   NA
    [2,]    1    2   NA   NA   NA   NA
    [3,]    1    2    3   NA   NA   NA
    [4,]    1    2    3    4   NA   NA
    [5,]    1    2    3    4    5   NA
    [6,]    1    2    3    4    5    6
    

    2)或者使用本机管道:

    diag(6) |> col() |> list(x = _) |> with(ifelse(row(x) < x, NA, x))
    

    3)将 cc 定义为 6x6 矩阵,其列号如上,然后使用所示的公式。

    cc <- col(diag(6))
    cc * NA ^ (cc > t(cc))
    
    • 3
  5. Arka Ghosh
    2024-09-17T19:06:03+08:002024-09-17T19:06:03+08:00

    您可以尝试以下操作,

    # Create an empty 6x6 matrix
    matrixinp <- matrix(data=NA, nrow=6, ncol=6)
    
    # Fill the matrix row by row
    for (i in 1:6) {
      matrixinp[i, 1:i] <- seq(i)
    }
    
    # Display the matrix
    print(matrixinp)
    

    保留初始创建的空矩阵,其中包含 NA 值。使用单个循环遍历行(1 到 6)。对于每一行 i,我们仅使用序列 seq(i) 填充前 i 列。每行中的其余元素保持初始设置的 NA。

    该方法确保每行都具有直到其行号的序列,其余部分保持为 NA。

    • 2
  6. TiredSquirrel
    2024-09-17T19:03:36+08:002024-09-17T19:03:36+08:00

    您是否特别需要使用循环来执行此操作seq()?

    你可以利用 R 的矩阵代数功能轻松地创建该矩阵:

    # Multiply a row vector of all 1s by a column vector of 1-6
    matrixinp <- rep(1,6) %*% t(1:6)
    
    # You have a matrix with an all-1s column, and all-2s column, etc. - now set the upper triangle to NA
    matrixinp[upper.tri(matrixinp)] <- NA
    

    但如果你想了解为什么你的循环不起作用:

        for (i in 1:6){
          aaa<-seq(i)
          print(aaa)
          for(j in 1:6){ 
            matrixinp[j,] = aaa
          } 
        }
    

    运行时,seq(4)您会得到一个长度为 4 的向量c(1,2,3,4)。然后您尝试将其分配给的每一行matrixinp,但该矩阵中的行长度为 6 个元素。当您进行循环的第 4 次迭代时,该分配将失败并出现错误number of items to replace is not a multiple of replacement length。

    在进行第 4 次迭代之前,6 是 1、2 和 3 的倍数,因此对于那些迭代,R 会用 aaa 向量的重复填充矩阵:

    • 当i=1时aaa=1,它用填充矩阵行c(1,1,1,1,1,1)。
    • 当 i=2 时,aaa=c(1,2)它用 填充矩阵行c(1,2,1,2,1,2)。
    • 当i=3时aaa=c(1,2,3),它用填充矩阵行c(1,2,3,1,2,3)。
    • 当 i=4 时,它会因错误而停止,而不是填充矩阵。

    这就是为什么你会得到那个奇怪的矩阵,其中每一行都是 1 2 3 1 2 3 - 当 i=3 时,内部循环将 j 分配c(1,2,3,1,2,3)给矩阵的每一行。然后你的循环在 i=4 处遇到错误时停止,只剩下 i=3 版本的矩阵。

    • 1
  7. TiredSquirrel
    2024-09-17T20:08:25+08:002024-09-17T20:08:25+08:00

    为了帮助原始提问者理解,以下是我在给 RuiBarradas 的评论中写的一句话:

    matrixinp <- ifelse(lower.tri(matrix(nrow=6,ncol=6),diag=T),rep(1,6) %*% t(1:6),NA)
    

    这是混乱而过于复杂的代码,因为它很愚蠢,试图在一行中完成所有事情。你通常不应该在实际代码中做这样的事情,这会让其他人难以阅读代码(或者几个月后你再次查看时难以阅读)。但它确实展示了 R 的一些有用功能,并且尝试这样的事情有时可以帮助你更多地了解 R。

    最好从外向内阅读此代码,例如从最外层的函数开始:

    • ifelse()是一个检查其第一个参数是否为真的函数 - 如果是,则返回其第二个参数,否则返回其第三个参数。
      • 所以ifelse(c(T,F,T,F),'A','B')会回来c('A','B','A','B')。
    • 我给出的第一个参数ifelse()是lower.tri(matrix(nrow=6,ncol=6),diag=T),一个 TRUE/FALSE 值矩阵,表示 6x6 矩阵中的哪些单元格位于下三角(包括对角线为“在下三角”)
    • 我给出的第二个参数是rep(1,6) %*% t(1:6),来自我对你的问题的另一个回答的矩阵代数,它创建一个列全为 1 的矩阵,列全为 2 的矩阵,等等。
      • 这部分实际上是在 R 中创建 1 列、2 列等矩阵的好方法,我这样做并不是在开玩笑。R 针对矩阵代数运算进行了优化,速度非常快,因此矩阵代数解决方案通常是最快的。
    • 我给出的第三个论点是 NA

    因此,此代码检查 6x6 矩阵的每个单元格是否位于下三角。如果是,它会从矩阵中获取该单元格的值,该单元格的列为全 1、全 2 等。但如果位于上三角,它会将该单元格设置为 NA。

    我的第二句台词是:(!upper.tri(diag(6)) | NA) * (rep(1,6) %*% t(1:6))

    • 再说一遍,这是愚蠢的代码,不要真的这么做
    • 要理解这一点,需要将其分解为几个部分 - 它是两个矩阵的元素乘积,一个由 创建,(!upper.tri(diag(6)) | NA)另一个由(rep(1,6) %*% t(1:6))
    • 左边的矩阵使用 R 的处理方法和/或逻辑创建一个在下三角为 TRUE、在上三角为 NA 的矩阵。
      • diag(6)创建一个 6x6 矩阵,对角线上为 1,其余部分为 0。其目的只是以比 更短的方式创建一个 6x6 矩阵matrix(nrow=6,ncol=6)。
      • !upper.tri(diag(6))使用upper.tri()该矩阵创建一个矩阵,其中上三角(不包括对角线)为 TRUE,下三角为 FALSE。然后它使用!(“非”运算符)将 TRUE 转换为 false,反之亦然。
        • 我也可以写成lower.tri(diag(6),diag=T)制作相同的 T/F 矩阵,但由于这要求矩阵diag=T包含对角线,!upper.tri(diag(6))因此写起来更短(尽管可读性较差)。
      • 最后,整个左矩阵:(!upper.tri(diag(6)) | NA)。我取该 T/F 矩阵,并与 NA 进行逻辑“或”。“真或 NA”计算结果为“真”,而“假或 NA”计算结果为 NA。
    • 左边的矩阵与我在其他答案中使用的基于矩阵代数的方法相同,该方法创建了全 1 列、全 2 列等的矩阵。
    • 当我逐个元素地将真值和 NA 矩阵与全 X 列矩阵相乘时,R 会将值 TRUE 转换为 1(如果存在任何 FALSE,它还会将值 FALSE 转换为 0)。因此,对于下半部分,我乘以 1*1、1*2、1*3 等。对于上半部分,我乘以 NA、NA*1、NA*2 等,结果为 NA。
    • -1

相关问题

  • 将复制活动的序列号添加到 Blob

  • Packer 动态源重复工件

  • 选择每组连续 1 的行

  • 图形 API 调用列表 subscribedSkus 状态权限不足,但已授予权限

  • 根据列值创建单独的 DF 的函数

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    Vue 3:创建时出错“预期标识符但发现‘导入’”[重复]

    • 1 个回答
  • Marko Smith

    为什么这个简单而小的 Java 代码在所有 Graal JVM 上的运行速度都快 30 倍,但在任何 Oracle JVM 上却不行?

    • 1 个回答
  • Marko Smith

    具有指定基础类型但没有枚举器的“枚举类”的用途是什么?

    • 1 个回答
  • Marko Smith

    如何修复未手动导入的模块的 MODULE_NOT_FOUND 错误?

    • 6 个回答
  • Marko Smith

    `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它?

    • 3 个回答
  • Marko Smith

    何时应使用 std::inplace_vector 而不是 std::vector?

    • 3 个回答
  • Marko Smith

    在 C++ 中,一个不执行任何操作的空程序需要 204KB 的堆,但在 C 中则不需要

    • 1 个回答
  • Marko Smith

    PowerBI 目前与 BigQuery 不兼容:Simba 驱动程序与 Windows 更新有关

    • 2 个回答
  • Marko Smith

    AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String”

    • 1 个回答
  • Marko Smith

    我正在尝试仅使用海龟随机和数学模块来制作吃豆人游戏

    • 1 个回答
  • Martin Hope
    Aleksandr Dubinsky 为什么 InetAddress 上的 switch 模式匹配会失败,并出现“未涵盖所有可能的输入值”? 2024-12-23 06:56:21 +0800 CST
  • Martin Hope
    Phillip Borge 为什么这个简单而小的 Java 代码在所有 Graal JVM 上的运行速度都快 30 倍,但在任何 Oracle JVM 上却不行? 2024-12-12 20:46:46 +0800 CST
  • Martin Hope
    Oodini 具有指定基础类型但没有枚举器的“枚举类”的用途是什么? 2024-12-12 06:27:11 +0800 CST
  • Martin Hope
    sleeptightAnsiC `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它? 2024-11-09 07:18:53 +0800 CST
  • Martin Hope
    The Mad Gamer 何时应使用 std::inplace_vector 而不是 std::vector? 2024-10-29 23:01:00 +0800 CST
  • Martin Hope
    Chad Feller 在 5.2 版中,bash 条件语句中的 [[ .. ]] 中的分号现在是可选的吗? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench 为什么双破折号 (--) 会导致此 MariaDB 子句评估为 true? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng 为什么 `dict(id=1, **{'id': 2})` 有时会引发 `KeyError: 'id'` 而不是 TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String” 2024-03-20 03:12:31 +0800 CST
  • Martin Hope
    MarkB 为什么 GCC 生成有条件执行 SIMD 实现的代码? 2024-02-17 06:17:14 +0800 CST

热门标签

python javascript c++ c# java typescript sql reactjs html

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve