算法介绍

首先我们先看一下“基于投票规则的细胞自动机”的定义:

基于投票规则的细胞自动机,实际上是具有如下限定条件的一种细胞自动机:

状态:0或1;

邻居:中心的3*3邻居;

规则:计数p表示中心的3*3邻居中1的个数(包括中心本身),if P<5,中心设置为0.否则设置为1 。

混沌随机序列:

一般我们采用混合光学双稳模型迭代方程实现混沌随机序列的产生:

题目要求:

现在给定系数A为4,Xb为2.5,要求生成一个长度为16的混沌序列{xi}。并且用一下方法将该序列转换为0 1序列:xi > 2.5 则赋值为1, 否则赋值为 0 。然后把这个序列排成4 * 4的0 1矩阵,并用上述的细胞自动机对该矩阵进行两次运算,给出最终的矩阵结果。

算法实现代码如下:

/*****************************************
Author: Nero
Data:2013/12/22
Deifning coefficient A as 4, Xb as 2.5;
*****************************************/ #include<stdio.h>
#include<math.h>
using namespace std;
const int A = ;
const float Xb = 2.5; void Rules_Impl(float P[],float dMatrix[][]); void Cellular_Automata(float dInit)
{
printf("dInit=%g\n\n",dInit);
int i ,j; //variables for counting
float dMatrix[][];
float P[];
float *X = new float[];
X[] = dInit; //Initializing X[0]
int count = ; //temp variable for counting index
for (i = ; i < ; i++)
{
X[i+] = * pow(sin(X[i]- Xb),); //Sequence with a length of 16;
}
//Print sequence
for (i = ; i < ; i++)
{
printf("%f\t",X[i]);
}
printf("\n\n"); for (i = ; i < ; i++)
{
X[i] = X[i]>2.5?:;
}
for (i = ; i < ; i++)
{
for (j = ; j< ; j++)
{
dMatrix[i][j] = X[count];
++count;
}
}
//Print Matrix
printf("The original matrix is \n");
for (i = ; i < ; i++)
{
for (j = ; j < ; j++)
{
printf("%g\t",dMatrix[i][j]);
}
printf("\n");
}
printf("\n"); //calculate the centers, Twice
for (i = ; i < ; i++)
{
Rules_Impl(P,dMatrix);
}
printf("The final matrix is \n");
for (i = ; i < ; i++)
{
for (j = ; j < ; j++)
{
printf("%g\t",dMatrix[i][j]);
}
printf("\n");
}
printf("\n");
} void Inter()
{
float Init;
printf("Input the init Num\n");
scanf_s("%g",&Init);
Cellular_Automata(Init);
} void Rules_Impl(float P[],float dMatrix[][])
{
//Four calculations for the center of the 3*3 neighbors
//Choose Matrix[1][1], Matrix[2][1], Matrix[1][2], Matrix[2][2] as centers
int i =, j = ; //Matrix[1][1]
for (i = ; i <; i++)
{
for (j = ; j < ; j++)
{
P[] += dMatrix[i][j];
}
}
//Matrix[2][1]
for (i = ; i<;i++)
{
for (j=;j <;j++)
{
P[]+=dMatrix[i][j];
}
}
//Matrix[1][2]
for (i = ; i<;i++)
{
for (j=;j <;j++)
{
P[]+=dMatrix[i][j];
}
}
//Matrix[2][2]
for (i = ; i<;i++)
{
for (j=;j <;j++)
{
P[]+=dMatrix[i][j];
}
}
dMatrix[][] = P[]<?:;
dMatrix[][] = P[]<?:;
dMatrix[][] = P[]<?:;
dMatrix[][] = P[]<?:;
}

其中Rules_Impl()函数的作用是进行细胞自动机运算。

Cellular_Automata()函数为主要功能实现函数,包括随机序列的产生,矩阵的产生以及对Rules_Impl()函数的调用。

