JAVA
私のプロジェクトでは、通常、巨大な配列をスカラーで乗算する必要があります。したがって、いわゆる を使用してメソッドを作成することを考えていましたloop unrolling
。これまでのところ、私はこれを思いつきました:
public static float[] arrayTimesScalar(float[] array, float scalar){
int n = array.length;
float[] result = new float[n];
int m = n % 7;
if(n == 0){ throw new Error("The input array must,at least, hold one element"); }
if (n < 7){
for(int i = 0; i < 7; i++){
result[i] = scalar*array[i];
} // end for
}
else{
if (m != 0){
for(int i = 0; i < m; i++){
result[i] = scalar*array[i];
}
for(int i = m; i < n; i += 7){
result[i] = scalar*array[i];
result[i + 1] = scalar*array[i + 1];
result[i + 2] = scalar*array[i + 2];
result[i + 3] = scalar*array[i + 3];
result[i + 4] = scalar*array[i + 4];
result[i + 5] = scalar*array[i + 5];
result[i + 6] = scalar*array[i + 6];
}
}
else{
for(int i = 0; i < n; i += 7){
result[i] = scalar*array[i];
result[i + 1] = scalar*array[i + 1];
result[i + 2] = scalar*array[i + 2];
result[i + 3] = scalar*array[i + 3];
result[i + 4] = scalar*array[i + 4];
result[i + 5] = scalar*array[i + 5];
result[i + 6] = scalar*array[i + 6];
}
}
}
return result;
}
高度に最適化されたコンパイラではありますが、現在表示されているメソッドが正しいかどうか、およびループ展開を使用してまだ意味があるかどうかを理解していただければ幸いです。