123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758 |
- using System;
- using System.Linq;
- using System.Windows;
- using System.Windows.Controls;
- using System.Windows.Controls.Primitives;
- using System.Windows.Input;
- using System.Windows.Media;
- using System.Windows.Media.Animation;
- using Matrix;
- namespace MatrixXAMLOnly
- {
- /// <summary>
- /// Interaction logic for MainWindow.xaml
- /// </summary>
- public partial class MainWindow : Window
- {
- public MainWindow()
- {
- InitializeComponent();
- BtnAddition.Content = "Сложение матрицы";
- BtnDifference.Content = "Вычитание матрицы";
- BtnMultiplicationOnScalar.Content = "Умножение матрицы \nна скаляр";
- BtnTransposition.Content = "Транспонирование матрицы";
- BtnMultiplicationOnTransposed.Content = "Умножение матрицы на её \nтранспонированную матрицу";
- BtnRowsReplace.Content = "Перестановка строк";
- BtnRowsTranspositionReplace.Content = "Перестановка строк согласно \nвектору транспозиции";
- BtnInverse.Content = "Обратная матрицы";
- }
- private void BtnHamburgerMenu_Click(object sender, RoutedEventArgs e)
- {
- DoubleAnimation menuAnimation = new DoubleAnimation();
- menuAnimation.From = CurtainMenu.ActualWidth;
- menuAnimation.DecelerationRatio = 1.0;
- if (menuAnimation.From == 250)
- {
- menuAnimation.To = 0;
- menuAnimation.Duration = TimeSpan.FromSeconds(0.2);
- }
- else
- {
- menuAnimation.To = 250;
- menuAnimation.Duration = TimeSpan.FromSeconds(0.2);
- }
- CurtainMenu.BeginAnimation(WidthProperty, menuAnimation);
- }
- private Grid CreateMatrix(int a, int b, bool isOnlyRead)
- {
- Grid matrixGrid = new Grid();
- matrixGrid.Margin = new Thickness(25, 75, 25, 75);
- // Добавление колонок
- for (int i = 0; i < b; i++)
- {
- matrixGrid.ColumnDefinitions.Add(new ColumnDefinition());
- }
- // Добавление строк
- for (int j = 0; j < a; j++)
- {
- matrixGrid.RowDefinitions.Add(new RowDefinition());
- }
- // Добавление TextBox'ов
- int tabCounter = 1;
- for (int i = 0; i < a; i++)
- {
- for (int j = 0; j < b; j++)
- {
- TextBox textBox = new TextBox()
- {
- HorizontalContentAlignment = HorizontalAlignment.Center,
- VerticalContentAlignment = VerticalAlignment.Center,
- TabIndex = tabCounter
- };
- if (isOnlyRead)
- {
- textBox.IsReadOnly = true;
- }
- tabCounter++;
- textBox.KeyDown += TextBox_KeyDown;
- Grid.SetColumn(textBox, j);
- Grid.SetRow(textBox, i);
- matrixGrid.Children.Add(textBox);
- }
- }
- return matrixGrid;
- }
- private void TextBox_KeyDown(object sender, KeyEventArgs e)
- {
- if (e.Key == Key.W ||
- e.Key == Key.A ||
- e.Key == Key.S ||
- e.Key == Key.D ||
- e.Key == Key.Tab)
- {
- e.Handled = true;
- FocusOnNext((TextBox)sender, e.Key);
- return;
- }
- if (e.Key != Key.NumPad0 && e.Key != Key.D0 &&
- e.Key != Key.NumPad1 && e.Key != Key.D1 &&
- e.Key != Key.NumPad2 && e.Key != Key.D2 &&
- e.Key != Key.NumPad3 && e.Key != Key.D3 &&
- e.Key != Key.NumPad4 && e.Key != Key.D4 &&
- e.Key != Key.NumPad5 && e.Key != Key.D5 &&
- e.Key != Key.NumPad6 && e.Key != Key.D6 &&
- e.Key != Key.NumPad7 && e.Key != Key.D7 &&
- e.Key != Key.NumPad8 && e.Key != Key.D8 &&
- e.Key != Key.NumPad9 && e.Key != Key.D9)
- {
- e.Handled = true;
- }
- }
- private void FocusOnNext(TextBox tb, Key KeyArg)
- {
- Grid matrixGrid = (Grid)tb.Parent;
- int columns = matrixGrid.ColumnDefinitions.Count;
- int rows = matrixGrid.RowDefinitions.Count;
- int element = tb.TabIndex;
- if (((int)KeyArg) == 40 || KeyArg == Key.S)
- {
- element += columns;
- }
- else if ((int)KeyArg == 38 || KeyArg == Key.W)
- {
- element -= columns;
- }
- else if ((int)KeyArg == 37 || KeyArg == Key.A)
- {
- element -= 1;
- }
- else if ((int)KeyArg == 39 || KeyArg == Key.D || KeyArg == Key.Tab)
- {
- element += 1;
- }
- else
- {
- return;
- }
- int counter = 0;
- for (int i = 0; i < rows; i++)
- {
- for (int j = 0; j < columns; j++)
- {
- counter++;
- if (element == counter)
- {
- matrixGrid.Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == j && Grid.GetRow(e) == i).Focus();
- }
- }
- }
-
- }
- #region HumburgerMenuItems
- private void BtnAddition_Click(object sender, RoutedEventArgs e)
- {
- GridContentAddition.Visibility = Visibility.Visible;
- GridContentDifference.Visibility = Visibility.Collapsed;
- GridContentMultiplication.Visibility = Visibility.Collapsed;
- GridContentMultiplicationOnTransposed.Visibility = Visibility.Collapsed;
- GridContentRowsReplace.Visibility = Visibility.Collapsed;
- GridContentTranspose.Visibility = Visibility.Collapsed;
- GridContentRowTranspositionReplace.Visibility = Visibility.Visible;
- // GridContentInverse;
- GridAdditionFrstTerm.Children.Add(CreateMatrix(5, 5, false));
- GridAdditionScndTerm.Children.Add(CreateMatrix(5, 5, false));
- GridAdditionResult.Children.Add(CreateMatrix(5, 5, true));
- }
- private void BtnDifference_Click(object sender, RoutedEventArgs e)
- {
- GridContentAddition.Visibility = Visibility.Collapsed;
- GridContentDifference.Visibility = Visibility.Visible;
- GridContentMultiplication.Visibility = Visibility.Collapsed;
- GridContentMultiplicationOnTransposed.Visibility = Visibility.Collapsed;
- GridContentRowsReplace.Visibility = Visibility.Collapsed;
- GridContentTranspose.Visibility = Visibility.Collapsed;
- GridContentRowTranspositionReplace.Visibility = Visibility.Visible;
- // GridContentInverse;
- GridDifferenceFrstTerm.Children.Add(CreateMatrix(5, 5, false));
- GridDifferenceScndTerm.Children.Add(CreateMatrix(5, 5, false));
- GridDifferenceResult.Children.Add(CreateMatrix(5, 5, true));
- }
- private void BtnMultiplicationOnScalar_Click(object sender, RoutedEventArgs e)
- {
- GridContentAddition.Visibility = Visibility.Collapsed;
- GridContentDifference.Visibility = Visibility.Collapsed;
- GridContentMultiplication.Visibility = Visibility.Visible;
- GridContentMultiplicationOnTransposed.Visibility = Visibility.Collapsed;
- GridContentRowsReplace.Visibility = Visibility.Collapsed;
- GridContentTranspose.Visibility = Visibility.Collapsed;
- GridContentRowTranspositionReplace.Visibility = Visibility.Visible;
- // GridContentInverse;
- GridMultiplicationOnScalarFrstTerm.Children.Add(CreateMatrix(5, 5, false));
- GridMultiplicationOnScalarResult.Children.Add(CreateMatrix(5, 5, true));
- }
- private void BtnTransposition_Click(object sender, RoutedEventArgs e)
- {
- GridContentAddition.Visibility = Visibility.Collapsed;
- GridContentDifference.Visibility = Visibility.Collapsed;
- GridContentMultiplication.Visibility = Visibility.Collapsed;
- GridContentMultiplicationOnTransposed.Visibility = Visibility.Collapsed;
- GridContentRowsReplace.Visibility = Visibility.Collapsed;
- GridContentTranspose.Visibility = Visibility.Visible;
- GridContentRowTranspositionReplace.Visibility = Visibility.Visible;
- // GridContentInverse;
- GridTransposeFrom.Children.Add(CreateMatrix(3, 5, false));
- GridTransposed.Children.Add(CreateMatrix(5, 3, true));
- }
- private void BtnMultiplicationOnTransposed_Click(object sender, RoutedEventArgs e)
- {
- GridContentAddition.Visibility = Visibility.Collapsed;
- GridContentDifference.Visibility = Visibility.Collapsed;
- GridContentMultiplication.Visibility = Visibility.Collapsed;
- GridContentMultiplicationOnTransposed.Visibility = Visibility.Visible;
- GridContentRowsReplace.Visibility = Visibility.Collapsed;
- GridContentTranspose.Visibility = Visibility.Collapsed;
- GridContentRowTranspositionReplace.Visibility = Visibility.Visible;
- // GridContentInverse;
- GridMultiplicationOnTransposedTerm.Children.Add(CreateMatrix(5, 5, false));
- GridMultiplicationOnTransposedResult.Children.Add(CreateMatrix(5, 5, true));
- }
- private void BtnRowsReplace_Click(object sender, RoutedEventArgs e)
- {
- GridContentAddition.Visibility = Visibility.Collapsed;
- GridContentDifference.Visibility = Visibility.Collapsed;
- GridContentMultiplication.Visibility = Visibility.Collapsed;
- GridContentMultiplicationOnTransposed.Visibility = Visibility.Collapsed;
- GridContentRowsReplace.Visibility = Visibility.Visible;
- GridContentTranspose.Visibility = Visibility.Collapsed;
- GridContentRowTranspositionReplace.Visibility = Visibility.Visible;
- // GridContentInverse;
- GridRowsReplaceMatrix.Children.Add(CreateMatrix(5, 5, false));
- GridRowsReplaceResult.Children.Add(CreateMatrix(5, 5, true));
- }
- private void BtnInverse_Click(object sender, RoutedEventArgs e)
- {
- GridContentAddition.Visibility = Visibility.Collapsed;
- GridContentDifference.Visibility = Visibility.Collapsed;
- GridContentMultiplication.Visibility = Visibility.Collapsed;
- GridContentMultiplicationOnTransposed.Visibility = Visibility.Collapsed;
- GridContentRowsReplace.Visibility = Visibility.Collapsed;
- GridContentTranspose.Visibility = Visibility.Collapsed;
- GridContentRowTranspositionReplace.Visibility = Visibility.Visible;
- // GridContentInverse;
- }
- private void BtnRowsTranspositionReplace_Click(object sender, RoutedEventArgs e)
- {
- GridContentAddition.Visibility = Visibility.Collapsed;
- GridContentDifference.Visibility = Visibility.Collapsed;
- GridContentMultiplication.Visibility = Visibility.Collapsed;
- GridContentMultiplicationOnTransposed.Visibility = Visibility.Collapsed;
- GridContentRowsReplace.Visibility = Visibility.Collapsed;
- GridContentTranspose.Visibility = Visibility.Collapsed;
- GridContentRowTranspositionReplace.Visibility = Visibility.Visible;
- // GridContentInverse;
- GridRowTranspositionReplaceMatrix.Children.Add(CreateMatrix(5, 5, false));
- GridRowTranspositionReplaceVector.Children.Add(CreateMatrix(5, 1, false));
- GridRowTranspositionReplaceResult.Children.Add(CreateMatrix(5, 5, true));
- }
- #endregion
- #region Addition
- private void BtnAdditionCalculate_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = ((Grid)GridAdditionResult.Children[0]).RowDefinitions.Count;
- int columnCount = ((Grid)GridAdditionResult.Children[0]).ColumnDefinitions.Count;
- double[,] frstTerm = new double[rowCount, columnCount];
- double[,] scndTerm = new double[rowCount, columnCount];
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- try
- {
- frstTerm[i, j] = Convert.ToDouble(((Grid)GridAdditionFrstTerm.Children[0]).Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == j && Grid.GetRow(e) == i).Text);
- scndTerm[i, j] = Convert.ToDouble(((Grid)GridAdditionScndTerm.Children[0]).Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == j && Grid.GetRow(e) == i).Text);
- }
- catch
- {
- MessageBox.Show("Матрица указана некорректно!");
- return;
- }
- }
- }
- MyMatrix matrixFrstTerm = new MyMatrix(frstTerm);
- MyMatrix matrixScndTerm = new MyMatrix(scndTerm);
- MyMatrix result = matrixFrstTerm + matrixScndTerm;
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- ((TextBox)((Grid)GridAdditionResult.Children[0]).Children[(i * columnCount) + j]).Text = result.data[i, j].ToString();
- }
- }
- }
- private void BtnAddtitionCreateMatrix_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = 0;
- int columnCount = 0;
- try
- {
- rowCount = Convert.ToInt32(TextBoxAdditionRowCount.Text);
- columnCount = Convert.ToInt32(TextBoxAdditionColumnCount.Text);
- }
- catch
- {
- MessageBox.Show("Количество строк/столбцов указано некорректно!");
- return;
- }
- GridAdditionFrstTerm.Children.Clear();
- GridAdditionScndTerm.Children.Clear();
- GridAdditionResult.Children.Clear();
- GridAdditionFrstTerm.Children.Add(CreateMatrix(rowCount, columnCount, false));
- GridAdditionScndTerm.Children.Add(CreateMatrix(rowCount, columnCount, false));
- GridAdditionResult.Children.Add(CreateMatrix(rowCount, columnCount, true));
- }
- #endregion
- #region Difference
- private void BtnDifferenceCreateMatrix_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = 0;
- int columnCount = 0;
- try
- {
- rowCount = Convert.ToInt32(TextBoxDifferenceRowCount.Text);
- columnCount = Convert.ToInt32(TextBoxDifferenceColumnCount.Text);
- }
- catch
- {
- MessageBox.Show("Количество строк/столбцов указано некорректно!");
- return;
- }
- GridDifferenceFrstTerm.Children.Clear();
- GridDifferenceScndTerm.Children.Clear();
- GridDifferenceResult.Children.Clear();
- GridDifferenceFrstTerm.Children.Add(CreateMatrix(rowCount, columnCount, false));
- GridDifferenceScndTerm.Children.Add(CreateMatrix(rowCount, columnCount, false));
- GridDifferenceResult.Children.Add(CreateMatrix(rowCount, columnCount, true));
- }
- private void BtnDifferenceCalculate_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = ((Grid)GridDifferenceResult.Children[0]).RowDefinitions.Count;
- int columnCount = ((Grid)GridDifferenceResult.Children[0]).ColumnDefinitions.Count;
- double[,] frstTerm = new double[rowCount, columnCount];
- double[,] scndTerm = new double[rowCount, columnCount];
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- try
- {
- frstTerm[i, j] = Convert.ToDouble(((Grid)GridDifferenceFrstTerm.Children[0]).Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == j && Grid.GetRow(e) == i).Text);
- scndTerm[i, j] = Convert.ToDouble(((Grid)GridDifferenceScndTerm.Children[0]).Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == j && Grid.GetRow(e) == i).Text);
- }
- catch
- {
- MessageBox.Show("Матрица указана некорректно!");
- return;
- }
- }
- }
- MyMatrix matrixFrstTerm = new MyMatrix(frstTerm);
- MyMatrix matrixScndTerm = new MyMatrix(scndTerm);
- MyMatrix result = matrixFrstTerm - matrixScndTerm;
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- ((TextBox)((Grid)GridDifferenceResult.Children[0]).Children[(i * columnCount) + j]).Text = result.data[i, j].ToString();
- }
- }
- }
- #endregion
- #region MultiplicationOnScalar
- private void BtnMultiplicationOnScalarCreateMatrix_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = 0;
- int columnCount = 0;
- try
- {
- rowCount = Convert.ToInt32(TextBoxMultiplicationOnScalarRowCount.Text);
- columnCount = Convert.ToInt32(TextBoxMultiplicationOnScalarColumnCount.Text);
- }
- catch
- {
- MessageBox.Show("Количество строк/столбцов указано некорректно!");
- return;
- }
- GridMultiplicationOnScalarFrstTerm.Children.Clear();
- TextBoxMultiplicationOnScalarScndTerm.Text = "";
- GridMultiplicationOnScalarResult.Children.Clear();
- GridMultiplicationOnScalarFrstTerm.Children.Add(CreateMatrix(rowCount, columnCount, false));
- GridMultiplicationOnScalarResult.Children.Add(CreateMatrix(rowCount, columnCount, true));
- }
- private void BtnMultiplicationOnScalarCalculate_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = ((Grid)GridMultiplicationOnScalarResult.Children[0]).RowDefinitions.Count;
- int columnCount = ((Grid)GridMultiplicationOnScalarResult.Children[0]).ColumnDefinitions.Count;
- double[,] frstTerm = new double[rowCount, columnCount];
- double scndTerm = 0;
- try
- {
- scndTerm = Convert.ToDouble(TextBoxMultiplicationOnScalarScndTerm.Text);
- }
- catch
- {
- MessageBox.Show("Скалярная величина указана некорректно!");
- return;
- }
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- try
- {
- frstTerm[i, j] = Convert.ToDouble(((Grid)GridMultiplicationOnScalarFrstTerm.Children[0]).Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == j && Grid.GetRow(e) == i).Text);
- }
- catch
- {
- MessageBox.Show("Матрица указана некорректно!");
- }
- }
- }
- MyMatrix matrixFrstTerm = new MyMatrix(frstTerm);
- MyMatrix result = matrixFrstTerm * scndTerm;
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- ((TextBox)((Grid)GridMultiplicationOnScalarResult.Children[0]).Children[(i * columnCount) + j]).Text = result.data[i, j].ToString();
- }
- }
- }
- #endregion
- #region Transposition
- private void BtnTranspositionCreateMatrix_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = 0;
- int columnCount = 0;
- try
- {
- rowCount = Convert.ToInt32(TextBoxTranspositionRowCount.Text);
- columnCount = Convert.ToInt32(TextBoxTranspositionColumnCount.Text);
- }
- catch
- {
- MessageBox.Show("Количество строк/столбцов указано некорректно!");
- }
- GridTransposeFrom.Children.Clear();
- GridTransposed.Children.Clear();
- GridTransposeFrom.Children.Add(CreateMatrix(rowCount, columnCount, false));
- GridTransposed.Children.Add(CreateMatrix(columnCount, rowCount, true));
- }
- private void BtnTranspositionCalculate_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = ((Grid)GridTransposeFrom.Children[0]).RowDefinitions.Count;
- int columnCount = ((Grid)GridTransposeFrom.Children[0]).ColumnDefinitions.Count;
- double[,] frstTerm = new double[rowCount, columnCount];
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- try
- {
- frstTerm[i, j] = Convert.ToDouble(((Grid)GridTransposeFrom.Children[0]).Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == j && Grid.GetRow(e) == i).Text);
- }
- catch
- {
- MessageBox.Show("Матрица указана некорректно!");
- }
- }
- }
- MyMatrix result = MyMatrix.Transpose(new MyMatrix(frstTerm));
- for (int i = 0; i < result.Rows; i++)
- {
- for (int j = 0; j < result.Columns; j++)
- {
- Grid matrixGrid = (Grid)GridTransposed.Children[0];
- TextBox tb = (TextBox)matrixGrid.Children[(i * result.Columns) + j];
- tb.Text = result.data[i, j].ToString();
- }
- }
- }
- #endregion
- #region MultiplicationOnTransposed
- private void BtnMultiplicationOnTransposedCreateMatrix_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = 0;
- int columnCount = 0;
- try
- {
- rowCount = Convert.ToInt32(TextBoxMultiplicationOnTransposedRowCount.Text);
- columnCount = Convert.ToInt32(TextBoxMultiplicationOnTransposedColumnCount.Text);
- }
- catch
- {
- MessageBox.Show("Количество строк/столбцов указано некорректно!");
- }
- GridMultiplicationOnTransposedTerm.Children.Clear();
- GridMultiplicationOnTransposedResult.Children.Clear();
- GridMultiplicationOnTransposedTerm.Children.Add(CreateMatrix(rowCount, columnCount, false));
- GridMultiplicationOnTransposedResult.Children.Add(CreateMatrix(rowCount, rowCount, true));
- }
- private void BtnMultiplicationOnTransposedCalculate_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = ((Grid)GridMultiplicationOnTransposedTerm.Children[0]).RowDefinitions.Count;
- int columnCount = ((Grid)GridMultiplicationOnTransposedTerm.Children[0]).ColumnDefinitions.Count;
- double[,] frstTerm = new double[rowCount, columnCount];
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- try
- {
- frstTerm[i, j] = Convert.ToDouble(((Grid)GridMultiplicationOnTransposedTerm.Children[0]).Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == j && Grid.GetRow(e) == i).Text);
- }
- catch
- {
- MessageBox.Show("Матрица указана некорректно!");
- return;
- }
- }
- }
- MyMatrix matrixFrst = new MyMatrix(frstTerm);
- MyMatrix matrixTransposed = MyMatrix.Transpose(matrixFrst);
- MyMatrix result = matrixFrst * matrixTransposed;
- for (int i = 0; i < result.Rows; i++)
- {
- for (int j = 0; j < result.Columns; j++)
- {
- ((TextBox)((Grid)GridMultiplicationOnTransposedResult.Children[0]).Children[(i * result.Columns) + j]).Text = result.data[i, j].ToString();
- }
- }
- }
- #endregion
- #region RowReplace
- private void BtnRowReplaceCreateMatrix_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = 0;
- int columnCount = 0;
- try
- {
- rowCount = Convert.ToInt32(TextBoxRowReplaceRowCount.Text);
- columnCount = Convert.ToInt32(TextBoxRowReplaceColumnCount.Text);
- }
- catch
- {
- MessageBox.Show("Количество строк/столбцов указано некорректно!");
- }
- GridRowsReplaceMatrix.Children.Clear();
- GridRowsReplaceResult.Children.Clear();
- GridRowsReplaceMatrix.Children.Add(CreateMatrix(rowCount, columnCount, false));
- GridRowsReplaceResult.Children.Add(CreateMatrix(rowCount, columnCount, true));
- }
- private void BtnRowsReplaceCalculate_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = ((Grid)GridRowsReplaceMatrix.Children[0]).RowDefinitions.Count;
- int columnCount = ((Grid)GridRowsReplaceMatrix.Children[0]).ColumnDefinitions.Count;
- double[,] frstTerm = new double[rowCount, columnCount];
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- try
- {
- frstTerm[i, j] = Convert.ToDouble(((Grid)GridRowsReplaceMatrix.Children[0]).Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == j && Grid.GetRow(e) == i).Text);
- }
- catch
- {
- MessageBox.Show("Матрица указана некорректно!");
- return;
- }
- }
- }
- MyMatrix matrixFrstTerm = new MyMatrix(frstTerm);
- MyMatrix result = MyMatrix.RowReplace(matrixFrstTerm, Convert.ToInt32(TextBoxRowReplaceFrstTerm.Text) - 1, Convert.ToInt32(TextBoxRowReplaceScndTerm.Text) - 1);
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- ((TextBox)((Grid)GridRowsReplaceResult.Children[0]).Children[(i * columnCount) + j]).Text = result.data[i, j].ToString();
- }
- }
- }
- #endregion
- #region RowTranspositionReplace
- private void BtnRowTranspositionReplaceCreateMatrix_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = 0;
- int columnCount = 0;
- try
- {
- rowCount = Convert.ToInt32(TextBoxRowTranspositionReplaceRowCount.Text);
- columnCount = Convert.ToInt32(TextBoxRowTranspositionReplaceColumnCount.Text);
- }
- catch
- {
- MessageBox.Show("Количество строк/столбцов указано некорректно!");
- }
- GridRowTranspositionReplaceMatrix.Children.Clear();
- GridRowTranspositionReplaceVector.Children.Clear();
- GridRowTranspositionReplaceResult.Children.Clear();
- GridRowTranspositionReplaceMatrix.Children.Add(CreateMatrix(rowCount, columnCount, false));
- GridRowTranspositionReplaceVector.Children.Add(CreateMatrix(rowCount, 1, false));
- GridRowTranspositionReplaceResult.Children.Add(CreateMatrix(rowCount, columnCount, true));
- }
- private void BtnRowTranspositionReplaceCalculate_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = ((Grid)GridRowTranspositionReplaceMatrix.Children[0]).RowDefinitions.Count;
- int columnCount = ((Grid)GridRowTranspositionReplaceMatrix.Children[0]).ColumnDefinitions.Count;
- double[,] frstTerm = new double[rowCount, columnCount];
- int[] vector = new int[rowCount];
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- try
- {
- frstTerm[i, j] = Convert.ToDouble(((Grid)GridRowTranspositionReplaceMatrix.Children[0]).Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == j && Grid.GetRow(e) == i).Text);
- }
- catch
- {
- MessageBox.Show("Матрица указана некорректно!");
- return;
- }
- }
- }
- for (int i = 0; i < rowCount; i++)
- {
- try
- {
- vector[i] = Convert.ToInt32(((Grid)GridRowTranspositionReplaceVector.Children[0]).Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == 0 && Grid.GetRow(e) == i).Text) - 1;
- }
- catch
- {
- MessageBox.Show("Матрица указана некорректно!");
- return;
- }
- }
- MyMatrix matrixFrstTerm = new MyMatrix(frstTerm);
- MyMatrix result = MyMatrix.RowReplaceByVector(matrixFrstTerm, vector);
- if (result != null)
- {
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- ((TextBox)((Grid)GridRowTranspositionReplaceResult.Children[0]).Children[(i * columnCount) + j]).Text = result.data[i, j].ToString();
- }
- }
- }
- else
- {
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- ((TextBox)((Grid)GridRowTranspositionReplaceResult.Children[0]).Children[(i * columnCount) + j]).Text = matrixFrstTerm.data[i, j].ToString();
- }
- }
- }
-
- }
- #endregion
- #region Inverse
- #endregion
- }
- }
|