সিসি প্রোগ্রাম তৈরি করুন যা সিসি সিটিতে সংকলন করতে সবচেয়ে দীর্ঘ সময় নেয়


27

একটি সংক্ষিপ্ত সি প্রোগ্রাম তৈরি করুন যা জিসিসি সহ সংকলন করতে অযৌক্তিকভাবে দীর্ঘ সময় নেয়। সংকলনের সময় নির্ধারণের পরে রেফারেন্স প্রোগ্রামের সংকলনের সময় বিয়োগ করে এন্ট্রিগুলি স্কোর করা হবে।

বিধি

  • যে কোনও সি ভাষার বৈশিষ্ট্য বা জিসিসি এক্সটেনশান
  • জিসিসি 4.2.1

1
ট্যাগিংটি পরিবর্তন করা হয়েছে কারণ [কোড-গল্ফ] এর স্পষ্টভাবে "শর্ট কোড (কী) স্ট্রোক কাউন্ট দ্বারা" অর্থ means
dmckee

6
চরিত্রের সংখ্যা দ্বারা বিভক্ত করা খুব বেশি অর্থবোধ করে না, কারণ এই চ্যালেঞ্জের যে কোনও যুক্তিসঙ্গত পদ্ধতির অবশ্যই একটি সংকলন-সময় জটিলতা বড় ( এন ) থাকবে, অর্থাত্ কোনও সমাধানের স্কোরকে তুচ্ছভাবে বৃদ্ধি করে কেবল এটি তৈরি করা যেতে পারে কিছুটা দীর্ঘ, যা সম্ভবত সর্বদা সুস্পষ্ট উপায়ে সম্ভব হবে।
পাল্টা থামানো বন্ধ হয়ে গেছে

উত্তর:


13
#define a "xxxxxxxxxxx"
#define b a a a a a a a
#define c b b b b b b b
#define d c c c c c c c
#define e d d d d d d d
#define f e e e e e e e
#define g f f f f f f f
#define h g g g g g g g
#define i h h h h h h h
#define j i i i i i i i
z=j;

আমার মেশিনে সংকলন করে না
FUZxxl

19
কমপক্ষে সর্বশেষ পংক্তিকে main(){char*z=j;}কোনও বৈধ সি প্রোগ্রাম তৈরি করার মতো কিছুতে পরিবর্তন করা দরকার ।
ডিএমকেেকে

2
আমার ভিএস2012 হিপথের জায়গা থেকে বেরিয়ে গেছে। আমি /Zmএটা ঠিক হবে
Rev

13

উভয় চার্লি এর উত্তর এবং আমার আগে এক প্রাক প্রসেসর লিখুন একটি লেট নীতির উপর কাজ অনেক কোডের কিন্তু তারা বেশিরভাগই প্রাক প্রসেসর নিজেই, lexer (ভাল ধারণা হিসাবে এই পদক্ষেপ ঐতিহ্যগতভাবে ধীর হয়েছে) এবং পার্সার ব্যায়াম। খনি অপ্টিমাইজেশন এবং কোড উত্পন্নকরণের পদক্ষেপগুলিও কাজ করার চেষ্টা করে, তবে এটি স্পষ্টভাবে সেখানে খুব বেশি লাভ করছে না।

একটি সাধারণ সি সংকলক কীভাবে কাজ করে তা ভেবে আমি বুঝতে পেরেছিলাম যে আমরা প্রতীক টেবিল সম্পর্কিত কোডটি কিছুই দিচ্ছি না। এই এন্ট্রি যে প্রতিকারের একটি প্রচেষ্টা। এটি সি বাস্তবায়নে বেসিক অবজেক্ট-ওরিয়েন্টেশনকে স্মরণ করিয়ে দেওয়ার মতো কথা বলে মনে করা হয়, তবে এটি আকর্ষণীয় কিছু করে না: প্রাক-প্রসেসরের সম্প্রসারণ কৌশলটি ঘৃণ্য ও তুচ্ছভাবে (এবং ভুলভাবে) অবজেক্টগুলির একগুচ্ছকে আরম্ভ করে। বিভিন্ন পদক্ষেপে একে অপরেরকে ছায়ায় ছড়িয়ে দেওয়ার সুযোগের বিভিন্ন স্তরে জটিল ধরণের ব্যবহার করে এমন অবজেক্ট। প্রতীক টেবিলটিকে একটি বাস্তব কাজ দেওয়া উচিত।

