Форум программистов, компьютерный форум, киберфорум
Наши страницы
Konst2016
Войти
Регистрация
Восстановить пароль
Оценить эту запись

Матричное умножение(матричный продукт) на Java

Запись от Konst2016 размещена 01.06.2019 в 11:43

Здравствуйте!Собираюсь показать матричное умножение на Java.Это специальное умножение, частный случай которого используется в нейросетях.Это когда каждый элемент строки первой матрицы умножается на каждый элемент столбца второй матрицы и
там также присутсвует сумма,и вот такая сумма записывается в элемент строки результирующей матрицы.
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
//MatrixASNN.java
package matrixasnn;
 
public class MatrixAsNN
{
    public static void multipleMatrix(float first[][],float second[][]) throws Exception
    {
       
        
        if(first[0].length!=second.length)
        throw new ShapesNotFitException("Shapes of matrices doesn not fit");
    int  result_height=first.length;
        int  result_width=second[0].length;
        int  second_height=second.length;
 
        float result[][]=new float[result_height][result_width];
 
 
        for(int N=0;N<result_height;N++)
        { 
        float res=0.0f;
        for(int M=0;M<result_width;M++)
                {
            for(int K=0;K<second_height;K++)
            {
            result[N][M]+=first[N][K]*second[K][M];
           
                        }
 
             }
 
             }
        for(int N=0;N<result_height;N++)
        {
        for(int M=0;M<result_width;M++)
            {
            System.out.print(result[N][M]+" ");
            }
        System.out.println();
        }
    
    }
 
    /**
     * @param args the command line arguments
     */
    public static void main(String[] args) throws Exception
    {
        // TODO code application logic here
 
    float   l[][]={
        {2.4f , 3.4f , 5.8f},
            {2.2f , 1.0f  ,3.0f}
    };
 
    float    m[][]={
        {5.0f},
            {6.0f},
            {0.0f}
    };
    multipleMatrix(l,m);
    }
 }
//ShapesNotFitException.java

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
package matrixasnn;
 
 
public class ShapesNotFitException extends Exception {
 
    /**
     * Creates a new instance of <code>ShapesNotFitException</code> without
     * detail message.
     */
    public ShapesNotFitException() {
    }
 
    /**
     * Constructs an instance of <code>ShapesNotFitException</code> with the
     * specified detail message.
     *
     * @param msg the detail message.
     */
    public ShapesNotFitException(String msg) {
        super(msg);
    }
}
Размещено в Без категории
Просмотров 114 Комментарии 0
Всего комментариев 0
Комментарии
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.
Рейтинг@Mail.ru