обратный слэш (\)
(\) левое матричное деление: точное решение или решение по методу наименьших квадратов
Синтаксис
X = A \ B
Описание
Обратный слэш означает левое матричное деление.
X=A\B является решением для A*X=B.
Если A - квадратная и невырожденная, то X=A\B
(уникально определённая) эквивалентно X=inv(A)*B в точном арифметическом смысле,
однако вычисления гораздо точнее и дешевле в арифметике с плавающей запятой.
Следовательно, чтобы вычислить решение линейной системы уравнений A*X=B,
следует использовать оператор "обратный слэш", а функцию inv не следует использовать.
В случае, когда A - квадратная матрица,
решение X может быть вычислено
либо через LU-разложение, либо через программу линейного
решения по методу наименьших квадратов.
Если число обусловленности матрицы A
меньше, чем 1/(10*%eps) (то есть, если
A хорошо обусловлена),
то используется LU-разложение с перестановками строк матрицы.
Если нет (то есть, если A плохо
обусловлена), то X является решением с
минимальной нормой, которое минимизирует
||A*X-B|| используя полное ортогональное
разложение A (то есть
X - это решение линейной задачи по методу
наименьших квадратов).
Если A не квадратная, то X является решением наименьших квадратов,
т.е. norm(A*X-B) является минимальной (эвклидова норма). Если ранг матрицы A
полный, то решение наименьших квадратов, X=A\B, является уникально
определённым (есть уникальное X, которое минимизирует norm(A*X-B)).
Если ранг матрицы A неполный, то решение наименьших квадратов не является уникальным,
и X=A\B, в общем, не является решением с минимальной нормой (решение минимальной
нормы равно X=pinv(A)*B).
A.\B является матрицей с (i,j)-тым элементом, равным A(i,j)\B(i,j).
Если A (или B) является скаляром, то A.\B эквивалентно
A*ones(B).\B (или A.\(B*ones(A)).
A\.B является оператором без предопределённого значения. Он может использоваться
для определения нового оператора (см. перегрузку) с тем же самым приоритетом
что и * или /.
Примеры
A=[ 9. -36. 30. -36. 192. -180. 30. -180. 180. ]; b=[ 3. -24. 30. ]; x=A\b A*x-b // близко к нулю A=rand(3,2); b=[1;1;1]; x=A\b; y=pinv(A)*b; x-y A=rand(2,3);b=[1;1]; x=A\b; y=pinv(A)*b; x-y, A*x-b, A*y-b // если ранг неполный A=rand(3,1)*rand(1,2); b=[1;1;1]; x=A\b; y=pinv(A)*b; A*x-b, A*y-b A=rand(2,1)*rand(1,3); b=[1;1]; x=A\b; y=pinv(A)*b; A*x-b, A*y-b // Проверка эффективности нескольких программ решения систем линейных уравнений [A,descr,ref,mtype] = ReadHBSparse(SCI+"/modules/umfpack/demos/bcsstk24.rsa"); b = zeros(size(A,1),1); tic(); res = umfpack(A,'\',b); mprintf('\nвремя, необходимое для решения системы с помощью umfpack: %.3f\n',toc()); tic(); res = linsolve(A,b); mprintf('\nвремя, необходимое для решения системы с помощью linsolve: %.3f\n',toc()); tic(); res = A\b; mprintf('\nвремя, необходимое для решения системы с помощью оператора ""обратный слэш"": %.3f\n',toc());
Смотрите также
- slash — (/) правое деление и обратная связь
- lsq — линейное решение наименьших квадратов A*X=B с минимальной norm(X)
- inv — matrix inverse
- pinv — pseudoinverse
- linsolve — linear equation solver
- umfpack — solve sparse linear system
- datafit — Non linear (constrained) parametric fit of measured (weighted) data
- kron .\. — Kronecker left and right divisions
- перегрузка — возможности перегрузки отображения, функций и операторов
История
| Версия | Описание |
| 5.5.0 | Пороговый уровень, который переключает при вычислении A\B между исключением по методу Гаусса и перестановкой строк матрицы, уменьшен от sqrt(eps) до eps. |
| Report an issue | ||
| << процент | Ключевые слова Scilab | brackets [,;] >> |