首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >具有R的非平方线性系统的求解

具有R的非平方线性系统的求解
EN

Stack Overflow用户
提问于 2013-11-04 00:01:44
回答 2查看 9.1K关注 0票数 10

如何求解具有R:A X = B的非平方线性系统?

(在这种情况下,系统没有解或无穷多个解)

例子:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
A=matrix(c(0,1,-2,3,5,-3,1,-2,5,-2,-1,1),3,4,T)
B=matrix(c(-17,28,11),3,1,T)

A
     [,1] [,2] [,3] [,4]
[1,]    0    1   -2    3
[2,]    5   -3    1   -2
[3,]    5   -2   -1    1


B
     [,1]
[1,]  -17
[2,]   28
[3,]   11
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-11-04 04:13:14

如果矩阵A的行数多于列数,则应使用最小二乘拟合。

如果矩阵A的行数少于列,则应执行奇异值分解。每一种算法都会尽最大努力,通过假设给出一个解决方案。

下面的链接展示了如何使用SVD作为求解器:

review.pdf

让我们将其应用于您的问题,看看它是否有效:

输入矩阵A和已知的RHS向量B

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
> A=matrix(c(0,1,-2,3,5,-3,1,-2,5,-2,-1,1),3,4,T)
> B=matrix(c(-17,28,11),3,1,T)
> A
     [,1] [,2] [,3] [,4]
[1,]    0    1   -2    3
[2,]    5   -3    1   -2
[3,]    5   -2   -1    1
> B
     [,1]
[1,]  -17
[2,]   28
[3,]   11

让我们分解您的A矩阵:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
> asvd = svd(A)
> asvd
$d
[1] 8.007081e+00 4.459446e+00 4.022656e-16

$u
           [,1]       [,2]       [,3]
[1,] -0.1295469 -0.8061540  0.5773503
[2,]  0.7629233  0.2908861  0.5773503
[3,]  0.6333764 -0.5152679 -0.5773503

$v
            [,1]       [,2]       [,3]
[1,]  0.87191556 -0.2515803 -0.1764323
[2,] -0.46022634 -0.1453716 -0.4694190
[3,]  0.04853711  0.5423235  0.6394484
[4,] -0.15999723 -0.7883272  0.5827720

> adiag = diag(1/asvd$d)
> adiag
          [,1]      [,2]        [,3]
[1,] 0.1248895 0.0000000 0.00000e+00
[2,] 0.0000000 0.2242431 0.00000e+00
[3,] 0.0000000 0.0000000 2.48592e+15

关键是:d中的第三个特征值非常小;相反,adiag中的对角线元素非常大。在求解之前,将其设为零:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
> adiag[3,3] = 0
> adiag
          [,1]      [,2] [,3]
[1,] 0.1248895 0.0000000    0
[2,] 0.0000000 0.2242431    0
[3,] 0.0000000 0.0000000    0

现在,让我们计算解决方案(请参阅我上面给您的链接中的幻灯片16 ):

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
> solution = asvd$v %*% adiag %*% t(asvd$u) %*% B
> solution
          [,1]
[1,]  2.411765
[2,] -2.282353
[3,]  2.152941
[4,] -3.470588

现在我们有了一个解决方案,让我们用它来代替它,看看它是否给了我们相同的B

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
> check = A %*% solution
> check
     [,1]
[1,]  -17
[2,]   28
[3,]   11

这就是你从B开始的一面,所以我认为我们很好。

下面是来自AMS的另一个很好的SVD讨论:

http://www.ams.org/samplings/feature-column/fcarc-svd

票数 12
EN

Stack Overflow用户

发布于 2017-10-16 01:24:53

目的是解决Ax = b问题

其中,给定A<>E 211和E 112bE 213,对于xx为q =1,b为p=1。

方法1:广义逆: Moore-Penrose inverse

将方程的两边相乘,我们得到

A‘A=A’b

其中A'A的转位。注意,A'A现在是q乘Q矩阵。解决这个问题的一种方法是用A'A的逆将方程的两边相乘。这给了,

x = ( A‘A)^{-1} A’b

