모바일 오유 바로가기
http://m.todayhumor.co.kr
분류 게시판
베스트
  • 베스트오브베스트
  • 베스트
  • 오늘의베스트
  • 유머
  • 유머자료
  • 유머글
  • 이야기
  • 자유
  • 고민
  • 연애
  • 결혼생활
  • 좋은글
  • 자랑
  • 공포
  • 멘붕
  • 사이다
  • 군대
  • 밀리터리
  • 미스터리
  • 술한잔
  • 오늘있잖아요
  • 투표인증
  • 새해
  • 이슈
  • 시사
  • 시사아카이브
  • 사회면
  • 사건사고
  • 생활
  • 패션
  • 패션착샷
  • 아동패션착샷
  • 뷰티
  • 인테리어
  • DIY
  • 요리
  • 커피&차
  • 육아
  • 법률
  • 동물
  • 지식
  • 취업정보
  • 식물
  • 다이어트
  • 의료
  • 영어
  • 맛집
  • 추천사이트
  • 해외직구
  • 취미
  • 사진
  • 사진강좌
  • 카메라
  • 만화
  • 애니메이션
  • 포니
  • 자전거
  • 자동차
  • 여행
  • 바이크
  • 민물낚시
  • 바다낚시
  • 장난감
  • 그림판
  • 학술
  • 경제
  • 역사
  • 예술
  • 과학
  • 철학
  • 심리학
  • 방송연예
  • 연예
  • 음악
  • 음악찾기
  • 악기
  • 음향기기
  • 영화
  • 다큐멘터리
  • 국내드라마
  • 해외드라마
  • 예능
  • 팟케스트
  • 방송프로그램
  • 무한도전
  • 더지니어스
  • 개그콘서트
  • 런닝맨
  • 나가수
  • 디지털
  • 컴퓨터
  • 프로그래머
  • IT
  • 안티바이러스
  • 애플
  • 안드로이드
  • 스마트폰
  • 윈도우폰
  • 심비안
  • 스포츠
  • 스포츠
  • 축구
  • 야구
  • 농구
  • 바둑
  • 야구팀
  • 삼성
  • 두산
  • NC
  • 넥센
  • 한화
  • SK
  • 기아
  • 롯데
  • LG
  • KT
  • 메이저리그
  • 일본프로야구리그
  • 게임1
  • 플래시게임
  • 게임토론방
  • 엑스박스
  • 플레이스테이션
  • 닌텐도
  • 모바일게임
  • 게임2
  • 던전앤파이터
  • 마비노기
  • 마비노기영웅전
  • 하스스톤
  • 히어로즈오브더스톰
  • gta5
  • 디아블로
  • 디아블로2
  • 피파온라인2
  • 피파온라인3
  • 워크래프트
  • 월드오브워크래프트
  • 밀리언아서
  • 월드오브탱크
  • 블레이드앤소울
  • 검은사막
  • 스타크래프트
  • 스타크래프트2
  • 베틀필드3
  • 마인크래프트
  • 데이즈
  • 문명
  • 서든어택
  • 테라
  • 아이온
  • 심시티5
  • 프리스타일풋볼
  • 스페셜포스
  • 사이퍼즈
  • 도타2
  • 메이플스토리1
  • 메이플스토리2
  • 오버워치
  • 오버워치그룹모집
  • 포켓몬고
  • 파이널판타지14
  • 배틀그라운드
  • 기타
  • 종교
  • 단어장
  • 자료창고
  • 운영
  • 공지사항
  • 오유운영
  • 게시판신청
  • 보류
  • 임시게시판
  • 메르스
  • 세월호
  • 원전사고
  • 2016리오올림픽
  • 2018평창올림픽
  • 코로나19
  • 2020도쿄올림픽
  • 게시판찾기
  • 게시물ID : programmer_21825
    작성자 : 한양공대
    추천 : 0
    조회수 : 545
    IP : 118.221.***.30
    댓글 : 3개
    등록시간 : 2017/12/05 22:39:31
    http://todayhumor.com/?programmer_21825 모바일
    코드 해석좀 부탁드립니다 실행창첨부(실행창보고)
    옵션
    • 본인삭제금지
    • 외부펌금지
    #include<iostream>
    #include<fstream>
    #include<cstdlib>


    using namespace std;

    int lru[500][20];

    //Function to change the tag order in the lru algo
    int bringtotop(int set, int assoc, int x)
    {
        int i,pos;
        for(i=0;i<assoc;i++)
            if(lru[set][i] == x)
                pos = i;
        for(i=pos;i<assoc-1;i++)
            lru[set][i] = lru[set][i+1];
        lru[set][assoc-1] = x;


    }

    void plot(int total, int hit, int miss);

    long int changebase(char hex[], int base);


    int convert(char);

    int main()
    {
     int cache_size, asso, block_size,i,j, no_blocks, base,r,alg, x,pos;
     long int address;
     float hitrate;
     char hex[20], filename[20];
     int no_set;
     int check=0, hit=0, miss=0;



     cout<<"Enter the cache_size : ";
     cin>>cache_size;
     cout<<"Enter the associativity : ";
     cin>>asso;
     cout<<"Enter the block size : ";
     cin>>block_size;
     cout<<"Enter trace filename : ";
     cin>>filename;
     cout<<"Enter the base of number in trace file : ";
     cin>>base;
     cout<<"1. FIFO  2.LRU  3. Random...Enter Your Choice : ";
     cin>>alg;

     no_blocks = cache_size / block_size;
     no_set = cache_size / (asso * block_size);

     int cache[no_set][asso];

     for(i=0;i<no_set;i++)
      for(j=0;j<asso;j++)
       cache[i][j] = -10; // Eliminating all garbage values in in the cache...


     int fifo[no_set];
     for(i=0;i<no_set;i++)
      fifo[i] = 0;

        for(i=0;i<no_set;i++)
            for(j=0;j<asso;j++)
                lru[i][j] = j;

     ifstream infile;
     infile.open(filename,ios::in);
     if(!infile)
     {
         cout<<"Error! File not found...";
         exit(0);

     }
     int set, tag, found;
     while(!infile.eof()) //Reading each address from trace file
     {

            if(base!=10)
            {
                infile>>hex;
                address = changebase(hex, base);
            }
            else
                infile>>address;

      set = (address / block_size) % no_set;
      tag = address / (block_size * no_set);


      check++;
      found = 0;
      for(i=0;i<asso;i++)
       if(cache[set][i] == tag)
        {
            found = 1;
            pos = i;
        }


      if(found)
      {
          hit++;
          if(alg == 2)
          {
                    bringtotop(set,asso,pos);
          }
      }

      else
      {
                if(alg==1)
                {
                 i = fifo[set];

       cache[set][i] = tag;
       fifo[set]++;

       if(fifo[set] == asso)
        fifo[set] = 0;

                }
                else if(alg==2)
                {
                    i = lru[set][0];
                    cache[set][i] = tag;
                    bringtotop(set,asso,i);

                }
                else
                {
                    r = rand() % asso;
                    cache[set][r] = tag;

                }

      }



     }
     infile.close();
     system("clear");
     cout<<"No: of checks : "<<check;
     cout<<" No: of hits : "<<hit;
     cout<<" No of misses : "<<check-hit;
     hitrate = float(hit)/float(check);
     cout<<" Hit Rate : "<<hitrate;
        plot(check,hit, check-hit);
     return 0;

    }







    int convert(char c)
    {
        if(c == '1')
            return 1;

        else if(c == '2')
            return 2;

        else if(c == '3')
            return 3;

        else if(c == '4')
            return 4;

        else if(c =='5')
            return 5;

        else if(c == '6')
            return 6;

        else if(c == '7')
            return 7;

        else if(c == '8')
            return 8;

        else if(c == '9')
            return 9;

        else if(c == '0')
            return 0;

        else if( (c == 'a') || (c == 'A') )
            return 10;

        else if( (c == 'b') || (c == 'B') )
            return 11;

        else if( (c == 'c') || (c == 'C') )
            return 12;

        else if( (c == 'd') || (c == 'D') )
            return 13;

        else if( (c == 'e') || (c == 'E') )
            return 14;

        else if( (c == 'f') || (c == 'F') )
            return 15;

        else
            return 0;

    }

    //Function to change the base of a number system to decimal
    long int changebase(char hex[], int base)
    {
        int pow = 1,len,i,j;
        char temp;
        long int dec;

        for(len=0;hex[len]!='\0';len++);

        for(i=0,j=(len-1);i<j;i++,j--)
        {
            temp = hex[i];
            hex[i]=hex[j];
            hex[j]=temp;
        }


        pow = 1;
        dec = 0;
        for(i=0;i<len;i++)
        {
            if(convert(hex[i]== -1))
            {
                dec =0;
                break;
            }
            dec = dec + (pow * convert(hex[i]));
            pow*=base;

        }
        return dec;

    }


    //Function to plot a graph...
    void plot(int total, int hit, int miss)
    {

        cout<<"\n\n     ************Graph**********\n\n";

        int hit_limit,miss_limit, i;
        hit_limit = (float (hit)/total)*30;
        miss_limit = (float(miss)/total)*30;



        cout<<"\n\t^";
        cout<<"\n\t|\n";
        for(i=30;i>=0;i--)
        {
            cout<<"\t";
            cout<<"|";
            cout<<"\t\t";

            //Total hit bar
            cout<<"|";
            if(i==30)
                cout<<"----";
            else
                cout<<"    ";
            cout<<"|";

            cout<<"\t\t";
            //Hit Bar...
            if(i<=hit_limit)
                cout<<"|";
            else
                cout<<" ";

            if(i==hit_limit)
                cout<<"----";
            else
                cout<<"    ";

            if(i<=hit_limit)
                cout<<"|";
            else
                cout<<" ";



             cout<<"\t\t";
            //Miss Bar...
            if(i<=miss_limit)
                cout<<"|";
            else
                cout<<" ";

            if(i==miss_limit)
                cout<<"----";
            else
                cout<<"    ";

            if(i<=miss_limit)
                cout<<"|";
            else
                cout<<" ";

            cout<<"\n";

        }
        cout<<"\t------------------------------------------------------------------------------>";
        cout<<"\n\t\t\tTotal\t\t Hits\t\tMiss\n";



    }
    KakaoTalk_20171205_223041749.png

    한양공대의 꼬릿말입니다
    enter trace filename 과 
    enter the base of number in trace file 에 입력을 뭐라고 쳐야하는지 모르겠습니다 

    이 게시물을 추천한 분들의 목록입니다.
    푸르딩딩:추천수 3이상 댓글은 배경색이 바뀝니다.
    (단,비공감수가 추천수의 1/3 초과시 해당없음)
    탐켄치(2017-12-06 02:11:40)172.69.***.64추천 0
    C++를 이렇게 C 처럼 쓰면서
    자기는 C와 C++ 둘다 쓴다고 하는 사람들이 없어져야 하는데...
    댓글 1개 ▲
    푸아(2017-12-06 20:05:33)121.137.***.169추천 0
    반성해봅니다 ㅠㅠ
    또란또란(2017-12-09 13:53:00)220.77.***.244추천 0
    trace filename에서는 특정 파일 경로 및 파일이름이 들어 갈것으로 판단되고,
    예를들면 c:test.txt or , ./test.txt (절대경로가 들어간 파일명 또는 상대경로로 들어간 파일명)
    enter the base of number in trace file은 아래 코드를 보시면 읽어온 파일을 끝까지 읽을 동안 입력된 base라는 값이 10이 아닐 경우에 특정 연산 처리를 한다는 것을 알수 있습니다.
    while(!infile.eof()) //Reading each address from trace file
    {
    if(base!=10)
    {
    infile>>hex;
    address = changebase(hex, base);
    }

    직관적으로 볼때 입력된 값에 따라 파일을 읽어서 1. FIFO  2.LRU  3. Random 변환해주는 어떠한 로직이라 할 수 있습니다.
    위에 코드는 너무 자기 중심적으로 짜서 세세하게 분석해서 알려드리기는 쉽지는 않겠내요.
    가령 어지럽게 물건들이 배치되어 있는 방에서 작은 열쇠를 하나 찾아 주라는 것과 비슷 하다고 할까요?
    할수는 있는데 시간도 그렇고 환경도 문제가 있고요.
    그리고 위에 분이 말씀 하셨지만, 위의 코드는 C++로 구현했지만 내용을 보면 C언어 형태로 구성되어 있다고 보입니다.
    (물론 C언어로 이문제를 구현을 할시에도 위에 코드 방식대로 main과 기능을 합쳐서 구현하지는 않습니다)
    객체지향적인 언어로 프로그램을 구성할때, Class의 결합과, Class별의 상관관계 (종속성)을 고려하여야 합니다.
    즉 위에 코드는 fifo, lru형태로 컨버터 해주는 특정 클래스가 있고 main에서는 어떠한 값을 파일에서 읽어들여 해당 클래스에
    요청 하여 결과값을 받는 형식으로 만들어야지 효율적이라고 생각 합니다.
    스스로 한번 천천히 분석해서 구현해 보시는것을 추천드립니다.
    댓글 0개 ▲

    죄송합니다. 댓글 작성은 회원만 가능합니다.

    번호 제 목 이름 날짜 조회 추천
    23467
    로또 까망사투리 25/05/07 11:18 464 0
    23466
    IT 개발자를 희망하는 취준생에게 공유하는 국비지원 교육 수강 후기 [1] 발토랑 25/04/15 22:52 797 0
    23465
    카페 주문 pos 만들기 html javascript 까망사투리 25/04/09 15:34 731 2
    23464
    진짜 벼랑끝에 몰려서 물어보는 질문 [6] 아젬라 25/03/13 16:33 1418 2
    23463
    로또 [1] 까망사투리 25/03/03 14:18 1290 0
    23462
    2월 8일 오후 8시 진행- 맛보기 강좌: 5시간 만에 웹 만들기 [1] quickturn 25/02/19 14:44 1196 0
    23461
    로또 [2] 까망사투리 25/02/12 13:13 1416 2
    23459
    C++ 입문전 초보자입니다. Qt / wxWidgets / FLTK 어떤 [6] OMG! 24/12/07 00:28 1667 0
    23458
    [KOCCA] 2024 게임콘텐츠 제작지원 이용자평가 체험단모집 장파랑 24/11/26 16:56 1524 0
    23457
    [한국콘텐츠진흥원] 2024 게임콘텐츠 제작지원 이용자평가 이용자 모집 장파랑 24/11/18 14:02 1586 0
    23456
    [한국콘텐츠진흥원] 2024 게임콘텐츠 제작지원 이용자평가 이용자 모집 장파랑 24/10/28 18:24 1930 0
    23455
    논문 읽는 사람들을 위한 문서 번역 서비스 rWhale 24/10/10 13:06 2286 2
    23453
    로또번호 [2] 까망사투리 24/09/19 11:10 2991 2
    23452
    AI와 함께가는 코딩 업계 [2] 펌글 우가가 24/09/02 22:19 3214 9
    23451
    Switch문 도배된 2100줄 짜리 함수 [4] 펌글 우가가 24/08/26 22:37 3067 4
    23450
    개인정보 수집 없는 이미지 리사이즈 사라밍 24/08/23 20:31 2393 0
    23449
    디자인 패턴의 템플릿 메소드 패턴 실무 적용 사례 [1] 써니썬 24/08/23 16:47 2413 1
    23448
    TMDB API Key 얻을 때 동의하게 되는 면책 및 포기 조항 우가가 24/08/18 16:07 2404 1
    23447
    펌) 아무튼 개쩌는 번역기를 국내기술로 개발완료 했다는 소식 [1] 펌글 우가가 24/08/15 17:30 2659 2
    23446
    쿠팡 가격 변동 추적 알림 서비스 피드백 요청 (제발) 창작글펌글 애오옹 24/08/10 14:30 2685 0
    23445
    넥사크로 17.1 관련 [2] 본인삭제금지 나르하나 24/08/01 12:30 2612 0
    23444
    개밯자 의자에 머리받침 없어 [2] 까망사투리 24/07/25 13:32 3062 1
    23443
    안드로이드 EditText 리스너 연동 문의드립니다. - 해결됨 [1] 창작글 상사꽃 24/07/01 17:47 2861 2
    23442
    펌) 파이어폭스 엔진이 신인 이유 [1] 펌글 우가가 24/06/30 23:25 3484 2
    23441
    예전에는 함수 하나에 대한 기능에 고민을 많이 했는데.. ssonacy 24/05/21 09:45 3230 0
    23440
    c++ 에서 DB 쿼리문처럼 사용할 방법이 있을까요? [8] 상사꽃 24/05/19 11:10 3385 0
    23439
    쉬운 배터리 알림 창작글 언젠가아자 24/05/14 10:47 3527 0
    23438
    아후 서터레스 [1] NeoGenius 24/04/02 17:52 3208 1
    23436
    로또 [3] 까망사투리 24/03/11 15:53 3904 4
    23434
    copilot 기업유료버전 intelliJ에 붙여서 쓰고있는데 지리네요 안녕월드 24/02/22 00:15 3901 0
    [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [다음10개▶]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