#include <stdlib.h>
#include <stdarg.h>
#include <string.h>
// Exercise the symbol table mechanism of the compiler in an effort to
// take a unreasonable about of time compiling

#define PTR(T) T*
#define CONST(T) T const
#define FUNC(NAME,RTYPE,ARG) RTYPE NAME(ARG)
#define FPTR(NAME,RTYPE,ARG) FUNC((*NAME),RTYPE,ARG)

// Forward decalration of repeated OO method pointers
typedef void* (*cctor_ptr)(void*this, void*that, ...);
typedef void* (*dtor_ptr)(void*this);

// Assumes three var-args: sizeof(payload type), cctor, dtor
void* default_ctor(void*this, ...){
  // Pull in variadac bits
  va_list list;
  va_start(list,this);
  int size=va_arg(list,int);
  cctor_ptr cctor=va_arg(list,cctor_ptr);
  dtor_ptr dtor=va_arg(list,dtor_ptr);
  va_end(list);
  // process
  if (!this) this = malloc(size);
  if (this) {
    memset(this,size,0);
    /* various dodges to install the cctor and dtor in the write places */
  }
  return this;
}
// Copies the payload from that to this; 
void* default_cctor(void*restrict this, void* restrict that, ...){
  // Pull in variadac bits
  va_list list;
  va_start(list,that);
  int size=va_arg(list,int);
  cctor_ptr cctor=va_arg(list,cctor_ptr);
  dtor_ptr dtor=va_arg(list,dtor_ptr);
  va_end(list);
  // process
  if (!this) this = malloc(size);
  if (this) {
    memcpy(this,that,size);
    /* various dodges to install the cctor and dtor in the write places */
  }
  return this;
}
// Assumes that his was allocated with malloc, does not use varargs
void* default_dtor(void*this, ...){
  free(this); 
  return NULL;
};

#define DECLARE_STRUCT(N) struct S##N##_s
#define TYPEDEF_ACCESSOR(N,T) typedef FPTR(f##N##_ptr,CONST(PTR(T)),PTR(CONST(struct S##N##_s)))
#define TYPEDEF_STRUCT(N,T) typedef struct S##N##_s {PTR(T)p; cctor_ptr cctor; dtor_ptr dtor; f##N##_ptr f##N;} S##N
#define OO_STRUCT(N,T) DECLARE_STRUCT(N); TYPEDEF_ACCESSOR(N,T); TYPEDEF_STRUCT(N,T)

OO_STRUCT(1,char);
OO_STRUCT(2,int);
OO_STRUCT(3,double*);
OO_STRUCT(4,S3);
OO_STRUCT(5,S4);
OO_STRUCT(6,S5);
OO_STRUCT(7,S6);
OO_STRUCT(8,S7);

#define SUBSCOPE(A) { \
    S1*A##1=default_ctor(NULL,sizeof(char),default_cctor,default_dtor); \
    S2 A##2; default_ctor(&A##2,sizeof(int),default_cctor,default_dtor); \
    S2*A##3=default_ctor(NULL,sizeof(double*),default_cctor,default_dtor); \
    S8 A##5; default_ctor(&A##5,sizeof(S4),default_cctor,default_dtor); \
    S6 A##6; default_ctor(&A##6,sizeof(S5),default_cctor,default_dtor); \
    S8*A##8=default_ctor(NULL,sizeof(S7),default_cctor,default_dtor); \
  }
