Fortune Telling Collection - Fortune-telling birth date - How to input matrix and how to operate matrix in MATLAB?
How to input matrix and how to operate matrix in MATLAB?
1, matrix elements must be within "[]";
2. The equivalent elements of the matrix are separated by spaces (or ",");
3. Used between rows of a matrix; "(or enter);
4. Elements of a matrix can be numerical values, variables, expressions or functions;
5. The size of the matrix does not need to be defined in advance.
Second, the operation of matrix
1, arithmetic operation
The basic arithmetic operations of MATLAB are:+(add),-(subtract), * (multiply),/(divide right), \ (divide left), (multiply) and' (transpose). The operation is carried out in the sense of matrix, and the arithmetic operation of single data is only a special case.
Addition and subtraction of (1) matrix If there are two matrices A and B, then the addition and subtraction of matrices can be realized by A+B and A-B. The operation rule is: if the dimensions of matrix A and matrix B are the same, the addition and subtraction of matrices can be carried out, and the corresponding elements of matrix A and matrix B can be added and subtracted. If the dimensions of A and B are different, MATLAB will give an error message, prompting the user that the dimensions of the two matrices do not match.
(2) Matrix multiplication assumes that there are two matrices A and B. If A is an m*n matrix and B is an n*p matrix, then C=A*B is an m*p matrix.
(3) Matrix Division In MATLAB, there are two matrix division operations: \ and/,which represent left division and right division respectively. If a matrix is nonsingular, then A\B and B/A operations can be realized.
A\B is equivalent to a's inverse left times b matrix, namely inv(A)*B, and B/A is equivalent to a's inverse right times b matrix, namely B*inv(A). For operations involving scalars, the results of two division operations are the same. For matrices, left division and right division represent two different relationships between divisor matrix and dividend matrix, which are generally a \ b ≠ b/a.
(4) The power operation of the power matrix of a matrix can be expressed as X, which requires that A is a square matrix and X is a scalar.
(5) matrix transposition: the real matrix is exchanged in rows and columns; For complex matrices, the * * * yoke is transposed, a special operator. * * * The yoke is not transposed (see point operation);
(6) Point operation In MATLAB, there is a special operation, because its operator is to add points in front of related arithmetic operators, so it is called point operation. The dot operator is. *,./,.\ And. The point operation of two matrices refers to the correlation operation of their corresponding elements, which requires that the dimension parameters of the two matrices are the same.
2. Relational operations
MATLAB provides six relational operators:&; lt; (less than),&; lt; = (less than or equal to),&; gt; (greater than),&; gt; = (greater than or equal to), = = (equal to), ~ = (not equal to). The algorithm of relational operators is:
(1) When two comparison quantities are scalars, directly compare the sizes of two numbers. If the relationship is established, the result of the relationship expression is 1, otherwise it is 0;
(2) When the quantities involved in the comparison are two matrices with the same dimension, the elements in the same position in the two matrices are compared one by one according to the scalar relation operation rules, and the element comparison results are given. The final result of relational operation is a matrix with the same dimension as the original matrix, and its elements are composed of 0 or 1
(3) When one party participating in the comparison is a scalar and the other party is a matrix, the elements of the scalar and the matrix are compared one by one according to the scalar relation operation rules, and the element comparison results are given. The final result of relational operation is a matrix with the same dimension as the original matrix, and its elements are composed of 0 or 1.
3. Logical operation
MATLAB provides three logical operators:&; (and), | (or) and ~ (not). The algorithm of logical operation is:
(1) In the logical operation, confirm that the non-zero element is true, which is represented by 1, and the zero element is false, which is represented by 0;
(2) Assuming that two scalars a & ampB are involved in the logical operation, then A&; If b a and b are not zero, the result of the operation is 1, otherwise it is 0. As long as one of a | b a and b is non-zero, the operation result is 1. ~a when a is zero, the operation result is1; When a is not zero, the operation result is 0.
(3) If two matrices with the same dimension are involved in the logical operation, the elements in the same position in the matrix will be operated one by one according to the scalar rule. The final operation result is a matrix with the same dimension as the original matrix, and its elements are composed of 1 or 0;
(4) If one of the logical operations is a scalar and the other is a matrix, then this operation will be carried out one by one between the scalar and each element in the matrix according to the scalar rule. The final operation result is a matrix with the same dimension as the matrix, and its elements are composed of 1 or 0;
(5) Logic is not a monocular operator, but also abides by the rules of matrix operation;
(6) Among arithmetic, relational and logical operations, arithmetic operation has the highest priority and logical operation has the lowest priority.
Extended data:
1. Get matrix elements
Elements of a matrix can be referenced by subscripts (column indexes), such as Matrix(m, n).
Matrix elements can also be referenced by their serial numbers.
The serial number of matrix elements is the arrangement order of corresponding elements in memory.
In MATLAB, matrix elements are stored in columns.
The serial number (index) corresponds to the subscript (subscript) one by one. Take the m*n matrix A as an example, the serial number of matrix element A(i, j) is (j-1) * m+i.
The conversion relationship can also be obtained by using sub2ind and ind2sub functions.
2. Matrix splitting
Using colon expression to obtain submatrix;
(1)A (:,j) means to take all the elements in the j-th column of a matrix; A(i,:) represents all the elements in the I-th row of the A matrix; A(i, j) represents the element in the i-th row and the j-th column of a matrix.
(2)A(i:i+m,:) represents all the elements of the i~i+m rows of the matrix A; A (:,k:k+m) means to take all the elements of column k~k+m of a matrix, and A(i:i+m, k:k+m) means to take all the elements of row i~i+m and column k~k+m of a matrix.
In addition, we can also use general vectors and end operators to represent matrix subscripts, thus obtaining submatrix. End indicates the last element subscript of the dimension.
Use an empty matrix to delete the elements of the matrix;
In MATLAB, [] is defined as an empty matrix. Giving the variable x an empty matrix is X=[]. Note that X=[] is different from clear X, which deletes x from the workspace, and there is an empty matrix in the workspace, but the dimension is 0.
3. Special matrix
(1) Rubik's cube matrix The Rubik's cube matrix has an interesting property, that is, the sum of elements on each row, column and diagonal is equal. For the n-order Rubik's cube array, its elements are composed of 1, 2, 3, …, n2***n2 integers. MATLAB provides the function magic(n) for finding the Rubik's cube matrix, and its function is to generate an n-order Rubik's cube matrix.
(2) Vandermonde Matrix The last column of Vandermonde matrix is all 1, the penultimate column is the specified vector, and the other columns are the dot products of the next column and the penultimate column. You can generate a Vandermonde matrix with the specified vector. In MATLAB, the function vander(V) generates Vandermonde matrix based on vector V. ..
(3) Hilbert matrix In MATLAB, the function of generating Hilbert matrix is Hilbert (n). Using the general method to find the inverse, because the original data has little disturbance, it will produce unreliable calculation results. There is a special function invhilb(n) in MATLAB to find the inverse of Hilbert matrix, and its function is to find the inverse of n-order Hilbert matrix.
(4) The toplitz matrix has the same elements as the upper left corner except the first row and the first column. The function of generating a toplitz matrix is toeplitz(x, y), and a toplitz matrix is generated, with x as the first column and y as the first row. Here x and y are vectors, and their lengths don't have to be equal. Toeplitz(x) uses vector x to generate a symmetric toplitz matrix.
(5) Adjoint Matrix The function of generating adjoint matrix by MATLAB is compan(p), where p is the coefficient vector of polynomial, with the coefficient of high power before and the coefficient of low power after.
(6) Pascal matrix We know that the coefficient of the quadratic term (x+y)n expands with the increase of n to form a triangle table, which is called Yang Hui triangle. The matrix composed of Yang Hui's triangle table is called Pascal matrix. The function pascal(n) generates an n-order pascal matrix.
References:
Baidu encyclopedia-Pascal matrix
Baidu encyclopedia -MATLAB
- Previous article:Outstanding teenagers who are "not old" in history
- Next article:Xiao fortune-telling formula _ Xiao fortune-telling accuracy
- Related articles
- Life span of fortune teller _ Life span of fortune teller
- Su Dongpo's Poems of Beifeng
- What about Shandong Yuncheng Jiuzhou Trailer Manufacturing Co., Ltd.?
- What does the fortune teller mean when he says that my future wife is not as good as me?
- Food fortune telling
- Fortune teller _ fortune teller
- What do the hearts, spades, diamonds, flowers, J, Q, K and A in poker stand for respectively?
- My son was born in Canada. Should the birthday be based on local time or Beijing time?
- Free couples fortune-telling pairing
- Fortune-telling needs to move _ Fortune-telling moves auspicious day