회원가입 ID/PW 찾기

1) 지식 창고는 본인이 작성한 콘텐츠(팁/노하우/리소스/강좌 등)을 무료 혹은 가상화폐인 납포인트를 통해 공유하는 공간입니다.
2) 본인이 작성한 콘텐츠에 대해서만 지식 창고에 등록할 수 있으며, 저작권에 위배되는 콘텐츠는 사전경고 없이 삭제될 수 있습니다.
3) 콘텐츠 구매 및 첨부파일 다운로드는 회원그룹 '연구원' 이상 가능하오니, 경험치를 쌓아 진급한 후에 이용 부탁드립니다.
4) 무료 콘텐츠의 본문은 구매절차 없이 즉시 이용할 수 있으며, 판매 납포인트가 있는 콘텐츠는 구매 후 이용할 수 있습니다.
5) 콘텐츠 판매에 따른 납포인트 수익은 지정한 비율(50%)에 따라 판매자에게 지급하며, 납포인트 수익을 통해 진급을 빨리할 수 있습니다.
6) 구매 후 평가를 하면 구매 납포인트의 20%를 돌려 드립니다.

콘텐츠 수 1,041
판매자 아크마 판매 납포인트 무료 평점 0점 / 총 0명 참여

///////////////////////////////////////////////////

//      GBezier Class

//

//      T : 계산에 쓰이는 타입 ( 사용자입장에서 고려할 필요가없다.)

//          D는 더블형을 쓴다 느리다. 그러나 값손실이 적다.

//          Fixed 는 빠르다.

//      F : 계산된 값이 들어가는 타입 (사용자가 고려할 타입 )

//

//    Usage : GTBezier<Type1, Type2> bez;

//

//            GBezierD bez;  // int형의 double형계산

//

//

///////////////////////////////////////////////////

 

#ifndef _GBezier_

#define _GBezier_

 

#define GBezierD    GTBezier<double,int>

#define GBezier     GTBezier<GFixed,int>

#define GDBezierD   GTBezier<double,double>

 

template < class T, class F>

class GTBezier{

    F m_nPoints[8];

    int m_nNpts;

    T BezierSplit( T mu, T x1, T x2 );

    T BezierValue( T mu, F* coor );

public:

    GTBezier();

    GTBezier( F pPoint[8] );

    GTBezier( const GTBezier& csBezier );

    ~GTBezier();

 

    void Calculate( F* x , F* y, int npts = -1 );

 

};

 

#endif

 

 

----------

 

#include "GTBezier.h"

 

template <class T, class F>

GTBezier<T,F>::GTBezier()

{

    m_nNpts = 0;

    m_nPoints[0]=m_nPoints[1]=m_nPoints[2]=m_nPoints[3]=\

    m_nPoints[4]=m_nPoints[5]=m_nPoints[6]=m_nPoints[7]=0;

}

 

template <class T, class F>

GTBezier<T,F>::GTBezier(  F pPoint[8] )

{

    m_nNpts = 10;

    for( int i = 0; i<8 ; i++)

    {

        m_nPoints[i] = pPoint[i];

    }

}

 

template <class T, class F>

GTBezier<T,F>::GTBezier( const GTBezier<T,F>& csBezier  )

{

    m_nNpts = csBezier.m_nNpts;

    for( int i = 0; i<8 ; i++)

    {

        m_nPoints[i] = F(csBezier.m_nPoints[i]);

    }

 

}

 

template <class T, class F>

GTBezier<T,F>::~GTBezier()

{

 

}

 

template <class T, class F>

T GTBezier<T,F>::BezierSplit( T mu, T x1, T x2 )

{

   return ( (T(1.0) - mu) *x1)+(mu*x2);

 

   //fmul((itofix(1.0)-mu), x1) + fmul(mu, x2);

}

 

template <class T, class F>

T GTBezier<T,F>::BezierValue( T mu, F *coor )

{

   T work[4];

   int i;

   int j;

 

   for (i=0; i<4; i++)

      work[i] = T(coor[i*2]);

      //itofix(coor[i*2]);

 

   for (j=0; j<3; j++)

      for (i=0; i<3-j; i++)

         work[i] = BezierSplit(mu, work[i], work[i+1]);

 

   return work[0];

}

 

 

template <class T, class F>

void GTBezier<T,F>::Calculate( F* x , F* y, int npts )

{

    if( npts <0 ) npts = m_nNpts;

    int i;

    T   denom;

 

    for (i=0; i < npts; i++)

    {

        denom = T(i) / T(npts-1);

        //fdiv(itofix(i), itofix(npts-1));

        x[i] = int( BezierValue( denom , m_nPoints ));

        //fixtoi(bezval(denom, points));

        y[i] = int( BezierValue( denom , m_nPoints + 1 ));

        //fixtoi(bezval(denom, points+1));

    }

}

 

-------------

