123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020 |
- using System;
- using System.Linq;
- using System.Windows;
- using System.Windows.Controls;
- using System.Windows.Input;
- using System.Windows.Media.Animation;
- using Matrix;
- namespace MatrixXAMLOnly
- {
- // TODO: Перепроверить все поля на валидацию
- // TODO: Создание диаграмм
- /// <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 = "Обратная матрицы";
- BtnAddition.RaiseEvent(new RoutedEventArgs(Button.ClickEvent));
- }
- 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.Key != Key.OemMinus && e.Key != Key.Subtract)
- {
- 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)
- {
- this.Title = "Калькулятор: матрицы - Сложение матриц";
- 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.Collapsed;
- GridContentInverse.Visibility = Visibility.Collapsed;
- GridAdditionFrstTerm.Children.Clear();
- GridAdditionScndTerm.Children.Clear();
- GridAdditionResult.Children.Clear();
- 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)
- {
- this.Title = "Калькулятор: матрицы - Вычитание матриц";
- 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.Collapsed;
- GridContentInverse.Visibility = Visibility.Collapsed;
- GridDifferenceFrstTerm.Children.Clear();
- GridDifferenceScndTerm.Children.Clear();
- GridDifferenceResult.Children.Clear();
- 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)
- {
- this.Title = "Калькулятор: матрицы - Умножение матрицы на скаляр";
- 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.Collapsed;
- GridContentInverse.Visibility = Visibility.Collapsed;
- GridMultiplicationOnScalarFrstTerm.Children.Clear();
- TextBoxMultiplicationOnScalarScndTerm.Text = "";
- GridMultiplicationOnScalarResult.Children.Clear();
- GridMultiplicationOnScalarFrstTerm.Children.Add(CreateMatrix(5, 5, false));
- GridMultiplicationOnScalarResult.Children.Add(CreateMatrix(5, 5, true));
- }
- private void BtnTransposition_Click(object sender, RoutedEventArgs e)
- {
- this.Title = "Калькулятор: матрицы - Транспонирование матрицы";
- 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.Collapsed;
- GridContentInverse.Visibility = Visibility.Collapsed;
- GridTransposeFrom.Children.Clear();
- GridTransposed.Children.Clear();
- GridTransposeFrom.Children.Add(CreateMatrix(3, 5, false));
- GridTransposed.Children.Add(CreateMatrix(5, 3, true));
- }
- private void BtnMultiplicationOnTransposed_Click(object sender, RoutedEventArgs e)
- {
- this.Title = "Калькулятор: матрицы - Умножение матрицы на её транспонированную матрицу";
- 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.Collapsed;
- GridContentInverse.Visibility = Visibility.Collapsed;
- GridMultiplicationOnTransposedTerm.Children.Clear();
- GridMultiplicationOnTransposedResult.Children.Clear();
- GridMultiplicationOnTransposedTerm.Children.Add(CreateMatrix(5, 5, false));
- GridMultiplicationOnTransposedResult.Children.Add(CreateMatrix(5, 5, true));
- }
- private void BtnRowsReplace_Click(object sender, RoutedEventArgs e)
- {
- this.Title = "Калькулятор: матрицы - Перестановка строк";
- 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.Collapsed;
- GridContentInverse.Visibility = Visibility.Collapsed;
- GridRowsReplaceMatrix.Children.Clear();
- GridRowsReplaceResult.Children.Clear();
- GridRowsReplaceMatrix.Children.Add(CreateMatrix(5, 5, false));
- GridRowsReplaceResult.Children.Add(CreateMatrix(5, 5, true));
- }
- private void BtnInverse_Click(object sender, RoutedEventArgs e)
- {
- this.Title = "Калькулятор: матрицы - Обратная матрица";
- 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.Collapsed;
- GridContentInverse.Visibility = Visibility.Visible;
- GridInverseMatrix.Children.Clear();
- GridInverseResult.Children.Clear();
- GridInverseMatrix.Children.Add(CreateMatrix(5, 5, false));
- GridInverseResult.Children.Add(CreateMatrix(5, 5, true));
- }
- private void BtnRowsTranspositionReplace_Click(object sender, RoutedEventArgs e)
- {
- this.Title = "Калькулятор: матрицы - Перестановка строк согласно вектору транспозиции";
- 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.Visibility = Visibility.Collapsed;
- GridRowTranspositionReplaceMatrix.Children.Clear();
- GridRowTranspositionReplaceVector.Children.Clear();
- GridRowTranspositionReplaceResult.Children.Clear();
- 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));
- }
- private void BtnAdditionDiagramm_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = ((Grid)GridAdditionResult.Children[0]).RowDefinitions.Count;
- int columnCount = ((Grid)GridAdditionResult.Children[0]).ColumnDefinitions.Count;
- double[,] result = new double[rowCount, columnCount];
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- result[i, j] = Convert.ToDouble(((Grid)GridAdditionResult.Children[0]).Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == j && Grid.GetRow(e) == i).Text);
- }
- }
- DiagramWindow wnd = new DiagramWindow(new MyMatrix(result));
- wnd.Show();
- }
- #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();
- }
- }
- }
- private void BtnDifferenceDiagramm_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = ((Grid)GridDifferenceResult.Children[0]).RowDefinitions.Count;
- int columnCount = ((Grid)GridDifferenceResult.Children[0]).ColumnDefinitions.Count;
- double[,] result = new double[rowCount, columnCount];
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- result[i, j] = Convert.ToDouble(((Grid)GridDifferenceResult.Children[0]).Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == j && Grid.GetRow(e) == i).Text);
- }
- }
- DiagramWindow wnd = new DiagramWindow(new MyMatrix(result));
- wnd.Show();
- }
- #endregion
- #region MultiplicationOnScalar
- private void BtnMultiplicationOnScalarCreateMatrix_Click(object sender, RoutedEventArgs e)
- {
- int rowCount, columnCount;
- 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("Матрица указана некорректно!");
- return;
- }
- }
- }
- 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();
- }
- }
- }
- private void BtnMultiplicationOnScalarnDiagramm_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = ((Grid)GridMultiplicationOnScalarResult.Children[0]).RowDefinitions.Count;
- int columnCount = ((Grid)GridMultiplicationOnScalarResult.Children[0]).ColumnDefinitions.Count;
- double[,] result = new double[rowCount, columnCount];
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- result[i, j] = Convert.ToDouble(((Grid)GridMultiplicationOnScalarResult.Children[0]).Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == j && Grid.GetRow(e) == i).Text);
- }
- }
- DiagramWindow wnd = new DiagramWindow(new MyMatrix(result));
- wnd.Show();
- }
- #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("Количество строк/столбцов указано некорректно!");
- return;
- }
- 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("Матрица указана некорректно!");
- return;
- }
- }
- }
- 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();
- }
- }
- }
- private void BtnTranspositionDiagramm_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = ((Grid)GridTransposed.Children[0]).RowDefinitions.Count;
- int columnCount = ((Grid)GridTransposed.Children[0]).ColumnDefinitions.Count;
- double[,] result = new double[rowCount, columnCount];
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- result[i, j] = Convert.ToDouble(((Grid)GridTransposed.Children[0]).Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == j && Grid.GetRow(e) == i).Text);
- }
- }
- DiagramWindow wnd = new DiagramWindow(new MyMatrix(result));
- wnd.Show();
- }
- #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("Количество строк/столбцов указано некорректно!");
- return;
- }
- 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();
- }
- }
- }
- private void BtnMultiplicationOnTransposedDiagramm_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = ((Grid)GridMultiplicationOnTransposedResult.Children[0]).RowDefinitions.Count;
- int columnCount = ((Grid)GridMultiplicationOnTransposedResult.Children[0]).ColumnDefinitions.Count;
- double[,] result = new double[rowCount, columnCount];
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- result[i, j] = Convert.ToDouble(((Grid)GridMultiplicationOnTransposedResult.Children[0]).Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == j && Grid.GetRow(e) == i).Text);
- }
- }
- DiagramWindow wnd = new DiagramWindow(new MyMatrix(result));
- wnd.Show();
- }
- #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("Количество строк/столбцов указано некорректно!");
- return;
- }
- 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();
- }
- }
- }
- private void BtnRowsReplaceDiagramm_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = ((Grid)GridRowsReplaceResult.Children[0]).RowDefinitions.Count;
- int columnCount = ((Grid)GridRowsReplaceResult.Children[0]).ColumnDefinitions.Count;
- double[,] result = new double[rowCount, columnCount];
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- result[i, j] = Convert.ToDouble(((Grid)GridRowsReplaceResult.Children[0]).Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == j && Grid.GetRow(e) == i).Text);
- }
- }
- DiagramWindow wnd = new DiagramWindow(new MyMatrix(result));
- wnd.Show();
- }
- #endregion
- #region RowTranspositionReplace
- private void BtnRowTranspositionReplaceCreateMatrix_Click(object sender, RoutedEventArgs e)
- {
- int rowCount, columnCount;
- try
- {
- rowCount = Convert.ToInt32(TextBoxRowTranspositionReplaceRowCount.Text);
- columnCount = Convert.ToInt32(TextBoxRowTranspositionReplaceColumnCount.Text);
- }
- catch
- {
- MessageBox.Show("Количество строк/столбцов указано некорректно!");
- return;
- }
- 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();
- }
- }
- }
-
- }
- private void BtnRowTranspositionReplaceDiagramm_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = ((Grid)GridRowTranspositionReplaceResult.Children[0]).RowDefinitions.Count;
- int columnCount = ((Grid)GridRowTranspositionReplaceResult.Children[0]).ColumnDefinitions.Count;
- double[,] result = new double[rowCount, columnCount];
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- result[i, j] = Convert.ToDouble(((Grid)GridRowTranspositionReplaceResult.Children[0]).Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == j && Grid.GetRow(e) == i).Text);
- }
- }
- DiagramWindow wnd = new DiagramWindow(new MyMatrix(result));
- wnd.Show();
- }
- #endregion
- #region Inverse
- private void BtnInverseCreateMatrix_Click(object sender, RoutedEventArgs e)
- {
- int rowCount, columnCount;
- try
- {
- rowCount = Convert.ToInt32(TextBoxInverseRowCount.Text);
- columnCount = Convert.ToInt32(TextBoxInverseColumnCount.Text);
- }
- catch
- {
- MessageBox.Show("Количество строк/столбцов указано некорректно!");
- return;
- }
- GridInverseMatrix.Children.Clear();
- GridInverseResult.Children.Clear();
- GridInverseMatrix.Children.Add(CreateMatrix(rowCount, columnCount, false));
- GridInverseResult.Children.Add(CreateMatrix(rowCount, columnCount, true));
- }
- private void BtnInverseCalculate_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = ((Grid)GridInverseMatrix.Children[0]).RowDefinitions.Count;
- int columnCount = ((Grid)GridInverseMatrix.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)GridInverseMatrix.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;
- try
- {
- result = MyMatrix.Inverse(matrixFrstTerm);
- }
- catch (Exception ex)
- {
- MessageBox.Show(ex.Message);
- return;
- }
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- ((TextBox)((Grid)GridInverseResult.Children[0]).Children[(i * columnCount) + j]).Text = result.data[i, j].ToString();
- }
- }
- }
- private void BtnInverseeDiagramm_Click(object sender, RoutedEventArgs e)
- {
- int rowCount = ((Grid)GridInverseResult.Children[0]).RowDefinitions.Count;
- int columnCount = ((Grid)GridInverseResult.Children[0]).ColumnDefinitions.Count;
- double[,] result = new double[rowCount, columnCount];
- for (int i = 0; i < rowCount; i++)
- {
- for (int j = 0; j < columnCount; j++)
- {
- result[i, j] = Convert.ToDouble(((Grid)GridInverseResult.Children[0]).Children.Cast<TextBox>().First(e => Grid.GetColumn(e) == j && Grid.GetRow(e) == i).Text);
- }
- }
- DiagramWindow wnd = new DiagramWindow(new MyMatrix(result));
- wnd.Show();
- }
- #endregion
- }
- }
|