[C++] 几行代码生成漂亮图片,数学家就是牛!
信息获得处:http://news.cnblogs.com/n/501488/
分形:http://baike.baidu.com/subview/83243/11213590.htm?fr=aladdin


代码:[采用宏定义的来选择绘制不同的图,所以把最后两个给注释掉了,因为宏冲突,想自己试试可以单独编译运行]
PS:生成的图片是ppm格式的要用格式工厂之类的软件进行转换,也可以自己在程序里直接把图片生成bmp或者其他格式的~
// NOTE: compile with g++ filename.cpp -std=c++11
#include <iostream>
#include <cmath>
#include <cstdlib>
#define DIM 1024
#define DM1 (DIM-1)
#define _sq(x) ((x)*(x)) // square
#define _cb(x) abs((x)*(x)*(x)) // absolute value of cube
#define _cr(x) (unsigned char)(pow ((x),1.0/3.0)) // cube root
#define F unsigned char GR (int,int);
unsigned char BL (int,int); unsigned char RD (int i,int j){
#ifdef A
return (char)(_sq(cos(atan2(j-,i-)/))*);
#endif #ifdef B
#define r(n) (rand ()%n)
static char c[][];
return!c[i][j]?c[i][j]=!r()?r():RD ((i+r())%,(j+r())%):c[i][j];
#endif #ifdef C
float x=,y=;
int k;
for(k=;k++<;){
float a=x*x-y*y+ (i-768.0)/;
y=*x*y+ (j-512.0)/;
x=a;
if(x*x+y*y>)break;
}
return log (k)*;
#endif #ifdef D
double a=,b=,c,d,n=;
while((c=a*a)+(d=b*b)<&&n++<){
b=*a*b+j*8e--.;
a=c-d+i*8e-+.;
}
return *pow ((n-)/,.);
#endif #ifdef E
static double k;
k+=rand ()/./RAND_MAX;
int l=k;
l%=;
return l>?-l:l;
#endif #ifdef F
float s=./(j+);
float y=(j+sin ((i*i+_sq (j-)*)/./DIM)*)*s;
return (int((i+DIM)*s+y)%+int((DIM*-i)*s+y)%)*;
#endif
/*
#ifdef G
#define D DIM
#define M m[(x+D+ (d==0)-(d==2))%D][(y+D+ (d==1)-(d==3))%D]
#define R rand ()%D
#define B m[x][y]
return(i+j)?256-(BL (i,j))/2:0;
#endif
*/
/*
#ifdef H
#define A float a=0,b,k,r,x
#define B int e,o
#define C (x) x>255?255:x
#define R return #define D DIM
R BL (i,j)*(D-i)/D;
#endif
*/
return ;
}
unsigned char GR (int i,int j){
#ifdef A
return (char)(_sq (cos (atan2(j-,i-)/-*acos (-)/))*);
#endif #ifdef B
static char c[][];
return!c[i][j]?c[i][j]=!r()?r():GR ((i+r())%,(j+r())%):c[i][j];
#endif #ifdef C
float x=,y=;
int k;
for(k=;k++<;){
float a=x*x-y*y+ (i-768.0)/;
y=*x*y+ (j-512.0)/;
x=a;
if(x*x+y*y>)break;
}
return log (k)*;
#endif #ifdef D
double a=,b=,c,d,n=;
while((c=a*a)+(d=b*b)<&&n++<){
b=*a*b+j*8e--.;
a=c-d+i*8e-+.;
}
return *pow ((n-)/,.);
#endif #ifdef E
static double k;
k+=rand ()/./RAND_MAX;
int l=k;
l%=;
return l>?-l:l;
#endif #ifdef F
float s=./(j+);
float y=(j+sin ((i*i+_sq (j-)*)/./DIM)*)*s;
return (int(*((i+DIM)*s+y))%+int(*((DIM*-i)*s+y))%)*;
#endif
/*
#ifdef G
#define A
static int m[D][D],e,x,y,d,c[4],f,n;
if (i+j<1){
for (d=D*D;d;d--){
m[d%D][d/D]=d%6?0:rand ()%2000?1:255;
}
for (n=1 return RD (i,j);
#endif
*/
/*
#ifdef H
#define E DM1
#define F static float
#define G for (
#define H r=a*1.6/D+2.4;x=1.0001*b/D
R BL (i,j)*(D-j/2)/D;
#endif
*/
return ;
}
unsigned char BL (int i,int j){
#ifdef A
return (char)(_sq (cos (atan2(j-,i-)/+*acos (-)/))*);
#endif #ifdef B
static char c[][];
return!c[i][j]?c[i][j]=!r()?r():BL((i+r())%,(j+r())%):c[i][j];
#endif #ifdef C
float x=,y=;
int k;
for(k=;k++<;){
float a=x*x-y*y+ (i-768.0)/;
y=*x*y+ (j-512.0)/;
x=a;
if(x*x+y*y>)break;
}
return -log (k)*;
#endif #ifdef D
double a=,b=,c,d,n=;
while((c=a*a)+(d=b*b)<&&n++<){
b=*a*b+j*8e--.;
a=c-d+i*8e-+.;
}
return *pow ((n-)/,.);
#endif #ifdef E
static double k;
k+=rand ()/./RAND_MAX;
int l=k;
l%=;
return l>?-l:l;
#endif #ifdef F
float s=./(j+);
float y=(j+sin ((i*i+_sq (j-)*)/./DIM)*)*s;
return (int(*((i+DIM)*s+y))%+int(*((DIM*-i)*s+y))%)*;
#endif
/*
#ifdef G
A;n;n++){
x=R;y=R;
if(B==1){
f=1;
for(d=0;d<4;d++){
c[d]=M;
f=f<c[d]?c[d]:f;
}
if(f>2){B=f-1;}
else{
++e%=4;
d=e;
if(!c[e]){
B=0;M=1;
}}}}}
return m[i][j];
#endif
*/
/*
#ifdef H
F c[D][D];
if(i+j<1){A;B;G;a<D;a+=0.1){G b=0;b<D;b++){H;G k=0;k<D;k++){x=r*x*(1-x);
if(k>D/2){e=a;o=(E*x);c[e][o]+=0.01;}}}}}
R C (c[j][i])*i/D;
#endif
*/ return ;
} void pixel_write (int,int);
FILE *fp;
int main (){
fp = fopen ("MathPic.ppm","wb");
fprintf (fp, "P6\n%d %d\n255\n", DIM, DIM);
for(int j=;j<DIM;j++)
for(int i=;i<DIM;i++)
pixel_write (i,j);
fclose (fp);
return ;
}
void pixel_write (int i, int j){
static unsigned char color[];
color[] = RD (i,j)&;
color[] = GR (i,j)&;
color[] = BL (i,j)&;
fwrite (color, , , fp);
}
[C++] 几行代码生成漂亮图片,数学家就是牛!的更多相关文章
- line-height行高与图片的隐匿文本间隙消除方法
(标注 文章来源 http://www.zhangxinxu.com/wordpress/2015/08/css-deep-understand-vertical-align-and-line-hei ...
- Bootstrap 3之美03-独立行,文字环绕,图片自适应,隐藏元素
本篇主要包括: ■ 添加独立的一行■ 文字环绕■ 图片自适应■ 隐藏元素 添加独立的一行 在id为body的section和id为main的section之间,添加2张图片. 我们发现,新加的 ...
- 利用iterm2,在命令行预览图片,服务器也是可以的
1.首先你本地电脑上要安装iterm2软件,我们这里使用brew安装 这个是一定要装的,因为能在命令行渲染出图片文件全靠它,其实不是服务器渲染出来的,而是iterm2 官方网站:https://www ...
- C语言乱谈(一) 20行代码生成BMP
在学习图形图像的过程中,最简单和常见的格式是BMP和PPM.下面将给出生成BMP的极度精简代码,然后讲解BMP格式. #include <stdio.h> #include <std ...
- 微信小程序rich-text 文本首行缩进和图片居中
微信小程序开发使用rich-text组件渲染html格式的代码,常常因为不能自定义css导致文本不能缩进,以及图片不能居中等问题,这里可以考虑使用js的replace方法,替换字符串,然后在渲染的同时 ...
- 使用命令行生成 APNG 图片
使用 apngasm 工具 下载地址 https://sourceforge.net/projects/apngasm/files/2.91/ 本地源码编译 make 或者 下载对应环境的可执行程序 ...
- python学习---50行代码实现图片转字符画1
转自:https://blog.csdn.net/mm1030533738/article/details/78447714 项目链接: https://www.shiyanlou.com/cours ...
- Activiti开发案例之代码生成工作流图片
图例 环境 软件 版本 SpringBoot 1.5.10 activiti-spring-boot-starter-basic 6.0 生成代码 以下是简化代码: /** * 查看实例流程图,根据流 ...
- [测试篇]MarkDown之代码块行号+折叠图片
对比测试代码编号 $(function(){ $('pre code').each(function(){ texts = $(this).text().replace(/&(?!#?[a-z ...
随机推荐
- 比较详细PHP生成静态页面教程
一,PHP脚本与动态页面. PHP脚本是一种服务器端脚本程序,可通过嵌入等方法与HTML文件混合, 也可以类,函数封装等形式,以模板的方式对用户请求进行处理.无论以何种方式,它的基本原理是这样的.由客 ...
- 如何用expdp、impdp按表空间导出、导入?
参考:http://blog.csdn.net/zftang/article/details/6387325 A数据库: 表空间:ylcois 用户名:ylcois 密码:ylcois B数据库: 表 ...
- Razor引擎中的_ViewStart.cshtml
Startup Code是在所有View执行之前加载和执行的代码. 在Razor引擎中的_ViewStart.cshtml 就是装载这些“预执行代码”的文件,它有两个特点: 一.就是所有View执行之 ...
- Linux 中write()函数的出错情况及处理
write函数首先将进程需要发送的数据先放在进程缓冲区中,然后向socket的发送缓冲区进行拷贝,在此,可能出现这样情况,即当进程缓冲区中的数据量大于此时发送缓冲区中所能接受的数据量时,若此时处于阻塞 ...
- android之RadioGroup
radioGroup这控件在开发中也是常用到的 RadioGroup 有时候比较有用.主要特征是给用户提供多选一机制. 用微信举一个例子吧! <?xml version="1.0&qu ...
- 新创建的项目利用git添加远程仓库
git initgit remote add origin https:// //git账号中的网址 (git remote //可以查询添加的远程仓库) git add . //添加刚刚导入的整个工 ...
- Markdown常用基本语法
现在是我在学习Markdown时做的笔记.学完这些Markdown的基本使用已经不成问题. 1. 标题设置(让字体变大,和word的标题意思一样)在Markdown当中设置标题,有两种方式:第一种:通 ...
- AjaxControlToolkit MaskedEdit Unspecified error 未指定错误
使用AjaxControlToolkit 里面的 MaskedEditValidator控件,IE里面在如下的js中出现未指定(Unspecified error)错误, if (document.a ...
- 【erlang】erlang几种生成随机数的方法
erlang有三个生产随机数的办法 random:uniform(). 这个函数是erlang库random模块提供的.一般都采用这个. 1> random:uniform(). 0.44358 ...
- 互联网云生态下DDOS安全产品的一些考虑和测试方法(一)
DDOS攻击简介 安全的三要素——“保密性”.“完整性”和“可用性”中,DOS(Denial of Service拒绝服务攻击)所针对的目标是服务的“可用性”.这种攻击方式利用目标系统的网络服务功能缺 ...