算法介绍

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

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

状态: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. tomcat7.0建立新的web服务目录

    今天参照网上的配置方法配置了下tomcat的web服务目录,结果总是显示404错误,错误原因是The requested resource is not available.搜索了半天解决方法,终于发 ...

  2. 关于修改Android手机的音量

    首先,必须要获取系统的声音服务权限 <uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS&qu ...

  3. c++ 设计模式7 (Bridge 桥模式)

    4.2 Bridge 桥模式 动机: 由于某些类型的固有的实现逻辑,使得它们具有两个变化的维度,乃至多个变化的维度. 代码示例: 实现一个Messager,含有基本功能PlaySound,Connec ...

  4. spark HA

    spark HA 的两种实现: 基于文件系统的单点恢复(Single-Node Recovery with Local File System) 基于zookeeper的Standby Masters ...

  5. app 性能优化的那些事

    来源:树下的老男孩 链接:http://www.jianshu.com/p/5cf9ac335aec iPhone上面的应用一直都是以流畅的操作体验而著称,但是由于之前开发人员把注意力更多的放在开发功 ...

  6. 利用VBA+OO4O构造CTAIS开放式通用平台

    利用VBA+OO4O构造CTAIS开放式通用平台 2010-06-08 14:59:28 | 来源:税务信息化论文集 | 作者:于非 易飞 摘  要:文立足于CTAIS系统体系,探讨如何通过OO4O技 ...

  7. SpringMVC上传(通过物理路径)

    内容来源:http://blog.csdn.net/kouwoo/article/details/40507565 一.配置文件:SpringMVC 用的是 的MultipartFile来进行文件上传 ...

  8. ZBarSDK扫描二维码

    1:如果报引用文件错误的话需要在设置一下:project->Build settings->build active architecture only选项设置为No.Valid Arch ...

  9. 3. Android框架和工具之 xUtils(DbUtils )

    1. xUtils简介 xUtils 包含了很多实用的android工具.xUtils 最初源于Afinal框架,进行了大量重构,使得xUtils支持大文件上传,更全面的http请求协议支持(10种谓 ...

  10. FormsAuthenticationTicket学习笔记

    FormsAuthenticationTicket ticket = , ), true, string.Format("{0}:{1}", "username" ...