수다닷컴

  • 해외여행
    • 괌
    • 태국
    • 유럽
    • 일본
    • 필리핀
    • 미국
    • 중국
    • 기타여행
    • 싱가폴
  • 건강
    • 다이어트
    • 당뇨
    • 헬스
    • 건강음식
    • 건강기타
  • 컴퓨터
    • 프로그램 개발일반
    • C언어
    • 비주얼베이직
  • 결혼생활
    • 출산/육아
    • 결혼준비
    • 엄마이야기방
  • 일상생활
    • 면접
    • 취업
    • 진로선택
  • 교육
    • 교육일반
    • 아이교육
    • 토익
    • 해외연수
    • 영어
  • 취미생활
    • 음악
    • 자전거
    • 수영
    • 바이크
    • 축구
  • 기타
    • 강아지
    • 제주도여행
    • 국내여행
    • 기타일상
    • 애플
    • 휴대폰관련
  • 프로그램 개발일반
  • C언어
  • 비주얼베이직

안녕하세요.프로그래밍초보자입니다.opencv질문을좀해도될까요??

DevilsTears

2023.04.01

// restart_1.cpp : Defines the entry point for the console application.
//
#include cv.h
#include cxcore.h
#include highgui.h
#include stdio.h

//Functions 함수
void doWork_A();
void doWork_B();
void on_qulity_level_A(int pos);
void on_qulity_level_B(int pos);
void on_min_distance_A(int pos);
void on_min_distance_B(int pos);
void CalibrateCamera(CvPoint3D32f* m_3DWorldPoint, CvPoint2D32f* m_ImgCoord, CvMat* m_ProjectionMatrix);
void LoadCoordinate(void);
//Groval valiables 전역변수
const int MAX_CORNERS = 500;
IplImage *imgA;
IplImage *imgB;
int ql=1; //Qulity level valiables
float fql=0.1f;
int md=5; //Min distance
double dmd=5;

CvPoint2D32f m_LeftFeatures[6], m_RightFeatures[6];
CvPoint3D32f _3DWorldPoint[6];
CvMat* m_ProMat = cvCreateMat(3,4,CV_32FC1);

//main() 메인
int main()
{
LoadCoordinate();
/*사진1*/
imgA= cvLoadImage(test1111.jpg, CV_LOAD_IMAGE_GRAYSCALE);
cvNamedWindow(Left Image);
//화면에출력
// doWork_A();
// cvWaitKey(0);
// cvReleaseImage(&imgA);
/*사진2*/
imgB= cvLoadImage(test2222.jpg, CV_LOAD_IMAGE_GRAYSCALE);
cvNamedWindow(Right Image);

//화면에출력
doWork_A();

doWork_B();
cvWaitKey(0);
cvReleaseImage(&imgB);
cvReleaseImage(&imgA);

return 0;
}

