배열의 모든 요소를 처리하는 데 문제가 있습니다. 두 개의 서로 다른 배열 (x[]
및 y[]
)을 가지고 있으며, 각 배열에는 40000 개의 요소가 있습니다. 저는 슬라이딩 윈도우를 사용하여 블록 들간의 상호 상관을 계산하기 위해 각각 5 개 요소를 스윕했습니다 (x[]
의 5 개 요소와 y[]
의 5 개 요소). 계산이 끝나면 두 번째 Window 및 배열 끝으로 계속 스윕됩니다. 상관 관계 결과를 가져 와서 새로운 배열에 저장할 수 있습니까? 입력 값은 gc_us_dist_data
및 gc_us_prox_data
이며 Correlation을 계산할 때 결과 배열을 수신하고 싶습니다. 모두의 도움을 받기를 바랍니다.처리 할 배열의 모든 요소를 다른 배열에 저장하십시오.
const int16_t gc_us_dist_data[SAMPLES] //4000 SAMPLES
const int16_t gc_us_prox_data[SAMPLES] //4000 SAMPLES
/* This function is real implementation of the sliding window algorithm */
int slide_window_01(int buffer1[], int N, int buffer_len){
int i = 0, j = 0, s;
int16_t dist[SAMPLES];
for(j=0 ; j + N < buffer_len; j++){
/* Window starts at index 0 and is of size N */
// printf("\nCurrent window :");
for(s =j; s<j+N; s++){
dist[SAMPLES] = buffer1[s];
}
}
}
int slide_window_02(int buffer2[], int N, int buffer_len){
int i = 0, j = 0, s;
int16_t prox[SAMPLES];
for(j=0 ; j + N < buffer_len; j++){
/* Window starts at index 0 and is of size N */
// printf("\nCurrent window :");
for(s =j; s<j+N; s++){
prox[SAMPLES] = buffer2[s];
}
}
}
/*------------- Cross Correlation between two signals -----------------------
---------------------------------------------------------------------------*/
// x = gc_us_dist_data, y = gc_us_prox_data
int correlation(int dist[], int prox[]){
int xy[SAMPLES], xsquare[SAMPLES], ysquare[SAMPLES];
int i, xsum, ysum, xysum, xsqr_sum, ysqr_sum;
float coeff[SAMPLES], num, deno;
xsum = ysum = xysum = xsqr_sum = ysqr_sum = 0;
/* find the needed data to manipulate correlation coeff */
for (i = 0; i < SAMPLES; i++)
{
xy[i] = dist[i] * prox[i];
xsquare[i] = dist[i] * dist[i];
ysquare[i] = prox[i] * prox[i];
xsum = xsum + dist[i];
ysum = ysum + prox[i];
xysum = xysum + xy[i];
xsqr_sum = xsqr_sum + xsquare[i];
ysqr_sum = ysqr_sum + ysquare[i];
}
num = 1.0 * ((SAMPLES * xysum) - (xsum * ysum));
deno = 1.0 * ((SAMPLES * xsqr_sum - xsum * xsum)* (SAMPLES * ysqr_sum - ysum * ysum));
/* calculate correlation coefficient */
for(int i=0; i < SAMPLES; i++)
{
coeff[i] = num/sqrt(deno);
}
}
int main(void)
{
int16_t buffer1[SAMPLES], dist[SAMPLES];
int16_t buffer2[SAMPLES], prox[SAMPLES];
memcpy(&buffer1, &gc_us_dist_data, sizeof buffer1); //copy all elements to buffer
memcpy(&buffer2, &gc_us_prox_data, sizeof buffer2); //copy all elements to buffer
const int N = 5;
int size1 = sizeof(buffer1)/ sizeof(buffer1[0]);
int size2 = sizeof(buffer2)/ sizeof(buffer2[0]);
slide_window_01(buffer1,N,size1);
slide_window_02(buffer2,N,size2);
correlation(dist, prox);
}
당신이 직면하는 어떤 문제? – Rohan
"코드가 작동하지 않습니다"라고 자세히 설명해 주실 수 있습니까? * 어떻게 작동하지 않습니까? 그것은 형성되지 않습니까? 그것은 추락합니까? 예기치 않은 결과가 있습니까? [좋은 질문을하는 법을 읽어보십시오] (http://stackoverflow.com/help/how-to-ask). –
Correlation() 함수의 결과를 얻을 수 없습니다. 각 블록 (x [] 및 y []) 슬라이딩 윈도우를 계산 한 후 상관 관계 결과를 수신하고 싶습니다. –