0

Java で単純な DCT アルゴリズムを作成しようとしています。私のfindDCTメソッドに、次のような整数配列をパラメータとして持たせたい:

public class DCT {
    private Random generator = new Random();
    private static final int N = 8;
    private int[][] f = new int[N][N];
    private double[] c = new double[N];

    public DCT() {
        this.initializeCoefficients();
    }

    private void initializeCoefficients() {
        int value;

        // temporary - generation of random numbers between 0 and 255 
        for (int x=0;x<8;x++) {
            for (int y=0;y<8;y++) {
              value = generator.nextInt(255);
              f[x][y] = value;
              System.out.println("Storing: "+value+" in: f["+x+"]["+y+"]");
            }
        }

        for (int i=1;i<N;i++) {
            c[i]=1/Math.sqrt(2.0);
            System.out.println("Storing: "+c[i]+" in: c["+i+"]");
        }
        c[0]=1;
    }

    public double[][] applyDCT() {
        double[][] F = new double[N][N];
        for (int u=0;u<N;u++) {
              for (int v=0;v<N;v++) {
                double somme = 0.0;
                for (int i=0;i<N;i++) {
                  for (int j=0;j<N;j++) {
                    somme+=Math.cos(((2*i+1)/(2.0*N))*u*Math.PI)*Math.cos(((2*j+1)/(2.0*N))*v*Math.PI)*f[i][j];
                  }
                }
                somme*=(c[u]*c[v])/4;
                F[u][v]=somme;
              }
            }
        return F;
    }
}

では、このメソッドを宣言し、f[][] をプライベート変数として宣言して現在のクラスのコンストラクターで初期化する代わりに、パラメーターとして 'int[][] f' を渡すにはどうすればよいでしょうか?

4

1 に答える 1

0

initializeCoefficientsを抽出してコンストラクタを変更するのはどうですか

public DCT() {
    this.initializeCoefficients();
}

public DCT(int[][] f) {
    this.f = f;
}

その後、次のようなクラスを使用できます

double[][] dctApplied = new DCT(yourTwoDimF).applyDCT();

また、私はNあなたのようには使いません。fDCT を適用するときは、それ自体の寸法を確認します。

つまり、私は変わります

    double[][] F = new double[N][N];
    for (int u=0;u<N;u++) {
          for (int v=0;v<N;v++) {
              // ...

のようなものに

    double[][] F = new double[f.length][];
    for (int u = 0; u < f.length; u++) {
          F[u] = new double[f[u].length];
          for (int v=0;v<N;v++) {
              // ...
于 2010-11-19T00:04:00.920 に答える