//fql, dmd 값에의해서cvGoodFreaturesToTrack함수를수행
// ...결과를화면에그림
void doWork_A()
{

//원본이미지복사
IplImage *img = cvCloneImage(imgA);

//cvGoodFeaturesToTrack을수행하기위해서변수값설정
//
int corner_count = MAX_CORNERS;
CvPoint2D32f* cornersA = new CvPoint2D32f[ MAX_CORNERS ];
//cvGoodFeaturesToTrack 함수를위한버퍼이미지생성
IplImage* eig_image = cvCreateImage( cvGetSize(img), IPL_DEPTH_32F, 1 );
IplImage* tmp_image = cvCreateImage( cvGetSize(img), IPL_DEPTH_32F, 1 );
//변수값화면에출력
printf(Qulity : %g, MinDist:%g\n, fql, dmd);
//함수수행
cvGoodFeaturesToTrack( img, eig_image, tmp_image,cornersA, &corner_count,0.08, 93);
//수행결과를그림에표시한다.
for(int i=0;icorner_count;i++)
{
CvPoint tmp[2];
tmp[0].x = cornersA[i].x-3;
tmp[0].y = cornersA[i].y-3;
tmp[1].x = cornersA[i].x+3;
tmp[1].y = cornersA[i].y+3;
// cvRectangle(img, tmp[0], tmp[1], cvScalarAll(0));
tmp[0].x = m_LeftFeatures[i].x;
tmp[0].y = m_LeftFeatures[i].y;
cvCircle(img, tmp[0], 5, cvScalarAll(0), 1);
}

CalibrateCamera(_3DWorldPoint, m_LeftFeatures, m_ProMat);

printf(%.3lf\t%.3lf\t%.3lf\t%.3lf\n, m_ProMat-data.fl[0], m_ProMat-data.fl[1], m_ProMat-data.fl[2], m_ProMat-data.fl[3] );
printf(%.3lf\t%.3lf\t%.3lf\t%.3lf\n, m_ProMat-data.fl[4], m_ProMat-data.fl[5], m_ProMat-data.fl[6], m_ProMat-data.fl[7] );
printf(%.3lf\t%.3lf\t%.3lf\t%.3lf\n, m_ProMat-data.fl[8], m_ProMat-data.fl[9], m_ProMat-data.fl[10], m_ProMat-data.fl[11] );

//윈도우창에출력
cvShowImage(Left Image, img);
}
void doWork_B()
{

//원본이미지복사
IplImage *img = cvCloneImage(imgB);

//cvGoodFeaturesToTrack을수행하기위해서변수값설정
int corner_count = MAX_CORNERS;
CvPoint2D32f* cornersA = new CvPoint2D32f[ MAX_CORNERS ];
//cvGoodFeaturesToTrack 함수를위한버퍼이미지생성
IplImage* eig_image = cvCreateImage( cvGetSize(img), IPL_DEPTH_32F, 1 );
IplImage* tmp_image = cvCreateImage( cvGetSize(img), IPL_DEPTH_32F, 1 );
//변수값화면에출력
printf(Qulity : %g, MinDist:%g\n, fql, dmd);
//함수수행
cvGoodFeaturesToTrack( img, eig_image, tmp_image,cornersA, &corner_count,0.06, 27);
//수행결과를그림에표시한다.
corner_count = 6;
for(int i=0;icorner_count;i++)
{
CvPoint tmp[2];
tmp[0].x = cornersA[i].x-3;
tmp[0].y = cornersA[i].y-3;
tmp[1].x = cornersA[i].x+3;
tmp[1].y = cornersA[i].y+3;
// cvRectangle(img, tmp[0], tmp[1], cvScalarAll(0));
tmp[0].x = m_RightFeatures[i].x;
tmp[0].y = m_RightFeatures[i].y;
cvCircle(img, tmp[0], 5, cvScalarAll(0), 1);
}
//윈도우창에출력
cvShowImage(Right Image, img);
}

