다중if문으로 데이터치환을 하고 있습니다. 간소화 할 경우 어떤 방법이 있나요?
하람
질문 제목 : 질문 내용 : 안녕하세요. 프로그램 작성에 앞서 연산처리가 상당히 느린 경우때문에 이렇게 질문을 드리고자 합니다.
카메라와 인터페이스 중에 카메라의 데이터값을 받아 연산하고 있습니다.
카메라의 값이 가끔씩 튀는 현상이 종종있음으로 인해서 배열값(1024배열)을 비교하여 치환해주는 프로그램을 짜보았지만,
처리결과는 만족스러운 반면, 처리속도가 느립니다.
아래와 같이 프로그램에 일부분이며 이런 경우 조금 간략하게 줄일 수 있는 방법이 있을가요??
카메라 데이터의 경우, 255, 255 255 255, 0, 255 255 255 이 경우 0은 데이터가 튄것으로 판단하여 255로 치환해줍니다.
for (i = 0; i pixel; i++)
{
if ((camset.camera_buffer[i-1] == 255 && camset.camera_buffer[i-2] == 255) && (camset.camera_buffer[i+1] == 255 && camset.camera_buffer[i] == 0)) camset.camera_buffer[i] = 255;
else if ((camset.camera_buffer[i-1] == 0 && camset.camera_buffer[i-2] == 0) && (camset.camera_buffer[i+1] == 0 && camset.camera_buffer[i] == 255)) camset.camera_buffer[i] = 0;
if(((camset.camera_buffer[i-1] == 255 && camset.camera_buffer[i-2] == 255)) && (camset.camera_buffer[i] == 0 && camset.camera_buffer[i+1] == 0) && (camset.camera_buffer[i+2] == 255 && camset.camera_buffer[i+3] == 255))
{
camset.camera_buffer[i] = 255;
camset.camera_buffer[i+1] = 255;
}
else if(((camset.camera_buffer[i-1] == 0 && camset.camera_buffer[i-2] == 0)) && (camset.camera_buffer[i] == 255 && camset.camera_buffer[i+1] == 255) && (camset.camera_buffer[i+2] == 0 && camset.camera_buffer[i+3] == 0))
{
camset.camera_buffer[i] = 0;
camset.camera_buffer[i+1] = 0;
}
if(((camset.camera_buffer[i-1] == 255 && camset.camera_buffer[i-2] == 255)) && (camset.camera_buffer[i] == 0 && camset.camera_buffer[i+1] == 0) && (camset.camera_buffer[i+2] == 0 && camset.camera_buffer[i+3] == 255))
{
camset.camera_buffer[i] = 255;
camset.camera_buffer[i+1] = 255;
camset.camera_buffer[i+2] = 255;
}
else if(((camset.camera_buffer[i-1] == 0 && camset.camera_buffer[i-2] == 0)) && (camset.camera_buffer[i] == 255 && camset.camera_buffer[i+1] == 255) && (camset.camera_buffer[i+2] == 255 && camset.camera_buffer[i+3] == 0))
{
 sp; camset.camera_buffer[i] = 0;
camset.camera_buffer[i+1] = 0;
camset.camera_buffer[i+2] = 0;
}
-
아리솔
감사합니다
-
진솔
예를 들면...
if ((CamSet.Camera_Buffer[i-1] == 255 && CamSet.Camera_Buffer[i-2] == 255) && (CamSet.Camera_Buffer[i+1] == 255 && CamSet.Camera_Buffer[i] == 0)) CamSet.Camera_Buffer[i] = 255;
를 좀 정리해서...
unsigned char noisePattern[4] = {255, 255, 0, 255};
i -
나라우람
대충이라도 틀 좀 잡아주실 수 있나요? 함수를 봐도 잘 이해가 안가서요
-
날개
지금은 배열을 비교하기 위해서 값을 하나 하나 비교하는 형태인데,
memcmp를 하면, 조금 더 간략하게 짤 수가 있겠죠?
(memcmp로 한번에 6개를 비교하는 것이 아니라요.) -
놓아주세요
memcmp 의 경우 2개의 배열을 비교하는것인데 저의 경우는 한개의 배열을 가지고 최대 6개값까지 비교를 해야하는데 memcmp로 가능한가요?
-
한지잠
모든 픽셀을 다 하지 않고, 건너 건너 한다던가... (처리 결과의 퀄리티가 떨어지겠죠.)
요즘은 코어가 여러개인 시대니까, 멀티 프로세스로 처리한다거나...
복사 / 비교 할때 memcmp, memcpy를 활용하시면 소스를 좀 더 간략화 해서 짤 수 있지 않을까 싶네요. ^^;;;
(속도도 아주 약간 향상?)
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692210 | 정보 올림피아드 문제인데.. 풀이 과정이 궁금합니다.(재귀함수) (5) | 물티슈 | 2025-04-20 |
2692144 | C언어와 리눅스에 대한 질문입니다. | 싴흐한세여니 | 2025-04-20 |
2692114 | 컨텍스트 스위칭하는데 걸리는 시간 측정.. | YourWay | 2025-04-19 |
2692086 | 간접참조 연산자, 증감연산자 질문이용! (2) | 블랙캣 | 2025-04-19 |
2692056 | 주석좀 달아주세요. 몇개적엇는데 몇개만달아주세요. (2) | DevilsTears | 2025-04-19 |
2691978 | 진수 쉽게 이해하는법... (3) | 지지않는 | 2025-04-18 |
2691949 | getchar() 한 문자를 입력받는 함수 질문 | 채꽃 | 2025-04-18 |
2691919 | 배열 정렬 및 합치기 질문입니다. | 사과 | 2025-04-18 |
2691845 | c언어왕초보 질문이 있습니다........ | 루나 | 2025-04-17 |
2691815 | void add(int num); 함수... (4) | 살랑살랑 | 2025-04-17 |
2691756 | 명령 프롬프트 스크롤바가 없어요 | 두메꽃 | 2025-04-16 |
2691725 | 자료구조에 관련해서 질문이 있어 글을 올립니다. | 누리알찬 | 2025-04-16 |
2691697 | if 문에서 구조체 배열에 저장되있던 문자열 검사하는 법 ? (2) | 민트맛사탕 | 2025-04-16 |
2691678 | C언어 함수 질문이요~!!! | 연보라 | 2025-04-15 |
2691650 | 반복문 | 돋가이 | 2025-04-15 |
2691618 | 링크드리스트 개념 질문이예요 (3) | 맨마루 | 2025-04-15 |
2691592 | 동적할당 이용 배열선언 질문입니다.ㅠㅠ (3) | 허리달 | 2025-04-15 |
2691542 | /=의 용도를 알려주세요 ㅠㅠ! (2) | 아라 | 2025-04-14 |
2691510 | sizeof 연산자 질문입니다 (2) | 종달 | 2025-04-14 |
2691483 | 파일 오픈시 에러 질문드립니다. (2) | 호습다 | 2025-04-14 |