#include <iostream.h>

#include "GTBezier.h"

#include "GTBezier.cpp"

 

int main()

{

    int pt[8] = { 0,0, 60, 5,  20,15 , 80,23 };

    GBezierD bez(pt);

 

    int ptx[10],pty[10];

    bez.Calculate ( ptx, pty, 20 );

 

    for ( int p = 0 ; p < 20 ; p ++)

    {

 

        cout << ptx[p] << " " << pty[p] << endl;

    }

}

 

모르는 것이 무엇인지 스스로 정리하고 질문하는 습관을 가집시다.
무성의/광범위하거나 직접 해보지 않고 올리는 질문은 서로를 피곤하게 합니다.
질문쪽지는 사절이오니 게시판에 글을 남겨주세요. 그래야 다같이 공유할 수 있으니까요.


profile
소이숭 2010.06.07 15:40
감사합니다 잘쓸게요 ㅎㅎ
profile
시나브로69 2016.04.02 12:49

좋은 자료 감사합니다.

search
List of Articles
번호 분류 제목 평점 포인트 판매자 등록일 구매수 조회 수
공지 공공의 목적으로 공유하고자 하는 소프트웨어는 '소프트웨어 자료실'에 업로드를 요청드립니다.
공지 구매후 평점 댓글을 남겨주시면 구매포인트의 20%를 돌려드립니다.
121 Software & IDEs 프린터포트를 이용한 PID모터 컨트롤 소스 [14] 무료 아크마 2007-04-13 0 1860
120 머신러닝, AI & 알고리즘 Cisco Internetworking Troubleshooting Handbook [3] 무료 아크마 2007-08-16 0 2128
119 머신러닝, AI & 알고리즘 카논맵에 대한 정리 [2] 무료 아크마 2007-06-06 0 2090
118 머신러닝, AI & 알고리즘 C++, 자료구조, 알고리즘등 복합자료 [11] 무료 화언 2007-05-29 0 2698
117 머신러닝, AI & 알고리즘 A* 알고리즘을 이용한 최단거리 검색 프로그램 [86] 무료 아크마 2007-05-20 0 5928
116 머신러닝, AI & 알고리즘 알고리즘 강좌 #8 [백 트래킹 #2] [4] 무료 뺘쑝 2007-04-22 0 2750
115 머신러닝, AI & 알고리즘 알고리즘 강좌 #7 [백 트래킹 #1] [8] 무료 뺘쑝 2007-04-22 0 3455
114 머신러닝, AI & 알고리즘 알고리즘 강좌 #6 [ 그리디 #2 ] [6] 무료 뺘쑝 2007-04-22 0 3325
113 머신러닝, AI & 알고리즘 알고리즘 강좌 #5 [그리디 #1] [3] 무료 뺘쑝 2007-04-22 0 2949
112 머신러닝, AI & 알고리즘 알고리즘 강좌 #4 [다이나믹 #3] [3] 무료 뺘쑝 2007-04-22 0 1746
111 머신러닝, AI & 알고리즘 알고리즘 강좌 #3 [ 다이나믹 #2 ] [5] 무료 뺘쑝 2007-04-22 0 1626
110 머신러닝, AI & 알고리즘 알고리즘 강좌 #2 [다이나믹 #1] [3] 무료 뺘쑝 2007-04-22 0 2032
109 머신러닝, AI & 알고리즘 알고리즘 강좌 #1 [ 알고리즘 개론 ] [10] 무료 뺘쑝 2007-04-22 0 1962
108 머신러닝, AI & 알고리즘 버블 정렬 알고리즘 [4] 무료 아크마 2007-04-11 0 1258
107 머신러닝, AI & 알고리즘 2진 검색 알고리즘 [2] 무료 아크마 2007-04-11 0 2487
106 머신러닝, AI & 알고리즘 이론상으로 가장 빠른 정렬 알고리즘 [3] 무료 아크마 2007-04-11 0 2280
105 머신러닝, AI & 알고리즘 최대값 검색 알고리즘 [3] 무료 아크마 2007-04-11 0 1969
104 머신러닝, AI & 알고리즘 최소값 검색 알고리즘 [3] 무료 아크마 2007-04-11 0 1850
103 머신러닝, AI & 알고리즘 기본 알고리즘 정리 [5] 무료 아크마 2007-04-11 0 2790
» 머신러닝, AI & 알고리즘 베이지 곡선 알고리즘 [2] 무료 아크마 2007-04-11 0 2347
  • 무거운 마음을 가지고 가벼운 시를 즐길 수 없다.
    - 베이커
  • * 납포인트 정보 *
  • 글 작성 : 3
  • 댓글 작성 : 1
저작권법에 위배되는 콘텐츠는 등록 불가하며, 저작물에 대한 권리는 저작자에게 있습니다.
Copyright 2006-2021 © hardwareis.com, All rights reserved.