在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;
}
我會很感激的瞭解,如果該方法是正確的,在現在看來,如果使用循環展開,還沒有使任何意義,儘管higly優化編譯器。
要確定它是否正確,您應該編寫一些單元測試。要確定它是否有意義,您應該對它進行基準測試。 –
JIT編譯器將爲您執行循環展開 - 如果您需要優化代碼的一部分,有更好的方法可以花費時間。讓JIT完成工作最好的辦法是編寫簡單而直接的代碼 - 就你的情況而言:一個簡單的for循環,其中1個增量就像你用於'n <7'的循環。 – assylias