Advertisement
Guest User

raycard

a guest
Sep 21st, 2013
222
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.31 KB | None | 0 0
  1. #include <stdlib.h>   // card > aek.ppm
  2. #include <stdio.h>
  3. #include <math.h>
  4. #define u return
  5. typedef int i;typedef float f;struct v{
  6. f x,y,z;v operator+(v r){u v(x+r.x,y+r.
  7. y,z+r.z);}v operator*(f r){u v(x*r,y*r,
  8. z*r);}f operator%(v r){u x*r.x+y*r.y+z*
  9. r.z;}v(){}v operator^(v r){u v(y*r.z-z*
  10. r.y,z*r.x-x*r.z,x*r.y-y*r.x);}v(f a,f b
  11. ,f c){x=a;y=b;z=c;}v operator!(){u*this
  12. *(1/sqrt(*this%*this));}};i G[]={247570
  13. ,280596,280600,249748,18578,18577,2311\
  14. 84,16,16};f R(){u(f)rand()/RAND_MAX;}i
  15. T(v o,v d,f&t,v&n){t=1e9;i m=0;f p=-o.z
  16. /d.z;if(.01<p)t=p,n=v(0,0,1),m=1;for(i
  17. k=19;k--;)for(i j=9;j--;)if(G[j]&1<<k){
  18. v p=o+v(-k,0,-j-4);f b=p%d,c=p%p-1,q=b*
  19. b-c;if(q>0){f s=-b-sqrt(q);if(s<t&&s>
  20. .01)t=s,n=!(p+d*t),m=2;}}u m;}v S(v o,v
  21. d){f t;v n;i m=T(o,d,t,n);if(!m)u v(.7,
  22. .6,1)*pow(1-d.z,4);v h=o+d*t,l=!(v(9+R(
  23. ),9+R(),16)+h*-1),r=d+n*(n%d*-2);f b=l%
  24. n;if(b<0||T(h,l,t,n))b=0;f p=pow(l%r*(b
  25. >0),99);if(m&1){h=h*.2;u((i)(ceil(h.x)+
  26. ceil(h.y))&1?v(3,1,1):v(3,3,3))*(b*.2+
  27. .1);}u v(p,p,p)+S(h,r)*.5;}i main(){
  28. printf("P6 512 512 255 ");v g=!v(-6,-16
  29. ,0),a=!(v(0,0,1)^g)*.002,b=!(g^a)*.002,
  30. c=(a+b)*-256+g;for(i y=512;y--;)for(i x
  31. =512;x--;){v p(13,13,13);for(i r=64;r--
  32. ;){v t=a*(R()-.5)*99+b*(R()-.5)*99;p=S(
  33. v(17,16,8)+t,!(t*-1+(a*(R()+x)+b*(y+R()
  34. )+c)*16))*3.5+p;}printf("%c%c%c",(i)p.x
  35. ,(i)p.y,(i)p.z);}}
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement