'In the world/컴퓨터'에 해당되는 글 19건

  1. 2009.06.09 MPI 2
  2. 2009.06.04 Fortran 교육 2
  3. 2009.06.01 Linux/Unix 교육
  4. 2009.05.22 fortran과 C언어로 소수 구하기

MPI

In the world/컴퓨터 2009. 6. 9. 10:46
MPI 관련 자료를 찾기 위해서 google, naver, daum 3가지 검색 사이트를 이용해 보았다.

1. google

대체로 내가 원하는 Message Passing Interface 에 대한 결과들이 나온다.

2. daum
뭔가 심상치 않다. MPI 가격 비교라..? 최상단에 쇼핑정보가 나온다. MPI 꽃무늬후드 -_-;;
쇼핑정보 다음에는 MPI엔진과 GDI엔진이라는 자동차관련 용어설명이 나온다. MPI가 자동차 관련 용어이기도 한지 처음 알았다. ;;

3. naver
역시나 최상단은 쇼핑정보가 나온다. 그래도 컴퓨터 관련 업체가 나오긴한다.. MPI 꽃무늬후드는 여기서도 볼수 있다 ^^;
역시나 지식IN에서는 MPI엔진이라는 자동차 용어가 주로 나온다. 쩝..

아무래도 우리나라 사람들은 IT쪽에는 관심이 별로 없는가 보다.

ps. nate에서는 다음과 같은 동문서답도 발견할수 있었다.


:

Fortran 교육

In the world/컴퓨터 2009. 6. 4. 01:27
포트란이라는 언어는 오래전 부터 들어는 봤지만, 직접 사용한 것은 고체물리를 전공하고 부터이다. 내가 아는 고체물리 이론 분야의 대부분의 계산 루틴은 포트란으로 되어있다. C언어가 세상에서 제일 편하다고 믿고 있던 나에게는 그야말로 문화적인 충격이었다. 그런데 어쩌다 보니 내가 포트란 언어 교육까지 하는 입장이 되고 말았다. 참 세상이란, 모를 일이 많다.

어쨌든, 요즘들어 점점 포트란의 매력에 빠져든다는 불길한(?) 느낌이 든다.

포트란의 장점

1. 참 쉽다. (다분히 포트란 프로그래머 입장이지만 어느 정도 단순하게 쓰기 편한 건 맞는 것 같다.)
2. 계산과학용 다양한 라이브러리가 많이 존재한다.
3. 복소수를 변수로 할수 있고 기본연산자를 이용한 연산도 가능하다.
4. 배열의 병렬 처리가 가능하다.
5. 배열의 부분 표현이 간편하다.
:

Linux/Unix 교육

In the world/컴퓨터 2009. 6. 1. 11:18
Linux/Unix 교육은 하루 짜리 교육이다. 하루에 뭘 얼마나 가르칠 수 있을까 하는 의문이 들었지만,
막상 하다보니 특별히 더 길다고 해서 많은 부분을 알게 해주기도 힘들다는 것을 느꼈다.

우선 오전에는 수강생 대부분이 익숙한 윈도우즈 시스템에서 Unix시스템으로 ssh를 이용하여 접속하는 방법을 소개하고, 접속한 시스템이 어떤 구조인가 설명하는 것 만으로도 시간이 다 지나간다.
음.. 시작이 반이라는 말을 실감할 수 있다.

오후에는 쉘 상에서 사용할 수 있는 각종 명령어들 설명하였는데, man page 가 얼마나 잘 정리되어 있는지 새삼 느낄 수 있는 시간이었다.
그리고 VI 에디터 사용법에 대하여 소개 정도만 하고, 몇 가지 실습을 하고 나의 첫 교육을 끝냈다.

cal 이라는 명령어는 터미널 상에서 달력을 보여준다.
이런 건 왜 만들어 놓았을까?
혹시.. 날짜 개념 마저 없어진 프로그래머 들을 위한 작은 배려가 아닐까..


:

fortran과 C언어로 소수 구하기

In the world/컴퓨터 2009. 5. 22. 17:25
소수 구하는 프로그램은 알려진 것이 많지만, 내 생각 구조가 일반적인 사람의 영역에 속한는 지 알아보기 위해 새로 만들어봤다.
먼저 fortran77로 구현해 보았다. 그 이유는 안타깝게도(?) fortran77이 나에게 가장 익숙한 언어이기 때문이다. 간단하게 제일 먼저 떠오른 생각은 소수의 정의이다. 어떤 자연수가 소수이기 위해서는 1과 자기 자신 이외로는 나누어 떨어지지 말아야 한다. 요넘을 그대로 적용해 보았다. 아주 단순 무식하게..

      PROGRAM PRIME_NUM

      IMPLICIT NONE

      INTEGER PRIME(20000),I,J,L,MAX_NUM
     LOGICAL N
     MAX_NUM=100000
     N=.TRUE.
     L=3
     PRIME(1)=1
     PRIME(2)=2
     PRINT*,PRIME(2)

      DO I=3,MAX_NUM,2
      DO J=2,L-1
       IF(MOD(I,PRIME(J)).EQ.0) N=.FALSE.
      ENDDO
      IF(N.EQ..TRUE.) THEN
       PRINT*,I
       PRIME(L)=I
       L=L+1
      ENDIF
      N=.TRUE.
     ENDDO

      END