#define SUBSCOPE2(A,B)  { \
    S2*B##5=default_ctor(NULL,sizeof(S4),default_cctor,default_dtor); \
    S4 A##7; default_ctor(&A##7,sizeof(S6),default_cctor,default_dtor); \
    SUBSCOPE(A) SUBSCOPE(B);                 \
  }
#define SUBSCOPE6(A,B,C)  { \
    S2*A##3=default_ctor(NULL,sizeof(double*),default_cctor,default_dtor); \
    S2 B##2; default_ctor(&B##2,sizeof(int),default_cctor,default_dtor); \
    S4*C##4=NULL;                           \
    SUBSCOPE2(A,C) SUBSCOPE2(B,C) SUBSCOPE2(A,B); \
  }
#define SUBSCOPE24(A,B,C,D) { \
    S1*D##1=default_ctor(NULL,sizeof(char),default_cctor,default_dtor); \
    S2 C##2; default_ctor(&C##2,sizeof(int),default_cctor,default_dtor); \
    S2*B##3=default_ctor(NULL,sizeof(double*),default_cctor,default_dtor); \
    S4 A##4; default_ctor(&A##4,sizeof(S3),default_cctor,default_dtor); \
    SUBSCOPE6(A,B,C) SUBSCOPE6(A,B,D) SUBSCOPE6(A,C,D) SUBSCOPE6(B,C,D); \
  }
#define SUBSCOPE120(A,B,C,D,E) { \
    S5*A##5=default_ctor(NULL,sizeof(S4),default_cctor,default_dtor); \
    S6*A##6=default_ctor(NULL,sizeof(S5),default_cctor,default_dtor); \
    S8 A##8; default_ctor(&A##8,sizeof(S7),default_cctor,default_dtor); \
    SUBSCOPE24(A,B,C,D) SUBSCOPE24(A,B,C,E) SUBSCOPE24(A,B,D,E); \
    SUBSCOPE24(A,C,D,E) SUBSCOPE24(B,C,D,E); \
  }
#define SUBSCOPE720(A,B,C,D,E,F) { \
    S5 A##5; default_ctor(&A##5,sizeof(S4),default_cctor,default_dtor); \
    S6 A##6; default_ctor(&A##6,sizeof(S5),default_cctor,default_dtor); \
    S8*A##8=default_ctor(NULL,sizeof(S7),default_cctor,default_dtor); \
    SUBSCOPE120(A,B,C,D,E) SUBSCOPE120(A,B,C,D,F) SUBSCOPE120(A,B,C,E,F); \
    SUBSCOPE120(A,B,D,E,F) SUBSCOPE120(A,C,D,E,F) SUBSCOPE120(B,C,D,E,F); \
  }

int main(){
  S4 s4;
  SUBSCOPE720(A,B,C,D,E,F)
}

আমার মেশিনে সংকলনের সময়টি 4 সেকেন্ডের -O3বেশি এবং কোনও অপ্টিমাইজেশন ছাড়াই 1 সেকেন্ডের বেশি।


স্পষ্টতই পরবর্তী পদক্ষেপটি হ'ল একটি বিসিডি ক্লাসগুলির জন্য ওও বাস্তবায়ন শেষ করা এবং পাই ব্যবহার করে পাই গণনাগুলি পুনরায় করা যাতে আমার উভয় প্রভাব কঠোরভাবে চলতে পারে।


12

এখানে এক্সফেনশনাল-প্রিপ্রোসেসর-এক্সপেনশন থিমের একটি খাঁজ দেওয়া হয়েছে যা কিছুটা মজার আকর্ষণীয় করে: সিরিজের পদ্ধতি অনুসারে পাইয়ের সাথে দুটি অনুমানকে গণনা করে এবং মান math.hএবং সাধারণ জ্বলন উভয়ের সাথে তুলনা করে ।

Ungolfed।

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

// Some random bits we'll need
#define MINUSONODD(n) (n%2?-1:+1)
#define TWON(n) (2*(n))
#define NPLUSONE(n) ((n)+1)
#define TWONPLUSONE(n) NPLUSONE(TWON(n))
#define FACT(n) (tgamma(NPLUSONE(n)))

