PseudoInverse
✖
PseudoInverse
Details and Options
data:image/s3,"s3://crabby-images/ee62e/ee62e36e435c0ff8e15bd97c355adb6289b2ca15" alt=""
- PseudoInverse works on both symbolic and numerical matrices.
- For a square matrix, PseudoInverse gives the Moore–Penrose inverse.
- For numerical matrices, PseudoInverse is based on SingularValueDecomposition.
- PseudoInverse[m,Tolerance->t] specifies that singular values smaller than t times the maximum singular value should be dropped.
- With the default setting Tolerance->Automatic, singular values are dropped when they are less than 100 times 10-p, where p is Precision[m].
- For non‐singular square matrices M, the pseudoinverse M(-1) is equivalent to the standard inverse.
Examples
open allclose allBasic Examples (5)Summary of the most common use cases
Find the pseudoinverse of an invertible matrix:
data:image/s3,"s3://crabby-images/cc6c9/cc6c97eb35d116f5d7ffab1443ef1cbf15089992" alt=""
https://wolfram.com/xid/0rs0l2k2a-htoxr7
data:image/s3,"s3://crabby-images/2e111/2e111050b5b3ee71ba692292c141ea3e1642bf99" alt=""
The pseudoinverse is merely the inverse:
data:image/s3,"s3://crabby-images/31851/3185134fcf7a6e5b18aa3797a1f109d0abe33029" alt=""
https://wolfram.com/xid/0rs0l2k2a-tyzi8r
data:image/s3,"s3://crabby-images/51329/513295b29f863e9d17bebce310cf05cb10ae4c6c" alt=""
Find the pseudoinverse of a singular matrix:
data:image/s3,"s3://crabby-images/24e70/24e7053f284748594916a648e4a46fa30fa62db5" alt=""
https://wolfram.com/xid/0rs0l2k2a-dn2wo0
data:image/s3,"s3://crabby-images/1adaa/1adaa63361a374ed94540f9893dbca5efe8a7291" alt=""
The determinant of is zero, so it does not have a true inverse:
data:image/s3,"s3://crabby-images/9c0b9/9c0b900ab95c1b59a34e7dae72e5fe177564557a" alt=""
https://wolfram.com/xid/0rs0l2k2a-8ssntl
data:image/s3,"s3://crabby-images/88188/881882fe6bca855c04451990a90fe422e789ab39" alt=""
For a pseudoinverse, both and
:
data:image/s3,"s3://crabby-images/4ccb7/4ccb7fc6773496da3573668cb2c79833941c57be" alt=""
https://wolfram.com/xid/0rs0l2k2a-rvdqhc
data:image/s3,"s3://crabby-images/8e585/8e5852f6a0f4b202a3e7ca6dfb6c74b31e6c51f2" alt=""
However, in this particular case neither nor
is an identity matrix:
data:image/s3,"s3://crabby-images/4483f/4483f0e17145ae0b9737c3f05fea70820c1a066a" alt=""
https://wolfram.com/xid/0rs0l2k2a-tuk8ac
data:image/s3,"s3://crabby-images/74ea5/74ea5c2389440a9be2c5ae7cc1f46cdcd9dc9e83" alt=""
Find the pseudoinverse of a rectangular matrix:
data:image/s3,"s3://crabby-images/12683/12683a0dbf7bbb76fd209b402c738cd7d958aaa5" alt=""
https://wolfram.com/xid/0rs0l2k2a-mrekcd
data:image/s3,"s3://crabby-images/2e5eb/2e5ebd1953154f52726f690f29761c472f3265e9" alt=""
In this particular case, is an identity matrix:
data:image/s3,"s3://crabby-images/6d38a/6d38ab225345c9bfc421fc8e17e7e07c61df4caf" alt=""
https://wolfram.com/xid/0rs0l2k2a-6irvfh
data:image/s3,"s3://crabby-images/b4845/b48451be65feebbac8e8c2c4424eabc9e9689d27" alt=""
data:image/s3,"s3://crabby-images/b5462/b546244d88d1f1bb647e22dec15781d2dbc71132" alt=""
https://wolfram.com/xid/0rs0l2k2a-zcejrl
data:image/s3,"s3://crabby-images/41c02/41c02d274035a505804175771437f0a157066079" alt=""
Find the pseudoinverse of a row matrix:
data:image/s3,"s3://crabby-images/c69c4/c69c44c8c4ed1ffb2424a3cba776b777d4efdd1b" alt=""
https://wolfram.com/xid/0rs0l2k2a-nhxt3
data:image/s3,"s3://crabby-images/ea8b7/ea8b7ee723bc13c37f003c13d2443646476fef5e" alt=""
Find the pseudoinverse of a zero matrix:
data:image/s3,"s3://crabby-images/1a18c/1a18cb38a27a596237d4c01fada94188a7b0b094" alt=""
https://wolfram.com/xid/0rs0l2k2a-cffd0i
data:image/s3,"s3://crabby-images/e9d71/e9d71bdc834084f12249ed1e3c3e3878bfda119d" alt=""
Scope (10)Survey of the scope of standard use cases
Basic Uses (6)
Find the pseudoinverse of a machine-precision matrix:
data:image/s3,"s3://crabby-images/c6598/c65983b7c0792ef58a210b3d110d6c06d8ff7ccb" alt=""
https://wolfram.com/xid/0rs0l2k2a-gzis3e
data:image/s3,"s3://crabby-images/02ccf/02ccfbc65cf8adbd592d5c7e2919ccf17c6efb3f" alt=""
Pseudoinverse of a complex matrix:
data:image/s3,"s3://crabby-images/02ff9/02ff987e8211da2f9379e8b4712febbec8061f73" alt=""
https://wolfram.com/xid/0rs0l2k2a-bjja1q
data:image/s3,"s3://crabby-images/cda02/cda024dee71e80860a6254be287196a1a2685648" alt=""
Pseudoinverse of an exact matrix:
data:image/s3,"s3://crabby-images/16316/163168241b5920bc353b461c806e640c2c7f6ae9" alt=""
https://wolfram.com/xid/0rs0l2k2a-piv3b5
data:image/s3,"s3://crabby-images/d29b0/d29b0cb7f55791853354d362f81d08b5e14a7beb" alt=""
Pseudoinverse of an arbitrary-precision matrix:
data:image/s3,"s3://crabby-images/be002/be0020b3ce674c56ee299f05d09ddb477b6821dd" alt=""
https://wolfram.com/xid/0rs0l2k2a-p8sjhl
data:image/s3,"s3://crabby-images/31fac/31fac12da5469c470c60fadc6925779de444f9ec" alt=""
Compute a symbolic pseudoinverse:
data:image/s3,"s3://crabby-images/f2680/f26803799a44c830d9ee1ddb51102e0cf1d1a3fc" alt=""
https://wolfram.com/xid/0rs0l2k2a-gtn59g
data:image/s3,"s3://crabby-images/fb27a/fb27a7098826a95b27b02cf029e8972df20151d9" alt=""
The inversion of large machine-precision matrices is efficient:
data:image/s3,"s3://crabby-images/c01b0/c01b0b4d0de8b9cc75790721d9714d1724c82a6d" alt=""
https://wolfram.com/xid/0rs0l2k2a-dkq7nk
data:image/s3,"s3://crabby-images/ef5ef/ef5ef56dbd89df703eb157e7db4b849d3633b383" alt=""
https://wolfram.com/xid/0rs0l2k2a-lx8juz
data:image/s3,"s3://crabby-images/db9ef/db9ef180f29e672f675cad4f84eb8dedde15eb4b" alt=""
Special Matrices (4)
The pseudoinverse of a sparse matrix is returned as a normal matrix:
data:image/s3,"s3://crabby-images/89984/899845fa2166566e4a4197ca61c5e3a5f2ab6141" alt=""
https://wolfram.com/xid/0rs0l2k2a-ocj3kf
data:image/s3,"s3://crabby-images/7d07a/7d07a3fec75d678f1912b6e7398356ee356dce77" alt=""
data:image/s3,"s3://crabby-images/3c9ea/3c9ea4b12780c54a9b38914a764ce9c3afac7a9d" alt=""
https://wolfram.com/xid/0rs0l2k2a-fm3xwv
data:image/s3,"s3://crabby-images/62720/62720e98c24a221fe7b48fccf44f66bf5486907c" alt=""
data:image/s3,"s3://crabby-images/2717c/2717cc2e9950c00584f10f8edbd402d5ac7f7f45" alt=""
https://wolfram.com/xid/0rs0l2k2a-eordwx
data:image/s3,"s3://crabby-images/d9b44/d9b442e3ac9c8adb14d2e1126e101d54f192d067" alt=""
When possible, the pseudoinverse of a structured matrix is returned as another structured matrix:
data:image/s3,"s3://crabby-images/2d450/2d4506430a6273e6d3e17941f5ca67ddcfa23b7f" alt=""
https://wolfram.com/xid/0rs0l2k2a-ebpduc
data:image/s3,"s3://crabby-images/8c85a/8c85a09dcfe1447d56c2388ba048474fb93cb651" alt=""
data:image/s3,"s3://crabby-images/2bbc9/2bbc967b6ea78ea3e8e04b5aaa7a069dffddad0d" alt=""
https://wolfram.com/xid/0rs0l2k2a-dhkxvx
data:image/s3,"s3://crabby-images/91be0/91be0ed7ebe6da35ecc1ed36277a993318d63d50" alt=""
data:image/s3,"s3://crabby-images/5bc62/5bc621a217f842a0d6f5711893af519bdb000f36" alt=""
https://wolfram.com/xid/0rs0l2k2a-wdjmwi
data:image/s3,"s3://crabby-images/3c14e/3c14e9f6515fae8b775b7b93f306dc9ba7c679cf" alt=""
data:image/s3,"s3://crabby-images/56a9a/56a9ab222f61762fde2ef4949796bc3486ee3a02" alt=""
https://wolfram.com/xid/0rs0l2k2a-j45yx1
data:image/s3,"s3://crabby-images/83f5f/83f5f860d74efb9ec80ff78bbfeb0dac39ac3119" alt=""
IdentityMatrix[n] is its own pseudoinverse:
data:image/s3,"s3://crabby-images/a241c/a241c7728a3de4272d3acf925f9d2b76b12c4466" alt=""
https://wolfram.com/xid/0rs0l2k2a-8vb729
data:image/s3,"s3://crabby-images/28228/28228379f9293c58689837128e90012f3b29d5a0" alt=""
The pseudoinverse of IdentityMatrix[{m,n}] is a transposition:
data:image/s3,"s3://crabby-images/be2fa/be2fac6dae8074ad955b247f553e022d3b0f4ae6" alt=""
https://wolfram.com/xid/0rs0l2k2a-pflv9c
data:image/s3,"s3://crabby-images/3f485/3f48517580af6d212a82d158dcc40ee580a9b8f5" alt=""
data:image/s3,"s3://crabby-images/eab20/eab20f4a9c4ccdad493f2afdb88cbbdcc85c76e2" alt=""
https://wolfram.com/xid/0rs0l2k2a-89ddq0
data:image/s3,"s3://crabby-images/c669c/c669c49d29fd7f68556175fbc8ffe03543bc3e65" alt=""
Compute the pseudoinverse for HilbertMatrix:
data:image/s3,"s3://crabby-images/d5d71/d5d713f485b76bb750a5da69a358f77c2cc10567" alt=""
https://wolfram.com/xid/0rs0l2k2a-q1l839
data:image/s3,"s3://crabby-images/69883/69883f2895a60ffff713fcf4e7e65b21aefd4d4b" alt=""
Options (1)Common values & functionality for each option
Tolerance (1)
data:image/s3,"s3://crabby-images/9f89b/9f89bd3f7648585300525a2258761dafe40e5a50" alt=""
https://wolfram.com/xid/0rs0l2k2a-g33jlv
Some singular values are below the default tolerance for machine precision:
data:image/s3,"s3://crabby-images/722ea/722eacf49cda840f8dc9b6d23b800fd0a6bdfccd" alt=""
https://wolfram.com/xid/0rs0l2k2a-hkuhvt
data:image/s3,"s3://crabby-images/7d501/7d501d89cb5e25ee70f11633e35c442f1ac76ac5" alt=""
Compute the pseudoinverse with the default tolerance:
data:image/s3,"s3://crabby-images/83b5a/83b5a36a928e24b3f7b9e49b00b7cdeac9ef55ca" alt=""
https://wolfram.com/xid/0rs0l2k2a-b0qgc0
It is not a true inverse since some singular values were considered to be effectively zero:
data:image/s3,"s3://crabby-images/b0704/b070461ac0679d1eaee99c9fd5b98d14598f2152" alt=""
https://wolfram.com/xid/0rs0l2k2a-cgimnl
data:image/s3,"s3://crabby-images/d0b9d/d0b9dacdf4bb4aa02baa723ddda36ab9991a0baa" alt=""
Compute the pseudoinverse with no tolerance:
data:image/s3,"s3://crabby-images/eecde/eecde5a24256be8c4ae522bea5f1d25326842f12" alt=""
https://wolfram.com/xid/0rs0l2k2a-h80yg5
Even though no singular values were considered zero, it is worse due to numerical error:
data:image/s3,"s3://crabby-images/b7102/b710295fe1c5217c6b7e16b9c8cd5e7001dd108d" alt=""
https://wolfram.com/xid/0rs0l2k2a-5olrz
data:image/s3,"s3://crabby-images/d95c1/d95c1642c146ae139d70e40597b08b84e1500622" alt=""
Applications (8)Sample problems that can be solved with this function
Equation Solving (4)
Solve the following system of equations using PseudoInverse:
data:image/s3,"s3://crabby-images/a1322/a13225346f22c89620a30d07d971f74af98df179" alt=""
https://wolfram.com/xid/0rs0l2k2a-upikkb
Rewrite the system in matrix form:
data:image/s3,"s3://crabby-images/8f4d7/8f4d7bee8ab480deeedf7bb48e9cb87ce6f02007" alt=""
https://wolfram.com/xid/0rs0l2k2a-zs7ify
data:image/s3,"s3://crabby-images/81403/8140386cf98cf62d9fb174840ad7347e2d35fbbc" alt=""
The general solution is given by for an arbitrary vector
:
data:image/s3,"s3://crabby-images/25418/254186e39b63de7bcf897201ca8e5f347914108d" alt=""
https://wolfram.com/xid/0rs0l2k2a-qytjf
data:image/s3,"s3://crabby-images/da08f/da08f09569cbc4dcecca6098e78d373033bf53d0" alt=""
Since the dropped out, the solution is unique, as can be verified using SolveValues:
data:image/s3,"s3://crabby-images/d4045/d4045bc332832c46c41db3fb5c27ac7f882ff544" alt=""
https://wolfram.com/xid/0rs0l2k2a-tqujfz
data:image/s3,"s3://crabby-images/edd9f/edd9f1d2b728efa3ae3d0285406967e7557e47f2" alt=""
Find all solutions of the following system of equations:
data:image/s3,"s3://crabby-images/3c0a1/3c0a1a8f48e449477d7a68b7d4af806cec2b2f97" alt=""
https://wolfram.com/xid/0rs0l2k2a-1c6b95
data:image/s3,"s3://crabby-images/4c178/4c178b72651f55b65fdb5dd656ef10c4a3444c3a" alt=""
First, write the coefficient matrix , vector variable
and constant vector
:
data:image/s3,"s3://crabby-images/822e2/822e252802c89e9b91ce7e02f1fac5207aec5be2" alt=""
https://wolfram.com/xid/0rs0l2k2a-vokjmu
data:image/s3,"s3://crabby-images/a4118/a41181da18d7aff658c14a3266899620660f40ad" alt=""
https://wolfram.com/xid/0rs0l2k2a-se2owl
data:image/s3,"s3://crabby-images/9a661/9a66114ffd7ad41fe116954336e4ef93bd185845" alt=""
The general solution is given by for an arbitrary vector
:
data:image/s3,"s3://crabby-images/396eb/396ebe9ce5b08d5d1efc4d2c9a8d12732f16aa49" alt=""
https://wolfram.com/xid/0rs0l2k2a-m3h2nw
data:image/s3,"s3://crabby-images/2829a/2829af1554994ea0b825b47f6a60244cd383d3b7" alt=""
data:image/s3,"s3://crabby-images/461b0/461b08f255881645857c578a1944352e4320455a" alt=""
https://wolfram.com/xid/0rs0l2k2a-kyqgwy
data:image/s3,"s3://crabby-images/3b173/3b173a7e0dcd025bcfa7dff93b92deb9e22c791d" alt=""
Although there are three parameters, this solution represents a line:
data:image/s3,"s3://crabby-images/e3e27/e3e276ae317c00e9f7eb7f7808cb2902d3c8f87b" alt=""
https://wolfram.com/xid/0rs0l2k2a-1yawfd
data:image/s3,"s3://crabby-images/12ddc/12ddcf6616829e37640f92f155df3b41c93d64af" alt=""
This is because the null space of is one-dimensional:
data:image/s3,"s3://crabby-images/6b76e/6b76e8f91c4f60ff87ce8a72f7d4c66aca15eec7" alt=""
https://wolfram.com/xid/0rs0l2k2a-ihejh6
data:image/s3,"s3://crabby-images/0d341/0d341c89644937dfb87a1b9549154f5fde363394" alt=""
Hence it is possible to reparameterize to eliminate two of the parameters:
data:image/s3,"s3://crabby-images/e09f5/e09f56772dfe28774588ba645559ef95744d0cf2" alt=""
https://wolfram.com/xid/0rs0l2k2a-dj3tes
data:image/s3,"s3://crabby-images/d2e6e/d2e6e6e4df415bb7ac4fe93176066dbd1de26090" alt=""
This parameterization gives the answer in the same form as SolveValues:
data:image/s3,"s3://crabby-images/be35b/be35bfb808a30cef5da8bd6f85147f022fd2a0d7" alt=""
https://wolfram.com/xid/0rs0l2k2a-14h576
data:image/s3,"s3://crabby-images/a18dc/a18dcf1f17819479836de9ba2542bd837a5957c4" alt=""
data:image/s3,"s3://crabby-images/1b0da/1b0da7b064e70a6b7898974e97bcbffadb7e3587" alt=""
Find the minimum Frobenius-norm solution to , with
and
as follows:
data:image/s3,"s3://crabby-images/5becb/5becbc9ae057a32c6f8893a62c4032165aeb9eb5" alt=""
https://wolfram.com/xid/0rs0l2k2a-ziuqcu
The minimum norm solution is :
data:image/s3,"s3://crabby-images/d0b24/d0b24c37b0f69d92354fe3543361b1a0e86e79f9" alt=""
https://wolfram.com/xid/0rs0l2k2a-nmbplo
data:image/s3,"s3://crabby-images/95202/952021ccdce55117d0eb2d55e9d73661eafeb1f2" alt=""
Compute the Frobenius norm of :
data:image/s3,"s3://crabby-images/4b090/4b0900f6ced2daed353a2daa8e043a61ceb66646" alt=""
https://wolfram.com/xid/0rs0l2k2a-hoiqzn
data:image/s3,"s3://crabby-images/a8074/a80742bf003607fc5b78399460ba8e7a9b2450b7" alt=""
As in the vector case, the general solution is given by , with
now an arbitrary matrix:
data:image/s3,"s3://crabby-images/d81d6/d81d69bd47b947cc991a7077d32456ef217c70bb" alt=""
https://wolfram.com/xid/0rs0l2k2a-q66wu2
data:image/s3,"s3://crabby-images/32da2/32da2d833f3f26146631606303ce039f7376bf49" alt=""
data:image/s3,"s3://crabby-images/11e74/11e74836c81c1a93aa666aaf115edab40245e97a" alt=""
https://wolfram.com/xid/0rs0l2k2a-vk1bir
data:image/s3,"s3://crabby-images/3710e/3710e34f38a2f9ae21a9b0c4746ca8203f01891f" alt=""
The minimum occurs when all the are zero, confirming that
is the minimum-norm solution:
data:image/s3,"s3://crabby-images/1d3b2/1d3b2c9ccaa4ac91c5c79bcd2ea4bb7540ccd9d2" alt=""
https://wolfram.com/xid/0rs0l2k2a-eb2arl
data:image/s3,"s3://crabby-images/4f740/4f740adc7fd3db6fc70bf07aaf92234512878003" alt=""
In this case there is no solution to :
data:image/s3,"s3://crabby-images/c7457/c74571aa05b38d4e3a4a565fec65c07a1a242573" alt=""
https://wolfram.com/xid/0rs0l2k2a-cmu0c9
data:image/s3,"s3://crabby-images/903f0/903f01557492473a4d79931fc392ec582c60c7ac" alt=""
https://wolfram.com/xid/0rs0l2k2a-g81vfi
data:image/s3,"s3://crabby-images/05234/05234dc9ffa926698c784c5d4ea4d6c5dd38baa8" alt=""
data:image/s3,"s3://crabby-images/78b88/78b885564d9a370182a6c0c805d75720b623c04c" alt=""
An approximate solution that minimizes the norm of is given by
:
data:image/s3,"s3://crabby-images/9c9d2/9c9d2e6c3bb261276489fcfec65abf1a7d22e1f7" alt=""
https://wolfram.com/xid/0rs0l2k2a-o6nyhb
data:image/s3,"s3://crabby-images/9e41a/9e41a59ea0262aa4ea28f76beda3f50e956e0969" alt=""
data:image/s3,"s3://crabby-images/f12df/f12dff61d44ed9d8a0d7d6d5d02038a8fce555d9" alt=""
https://wolfram.com/xid/0rs0l2k2a-g2o5mo
data:image/s3,"s3://crabby-images/8e90a/8e90ab3a412f132c9216a9d8d03809b062bdfdc1" alt=""
Compare to general minimization:
data:image/s3,"s3://crabby-images/4693b/4693b911c3d7f9f5b8bf65c7714e54e7d72b4685" alt=""
https://wolfram.com/xid/0rs0l2k2a-g5rxbt
data:image/s3,"s3://crabby-images/90a91/90a91b7cf439cef0529ac9570cea7d4d2a01a9ec" alt=""
A more general solution is given by :
data:image/s3,"s3://crabby-images/94104/94104609ad6f7a5ac7f8269b0d41ad641fbefe49" alt=""
https://wolfram.com/xid/0rs0l2k2a-5uz3ix
data:image/s3,"s3://crabby-images/621fa/621fa362ab3b26cc20f4e7fc560fb7e1586d84ea" alt=""
data:image/s3,"s3://crabby-images/a43c7/a43c7cd52370fc07ea145464fbc4d34a2f4f6612" alt=""
https://wolfram.com/xid/0rs0l2k2a-qusxb6
data:image/s3,"s3://crabby-images/aedf6/aedf6acf56b4d605d119e25da386d22e0b8dd58c" alt=""
Although there are three parameters in , it represents a line:
data:image/s3,"s3://crabby-images/645e1/645e16dcd4461dc0116e5e5b94cc0fd7ad1d76c2" alt=""
https://wolfram.com/xid/0rs0l2k2a-107pgz
data:image/s3,"s3://crabby-images/3c592/3c592f79428984a34d24668dd5b80d056ff1be0c" alt=""
This is because the null space of is one-dimensional:
data:image/s3,"s3://crabby-images/bd756/bd756c2d301ece780ff2633dfe57ae0f94637256" alt=""
https://wolfram.com/xid/0rs0l2k2a-p5kqmy
data:image/s3,"s3://crabby-images/4ce35/4ce35cc393387b08810e8924ef1de872a452f584" alt=""
Least Squares and Curve Fitting (4)
For the matrix and vector
that follow, find a vector
that minimizes
:
data:image/s3,"s3://crabby-images/9dc85/9dc85f37cebc447b21dd9869a3fa9ccede8ec6ad" alt=""
https://wolfram.com/xid/0rs0l2k2a-e4enjw
One solution, in this case unique, is given by :
data:image/s3,"s3://crabby-images/4dac1/4dac1cec6f259aa7b3a9963f9021879dc44890c1" alt=""
https://wolfram.com/xid/0rs0l2k2a-s7lr4r
data:image/s3,"s3://crabby-images/12f7c/12f7c0f4f590f936006587b42d353f53711275b6" alt=""
This result could also have been obtained using LeastSquares[m,b]:
data:image/s3,"s3://crabby-images/2913f/2913fe1c1c1ff72245b4004495e8980d0c0ccbac" alt=""
https://wolfram.com/xid/0rs0l2k2a-2cpasl
data:image/s3,"s3://crabby-images/1604a/1604a057138efe09fd5cbd12bf8a37337695bdb6" alt=""
Confirm the answer using Minimize:
data:image/s3,"s3://crabby-images/f7902/f7902677ab24f10f896a101cdfc36dbd895a216d" alt=""
https://wolfram.com/xid/0rs0l2k2a-w70jbo
data:image/s3,"s3://crabby-images/0007a/0007aac303b0072c8a3ebc63dd28c2cd607e4fa4" alt=""
For the matrices and
that follow, find a matrix
that minimizes
:
data:image/s3,"s3://crabby-images/d5097/d5097d15ec179b41624bc373df9540bfb336b4ff" alt=""
https://wolfram.com/xid/0rs0l2k2a-pqffuw
One solution, in this case unique, is given by :
data:image/s3,"s3://crabby-images/53ec7/53ec7be0440df9415a3bf6e30024eb55d7eb0344" alt=""
https://wolfram.com/xid/0rs0l2k2a-ivgyxa
data:image/s3,"s3://crabby-images/49b81/49b81880b3f7fcfb855f65e0adac1d1a4ce56098" alt=""
This result could also have been obtained using LeastSquares[m,b]:
data:image/s3,"s3://crabby-images/2395d/2395d76b4ba3276a9efcfdda6bf420336a867a6d" alt=""
https://wolfram.com/xid/0rs0l2k2a-zp70nm
data:image/s3,"s3://crabby-images/0d7fa/0d7fa7ccc0366aa74b064eed3753a06f5817c278" alt=""
Confirm the answer using Minimize:
data:image/s3,"s3://crabby-images/1bd7a/1bd7abc8aca3e8d01927992c42bad7a46d8a208c" alt=""
https://wolfram.com/xid/0rs0l2k2a-4kcdw8
data:image/s3,"s3://crabby-images/ba19e/ba19eda557b72ee09a2616c47f3c281393c2b648" alt=""
PseudoInverse can be used to find a best-fit curve to data. Consider the following data:
data:image/s3,"s3://crabby-images/2e5ad/2e5ad879803c3f6d54f5341dd2b331dd3778daf1" alt=""
https://wolfram.com/xid/0rs0l2k2a-v42zji
data:image/s3,"s3://crabby-images/ea93f/ea93fc621f201dda3394d62f48fc74fd3ce2898d" alt=""
Extract the and
coordinates from the data:
data:image/s3,"s3://crabby-images/cbe59/cbe59232505ca79ffff5d20bb0599712389e414b" alt=""
https://wolfram.com/xid/0rs0l2k2a-i4v6jo
Construct a design matrix, whose columns are and
, for fitting to a line
:
data:image/s3,"s3://crabby-images/1d516/1d51603a533e7b650963456727a23cdcf39e3c99" alt=""
https://wolfram.com/xid/0rs0l2k2a-pkve26
Get the coefficients and
for a linear least‐squares fit:
data:image/s3,"s3://crabby-images/06d8a/06d8a88990538ff7d9b697dc3d1274cb08eaa1e5" alt=""
https://wolfram.com/xid/0rs0l2k2a-7p26fs
data:image/s3,"s3://crabby-images/45fda/45fda23fbd434554564b658f96d2c1ba6fa9241f" alt=""
Verify the coefficients using Fit:
data:image/s3,"s3://crabby-images/e6b56/e6b566ac75dca69803a9e05e76785614a848e338" alt=""
https://wolfram.com/xid/0rs0l2k2a-480xbe
data:image/s3,"s3://crabby-images/194df/194df555426b3b881bddc4dd1c3ddc84f29626c3" alt=""
Plot the best-fit curve along with the data:
data:image/s3,"s3://crabby-images/c5dd9/c5dd99f4e84430b17393226148ab200c224e7a85" alt=""
https://wolfram.com/xid/0rs0l2k2a-wzqna8
data:image/s3,"s3://crabby-images/953b8/953b8c9384c03a00f8a715ad17872e6b455555c5" alt=""
Find the best-fit parabola to the following data:
data:image/s3,"s3://crabby-images/789a7/789a7993f614223f0c3b963c2cbba40ffb5d01c8" alt=""
https://wolfram.com/xid/0rs0l2k2a-x7pawr
data:image/s3,"s3://crabby-images/689e4/689e418419626051f0c93bfce90ff5e23dfb328d" alt=""
Extract the and
coordinates from the data:
data:image/s3,"s3://crabby-images/726b4/726b468b573c36ef191f26380b2534077dbecba0" alt=""
https://wolfram.com/xid/0rs0l2k2a-w5dwto
Construct a design matrix, whose columns are ,
and
, for fitting to a line
:
data:image/s3,"s3://crabby-images/fe7e6/fe7e63e6b4bd368512cc848bb1ab28ac84003e54" alt=""
https://wolfram.com/xid/0rs0l2k2a-bmqc8e
Get the coefficients ,
and
for a least‐squares fit:
data:image/s3,"s3://crabby-images/5f719/5f7198dce02871397a27337055c3374391dc25a8" alt=""
https://wolfram.com/xid/0rs0l2k2a-z5bw8q
data:image/s3,"s3://crabby-images/03bfe/03bfe4f1305b154527b38f6989a5b04acfabc36d" alt=""
Verify the coefficients using Fit:
data:image/s3,"s3://crabby-images/33ef0/33ef0f86e4ddedec9adeae6e60282fea4421a55e" alt=""
https://wolfram.com/xid/0rs0l2k2a-pp5xfy
data:image/s3,"s3://crabby-images/7b1c4/7b1c44d506ca37dd02f622c8a825de2b4d4a8334" alt=""
Plot the best-fit curve along with the data:
data:image/s3,"s3://crabby-images/9a64c/9a64ce95a4041184df79880b60c3c8b0af8ea500" alt=""
https://wolfram.com/xid/0rs0l2k2a-04d0qo
data:image/s3,"s3://crabby-images/776f2/776f21365771bfb80920f47c4c09924621db9295" alt=""
Properties & Relations (14)Properties of the function, and connections to other functions
For a nonsingular matrix, the pseudoinverse is the same as the inverse:
data:image/s3,"s3://crabby-images/f1123/f11230e9e9dd62d886cdf6ebde3ac83a59dc5463" alt=""
https://wolfram.com/xid/0rs0l2k2a-g2efuw
data:image/s3,"s3://crabby-images/49a0d/49a0d34264a1e6c857541fd2011c0f9c9a5381d2" alt=""
data:image/s3,"s3://crabby-images/fde8d/fde8d4e1610137186bfec53bbf4b1293392d661b" alt=""
https://wolfram.com/xid/0rs0l2k2a-hq2ojv
data:image/s3,"s3://crabby-images/d5dd6/d5dd6e9d2b6b5c0d4e257cc6df121061f6df5834" alt=""
PseudoInverse is involutive, :
data:image/s3,"s3://crabby-images/3fbe3/3fbe339f23b2f59ff91dbd56d7154842a91c87ee" alt=""
https://wolfram.com/xid/0rs0l2k2a-ci246w
data:image/s3,"s3://crabby-images/a3434/a34343cb5c38197891b29494bf3c3533b102d52b" alt=""
https://wolfram.com/xid/0rs0l2k2a-zwdjpl
data:image/s3,"s3://crabby-images/fac04/fac044b9acfdb51a97a5ea7220ffd52355291a45" alt=""
PseudoInverse commutes with Transpose, i.e :
data:image/s3,"s3://crabby-images/e4681/e4681807b0a9257307110e73c6b3a1794b6ef8da" alt=""
https://wolfram.com/xid/0rs0l2k2a-r5artr
data:image/s3,"s3://crabby-images/1a26b/1a26b52dcde34e0a11ff57bd167f00759d4df54a" alt=""
It also commutes with Conjugate, :
data:image/s3,"s3://crabby-images/c37c3/c37c3278874f76a8d4e2fd5db3ff8ace45036877" alt=""
https://wolfram.com/xid/0rs0l2k2a-s204v
data:image/s3,"s3://crabby-images/7bee6/7bee65d2828de172d0f4380468fdfa7d3050949a" alt=""
Hence it commutes with ConjugateTranspose, :
data:image/s3,"s3://crabby-images/24ea7/24ea79d63c8116017bbddc76c3cf8e552b8f3448" alt=""
https://wolfram.com/xid/0rs0l2k2a-ee2zf9
data:image/s3,"s3://crabby-images/da9a5/da9a55c28bae42d0aefa3c510d90a82676a427fc" alt=""
PseudoInverse satisfies the Moore–Penrose equations [more info]:
data:image/s3,"s3://crabby-images/df90d/df90da3af0b84e1bee8836214a426fc34f5f8bfd" alt=""
https://wolfram.com/xid/0rs0l2k2a-p2fhsi
data:image/s3,"s3://crabby-images/7d6ca/7d6cae9fdea2c89cf0c310959600c5ac867bcdb3" alt=""
https://wolfram.com/xid/0rs0l2k2a-bs1pa5
data:image/s3,"s3://crabby-images/0364e/0364eae3061135e75bccf33479349934d05c72ab" alt=""
https://wolfram.com/xid/0rs0l2k2a-bsvl0m
data:image/s3,"s3://crabby-images/b0ca2/b0ca29fdd195fdd5b441b780f72c132507f390b5" alt=""
If MatrixRank[m] equals the number of columns of , then
:
data:image/s3,"s3://crabby-images/e6bbe/e6bbe3bcb762cff12eeba83070cda3ee0e1bb9cd" alt=""
https://wolfram.com/xid/0rs0l2k2a-0x2fwg
data:image/s3,"s3://crabby-images/499df/499df0715810d863d4735129d8ebaade70c2cca7" alt=""
data:image/s3,"s3://crabby-images/6d5d4/6d5d43a2c8283de949032fe12eeaaa168d24af8b" alt=""
https://wolfram.com/xid/0rs0l2k2a-sgmkky
data:image/s3,"s3://crabby-images/e179b/e179b9b1cad24ba7ccda072f50120117f9dd8489" alt=""
In particular, PseudoInverse[m] is a left-inverse of m:
data:image/s3,"s3://crabby-images/eff2e/eff2e500a6c3261fcc4876925ca47a4b3767959d" alt=""
https://wolfram.com/xid/0rs0l2k2a-n8bjnc
data:image/s3,"s3://crabby-images/cc07f/cc07faf5492b860040f131eb96ef9a575a0b0099" alt=""
If MatrixRank[m] equals the number of rows of , then
:
data:image/s3,"s3://crabby-images/7882e/7882e9e5a81c63dd6334588889b6b5d0adb32974" alt=""
https://wolfram.com/xid/0rs0l2k2a-s17ijx
data:image/s3,"s3://crabby-images/93f5b/93f5b688736f67035f6a84e1e1065dd9b8b44e1b" alt=""
data:image/s3,"s3://crabby-images/cf652/cf652db07fc94dab936d6eb0e8c602c6d702625b" alt=""
https://wolfram.com/xid/0rs0l2k2a-c2g8j6
data:image/s3,"s3://crabby-images/8300b/8300b4426ada4cb86671e9570fd5a4a9d9097c93" alt=""
In particular, PseudoInverse[m] is a right-inverse of m:
data:image/s3,"s3://crabby-images/c90af/c90afbbc2f04e69ae8a380baff2cebb8e9652b74" alt=""
https://wolfram.com/xid/0rs0l2k2a-t4cimv
data:image/s3,"s3://crabby-images/02cf3/02cf37f2ae951dd7bbbc60abd0253620fbb98a76" alt=""
For a diagonal matrix d, PseudoInverse[d] is the transpose with nonzero elements inverted:
data:image/s3,"s3://crabby-images/448bb/448bb2c0cddefa394564fcd55a2227eb468be92c" alt=""
https://wolfram.com/xid/0rs0l2k2a-d17ssz
data:image/s3,"s3://crabby-images/50108/501087970bbd009d7e82088e016bbfe37c7c05a9" alt=""
If has the singular value decomposition
, then
:
data:image/s3,"s3://crabby-images/9107f/9107fbb52b696809293b627fa3a4da1812ae37cf" alt=""
https://wolfram.com/xid/0rs0l2k2a-v34myz
data:image/s3,"s3://crabby-images/ad7fc/ad7fc62d01610a70a5649851a2e2baec1c125434" alt=""
https://wolfram.com/xid/0rs0l2k2a-s69vp9
data:image/s3,"s3://crabby-images/9ad78/9ad783672ab40a7c6421befe75074297f1d74fa1" alt=""
data:image/s3,"s3://crabby-images/03ede/03edee470e9065547b9c96233cd1b2a022509fdb" alt=""
https://wolfram.com/xid/0rs0l2k2a-mdilnn
data:image/s3,"s3://crabby-images/98071/980717d8cc240f94b8bc24be3ebeddf380e813d7" alt=""
If a is an matrix and MatrixRank[a]==m, QRDecomposition will give the pseudoinverse:
data:image/s3,"s3://crabby-images/14a14/14a14a5ba5154ea759d955719ec9957f7f0730c7" alt=""
https://wolfram.com/xid/0rs0l2k2a-zpyy8q
data:image/s3,"s3://crabby-images/0a1a9/0a1a9c96919d3b412190565c174332b93cd66753" alt=""
data:image/s3,"s3://crabby-images/c7505/c75055967bb0471707c41e5ab508d10a53430cc9" alt=""
https://wolfram.com/xid/0rs0l2k2a-x6p50r
data:image/s3,"s3://crabby-images/c537b/c537b036e47bfff60a19da54bc3f7cba00528e7d" alt=""
A normal matrix commutes with its pseudoinverse:
data:image/s3,"s3://crabby-images/2aca3/2aca3bba451889a38e9da1e7c3481ac852c80a8c" alt=""
https://wolfram.com/xid/0rs0l2k2a-n714iw
data:image/s3,"s3://crabby-images/96640/96640168da48b6eee81c6cfbc5f77e6b20abdc96" alt=""
https://wolfram.com/xid/0rs0l2k2a-nzl1fk
data:image/s3,"s3://crabby-images/b2d39/b2d395e68fbdaa84b63b165fa422aaf5347a8d4c" alt=""
data:image/s3,"s3://crabby-images/5999f/5999fa42977e25dfa60f22dd415a5fb5e139376c" alt=""
https://wolfram.com/xid/0rs0l2k2a-cvfe76
data:image/s3,"s3://crabby-images/162ad/162add39da83186923ffb5e214283cbfbbbfa462" alt=""
PseudoInverse[m] can be computed as , where
denotes DrazinInverse:
data:image/s3,"s3://crabby-images/a2288/a2288b84c007e5d54a19c060c310d7c7894f58a8" alt=""
https://wolfram.com/xid/0rs0l2k2a-cceowv
data:image/s3,"s3://crabby-images/a6c46/a6c4636b3e1c3a656bec8f78ce1bc10f8e4b3799" alt=""
https://wolfram.com/xid/0rs0l2k2a-ei7hch
data:image/s3,"s3://crabby-images/378be/378beb83219d1657ad39545344b8f0518b8915a7" alt=""
LeastSquares and PseudoInverse can both be used to solve the least-squares problem:
data:image/s3,"s3://crabby-images/5c5f3/5c5f3ba6b1b81337766fa03284f34826825cfa29" alt=""
https://wolfram.com/xid/0rs0l2k2a-h3z3e9
data:image/s3,"s3://crabby-images/02b88/02b889849d9f2bffc06dc90625dd5fac05c03a0d" alt=""
https://wolfram.com/xid/0rs0l2k2a-e5dgz8
data:image/s3,"s3://crabby-images/7b93d/7b93de8a7c020aa564396aa0ba8845d6487ab46d" alt=""
gives the minimum norm
that minimizes the residual
:
data:image/s3,"s3://crabby-images/7ddc3/7ddc367584a08f13b98966b012a6ebf3b2d024ee" alt=""
https://wolfram.com/xid/0rs0l2k2a-lbfrc5
data:image/s3,"s3://crabby-images/4ca2a/4ca2affeae45e002b616f000d9180851035880c8" alt=""
https://wolfram.com/xid/0rs0l2k2a-884c7
data:image/s3,"s3://crabby-images/635fa/635fa4a94b1b9d600a84c65352d4fa7a5fb185c7" alt=""
Verify that minimizes the residual:
data:image/s3,"s3://crabby-images/4c301/4c3012ac0604f2285f910f53bb647bdf0bb24c83" alt=""
https://wolfram.com/xid/0rs0l2k2a-9nhura
data:image/s3,"s3://crabby-images/89441/894416e2bbcd0156ea7c5c1dcea4a98cf9560474" alt=""
Adding any vector in the NullSpace of to
will leave the residual unchanged:
data:image/s3,"s3://crabby-images/8e009/8e0095639ce3dffc5e1c086668e8dcb6d1ed0cda" alt=""
https://wolfram.com/xid/0rs0l2k2a-7iufp
data:image/s3,"s3://crabby-images/aa262/aa2625cc2469e78ab25c2a389f56f3864e76d4ee" alt=""
data:image/s3,"s3://crabby-images/8ddf6/8ddf6e3731315eb4bdd92c7f26956d461a808aa0" alt=""
https://wolfram.com/xid/0rs0l2k2a-c5eqo0
data:image/s3,"s3://crabby-images/397a0/397a0c41140380081a11065365a1d21045e3d5e2" alt=""
The minimum norm occurs at
, i.e when
:
data:image/s3,"s3://crabby-images/43ba5/43ba5b8466914f48fa37ede2b35159b33869b06a" alt=""
https://wolfram.com/xid/0rs0l2k2a-b2f6yi
data:image/s3,"s3://crabby-images/f63cb/f63cbe764cde0e642a5327664267ae5c414fde0b" alt=""
For a vector and a matrix
with empty nullspace,
equals ArgMin[Norm[m.x-b],x]:
data:image/s3,"s3://crabby-images/ede66/ede66d5b2be70199794780b39516fa126318cd08" alt=""
https://wolfram.com/xid/0rs0l2k2a-c6zrbw
data:image/s3,"s3://crabby-images/58e93/58e93fa7b76e8e687a3541a7eaf382f2de6cd43f" alt=""
https://wolfram.com/xid/0rs0l2k2a-9lyuvk
data:image/s3,"s3://crabby-images/d81ad/d81ad6a84cb454e7e1ba45816a564984717f089d" alt=""
data:image/s3,"s3://crabby-images/26370/26370c550b7237067b388923508aa30ec8d61ab7" alt=""
https://wolfram.com/xid/0rs0l2k2a-fvs5bz
data:image/s3,"s3://crabby-images/dcfec/dcfec4e89ba0497ed8e38328af1e3f8befbe6b6e" alt=""
Wolfram Research (1988), PseudoInverse, Wolfram Language function, https://reference.wolfram.com/language/ref/PseudoInverse.html (updated 2003).
Text
Wolfram Research (1988), PseudoInverse, Wolfram Language function, https://reference.wolfram.com/language/ref/PseudoInverse.html (updated 2003).
Wolfram Research (1988), PseudoInverse, Wolfram Language function, https://reference.wolfram.com/language/ref/PseudoInverse.html (updated 2003).
CMS
Wolfram Language. 1988. "PseudoInverse." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 2003. https://reference.wolfram.com/language/ref/PseudoInverse.html.
Wolfram Language. 1988. "PseudoInverse." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 2003. https://reference.wolfram.com/language/ref/PseudoInverse.html.
APA
Wolfram Language. (1988). PseudoInverse. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/PseudoInverse.html
Wolfram Language. (1988). PseudoInverse. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/PseudoInverse.html
BibTeX
@misc{reference.wolfram_2025_pseudoinverse, author="Wolfram Research", title="{PseudoInverse}", year="2003", howpublished="\url{https://reference.wolfram.com/language/ref/PseudoInverse.html}", note=[Accessed: 24-February-2025
]}
BibLaTeX
@online{reference.wolfram_2025_pseudoinverse, organization={Wolfram Research}, title={PseudoInverse}, year={2003}, url={https://reference.wolfram.com/language/ref/PseudoInverse.html}, note=[Accessed: 24-February-2025
]}