100000까지의 자연수 중에 소수를 출력하는 코드이다. 1은 소수가 아니고 2는 소수라는 기본 정보를 넣고, 그 다음부터는 자신보다 작은 소수로 나누어 떨어지는지를 확인하고 소수면 출력하고 PRIME이란 배열에 넣어준다. PRIME이라는 배열은 다음 숫자의 소수여부를 판단할 때 사용한다.
얼핏보면 그럴 듯 하고, 맞는 결과를 출력하지만 예상대로 매우 느리다.

이쯤되면 생각의 전환이 필요하다. 숫자 하나하나 소수여부를 판단하는 방식을 버리자. 어렸을 때 배운 소수 찾아내는 방법이 생각 났다. 숫자를 쭉 적어놓고, 2의배수를 지운다. 그다음 3의 배수를 지운다. 이런 식으로 소수의 배수들을 지워나가면, 결국 소수들만 남을 것이다. 코드로 만들어 보자.

      PROGRAM PRIME_NUM

      IMPLICIT NONE

      INTEGER I,J,MAX_NUM
     LOGICAL PRIME(100000)

      MAX_NUM=100000
     DO I=1,MAX_NUM
      PRIME(I)=.TRUE.
     ENDDO

      DO I=2,MAX_NUM
      IF(PRIME(I).EQ..TRUE.) THEN
       J=2
       DO WHILE(I*J.LE.MAX_NUM)
        PRIME(I*J)=.FALSE.
        J=J+1
       ENDDO
      ENDIF
     ENDDO

      DO I=2,MAX_NUM
      IF(PRIME(I).EQ..TRUE.) PRINT*,I
     ENDDO

      END

첫 번째 것보다 코드가 복잡하지도 않으면서 속도는 많이 빨라졌다. time명령어로 알아보니까 첫 번째 코드는 수행시간이 4.723 초가 나오고, 두 번째 코드는 0.043 초가 나온다. 대략 100배 정도 빠르다. 첫 번째 코드가 얼마나 쓰레기인지 알수 있다. ~.~;

요 넘을 이제 C코드로 만들어 보자.

#include <stdio.h>

int main()
{

 int i,j,max_num;
int prime[100000];

 max_num=100000;
for(i=1;i<=max_num;i++){
  prime[i-1]=1;
}

 for(i=2;i<=max_num;i++){
  if(prime[i-1]==1){
  j=2;
  while(i*j<=max_num){
   prime[i*j-1]=0;
   j++;
  }
  }
}

 for(i=2;i<=max_num;i++){
  if(prime[i-1]==1) printf("%d\n",i);
}

 return 0;
}

컴파일 해서 수행해보니, 0.032 초가 나온다. 포트란 컴파일러(pgf77)보다는 C 컴파일러(pgcc)가 최적화 성능이 좋은가 보다. gnu 계열 컴파일러는 더 느리게 나온다. cpu는 AMD 바로셀로나 칩 이란다.

이제 궁금한 점이 생겼다. 첫 번째 코드는 배터지게 욕먹을 코드라는 것이 증명되었고, 그럼 두 번째 코드는 어느 정도 좋은 성능을 발휘하는 것일까. google 에서 소수 구하는 fortran 코드를 구해보았다. 잘 안 찾아진다. 내가 검색을 잘 못하나보다. 그래서 그럴 듯한 C 코드 하나 긁어와 봤다.
#include <stdio.h>
#include <math.h>

int isPrime(unsigned int number);


void main(void) {

          puts("2\n3");

            for (unsigned int i = 5; i < 100000; i += 2)
                       if (isPrime(i)) printf("%u\n", i);

}




int isPrime(unsigned int number) {
         if (number % 3 == 0) return 0;

            unsigned int y = 2;
             unsigned int x = (unsigned int) sqrt((double)number);

                for (unsigned int i = 5; i <= x; i += y, y = 6 - y)
                           if (number % i == 0) return 0;

                  return 1;
}

요 작은 코드에 함수까지 구현하고, 변수 타입도 상황에 맞게 양수로만 정의하는 등, 일단 내가 만든 것 보다는 표면적으로 뭔가 있어보인다. 같은 컴파일러로 컴파일하여 같은 조건에서 수행해 보았다.

수행시간 0.049 초 나온다. 아마도 함수 호출 때문에 지연 시간이 조금 있는 것 같다. 뭐 아무튼 내가 만든 것과 큰 차이를 보이지 않는다. 다행이다.
: