2014 dxdy logo

Научный форум dxdy

Математика, Физика, Computer Science, Machine Learning, LaTeX, Механика и Техника, Химия,
Биология и Медицина, Экономика и Финансовая Математика, Гуманитарные науки


Правила форума


Посмотреть правила форума



Начать новую тему Ответить на тему
 
 Подскажите как лучше сделать в матричных вычислениях
Сообщение20.03.2018, 18:50 


07/01/16
4
Здравствуйте форумчане!
Прошу вашей подсказки в следующих матричных вычислениях, как лучше сделать и посчитать…
Имеем следующее:
$\[\left[ {\begin{array}{*{20}{c}}
  {{x_3}} \\ 
  {{x_4}} 
\end{array}} \right] = \left[ {\begin{array}{*{20}{c}}
  {{x_1}}&{ - x_2^*} \\ 
  {{x_2}}&{x_1^*} 
\end{array}} \right] \cdot \left[ {\begin{array}{*{20}{c}}
  {{K_1}} \\ 
  {{K_2}} 
\end{array}} \right]\]$ (обозначение * означает комплексное сопряжение), обозначим $\[{X_1} = \left[ {\begin{array}{*{20}{c}}
  {{x_1}}&{ - x_2^*} \\ 
  {{x_2}}&{x_1^*} 
\end{array}} \right]\]$, получим $\[\left[ {\begin{array}{*{20}{c}}
  {{x_3}} \\ 
  {{x_4}} 
\end{array}} \right] = {X_1} \cdot \left[ {\begin{array}{*{20}{c}}
  {{K_1}} \\ 
  {{K_2}} 
\end{array}} \right]\]$.
Далее, $\[\left[ {\begin{array}{*{20}{c}}
  {{r_1}} \\ 
  {{r_2}} 
\end{array}} \right] = X_1^T \cdot \left[ {\begin{array}{*{20}{c}}
  {{h_1}} \\ 
  {{h_2}} 
\end{array}} \right] + \left[ {\begin{array}{*{20}{c}}
  {{n_1}} \\ 
  {{n_2}} 
\end{array}} \right]\]$, обозначим $\[{R_1} = \left[ {\begin{array}{*{20}{c}}
  {{r_1}} \\ 
  {{r_2}} 
\end{array}} \right]\]$, $\[H = \left[ {\begin{array}{*{20}{c}}
  {{h_1}} \\ 
  {{h_2}} 
\end{array}} \right]\]$, $\[N = \left[ {\begin{array}{*{20}{c}}
  {{n_1}} \\ 
  {{n_2}} 
\end{array}} \right]\]$, получим $\[{R_1} = X_1^T \cdot H + N\]$.
Аналогично, $\[\left[ {\begin{array}{*{20}{c}}
  {{r_3}} \\ 
  {{r_4}} 
\end{array}} \right] = \left[ {\begin{array}{*{20}{c}}
  {{x_3}}&{{x_4}} \\ 
  { - x_4^*}&{x_3^*} 
\end{array}} \right] \cdot H + N\]$, обозначим $\[{R_2} = \left[ {\begin{array}{*{20}{c}}
  {{r_3}} \\ 
  {{r_4}} 
\end{array}} \right]\]$, $\[X_2^T = \left[ {\begin{array}{*{20}{c}}
  {{x_3}}&{{x_4}} \\ 
  { - x_4^*}&{x_3^*} 
\end{array}} \right]\]$, получим $\[{R_2} = X_2^T \cdot H + N\]$.
Сведем, $\[\left\{ {\begin{array}{*{20}{c}}
  {{R_1} = X_1^T \cdot H + N} \\ 
  {{R_2} = X_2^T \cdot H + N} 
\end{array}} \right.\, \Rightarrow \left[ {\begin{array}{*{20}{c}}
  {{R_1}} \\ 
  {{R_2}} 
\end{array}} \right] = \left[ {\begin{array}{*{20}{c}}
  {X_1^T}&1 \\ 
  {X_2^T}&1 
\end{array}} \right] \cdot \left[ {\begin{array}{*{20}{c}}
  H \\ 
  N 
\end{array}} \right]\]$.
Значения $\[{R_1}\]$, $\[{R_2}\]$, $\[X_1^T\]$, $\[X_2^T\]$ - нам известны.
Методом Крамера попытаемся найти H и N.
$\[H = \dfrac{{\left[ {\begin{array}{*{20}{c}}
  {{R_1}}&1 \\ 
  {{R_2}}&1 
\end{array}} \right]}}{{\left[ {\begin{array}{*{20}{c}}
  {X_1^T}&1 \\ 
  {X_2^T}&1 
\end{array}} \right]}} = \dfrac{{{R_1} - {R_2}}}{{X_1^T - X_2^T}} \Rightarrow {\left( {X_1^T - X_2^T} \right)^{ - 1}} \cdot \left( {{R_1} - {R_2}} \right)\]$, и тут все получается. При подстановке комплексных чисел посчитанное значение H по данной формуле совпадает с значением H, заданным изначально. Что мне и нужно.
$\[N = \dfrac{{\left[ {\begin{array}{*{20}{c}}
  {X_1^T}&{{R_1}} \\ 
  {X_2^T}&{{R_2}} 
\end{array}} \right]}}{{\left[ {\begin{array}{*{20}{c}}
  {X_1^T}&1 \\ 
  {X_2^T}&1 
\end{array}} \right]}} = \dfrac{{{R_2} \cdot X_1^T - {R_1} \cdot X_2^T}}{{X_1^T - X_2^T}}\]$, а вот тут ничего не получается, как бы я не крутил… Вот тут мне и нужна Ваша помощь, как посчитать значение N.
Да, значение N можно конечно найти иначе. Зная посчитанное значение H, $\[N = {R_1} - X_1^T \cdot H\]$. Получается только так…

 Профиль  
                  
 
 Re: Подскажите как лучше сделать в матричных вычислениях
Сообщение20.03.2018, 21:14 


07/01/16
4
Формулу $\[N = \dfrac{{\left[ {\begin{array}{*{20}{c}}
  {X_1^T}&{{R_1}} \\ 
  {X_2^T}&{{R_2}} 
\end{array}} \right]}}{{\left[ {\begin{array}{*{20}{c}}
  {X_1^T}&1 \\ 
  {X_2^T}&1 
\end{array}} \right]}} = \dfrac{{{R_2} \cdot X_1^T - {R_1} \cdot X_2^T}}{{X_1^T - X_2^T}}\]$ читать формулой $\[N = \dfrac{{\left[ {\begin{array}{*{20}{c}}
  {X_1^T}&{{R_1}} \\ 
  {X_2^T}&{{R_2}} 
\end{array}} \right]}}{{\left[ {\begin{array}{*{20}{c}}
  {X_1^T}&1 \\ 
  {X_2^T}&1 
\end{array}} \right]}} = \dfrac{{X_1^T \cdot {R_2} - X_2^T \cdot {R_1}}}{{X_1^T - X_2^T}}\]$.

 Профиль  
                  
 
 Re: Подскажите как лучше сделать в матричных вычислениях
Сообщение21.03.2018, 03:45 
Заслуженный участник


18/01/15
3258
Применять формулы Крамера к системе, коэффициенты и неизвестные в которой --- матрицы, вообще говоря, нельзя, в следующем смысле. Пусть $A_{11}$, $A_{12}$, $A_{21}$, $A_{22}$ --- четыре $2\times2$ матрицы, $B_1$ и $B_2$ --- две $2\times1$ матрицы (т.е. столбца высоты 2). Мы можем рассмотреть систему "матричных уравнений"
$$ A_{11}X_1+A_{12}X_2=B_1 $$ $$ A_{21}X_1+A_{22}X_2=B_2, $$ где $X_1$, $X_2$ --- неизвестные $2\times1$ матрицы, которые мы хотим найти (а $A_{11},\ldots,B_2$ считаются известными). Возникает искушение формально написать "формулы Крамера" $$ X_1=\frac{\begin{vmatrix} B_1 & A_{12} \\ B_2 & A_{22} \end{vmatrix} } {\begin{vmatrix} A_{11} & A_{12} \\ A_{21} & A_{22} \end{vmatrix} }=\frac{A_{22}B_1-A_{12}B_2}{A_{11}A_{22}-A_{21}A_{12}}$$ и для $X_2$ аналогично. Однако эти формулы не имеют смысла! Прежде всего, нельзя писать $A=\frac{B}{C}$, в случае, когда $B$ и $C$ матрицы (во-первых, у $B$ и $C$ могут быть несовместимые размеры. Во-вторых, даже если $B$ и $C$ --- квадратные матрицы одинакового размера, "левое частное" $C^{-1}B$ может не совпадать с "правым частным" $BC^{-1}$, поскольку умножение матриц, вообще говоря, не коммутативно. И вообще может быть так, что $C$ ненулевая, но не обратимая). Но даже если написать
$X_1=(A_{11}A_{22}-A_{21}A_{12})^{-1}(A_{22}B_1-A_{12}B_2)$
или
$X_1=(A_{22}B_1-A_{12}B_2)(A_{11}A_{22}-A_{21}A_{12})^{-1}$,
это всё равно будет неверно. Говоря короче, нельзя обращаться с матрицами так же, как с числами. Разве что при умножении двух матриц, разбитых на блоки. И то при этом надо следить за соответствием размеров блоков и за порядком умножения.

 Профиль  
                  
 
 Re: Подскажите как лучше сделать в матричных вычислениях
Сообщение28.03.2018, 18:25 


07/01/16
4
vpb, спасибо вам за разъяснения, действительно все так.
Подытожим с учетом некоторых полученных результатов.
Итак, мы имеем систему $\[\left\{ {\begin{array}{*{20}{c}}
  {{r_1} = {x_1}{h_1} + {x_2}{h_2} + {n_1}} \\ 
  {{r_2} =  - x_2^*{h_1} + x_1^*{h_2} + {n_2}} \\ 
  {{r_3} = {x_3}{h_1} + {x_4}{h_2} + {n_1}} \\ 
  {{r_4} =  - x_4^*{h_1} + x_3^*{h_2} + {n_2}} 
\end{array}} \right. \Rightarrow \]$ $\[\left\{ {\begin{array}{*{20}{c}}
  {\left[ {\begin{array}{*{20}{c}}
  {{r_1}} \\ 
  {{r_2}} 
\end{array}} \right] = \left[ {\begin{array}{*{20}{c}}
  {{x_1}}&{{x_2}} \\ 
  { - x_2^*}&{x_1^*} 
\end{array}} \right] \cdot \left[ {\begin{array}{*{20}{c}}
  {{h_1}} \\ 
  {{h_2}} 
\end{array}} \right] + \left[ {\begin{array}{*{20}{c}}
  {{n_1}} \\ 
  {{n_2}} 
\end{array}} \right]} \\ 
  {\left[ {\begin{array}{*{20}{c}}
  {{r_3}} \\ 
  {{r_4}} 
\end{array}} \right] = \left[ {\begin{array}{*{20}{c}}
  {{x_3}}&{{x_4}} \\ 
  { - x_4^*}&{x_3^*} 
\end{array}} \right] \cdot \left[ {\begin{array}{*{20}{c}}
  {{h_1}} \\ 
  {{h_2}} 
\end{array}} \right] + \left[ {\begin{array}{*{20}{c}}
  {{n_1}} \\ 
  {{n_2}} 
\end{array}} \right]} 
\end{array}} \right. \Rightarrow \]$ $\[\left\{ {\begin{array}{*{20}{c}}
  {{R_1} = X_1^T \cdot H + N} \\ 
  {{R_2} = X_2^T \cdot H + N} 
\end{array}} \right. \Rightarrow \]$ $\[\left[ {\begin{array}{*{20}{c}}
  {{R_1}} \\ 
  {{R_2}} 
\end{array}} \right] = \left[ {\begin{array}{*{20}{c}}
  {X_1^T}&1 \\ 
  {X_2^T}&1 
\end{array}} \right] \cdot \left[ {\begin{array}{*{20}{c}}
  H \\ 
  N 
\end{array}} \right]\]$
Задача найти значение $N$, при том, что $H$ тоже неизвестно.
Из системы нам удалось получить значение $H$.
$\[\tilde H = \dfrac{{\left[ {\begin{array}{*{20}{c}}
  {{R_1}}&1 \\ 
  {{R_2}}&1 
\end{array}} \right]}}{{\left[ {\begin{array}{*{20}{c}}
  {X_1^T}&1 \\ 
  {X_2^T}&1 
\end{array}} \right]}} = \dfrac{{{R_1} - {R_2}}}{{X_1^T - X_2^T}} = {\left( {X_1^T - X_2^T} \right)^{ - 1}} \cdot \left( {{R_1} - {R_2}} \right)\]$, и тут все получается. При подстановке комплексных чисел восстановленное значение $\[\tilde H\]$ по данной формуле совпадает с значением $H$, заданным изначально. Что мне и нужно.
Далее, подставив $\[\tilde H = {\left( {X_1^T - X_2^T} \right)^{ - 1}} \cdot \left( {{R_1} - {R_2}} \right)\]$ в $\[{R_1} = X_1^T \cdot H + N\]$, получим $\[{R_1} = X_1^T \cdot \left( {{{\left( {X_1^T - X_2^T} \right)}^{ - 1}} \cdot \left( {{R_1} - {R_2}} \right)} \right) + N \to \tilde N = {R_1} - \left( {{{\left( {X_1^T - X_2^T} \right)}^{ - 1}} \cdot \left( {{R_1} - {R_2}} \right)} \right)\]$ или $\[\tilde N = \left( {E - {{\left( {E - X_2^TX_1^{ - T}} \right)}^{ - 1}}} \right){R_1} + {\left( {E - X_2^TX_1^{ - T}} \right)^{ - 1}}{R_2}\]$ (данную формулу мне подсказали на форуме http://www.cyberforum.ru/algebra/thread2213949.html#post12255422).
Вроде как отлично! Что требовалось, то и получили и, что самое главное, все работает. Подставив комплексные числа все вычисляется идеально, за исключением случая, при котором $\[X_2^T = X_1^T\]$. У меня, к сожалению, один такой случай предполагается и поэтому не знаю, что предпринять…
Имеется такая таблица значений $\[{x_1}\]$, $\[{x_2}\]$, $\[{x_3}\]$, $\[{x_4}\]$, $\[{K_1}\]$, $\[{K_2}\]$ в зависимости от информационных сигналов $\[{c_1}...\,{c_4}\]$.
Изображение

И вот в первом случае получается как раз, что $\[X_2^T = X_1^T\]$ и, следовательно, $N$, по той формуле вычислить не получается, а необходимо.

 Профиль  
                  
Показать сообщения за:  Поле сортировки  
Начать новую тему Ответить на тему  [ Сообщений: 4 ] 

Модераторы: Модераторы Математики, Супермодераторы



Кто сейчас на конференции

Сейчас этот форум просматривают: F111mon


Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете добавлять вложения

Найти:
Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group