File: Matrix2D.cs

package info (click to toggle)
cadencii 3.3.9%2Bsvn20110818.r1732-6
  • links: PTS
  • area: main
  • in suites: buster
  • size: 35,916 kB
  • sloc: cs: 160,836; java: 42,449; cpp: 7,605; ansic: 1,728; perl: 1,087; makefile: 236; php: 142; xml: 117; sh: 21
file content (104 lines) | stat: -rw-r--r-- 3,351 bytes parent folder | download | duplicates (5)
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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
/*
 * Matrix2D.cs
 * Copyright © 2010-2011 kbinani
 *
 * This file is part of org.kbinani.cadencii.
 *
 * org.kbinani.cadencii is free software; you can redistribute it and/or
 * modify it under the terms of the GPLv3 License.
 *
 * org.kbinani.cadencii is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 */
#if JAVA
package org.kbinani.cadencii;

import java.util.*;
import org.kbinani.media.*;
#else
using org.kbinani.java.util;
using org.kbinani.media;

namespace org.kbinani.cadencii {
    using boolean = System.Boolean;
#endif

    /// <summary>
    /// 2次元の配列を格納します。XMLシリアライズ用
    /// </summary>
    /// <typeparam name="T"></typeparam>
    public class Matrix2D<T> {
        public Vector<T> Data;
        public int Rows;
        public int Columns;

        public Matrix2D() {
            this.Rows = 0;
            this.Columns = 0;
            this.Data = newArray( 0 );
        }

        public Matrix2D( int rows, int columns ) {
            this.Rows = rows;
            this.Columns = columns;
            this.Data = newArray( rows * columns );
        }

        public void addRow() {
            Vector<Vector<T>> buffer = new Vector<Vector<T>>();

            for ( int i = 0; i < this.Rows; i++ ) {
                buffer.add( newArray( this.Columns ) );
                for ( int j = 0; j < this.Columns; j++ ) {
                    buffer.get( i ).set( j, this.get( i, j ) );
                }
            }
            this.Data = newArray( (this.Rows + 1) * this.Columns );
            for ( int i = 0; i < this.Rows; i++ ) {
                for ( int j = 0; j < this.Columns; j++ ) {
                    int indx = i * this.Columns + j;
                    this.Data.set( indx, buffer.get( i ).get( j ) );
                }
            }
            this.Rows++;
        }

        public void addColumn() {
            Vector<Vector<T>> buffer = new Vector<Vector<T>>();
            for ( int i = 0; i < this.Rows; i++ ) {
                buffer.add( newArray( this.Columns ) );
                for ( int j = 0; j < this.Columns; j++ ) {
                    buffer.get( i ).set( j, this.get( i, j ) );
                }
            }
            this.Data = newArray( this.Rows * (this.Columns + 1) );
            for ( int i = 0; i < this.Rows; i++ ) {
                for ( int j = 0; j < this.Columns; j++ ) {
                    int indx = i * this.Columns + j;
                    this.Data.set( indx, buffer.get( i ).get( j ) );
                }
            }
            this.Columns++;
        }

        private Vector<T> newArray( int size ) {
            Vector<T> ret = new Vector<T>();
            ret.setSize( size );
            return ret;
        }

        public T get( int row_index, int column_index ) {
            int indx = row_index * this.Columns + column_index;
            return this.Data.get( indx );
        }

        public void set( int row_index, int column_index, T value ) {
            int indx = row_index * this.Columns + column_index;
            this.Data.set( indx, value );
        }
    }

#if !JAVA
}
#endif