G.I.S Developer, 개발자 김형준(Dip2K)  
Front Page
Notice | Keyword | Tag | E-Mail | Guestbook | Admin | Write Article   
 
2010/02에 해당하는 글 6건
2010/02/28   ESRI의 SHP,DBF와 지오서비스의 XrV,XrT의 파일 크기 비교 (4)
2010/02/22   MySql 터미널 모니터 사용 정리 (6)
2010/02/19   구글로 받은 항공우편 AdSense 계정정보 (2)
2010/02/16   JavaDoc 주석 다는 방법, 기본적인 예 (6)
2010/02/16   [C#] C++의 multimap 컨테이너
2010/02/01   "OpenGL ES와 M3G를 이용한 모바일 3D 그래픽스" 정오표 (2)


2010/02/28 16:47 2010/02/28 16:47
ESRI의 SHP,DBF와 지오서비스의 XrV,XrT의 파일 크기 비교
파일 크기가 작다고해서 효율성이 뛰어나다는 것은 아닙니다. 지오서비스의 Xr 맵엔진이 사용하는 수치지도 포맷인 XrV와 속성데이터 포맷인 XrT는 네트워크 서비스에 최적화하기 위해 파일 크기를 최소화하였습니다. 물론 압축은 하지 않습니다. 압축에 대한 트레이드오프가 발생하는데.. 압축을 하면 크기가 줄어 네트워크 전송에 대한 속도를 단축할 수 있지만 압축을 하고 압축을 푸는 시간을 고려하면 이러한 시간 단축에 대한 이점이 상쇄되는지라 압축에 대한 선택은 파일 포맷에서 결정하지 않고 이 파일을 사용하는 클라이언트 어플리케이션의 책임으로 넘겼습니다. ESRI가 처음부터 SHP와 DBF는 네트워크 통신을 통한 서비스 기반으로 설계되지 않았으므로 이러한 크기 최적화가 거의 되어 있지 않습니다.

사용자 삽입 이미지

위의 그래프는 150MB의 DBF 파일과 100MB의 SHP 파일을 지오서비스의 지도 파일(XrV, XrT)로 변환하여 크기를 서로 비교한 것입니다. 벡터 데이터의 경우 절반정도로 줄었고 속성 데이터의 경우 1/5로 상당히 줄었음을 알 수 있습니다.

Xr 맵엔진의 서버를 개발하기에 앞서 서버의 퍼포먼스를 최대화 하기 위해 기반이 되는 데이터를 최적화하는 작업을 하면서 SHP와 DBF 간의 파일 크기면에서 살펴보았습니다.
Tag :
2010/02/22 23:55 2010/02/22 23:55
MySql 터미널 모니터 사용 정리
이 문서는 MySQL을 설치하면 제공되는 터미널 모니터의 사용법을 간단히 정리한 것입니다. 가장 먼저 서버에 연결하는 방법은 아래와 같습니다.

쉘에서 mysql 명령을 통해 인자 -h에는 호스트(여기서는 localhost를 지정했으며 로컬일때는 생략이 가능)를 제공하며 -u에는 사용자의 ID(여기서는 root)를 제공하고 마지막으로 -p 옵션을 주어 패스워드를 입력받을 수 있도록 합니다.

사용자 삽입 이미지

패스워드를 올바르게 입력하고 모든 것이 성공하면 위의 그림처럼 mysql>가 뜨고 명령을 입력할 수 있는 상태가 됩니다. 참고로 연결을 끊는 방법은 quit 명령을 내려 종료할 수 있습니다.

시험 삼아 다음 명령을 내려 MySQL의 기능을 테스트해 보도록 하겠습니다.

이 세 명령에 대한 결과는 아래와 같습니다.

사용자 삽입 이미지

참가로 명령어 입력 도중에 취소를 하고자 한다면 \c를 입력하고 엔터키를 누르면 됩니다. 정리하면 명령어는 대소문자를 구분하지 않으며 끝은 반드시 ; 으로 끝나야 합니다.

이제 다음은 데이터베이스를 생성하는 명령입니다.

지금까지 생성되어진 데이터베이스의 목록을 살펴보는 명령은 다음과 같습니다.

이 데이터베이스 중에 사용할 데이터베이스를 선택하는 명령은 다음과 같습니다.

아래는 위에서 새롭게 보인 세개의 명령을 순차적으로 내려 MySQL에서 처리된 결과 화면입니다.

사용자 삽입 이미지

데이터베이스에 대한 명령으로써 삭제에 대한 것은 아래와 같습니다.

이제 데이터베이스를 선택했고 이 선택한 데이터베이스 안에 테이블을 생성하는 명령은 아래와 같습니다.

테이블이 잘 생성되었는지 선택된 데이터베이스에 존재하는 테이블의 목록을 살펴보는 명령은 다음과 같습니다.

특정 테이블에 대한 테이블 스키마를 살펴보는 명령은 다음과 같습니다.

아래의 그림은 위의 세가지 명령을 순서대로 수행한 것에 대한 화면의 결과입니다.

사용자 삽입 이미지

참고로 테이블의 이름을 변경하는 명령은 다음과 같습니다.

그리고 필요하지 않은 테이블을 삭제하는 명령은 다음과 같습니다.

MySQL은 사용자가 작업하는 과정의 상태 정보를 제공하기 위해 status 명령을 제공합니다. 또한 명령 처리에 대해 오류나 경고가 발생할 경우 그 메세지를 다시 보기 위해 show errors와 show warnings 명령을 제공합니다.

이외에 데이터를 쿼리하고 레코드를 추가하고 변경하는 등의 SQL문에 대해 간단한 예를 통해 보이고 마무리 하겠습니다.

테이블로부터 지정한 필드들에 대한 값을 쿼리하는 명령

레코드를 추가하는 명령
조건에 맞는 레코드의 값을 변경하는 명령
레코드를 삭제하는 명령
Tag :
2010/02/19 11:57 2010/02/19 11:57
구글로 받은 항공우편 AdSense 계정정보
사용자 삽입 이미지

몇년전에 시작했던 구글의 에드센스를 다시 재개했습니다. 예전 계정을 이용해 3년만에 다시 시작을 하려니 무슨 PIN 번호를 입력하라고 하더군요. 입력을 하지 않으니 공익광고만 뜨구요. 해서 신청을 했더랬습니다.

한 10일 조금 넘으니 사무실에 도착해 있더군요. 퇴근길에 우편함에서 발견했는데.. 다시 곧장 사무실에 들려 PIN 입력했더랬습니다. 그런데 여전이 공익광고... -_-;

오늘 아침에 출근해 보니 공익광고가 더 이상 뜨지 않네요. 아.. 좋습니다. 요즘 여러가지로 제정부담을 줄일 목적으로 다시 시작한 구글 에드센스. 최소한 블로그 유지비는 나올지 않을까 싶습니다.

여하튼... 이렇게 미국으로부터 항국우편을 받으니.. 국가가의 경계가 부담스럽지 않다... 라는 생각이 듭니다. 가끔 와이프가 회사에서 외국 고객들에게 보낼 글귀를 영작해 달라고 압박을 넣습니다. 개발자가 열심히 코딩하고 있는데 갑작이 문서 작업 시킬때의 상황인거죠.. -_-a

영작을 잘하는 것은 아니지만, 뭐.. 의미만 통하면 되지 않겠냐라는 마음으로 작성해 보내줍니다. 사실... 인터넷상에서 도움을 받을 만한 수단은 총동원해서 최대한 문법에 맞게 작성해서 보내주려 노력합니다만... 수십차례 이렇게 와이프에게 도움을 줬음에도 별탈이 없이 계속 저에게 부탁을 하는거 보면.. 뭐.. 언어란 의미만 통하면 되는거다라는 제 관점이 크게 틀린 것만은 아닌 듯 싶습니다.
2010/02/16 22:16 2010/02/16 22:16
JavaDoc 주석 다는 방법, 기본적인 예

여전이 주석이라는 것에 대해 긍정적인 면보다는 부정적인 면이 더 많다고 생각하고 있지만.. 소스 코드와 주석을 통해 멋지게 문서를 자동으로 생성해 주는 개념은 주석에 대한 부정적인 많은 부분을 불식시키고도 남는듯합니다.

Java로 만든 어플리케이션(또는 서비스)의 소스를 협업자 또는 제3자에게 제공하기 위해 주석을 달때 JavaDoc의 도움을 받아 좀더 체계적으로 작업할 수 있도록 하기 위한 주석법입니다. 간단히 제 스스로 개발할때 참고하여 사용할만한 예제 코드로 정리해 봅니다.

먼저 클래스에 대한 주석의 예입니다.

다음은 클래스의 필드에 대한 주석의 예입니다.

끝으로 클래스의 매서드에 대한 주석의 예입니다.

Tag :
2010/02/16 22:15 2010/02/16 22:15
[C#] C++의 multimap 컨테이너

C++의 STL에 multimap이라는 컨테이너가 존재합니다. 이 컨테이너는 키(key)와 값(value)의 쌍으로 구성된 요소를 저장하고 있으며 key 값으로 정렬 되어 있습니다. 여기서 중요한 것은 이 키가 유일하지 않다는 점입니다. 즉 중복될 수 있다는 점인데요. 이러한 C++의 multimap의 성질을 갖는 컨터이너가 C#에는 기본적으로 존재하지 않습니다. 해서 이러한 컨터이너를 직접 개발자가 만들어 써야 하는데.. 다행히 C#에서 어렵지 않게 구현할 수 있습니다.

C#에서 제공하는 컨테이너(NET에서는 컬렉션(Collection)이라는 다른 이름을 사용) 중에 List와 SortedDictionary 컬렉션을 조합하여 우리가 원하는 C++의 multimap 컨테이너를 만들 수 있습니다. 아래는 이렇게 구현한 컬렉션으로 클래스 이름을 .NET의 이름에 맞게 MultiSortedDictionary라고 지었습니다.

MultiSortedDictionary 클래스의 코드가 그리 길지 않습니다. C#은 이미 매우 잘 만들어진 컬렉션 클래스를 가지고 있으므로 이들을 조합하여 쉽게 구현할 수 있었기 때문입니다. 이제 MultiSortedDictionary 클래스를 사용해 보겠습니다.

먼저 요소를 추가합니다. 요소의 키는 정수(int)이고 값(value)은 POINT라는 사용자 정의 구조체로 하겠습니다. 먼저 POINT 타입의 구조체는 아래와 같습니다.

이제 MuiltiSortedDictionary 클래스의 인스턴스를 생성하고 몇가지 요소를 추가하는 코드를 작성해 보면 아래와 같습니다.

실제로 키에 대해 정렬이 되어 있는지를 살펴보기 위해 임의로 요소를 추가할때 키의 순서를 정렬되지 않은 키값 순서로 추가하고 있습니다. 실제로 키 값이 정렬되어 있는지 파악하는 코드는 아래와 같습니다.

실행 결과는 아래와 같습니다.

사용자 삽입 이미지

결과를 보면 요소에 대한 키의 순서가 옳바르게 정렬되어 있다는 것을 알 수 있습니다. 염두할 점은 C++의 경우라면 그 결과가 10 10 10 20 20 30 이라는 점입니다.  이제 이렇게 저장된 요소 중에 키가 10인 요소에 대한 값을 얻는 코드를 살펴보면 아래와 같습니다.

실행 결과는 아래와 같습니다.

사용자 삽입 이미지

키가 10인 요소에 대한 값이 모두 3개인데, 생각했던 올바른 결과가 나온 것을 확인할 수 있습니다. C#에서 .NET을 살펴보면 볼수록 참으로 체계적이고 멋진 언어 그리고 프레임워크라고 생각됩니다.
 
Tag :
2010/02/01 14:12 2010/02/01 14:12
"OpenGL ES와 M3G를 이용한 모바일 3D 그래픽스" 정오표

이번에 출간된 OpenGL ES와 M3G를 이용한 모바일 3D 그래픽스에 대한 정오표입니다. 역자로써 좀 더 꼼꼼하게 챙기지 못한 점 사과드리고.. 이로 인해 당연히 불편하게 해 드린 독자분에게 이 자리를 빌어 다시 한번 사과드립니다... 향후에 이 블로그를 통해 지속적으로 모바일 3D 그래픽스에 대한 책의 오류 부분에 대한 내용을 추가해 나가도록 하겠습니다.

사용자 삽입 이미지

사용자 삽입 이미지

사용자 삽입 이미지

사용자 삽입 이미지

MS Word 2007로 작성된 파일을 다운로드 받으시면 되고.. 혹 프로그램이 없는 분은 이미지를 통해 살펴볼 수 있습니다. 이미지를 클릭하여 원래 크기로 보실 수 있습니다.

책을 읽다가 오타나 이상한 부분에 대해 질문이 있으면 저에게 메일로 전달해 주시기 바랍니다. 하면 그에 대해서 답변하도록 하겠습니다.
Tag :
BLOG main image
 Notice
듀라맵(DuraMap) 라이센스 정책
듀라맵 소개 및 다운로드
OpenGL Tutorials
운영자(Dip2K)에 대해
 Category
전체 (399)
GIS 개발 (86)
프로그래밍 (186)
스치는 생각들 (117)
번역 또는 집필 (3)
 TAGS
GIS OpenGL Xr Shader Algorithm Map Engine WPF ArcObjects ArcGIS C++
 Calendar
«   2010/02   »
  1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28            
 Recent Entries
[안드로이드] 사용자 정의...
[안드로이드] 타이머 기능
[Java] @Override 어노테...
안드로이드의 패스위의 텍...
안드로이드의 선언 태그에...
 Recent Comments
네, 일단 shp로 익스포팅...
김형준 - 09/01
혹시 변환된 좌표는 텍스...
박광호 - 09/01
아이폰4G가 현존하는 스마...
김형준(Dip2K) - 08/26
아이폰3Gs 는 320x480이고...
http://iyeti.kr/ - 08/26
안타깝지만... 이 프로그...
김형준 - 08/24
좋은자료 감사합니다....
박찬원 - 08/24
댓글, 감사합니다!
김형준(Dip2K) - 08/20
많은 도움이 됐습니다.
나쁜남자 - 08/20
저는 다음에 대한 요청 ur...
김형준 - 08/20
웹 트래픽을 추적하는 방...
강부자아들 - 08/20
 Archive
2010/09
2010/08
2010/07
2010/06
2010/05
2010/04
2010/03
2010/02
2010/01
2009/12
2009/11
2009/10
 Link Site
Adobe Flex 3 Help
Cartograph 2.0
GIS 위키디피아
GIS 프로그래밍 연구소
MapTools.org
OGC
OGRE3D
OSGeo 한국 지부
Wikipedia
국가수자원관리 정보시스템
국립지리원
국토연구원
국토해양부
네이버 과학
대한측량협회
류광님의 블로그
이민파님의 공간분석과 리...
 Visitor Statistics
Total : 675601
Today : 6
Yesterday : 461
태터툴즈 배너
rss