void on_qulity_level_A(int pos)
{
//0이면에러나므로0.1로조정
if(pos == 0)
fql = 0.01;
else
fql = (float)pos/100;
//화면에출력
doWork_A();
}
void on_qulity_level_B(int pos)
{
//0이면에러나므로0.1로조정
if(pos == 0)
fql = 0.01;
else
fql = (float)pos/100;
//화면에출력
doWork_B();
}
//min_distance 이벤트핸들러
void on_min_distance_A(int pos)
{
//0일경우에러나므로0.1로조정
if(pos == 0)
dmd = 0.1;
else
dmd = pos;
//화면에출력
doWork_A();

}
void on_min_distance_B(int pos)
{
//0일경우에러나므로0.1로조정
if(pos == 0)
dmd = 0.1;
else
dmd = pos;
//화면에출력
doWork_B();

}
void CalibrateCamera(CvPoint3D32f* m_3DWorldPoint, CvPoint2D32f* m_ImgCoord, CvMat* m_ProjectionMatrix)
{
/*
CvMat* A = cvCreateMat(3,3,CV_32FC1);
CvMat* U = cvCreateMat(3,3,CV_32FC1);
CvMat* D = cvCreateMat(3,3,CV_32FC1);
CvMat* V = cvCreateMat(3,3,CV_32FC1);
cvSetZero(A);
cvmSet(A, 0, 0, 2.);
cvmSet(A, 0, 1, 0.);
cvmSet(A, 0, 2, -2.);
cvmSet(A, 1, 0, 0.);
cvmSet(A, 1, 1, 2.);
cvmSet(A, 1, 2, -2.);
cvmSet(A, 2, 0, -2.);
cvmSet(A, 2, 1, -2.);
cvmSet(A, 2, 2, 4.);

cvSVD(A, D, U, V, CV_SVD_U_T|CV_SVD_V_T); // A = U D V^T
*/
CvMat* A = cvCreateMat(12,12,CV_32FC1);
CvMat* U = cvCreateMat(12,12,CV_32FC1);
CvMat* D = cvCreateMat(12,12,CV_32FC1);
CvMat* V = cvCreateMat(12,12,CV_32FC1);
cvSetZero(A);
for(int i = 0; i 6; i++)
{
cvmSet(A, i, 0, m_3DWorldPoint[0].x);
cvmSet(A, i, 1, m_3DWorldPoint[0].y);
cvmSet(A, i, 2, m_3DWorldPoint[0].z);
cvmSet(A, i, 3, 1.);
cvmSet(A, i, 4, 0.);
cvmSet(A, i, 5, 0.);
cvmSet(A, i, 6, 0.);
cvmSet(A, i, 7, 0.);
cvmSet(A, i, 8, -m_ImgCoord[0].x* m_3DWorldPoint[0].x);
cvmSet(A, i, 9, -m_ImgCoord[0].x* m_3DWorldPoint[0].y);
cvmSet(A, i, 10, -m_ImgCoord[0].x* m_3DWorldPoint[0].z);
cbr / cvmSet(A, i, 11, -m_ImgCoord[0].x );
cvmSet(A, i+1, 0, 0.);
cvmSet(A, i+1, 1, 0.);
cvmSet(A, i+1, 2, 0.);
cvmSet(A, i+1, 3, 0.);
cvmSet(A, i+1, 4, m_3DWorldPoint[0].x);
cvmSet(A, i+1, 5, m_3DWorldPoint[0].y);
cvmSet(A, i+1, 6, m_3DWorldPoint[0].z);
cvmSet(A, i+1, 7, 1.);
cvmSet(A, i+1, 8, -m_ImgCoord[0].y* m_3DWorldPoint[0].x);
cvmSet(A, i+1, 9, -m_ImgCoord[0].y* m_3DWorldPoint[0].y);
cvmSet(A, i+1, 10, -m_ImgCoord[0].y* m_3DWorldPoint[0].z);
cvmSet(A, i+1, 11, -m_ImgCoord[0].y);
}
CvMat* AAT= cvCreateMat(12,12,CV_32FC1);
CvMat* AT= cvCreateMat(12,12,CV_32FC1);
cvTranspose(A, AT);
cvMatMul(A, AT, AAT);
cvSVD(AAT, D, U, V, CV_SVD_U_T|CV_SVD_V_T); // A = U D V^T
cvmSet( m_ProMat, 0, 0, cvmGet(V, 11, 0));
cvmSet( m_ProMat, 0, 1, cvmGet(V, 11, 1));
cvmSet( m_ProMat, 0, 2, cvmGet(V, 11, 2));
cvmSet( m_ProMat, 0, 3, cvmGet(V, 11, 3));
cvmSet( m_ProMat, 1, 0, cvmGet(V, 11, 4));
cvmSet( m_ProMat, 1, 1, cvmGet(V, 11, 5));
cvmSet( m_ProMat, 1, 2, cvmGet(V, 11, 6));
cvmSet( m_ProMat, 1, 3, cvmGet(V, 11, 7));
cvmSet( m_ProMat, 2, 0, cvmGet(V, 11, 8));
cvmSet( m_ProMat, 2, 1, cvmGet(V, 11, 9));
cvmSet( m_ProMat, 2, 2, cvmGet(V, 11, 10));
cvmSet( m_ProMat, 2, 3, cvmGet(V, 11, 11));
cvmSet( m_ProMat, 0, 0, 5.);
cvmSet( m_ProMat, 2, 3, 10.);
// m_ProMat = m_ProMat / cvmGet(m_ProMat, 2, 3);
// cvDiv(m_ProMat, cvmGet(m_ProMat, 2, 3), m_ProMat);
cvConvertScale(m_ProMat, m_ProjectionMatrix, 1./cvmGet(m_ProMat, 2, 3));
}
void LoadCoordinate(void)
{
_3DWorldPoint[0].x = 0.;
_3DWorldPoint[0].y = 0.;
_3DWorldPoint[0].z = 0.;
_3DWorldPoint[1].x = 150.;
_3DWorldPoint[1].y = 0.;
_3DWorldPoint[1].z = 0.;
_3DWorldPoint[2].x = 150.;
_3DWorldPoint[2].y = 230.;
_3DWorldPoint[2].z = 0.;
_3DWorldPoint[3].x = 150.;
_3DWorldPoint[3].y = 230.;
_3DWorldPoint[3].z = 60.;
_3DWorldPoint[4].x = 150.;
_3DWorldPoint[4].y = 0.;
_3DWorldPoint[4].z = 60.;
_3DWorldPoint[5].x = 0.;
_3DWorldPoint[5].y = 0.;
_3DWorldPoint[5].z = 60.;
m_LeftFeatures[0].x = 143.;
m_LeftFeatures[0].y = 312.;
m_LeftFeatures[1].x = 403.;
m_LeftFeatures[1].y = 430.;
m_LeftFeatures[2].x = 532.;
m_LeftFeatures[2].y = 269.;
m_LeftFeatures[3].x = 549.;
m_LeftFeatures[3].y = 165.;
m_LeftFeatures[4].x = 420.;
m_LeftFeatures[4].y = 287.;
m_LeftFeatures[5].x = 133.;
m_LeftFeatures[5].y = 191.;
m_RightFeatures[0].x = 128.;
m_RightFeatures[0].y = 233.;
m_RightFeatures[1].x = 275.;
m_RightFeatures[1].y = 366.;
m_RightFeatures[2].x = 546.;
m_RightFeatures[2].y = 252.;
m_RightFeatures[3].x = 567.;
m_RightFeatures[3].y = 136.;
m_RightFeatures[4].x = 282.;
m_RightFeatures[4].y = 214.;
m_RightFeatures[5].x = 114.;
m_RightFeatures[5].y = 112.;
}
안녕하세요~영상처리 입문자입니다.
제가 초보다 보니까 인터넷에 돌아다니는 소스를 이것 저것 조합해서 이미지(직육면체)의 각모서리를 잡고 투영행렬을 구하는
소스를 만들어 보았습니다. 그런데 한눈에도 보이듯이 소스가 매우 복잡합니다. 저는 원하는 것이 2장의 이미지를 불러와 임의로
(이미지상의 사각형의 각꼭지점의 좌표 x,y를 알고 실제 박스의 3차원 좌표를 알고 있을 때)좌표를 다 정해 놓고 투영 행렬을 구하려고 합니다. 위소스를 간단하게 정리좀 해주실분 없나요 ㅠㅠㅠ제가 아직 소스분석이 약한지라 너무 어렵네요. 또한그레이스케로 표현되는 것이 아니라 컬러이미지로 표현이 되게끔 가능하게끔도요.CV_LOAD_IMAGE_COLOR이걸로 소스를 바꾸면 에러가 자꾸 나게 되서요. 부탁드립니다.고수님들!