这就是广义逆背后的理论。这里G = (A'A)^{-1} A'A的伪逆.

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
library(MASS)

ginv(A) %*% B

#          [,1]
#[1,]  2.411765
#[2,] -2.282353
#[3,]  2.152941
#[4,] -3.470588

方法2:使用SVD的广义逆。

@duffymo利用SVD方法得到A的伪逆。

但是,svd(A)$d的最后一个元素可能不像本例中的那么小。因此,可能不应该像那样使用该方法。这里有一个例子,A的最后一个元素没有一个接近于零。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
A <- as.matrix(iris[11:13, -5])    
A
#   Sepal.Length Sepal.Width Petal.Length Petal.Width
# 11          5.4         3.7          1.5         0.2
# 12          4.8         3.4          1.6         0.2
# 13          4.8         3.0          1.4         0.1

svd(A)$d
# [1] 10.7820526  0.2630862  0.1677126

一种选择是将cor(A)中的奇异值看作

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
svd(cor(A))$d
# [1] 2.904194e+00 1.095806e+00 1.876146e-16 1.155796e-17

现在,很明显只有两个大的奇异值存在。因此,现在可以将svd应用到A上,得到如下伪逆。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
svda <- svd(A)
G = svda$v[, 1:2] %*% diag(1/svda$d[1:2]) %*% t(svda$u[, 1:2])
# to get x
G %*% B
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19763698

复制
相关文章
如何删除对象的某个属性(对象属性方法是什么)
const object = { ‘a’: 1, ‘b’: ‘2’, ‘c’: 3 };
全栈程序员站长
2022/07/29
4.5K0
如何遍历JavaScript中对象属性
在2016年6月发布的ECMAScript 2016的同一时期,令JavaScript开发人员开心的是知道另一组很棒的提案已经达到了第4阶段(完成)。
疯狂的技术宅
2019/03/27
3.6K0
如何遍历JavaScript中对象属性
java反射获取Object的属性和值,包括单个对象,list集合里面的多个对象
import java.lang.reflect.Field; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; /** * 反射处理Bean,得到里面的属性值 * * @author liulinsen * */ public class ReflexObjectUtil { /** * 单个对象的所有键值 *
一写代码就开心
2020/12/18
8.8K0
JavaScript——对象的属性
在JavaScript中,所有的对象都是一组属性的集合,属性可以是数值,字符串等原始类型,也可以是函数,或者是其他对象。
Html5知典
2019/11/26
2.5K0
Javascript如何合并两个对象的属性[ 总结 ]
上面的代码会将obj2的所有属性添加到obj1对象中,如果你想到的是obj1未修改的,这可能不是你想要的结果。
IT工作者
2022/01/26
4.1K0
JavaScript之面向对象的概念,对象属性和对象属性的特性简介
  一、大家都知道,面向对象语言有一个标志,那就是他们都有类的概念,通过类我们可以创建任意多个具有相同属性和方法的对象。但ECMAScript(指定JavaScript标准的机构,也就是说JavaScript是实现其标准的扩展)并没有类的概念,因此他的对象和基于类的语言中的对象有所不同,ECMAScript把对象定义为:"无需属性的集合,其属性可以包含基本值、对象或者函数"。严格的来说,这就相当于说对象是一组没有特定顺序的值。对象的每个属性或方法都有一个名字,而每个名字都映射到一个值。正应为这样,我们可以把
郑小超.
2018/01/24
2.4K0
javascript如何去除对象的某个属性「建议收藏」
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/128151.html原文链接:https://javaforall.cn
全栈程序员站长
2022/07/31
1.4K0
对象属性的遍历
爱学习的前端歌谣
2023/10/24
1800
对象属性的遍历
将数组中多个对象的同名属性值取出合并成新数组
业务中需求的方法,接口返回一个数组,里面包含了大量的对象,具有同名的属性名,比较常见。但是需要将其中参数为name的属性值全部取出,合并成数组。
子舒
2023/08/23
5400
如何判断对象里有某个属性
剁椒鱼鳞
2023/06/06
3440
如何判断对象里有某个属性
如何从JavaScript对象中删除属性?
在使用 JavaScript 中的对象时,你可能会遇到需要从对象中完全删除属性的情况。为实现这一点可以有好几个选择:
疯狂的技术宅
2021/04/01
12.4K0
多个Promise对象的处理
如果某件事情需要依照多个对象完成后才能执行,那么我们可以使用Promise.all来管理,将这些状态全部执行完毕后才执行下一个!
十月梦想
2018/10/09
1.1K0
如何高效找出对象发生变化的属性
如图,假设选项A固定,可增删,不可改变,选项B可自定义但不可重复,并且横向对应A:出行,B:去公园,value:1,以此类推
疯狂的KK
2020/11/09
1.5K0
如何高效找出对象发生变化的属性
Django批量更新多个属性
有时候我们需要同时(一次性)更新某个用户的多条属性。 1. 用户model如下: class User(models.Model): UID = models.CharField('员工uid', max_length=200,) name = models.CharField('员工名字', max_length=200,) mobile = models.CharField('手机号', max_length=200,) mail = models.EmailField(u'邮箱', max_lengt
BigYoung小站
2020/05/04
2.1K0
Python 类对象和实例对象访问属性的区别、property属性
下面的一个小demo,定义了一个省份类  Province ,即类对象 Province ,开辟了一块内存空间,空间中存放着 类属性 country 和 __init__()方法 。
用户7886150
2020/12/20
3.7K0
链接a对象的pathname属性
再补充一点,location具有的属性链接a对象也有,不过location对象的方法,链接a对象不一定具有。
IT工作者
2021/12/29
1.1K0
初识: 对象的属性特征
众所周知,默认情况下我们可以任意对自己定义的对象进行增删改的。但是,在某些情况下,我们不能让别人去随便修改我们定义的对象的属性,那么我们应该怎么处理呢 ?这就需要了解下对象的属性特征了。
很酷的站长
2022/12/21
8090
初识: 对象的属性特征
js对象属性
相信对于对象属性大家都或多或少的知道一些,那么本文从属性说开去,看看大家对属性的了解是否有遗漏的部分。
RobinsonZhang
2018/11/07
15.7K0
如何使用 JS 动态合并两个对象的属性
我们可以使用扩展操作符(...)将不同的对象合并为一个对象,这也是合并两个或多个对象最常见的操作。
前端小智@大迁世界
2022/06/15
6.7K0
如何使用 ref 属性获取子组件实例对象?
在 Vue 中,我们可以使用 ref 属性来获取子组件的实例对象。这个功能非常方便,可以让父组件直接访问子组件的方法和数据。本文将详细介绍如何使用 ref 属性获取子组件实例对象。
网络技术联盟站
2023/06/04
2.9K0

相似问题

合并分支,但在修改它时,master会被修改

20

我需要将最新/更新的代码从master带到我的本地分支- GH6789/learninggit

10

我可以强制推送到我的分支,然后合并到master吗?

02

如果我需要修改保龄球的内容呢?

10

如何将来自master的任何并行更改合并到我的分支中,而不修改master?

12
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文