BRONZE
BRONZE 등급의 판매자 자료

chi- square 알고리즘

레가 확률과 정론 레폿으로 낸 소스와 discussion 그리고 결과 화면입니다.
8 페이지
한컴오피스
최초등록일 2005.06.18 최종저작일 2005.06
chi- square 알고리즘
  • 미리보기

    소개

    레가 확률과 정론 레폿으로 낸 소스와 discussion
    그리고 결과 화면입니다.

    컴파일 실행환경

    비쥬얼 C

    본문내용

    이번 프로그램은 컴퓨터 프로그램에 의해 랜덤 변수(random variable)를 발생시켰을때(50,250,500) 그 값이 적합한 값인지를 Chi-square테스트를 해 보는 것이었다. 그리고 이때 발생된 실험을 통해 누적된 분포(empirical cumulative distribution)와 발생된 누적 확률분포함수(cumulative distribution function)의 값을 비교하는 것이었다. 이번 Chi-square테스트를 하기 위해서 우선 exponential random sample을 각각 50개, 250개, 500개를 발생키켰을때, 이때 발생하는 exponential값을 가지고 내가 나누어준 구간(0.2)에 발생한 갯수를 가지고 실험에 임하게 된다. 이 개수는 Chi-square테스트를 하는데 사용되게 되는데 Chi-square계산 수식중 (실제적 측정치 - expect value) 부분에서 이 exponential값은 실제적 측정치(관측값)으로 들어가게 된다. 그리고 Chi-square값을 계산하기 위해서 필요한 값은 expected value(기대값)인데, 수식에서 expected value(Mk) = N*Bk를 이용하여 유도한다. 여기서 N은 컴퓨터 프로그램에 의해 발생된 랜덤 변수값 50,250,500을 의미하고, Bk값은 구간내에서 발생된 값으로서 그 값은 누적확률분포(cdf)의 특성을 이용하여 구한다. 구간에서의 발생하는 확률값은 P[a< X <=b] = Fx[b]-Fx[a]인 cdf의 특성을 이용하여 구하게 되는데, 만약 P[0.2<X<0.4]라고한다면 Fx[0.4]-Fx[0.2]값을 구하게 되고, 이때 Fx[0.4]=1-exp(-Ramda*0.4)이라는 cdf와 exponential의 성질을 이용하게 된다. 이렇게 구해진 Fx[0.4]까지의 분포함수에서 Fx[0.2]를 빼줌으로서 해서 0.2에서 0.4까지의 분포값을 구할 수 있었다. 하지만 이 부분에서 가장 처음(0)일때는 이전까지의 값이 없기 때문에 축적되지 않으므로 값을 할당해 주지 않았으며, 가장 끝(3.8)에서는 exponential의 그래프에서도 볼 수 있듯이 끝으로 갈수로 꼬리가 생기기 때문에 구간 3.8을 넘어서는 것까지도 생각해 주어야 했다. 이렇게 유도 된 expected value은 Chi-square테스트를 위해 사용된다.

    #include<stdio.h>
    #include<math.h>

    #define A 16807.0 // multiplier
    #define M 2147483647.0 // modulus
    #define Ramda 1
    static double r_seed = 1.0; // seed number

    double rnd(); // 난수 발생 함수
    double expo(double a); // exponential 함수

    void main()
    {
    int i, count, N; // N은 random number
    double j,value=0.0,sum=0.0,obser[20]={0,},cnt[1000]={0,}, // 배열선언과 초기화 부분
    cdf[20]={0,},ex_cdf[20]={0,},mk[20]={0,},bk[20]={0,},ex[20]={0,},chi[20]={0,};
    printf("N (50,250,500) = "); // random number입력받는 부분
    scanf("%d",&N);
    for (i=0; i<N; i++) {
    cnt[i] = expo(Ramda); // 발생된 exponential값을 배열에 집어넣음
    count = 0; // 해당 interval에 발생된 값을 카운터 하기 위한 변수
    for (j=0;<font color=aaaaff>..</font>

    참고자료

    · 없음
  • 자료후기

      Ai 리뷰
      지식판매자의 해당 자료는 과제를 작성하는 데 큰 도움이 되었고, 내용이 풍부하여 많은 정보를 얻을 수 있었습니다. 정말 추천할 만한 자료입니다.
    • 자주묻는질문의 답변을 확인해 주세요

      해피캠퍼스 FAQ 더보기

      꼭 알아주세요

      • 자료의 정보 및 내용의 진실성에 대하여 해피캠퍼스는 보증하지 않으며, 해당 정보 및 게시물 저작권과 기타 법적 책임은 자료 등록자에게 있습니다.
        자료 및 게시물 내용의 불법적 이용, 무단 전재∙배포는 금지되어 있습니다.
        저작권침해, 명예훼손 등 분쟁 요소 발견 시 고객센터의 저작권침해 신고센터를 이용해 주시기 바랍니다.
      • 해피캠퍼스는 구매자와 판매자 모두가 만족하는 서비스가 되도록 노력하고 있으며, 아래의 4가지 자료환불 조건을 꼭 확인해주시기 바랍니다.
        파일오류 중복자료 저작권 없음 설명과 실제 내용 불일치
        파일의 다운로드가 제대로 되지 않거나 파일형식에 맞는 프로그램으로 정상 작동하지 않는 경우 다른 자료와 70% 이상 내용이 일치하는 경우 (중복임을 확인할 수 있는 근거 필요함) 인터넷의 다른 사이트, 연구기관, 학교, 서적 등의 자료를 도용한 경우 자료의 설명과 실제 자료의 내용이 일치하지 않는 경우

    찾으시던 자료가 아닌가요?

    지금 보는 자료와 연관되어 있어요!
    왼쪽 화살표
    오른쪽 화살표
    문서 초안을 생성해주는 EasyAI
    안녕하세요. 해피캠퍼스의 방대한 자료 중에서 선별하여 당신만의 초안을 만들어주는 EasyAI 입니다.
    저는 아래와 같이 작업을 도와드립니다.
    - 주제만 입력하면 목차부터 본문내용까지 자동 생성해 드립니다.
    - 장문의 콘텐츠를 쉽고 빠르게 작성해 드립니다.
    - 스토어에서 무료 캐시를 계정별로 1회 발급 받을 수 있습니다. 지금 바로 체험해 보세요!
    이런 주제들을 입력해 보세요.
    - 유아에게 적합한 문학작품의 기준과 특성
    - 한국인의 가치관 중에서 정신적 가치관을 이루는 것들을 문화적 문법으로 정리하고, 현대한국사회에서 일어나는 사건과 사고를 비교하여 자신의 의견으로 기술하세요
    - 작별인사 독후감
    해캠 AI 챗봇과 대화하기
    챗봇으로 간편하게 상담해보세요.
    2025년 08월 06일 수요일
    AI 챗봇
    안녕하세요. 해피캠퍼스 AI 챗봇입니다. 무엇이 궁금하신가요?
    5:11 오후