C语言实现基于投票规则的细胞自动机的更多相关文章

  1. 转:从开源项目学习 C 语言基本的编码规则

    从开源项目学习 C 语言基本的编码规则 每个项目都有自己的风格指南:一组有关怎样为那个项目编码约定.一些经理选择基本的编码规则,另一些经理则更偏好非常高级的规则,对许多项目而言则没有特定的编码规则,项 ...

  2. C语言中内存对齐规则讨论(struct)

    C语言中内存对齐规则讨论(struct) 对齐: 现代计算机中内存空间都是按着byte划分的,从理论上讲似乎对任何类型的变量的访问可以从任何地址开始,但实际情况是在访问特定变量的时候经常在特定的内存地 ...

  3. [转载] 使用C/C++语言编写基于DSP程序的注意事项

    原文地址:『转』使用C/C++语言编写基于DSP程序的注意事项作者:skysmile   1.不影响执行速度的情况下,可以使用c或c/c++语言提供的函数库,也可以自己设计函数,这样更易于使用“裁缝师 ...

  4. Tars | 第3篇 Tars中期汇报测试文档(Java语言实现Subset路由规则)

    目录 前言 1. 任务介绍 2. 测试模拟方案 2.0 *前置工作 2.1 添加路由规则 2.2 添加存活节点 2.3 [输出]遍历输出当前存活节点 2.4 [核心]对存活节点按subset规则过滤 ...

  5. WCF学习笔记(基于REST规则方式)

    一.WCF的定义 WCF是.NET 3.0后开始引入的新技术,意为基于windows平台的通讯服务. 首先在学习WCF之前,我们也知道他其实是加强版的一个面向服务(SOA)的框架技术. 如果熟悉Web ...

  6. C语言函数的作用域规则

      “语言的作用域规则”是一组确定一部分代码是否“可见”或可访问另一部分代码和数据的规则. “同一函数中,不同的结构体成员名能相同,当变量处于不同的作用域时,名称可以相同. 注:作用域,其对象是变量, ...

  7. C语言编程规范—命名规则

    C是一门朴素的语言,你使用的命名也应该这样.与Modula-2和Pascal程序员不同,C程序员不使用诸如“ThisVariableIsATemporaryCounter”这样“聪明”的名字.C程序员 ...

  8. Django模板语言(常用语法规则)

    Django模板语言 The Django template language 模板中常用的语法规则 {最新版本的Django语法可能有改变,不支持的操作可能支持了.[HTML教程 - 基本元素/标签 ...

  9. 【java规则引擎】一个基于drools规则引擎实现的数学计算例子

    最近在研究JBPM工作流引擎,发现JBPM是基于Drools的,官方文档查看得知Drools是一款规则引擎.兴趣之下,仔细了解了下 Drools,Drools作为JBoss出品的一款开源推理和规则引擎 ...

随机推荐

  1. 0c-41-ARC使用特点及注意事项

    1.ARC特点总结 1)不允许调用release,retain,retainCount 2)允许重写dealloc,但是不允许调用[super dealloc] 3)@property的参数: str ...

  2. 如何快速检查js语法学习Javascript

    这里给大家推荐一个快速进行语法检查的方法,可以发现绝大多数语法错误,也可以作为在线编辑器,提高编程效率. 地址:http://www.jslint.com/ 同时推荐一个在线学习Javascript的 ...

  3. mysql性能优化(二)

    ###> mysql中有一个explain 命令可以用来分析select 语句的运行效果,例如explain可以获得select语句使用的索引情况.排序的情况等等.除此以外,explain 的e ...

  4. keytool 错误 java.io.IOException: incorrect AVA format

    给一个APK做签名,选择新建一个key并填写相关信息,但在Finish时,keytool报出了一个错误:keytool error: java.io.IOException: Incorrect AV ...

  5. xcode5项目图标添加

    转载文章 地址http://www.360doc.com/content/14/0103/08/14615320_342227413.shtml 最近提交itunesconnect应用时,有个警告说缺 ...

  6. iOS 抓取 UIwebview 上 所有 图片 并进行滚动播放

    关于在UIwebview上添加滚动图片 两种滚动手势会混淆,应为webview有webview.scrollview的属性 故参照昨天的随笔 scrollview嵌套解决方案. 本篇随笔主要讲循环使用 ...

  7. 杂乱无章之Oracle(二)

    六.IMPDP用法 1.导入表 impdp hsiufo/hsiufo directory=dump_dir dumpfile=full.dmp tables=scott.emp remap_sche ...

  8. Android进阶笔记18:选用合适的IPC方式

    1. 相信大家都知道Android进程间通信方式很多,比如AIDL.Messenger等等,接下来我就总结一下这些IPC方式优缺点. 2. IPC方式的优缺点和适用场景 3. 附加:使用Intent实 ...

  9. 一些英文面试题(Android)

    Describe the APK format. The APK file is compressed the AndroidManifest.xml file, application code ( ...

  10. linux之磁盘配额(quota)

    1.什么是quota 简单的说就是限制用户对磁盘空间的使用量. 因为Linux是多用户多任务的操作系统,许多人共用磁盘空间,为了合理的分配磁盘空间,于是就有了quota的出现. 2.quota的用途  ...