以下鄙人实现了排队论思想,语言是C语言
#include<stdio.h>
#include<float.h>
int main()
{
/************************************what we know in the system**************************************/
float arrivals[] = {0.4, 1.6, 2.1, 3.8, 4.0, 5.6, 5.8, 7.2};//the time of each customer's arrival
float departures[] = {2.4, 3.1, 3.3, 4.9, 8.6};//the time of each customer's departure
int acount = 0;//the index of arrivals array
int dcount = 0;//the index of departures array
/***************the clock and clock event in the simulating system******************/
float clock = 0;//simulation clock
float clock_event[2] = {arrivals[acount],departures[dcount]};//clock[0] means arrival time,clock[1] means departure time
int clock_event_times[2] = {0, 0}; //clock_event_times[0] means the count of arrival event happened;
//clock_event_times[1] means the count of departure event happened
/*****************system state ****************************/
int serve_status = 0;//false means ideal and 1 means busy
int no_in_queue = 0;//the number in queue
float time_of_arrival[4] = {0};//the time of arrival
float time_of_last_event = 0;// the time of last event
/*****************statistical counters***************/
int no_delayed = 0;//the number of delayed
float total_delay = 0;//the total delay time
float area_under_Q = 0;//the area under queue(t)
float area_under_B = 0;//the area under busy(t)
/********the stop time***/
char temp;
int end_event;
printf("Please input the stop event of this simulating system(a means arrival and d means departure): ");
scanf("%c", &temp);
if (temp == 'd')
end_event = 1;
else
end_event = 0;
int ordinal;
printf("Please input the customer's ordinal of the stop event you have input:");
scanf("%d", &ordinal);
/***********start********************/
while(clock_event_times[end_event] < ordinal)
{
if(clock_event[0]<clock_event[1] )//arrival event
{
clock = clock_event[0];
acount += 1;
clock_event[0] = arrivals[acount];
clock_event_times[0] += 1;
if(serve_status == 0)//no body
{
serve_status = 1;
}
else
{
time_of_arrival[no_in_queue] = clock;
area_under_B += serve_status * (clock - time_of_last_event);
area_under_Q += no_in_queue * (clock - time_of_last_event);
no_in_queue += 1;
}
}
else//department event
{
clock = clock_event[1];
dcount += 1;
clock_event[1] = departures[dcount];
clock_event_times[1] += 1;
area_under_B += clock - time_of_last_event;
if(no_in_queue == 0)
{
serve_status = 0;
}
else
{
clock_event[1] = departures[dcount];
total_delay += clock - time_of_arrival[0];
area_under_Q += no_in_queue * (clock - time_of_last_event);
no_in_queue -= 1;
time_of_arrival[0] = time_of_arrival[1];
time_of_arrival[1] = time_of_arrival[2];
time_of_arrival[2] = time_of_arrival[3];
}
}
time_of_last_event = clock;
}
printf("Number delayed: %d\n", clock_event_times[1]);
printf("Total delay: %2f\n", total_delay);
printf("Area under Q(t): %2f\n", area_under_Q);
printf("Area under B(t): %2f\n", area_under_B);
return 0;
}
- JAVA实现排队论
转载请注明出处:http://blog.csdn.net/xiaojimanman/article/details/50401727 http://www.llwjy.com/blogdetail/3 ...
- 建模算法(七)——排队论模型
(一)基本概念 一.排队过程的一般表示 凡是要求服务的对象称为顾客,凡是为顾客服务的称为服务员 二.排队系统的组成和特征 主要由输入过程.排队规则.服务过程三部分组成 三.排队模型的符号表示 1.X: ...
- 更新过程 renewal process
一类随机过程.是描述元件或设备更新现象的一类随机过程.设对某元件的工作进行观测.假定元件的使用寿命是一随机变量,当元件发生故障时就进行修理或换上新的同类元件,而且元件的更新是即时的(修理或更换元件所需 ...
- 十分钟了解分布式计算:GraphLab
GraphLab是一个面向大规模机器学习/图计算的分布式内存计算框架,由CMU在2009年开始的一个C++项目,这里的内容是基于论文 Low, Yucheng, et al. "Distri ...
- SQL Server 内存数据库原理解析
前言 关系型数据库发展至今,细节上以做足文章,在寻求自身突破发展的过程中,内存与分布式数据库是当下最流行的主题,这与性能及扩展性在大数据时代的需求交相辉映.SQL Server作为传统的数据库也在最新 ...
- little's law(律特法则)
参考:https://en.wikipedia.org/wiki/Little%27s_law(周末看一下) 最近在做性能压力测试,开始时,压力压不上去,参考: N = X * E[T] ,N就是你的 ...
- [珠玑之椟]估算的应用与Little定律
[珠玑之椟]估算的应用与Little定律 估算的数据主要依赖于所能获得的数据和常识,有时还包括实践而不仅仅是理论.它常常作为一个大问题中的子问题,恰当地估算可以省去精确计算的时间和开销.在计算机领域, ...
- RabbitMQ-从基础到实战(6)— 与Spring集成
0.目录 RabbitMQ-从基础到实战(1)- Hello RabbitMQ RabbitMQ-从基础到实战(2)- 防止消息丢失 RabbitMQ-从基础到实战(3)- 消息的交换(上) Rabb ...
- 【概率论与数理统计】小结4 - 一维连续型随机变量及其Python实现
注:上一小节总结了离散型随机变量,这个小节总结连续型随机变量.离散型随机变量的可能取值只有有限多个或是无限可数的(可以与自然数一一对应),连续型随机变量的可能取值则是一段连续的区域或是整个实数轴,是不 ...
随机推荐
- cf B. Flag Day
http://codeforces.com/contest/357/problem/B #include <cstdio> #include <cstring> #includ ...
- LeetCode_Climbing Stairs
ou are climbing a stair case. It takes n steps to reach to the top. or steps. In how many distinct w ...
- Linux企业级项目实践之网络爬虫(15)——区分文本文件和二进制文件
HTTP协议支持文本和二进制文件传输.最常见的html格式的页面即文本,图片.音乐等为二进制文件.我们要对这两类文件加以区分并分别处理. static char * BIN_SUFFIXES = &q ...
- 【转】使用 vim + ctags + cscope + taglist 阅读源码
原文网址:http://my.oschina.net/u/554995/blog/59927 最近,准备跟学长一起往 linux kernel 的门里瞧瞧里面的世界,虽然我们知道门就在那,但我们还得找 ...
- 【转】 ubuntu12.04更新源 官网和163等
原文网址:http://blog.csdn.net/zhangliang_571/article/details/8813999 分类: LINUX 摘要: 本文列出ubuntu 12.04 LTS更 ...
- Android 通过外键连接两个数据库
Learn: 1.Android数据库的语法. 2.通过外键连接两个数据库. 3.加强了对数据库的熟悉度. 4.对文本框的visiblity属性的了解. Demo:http://pan.baidu.c ...
- eclipse 添加resources 目录
java项目需要一些配置,配置放置目录如:/src/main/resources; 如果没有这个文件夹,需要右键项目>new>source folder > Folder name ...
- 【公告】CSDN个人空间将于2014年4月20日全新改版上线
尊敬的用户: 你们好! CSDN个人空间将在2014年4月20日全新改版上线! CSDN个人空间是2008年8月推出的服务,致力于给广大用户提供在线技术分享和资料 ...
- EnableDocking
CFrameWnd::EnableDocking void EnableDocking(DWORD dwDockStyle); 參数: dwDockStyle 指定框架窗体的哪一边可作为控件条的停靠点 ...
- HDU--4784 Dinner Coming Soon DP+BFS
题意非常长非常变态.一个人要到他男朋友家,他最初有R元以及T分钟的时间来赶到他男朋友家.有N个房子M条道路,每条道路有须要消耗的时间以及过路费,同一时候还要顺路做食盐生意,起初身上没有食盐,最多带B袋 ...