신청하기





COMMENT

댓글을 입력해주세요. 비속어와 욕설은 삼가해주세요.

번호 제 목 글쓴이 날짜
2699895 무한루프에 빠집니다.!! 해결좀부탁드려요 (10) 선아 2025-06-30
2699842 질문을 너무 많이 하네여.....죄송.... (2) 해님꽃 2025-06-29
2699816 오류 질문입니다.. (1) 해비치 2025-06-29
2699763 질문입니다 ! 꼭 좀 도와주세요ㅠㅠ (2) 미라 2025-06-28
2699555 c언어 다항식을 입력을 했는데 왜 출력이 안될까요? 피스케스 2025-06-27
2699528 C언어 포인터연산 질문입니다. (3) 안녕나야 2025-06-26
2699476 끌어올림;;달력 짜봤는데요 이 소스 줄일 수 있나요? - 스샷첨부 (2) 클라우드 2025-06-26
2699444 [좀 급함] system("explorer [주소] ") 문에 변수를 사용할 수 있나요? 알 2025-06-26
2699415 파일//read//와 배열 아란 2025-06-25
2699386 구조체 안에 일부분만 char 배열에 복사하려면 어떻게 해야하나요? (1) 미즈 2025-06-25
2699361 연결리스트 정렬하는 부분에 대해서 질문 드립니다 아이처럼 2025-06-25
2699304 [기초]아직 안주무시는분 계신가요..?포인터배열? 좀 도와주세요. 놀리기 2025-06-24
2699272 printf() 함수이용해서 프로그램 만들기 질문요! (5) 다가 2025-06-24
2699221 PUSH와 POP코드를 더 간단하게 어떻게 해야할까요? 파라미 2025-06-24
2699192 설치오류가 자꾸 나요 한번봐주세여~ (1) 소녀틳향기 2025-06-23
2699161 for loop안에 있는 if문 (9) Orange 2025-06-23
2699105 링크더리스트 이전 링크값 출력함수. 꼬꼬마 2025-06-23
2699078 정수를 한자리씩 배열에 담는 법은 어떻게 하나요.. (4) 귀염포텐 2025-06-22
2699024 C언어 공부하려는데 도와주세요!!! (2) 달님 2025-06-22
2698994 날짜 계산하는 C 코드 짜고 있는데 꽉 막혀서 질문드립니다.. (6) 별 2025-06-22
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

수다닷컴 | 여러분과 함께하는 수다토크 커뮤니티 수다닷컴에 오신것을 환영합니다.
사업자등록번호 : 117-07-92748 상호 : 진달래여행사 대표자 : 명현재 서울시 강서구 방화동 890번지 푸르지오 107동 306호
copyright 2011 게시글 삭제 및 기타 문의 : clairacademy@naver.com