// The Euler series
//                           2^(2n) * (n!)^2      z^(2n+1)
// atan(z) = \sum_n=0^\infty --------------- * ---------------
//                               (2n+1)!       (1 + z^2)^(n+1)
#define TERMEULER(n,z) (pow(2,TWON(n))*                 \
            FACT(n)*FACT(n)*                \
            pow((z),TWONPLUSONE(n))/            \
            FACT(TWONPLUSONE(n)) /              \
            pow((1+z*z),NPLUSONE(n)) )

// The naive version
//                           (-1)^n * z^(2n+1)
// atan(z) = \sum_n=0^\infty -----------------
//                                2n + 1
#define TERMNAIVE(n,z) (MINUSONODD(n)*pow(z,TWONPLUSONE(n))/TWONPLUSONE(n))


// Define a set of bifruncations of the sum
#define N2TERMS(n,z,ALG)  (TERM##ALG(TWON(n),(z)) + TERM##ALG(TWONPLUSONE(n),(z)))
#define N4TERMS(n,z,ALG)  (N2TERMS(TWON(n),(z),ALG)+N2TERMS(TWONPLUSONE(n),(z),ALG))
#define N8TERMS(n,z,ALG)  (N4TERMS(TWON(n),(z),ALG)+N4TERMS(TWONPLUSONE(n),(z),ALG))
#define N16TERMS(n,z,ALG) (N8TERMS(TWON(n),(z),ALG)+N8TERMS(TWONPLUSONE(n),(z),ALG))
#define N32TERMS(n,z,ALG) (N16TERMS(TWON(n),(z),ALG)+N16TERMS(TWONPLUSONE(n),(z),ALG))

// Sum the fist 32*2+16 = 80 terms of a series...
#define PARTIALSUM(z,ALG) N32TERMS(0,(z),ALG)+N32TERMS(1,(z),ALG)+N16TERMS(4,(z),ALG)


int main(void){
  const double PI_TRAD = 4.0L * atan(1.0);
  const double PI_NAIVE = 4.0L * PARTIALSUM(0.999999L,NAIVE);
  const double PI_EULER = 4.0L * PARTIALSUM(0.999999L,EULER);
  printf("pi (math.h) = %10.8f\n",M_PI);
  printf("pi (trad.)  = %10.8f\n",PI_TRAD);
  printf("pi (NAIVE)  = %10.8f\n",PI_NAIVE);
  printf("pi (EULER)  = %10.8f\n",PI_EULER);
}

ধরে নিই যে আপনি ব্যবহার করছেন gccএবং glibcঅন্য ব্যবস্থা নিয়ে কাজও করতে পারেন বা নাও করতে পারেন। আমার ২.৪ গিগাহার্টজ ইন্টেল কোর 2 ডুও ম্যাকবুকটিতে 1time (1) দিয়ে সংকলন করতে প্রসেসরের সময়টির (মূল্যায়ন ) প্রায় 1.0-1.1 সেকেন্ড সময় লাগে । একটি ডিফল্ট সংকলন প্রসেসরের সময়ের প্রায় 0.4 সেকেন্ড সময় নেয়।-03

হায়, আমি powবা tgammaসংকলক সময়ে মূল্যায়ন করার জন্য জিসিসি পেতে পারি না , যা সত্যই সহায়তা করবে।

আপনি যখন এটি চালান আউটপুট হয়:

pi (math.h) = 3.14159265
pi (trad.)  = 3.14159265
pi (NAIVE)  = 3.11503599
pi (EULER)  = 3.14159065

যা দেখায় যে আস্তে আস্তে কতটা নির্লজ্জ সিরিজ রূপান্তরিত হয়।


1 যতটা সম্ভব ধ্রুবক ভাঁজ এবং সাব-এক্সপ্রেশন নির্মূল সম্ভব get

আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.