版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、北京邮电大学实验报告通信网理论基础实验报告学院:信息与通信工程学院班级:2013211124学号:姓名:O unknownQ UnknownUnknosvn实验一ErlangB公式计算器一实验内容编写ErlangB公式的图形界面计算器,实现给定任意两个变量求解第三个变量的功能:1)给定到达的呼叫量a和中继线的数目s,求解系统的时间阻塞率B;2)给定系统的时间阻塞率的要求B和到达的呼叫量a,求解中继线的数目s,以实现网络规划;3)给定系统的时间阻塞率要求B以及中继线的数目s,判断该系统能支持的最大的呼叫量二实验描述1实验思路使用MATLABGUITOOL设计图形界面,通过单选按钮确定计算的变量,
2、同时通过可编辑文本框输入其他两个已知变量的值,对于不同的变量,通过调用相应的函数进行求解并显示最终的结果。2程序界面EHangRCalczulationby虻途球:&.裆E日login©CakdlAtion3流程图4主要的函数符号规定如下:b(Blocking):阻塞率;a(BHT):到达呼叫量;s(Lines):中继线数量。1)已知到达呼叫量a及中继线数量s求阻塞率b使用迭代算法提高程序效率?1,?=?+?(?1,?)代码如下:functionb=ErlangB_b(a,s)b=1;fori=1:sb=a*b/(i+a*b);endend2)已知到达呼叫量a及阻塞率b求中继
3、线数量s考虑到s为正整数,因此采用数值逼近的方法。采用循环的方式,在每次循环中增加s的值,同时调用???函数计算阻塞率并与已知阻塞率比较,当本次误差小于上次误差时,结束循环,得到s值。代码如下:functions=ErlangB_s(a,b)s=1;Bs=ErlangB_b(a,s);err=abs(b-Bs);err_s=err;while(err_s<=err)err=err_s;s=s+1;Bs=ErlangB_b(a,s);err_s=abs(b-Bs);ends=s-1;end3)已知阻塞率b及中继线数量s求到达呼叫量a考虑到a为有理数,因此采用变步长逼近的方法。采用循环的方式
4、,在每次循环中增加a的值(步长为s/2),同时调用???函数计算阻塞率并与已知阻塞率比较,当本次误差小于预设阈值时,结束循环,得到a值。代码如下:functiona=ErlangB_a(b,s)a=0;step=s/2;b_temp=ErlangB_b(a,s);b_temps=ErlangB_b(a+step,s);while(abs(b-b_temp)>0.000001)if(b-b_temp)*(b-b_temps)<0)step=step/2;elsea=a+step;endb_temp=ErlangB_b(a,s);b_temps=ErlangB_b(a+step,s);
5、endend三结果分析a125102050100b0.50.50.50.50.50.50.5s1236112651a1010101010b0.10.20.50.81.0s13106213)已知阻塞率b及中继线数量s求到达呼叫量ab0.50.50.50.50.50.50.5s125102050100a12.73208.436918.272638.159298.0719198.0377b0.10.20.50.60.8s1010101010a7.51069.685018.272623.479848.78634)分析将程序结果与在线ErlangB公式计算器结果进行比较,结果基本一致,说明程序的正确性。
6、实验二M/M/1排队系统一实验内容实现M/M/1单窗口无限排队系统的系统仿真,利用事件调度法实现离散事件系统仿真,并统计平均队列长度以及平均等待时间等值,以与理论分析结果进行对比。二实验原理1顾客到达模式设到达过程是一个参数为服从Poisson分布,即?勺Poisson过程,则长度为?勺时间内到达?外呼叫的概率?义?(?%??=?!2服务模式设每个呼叫的持续时间为?则服从参数为?负指数分布,即?> ?= 1 - ?> 03服务规则服务规则为:FIFO4理论分析设系统到达率为?服务率为?则理论分析如下:理论平均等待时间:Ew=袅理论平均排队时间:Eq=痴?)理论系统中平均顾客数:EN
7、=短理论系统中平均等待队长:ENq=入?万?)三实验描述1实验思路仿真时序图示例时序关系图如下:S2S3v*bO bl tob2t2D2 b3 db4TT*D3+b5b6b8c2 M-A4D5*b9150AlA2各参数含义如下:bi:第i个事件(到达或离开)发生的时间ti:第i个到达事件发生的时间ci:第i个离开事件发生的时间Ai:第(i-1)个顾客与第i个顾客到达时间间隔Di:第i个顾客排队等待时间间隔Si:第i个顾客服务时间长度仿真设计算法1)利用负指数分布与泊松过程的关系,产生符合泊松过程的顾客流;2)分别构建一个顾客到达队列和一个顾客等待队列。顾客到达后,首先进入到达的队尾排队,并检测
8、是否有顾客等待以及是否有服务台空闲,如果无人等待并且有服务员空闲则进入服务状态,否则顾客将进入等待队列的队尾等待;3)产生符合负指数分布的随机变量作为每个顾客的服务时间;4)当服务员结束一次服务后,就取出等待队列中位于对头的顾客进入服务状态,如果迭代队列为空则服务台空闲等待下一位顾客到来;5)在系统到达稳态时,计算系统的平均等待时间以及平均等待队长等数据。2流程图3主要的函数1)产生符合泊松过程的顾客流Interval_Arrive=-10g(rand(1,SimTotal)/Lambda;%ArrivalTimeInterval2)产生符合负指数分布的服务时间Interval_Serve=-
9、log(rand(1,SimTotal)/Mu;%ServiceTime3)计算顾客到达时间%*ArriveTimeforeachCustomer*t_Arrive(1)=Interval_Arrive(1);ArriveNum(1)=1;fori=2:SimTotalt_Arrive(i)=t_Arrive(i-1)+Interval_Arrive(i);ArriveNum(i)=i;end4)计算顾客离开时间%LeaveTimeforeachCustomer|t_Leave(1)=t_Arrive(1)+Interval_Serve(1);LeaveNum(1)=1;fori=2:SimT
10、otal|ift_Leave(i-1)<t_Arrive(i)%Newcustomerarrivesaftertheformerhasbeenserved.t_Leave(i)=t_Arrive(i)+Interval_Serve(i);else%Newcustomerarriveswhiletheformerisbeingserved.t_Leave(i)=t_Leave(i-1)+Interval_Serve(i);endLeaveNum(i)=i;|end5)计算平均等待时间t_Wait=t_Leave-t_Arrive;%WaitingTimeforeachCustomert_W
11、ait_avg=mean(t_Wait);%AverageWaitingTime6)计算平均排队时间t_Queue=t_Wait-Interval_Serve;%QueueingTimeforeachCustomer%Average Queueing Timet_Queue_avg=mean(t_Queue);7)计算平均顾客数%Timeline|Timepoint=t_Arrive,t_Leave;%RecordArrivalTime&LeavingTimeforeachCustomer.Timepoint=sort(Timepoint);%SortallTimepoints.Arr
12、iveFlag=zeros(size(Timepoint);%FlagofArrivalCusNum=zeros(size(Timepoint);|temp=2;CusNum(1)=1;fori=2:length(Timepoint)if(temp<=length(t_Arrive)&&(Timepoint(i)=t_Arrive(temp)%ifthetimepointisaboutArrivalCusNum(i)=CusNum(i-1)+1;%addNumberofCustomerstemp=temp+1;ArriveFlag(i)=1;else%ifthetimep
13、ointisaboutLeavingCusNum(i)=CusNum(i-1)-1;%reduceNumberofCustomersendend%AverageNumberofCustomersTime_interval=zeros(size(Timepoint);Time_interval(1)=t_Arrive(1);fori=2:length(Timepoint)Time_interval(i)=Timepoint(i)-Timepoint(i-1);%TimepointIntervalendCusNum_fromStart=0CusNum;%AverageNumberofCustome
14、rs|CusNum_avg=sum(CusNum_fromStart.*Time_interval0)/Timepoint(end);8)计算平均队长%LengthofQueue(ExcludingCustomerbeingServiced)QueLength=zeros(size(CusNum);|fori=1:length(CusNum)|ifCusNum(i)>=2QueLength(i)=CusNum(i)-1;%ExcludingCustomerbeingServicedelseQueLength(i)=0;|endend%AverageWaitingLengthofQueue
15、QueLength_avg=sum(0QueLength.*Time_interval0)/Timepoint(end);9)仿真图:各顾客到达时间与离去时间subplot(2,2,1);stairs(0ArriveNum,0t_Arrive,'b');holdon;|stairs(0LeaveNum,0t_Leave,'r');legend('ArriveTime','LeaveTime');title('ArriveTimeandLeaveTimeforeachcustomer');xlabel('Cu
16、stomerID');|ylabel('Arrive/LeaveTime(Accumulated)');10)仿真图:系统等待队长分布subplot(2,2,2);stairs(Timepoint,CusNum,'b')axis(0Timepoint(end)0max(CusNum)title('DistributionofSystemCustomerNumber');xlabel('Time(Accumulated)');|ylabel('CustomerNumber');|11)仿真图:各顾客在系统中的
17、排队时间和等待时间subplot(2,2,3);stairs(0ArriveNum,0t_Queue,'b');holdon;|stairs(0LeaveNum,0t_Wait,'r');holdoff;axis(0max(max(ArriveNum),max(LeaveNum)0);max(max(t_Queue),max(t_Wait);title('QueueingTimeandWaitingTimeforeachcustomer'xlabel('CustomerID');|ylabel('Queueing/Wait
18、ingTime');legend('QueueingTime','WaitingTime');四结果分析为了检验算法的正确性,我们进行了多次实验。1数值分析1) SimTotal=5000Lambda=0.25Mu=0.5»UMISimTortal"5000Lambda=O.25Mu=Q,aAerageWaitinglimeinTheory:T_s=4AverageQueueinTim+inTheory;*.'_q=2A-erageNumberofCusto.ier5inTheory:L_s=lAverageWaitingLe
19、ngthofQu&ueinIh&ory;L_q=Q,aA-SrageWaitinglineinSimulation*_目二LOilAv?rac*QueueincTim己inSimulation",_q=l09S9At-sragNuinber4fCastfiaerstnSmulatianL_s=L.0122AverageWaitingLensthofQu&ueinSinuLaii0nL=q=0.8044d»O1SiET&tal"5000Larabda=Oi25Mu=0.5AverageWaitingIin$inIh?ctv:V_s=4
20、AverageQueueingTimeinTlieory:_q=2AverageNuibezofCustoiersinTheory:L_s=lAverage97itingLengthofQucveinTheory:L_(r0.5AverageWaitingli白inSiaulatiany_s«4.0457AverageQueueingIimeinSinulation_q=2.0516ArftrageNumbelo£CustomersljiSimLilationL_s=l_0L&fiAverageaitingLengthofQueueinSimulationL_q=0
21、.517032) SimTotal=10000Lambda=0.6Mu=0.8»MinSiiTotal"100D0Lajnbrla=(J.启Mu=0.SAvgj-ge讶很itin芸Iiu&ihTheory;W_s=qAvsrsgeQueueinginIhfr&i-y:Lq-3-:5AverageNumtieiofCustomersinTheory:L_s=3AverageVaitmgLengtkofQueueinTheory:L_q=2.25AverageaitingIineinSimulationV_s-4,bo21A-erageQueueingTmein
22、Sranlation%_q=m.3268AverageNaubeiofCustonersinSimulationL_s=2.7316Av?rge-faitinsLungthQfQuruinSiwlxiQnL_q=l,9963»MM1SiiTet81=10000Lajiibda=Oi6Mu?O.SAverage'iFaixingTineinItieoiy;孑一s=5A"ftTQgeQueueingTuneinTh.eOTy:r_q=3_75AverageNumberofCustomersinTheory:L_s=3AverageVa.itmgLengthq£
23、QueuelhTheory:L_q2.25AverageIfaitingFineinSimulationW_s»4*7557AverageQueueingIinSimlatLQn._q=3.5018AverageNamberofCustoaersinSimalationL_s=2_8018AverageTa.itingLengthofgm片in51m0ti。L_q=Q5313) SimTotal=2000Lambda=0.8Mu=0.9»MK1Simrotal=2000Lajnbd=Q*8Mu-o.gAverage'VaitinsTimeinTheory:不一s=1
24、0AverageQueueingTineinTheory:B889AverageNunbeiofCustonersinTheciy:L_s=8AverageLengthofQueueinTheory:L_q=7.1111AverageWaitingTimeinSimulatronW_s"7t8662AverageQueueinglimeinSimulat:tm苫_q=6.796©AverageNuaberofCustoLersinSimulationL_s«6.4024Avera."Hait工nglength<?fQu琮uginSiaul/tion
25、L一于55321»SimTotal=2000Lambcia=0.0Mu=0.9Average.iiaitIllgTimeltiThecrv:百s=10AverageQueueingTi>einThetuy:W_=8_8E89ofCust«nrsinIhory;L一铲8AverageVaitingL&nthofQueiiinThqt?,:L_q=7.ILLIAverageWaitinglineinSimulationT_s=o*4B41AverageQueueingTimeinSimulation,_q=4.406:AverageNunbezofCastoner
26、sinSimulatianL_e»4-1698AveragetingLengtHo£QueuemSimulation.3口Of4)分析从上面几次实验结果可以看出,仿真的结果基本符合理论分析的结果。在系统存在稳态时,即??<?寸,仿真结果与理论分析结果的误差较小,此误差值仿真次数即??蚓?帅?大小影响比较明显,当????醒?时,误差比较大,当??????时,误差比较小。2仿真图分析由于仿真图过多,这里只选取其中一次实验的仿真图,其他图片在上传文件的压缩包中。这里选择第一次实验的仿真图。SioiTataI"5000Lambda=O.25Mu二山aA%erageW
27、aLtinglim?inTheory:"v_e=4AverageQueuemgTim已inTheory;二_0=2A-erageNiunberofCustoaersLnTheory:L_s=lAverageVaitingLengthofQueueinTheory;L_q=0.aA'erageWaitinglimeinSunulation谭_r:=4.OilAverageQueueingTineinSiculationW_q=1,99S9Af&rageNumberofCustoaersLnSinulatianL_e=L.0122AverageWaitingLengtho
28、fQueueinSiiuuLationL_cj=O.504462 5 15 0106U后一 nlusuqdJE 二 UAmlJ1ru>fe<1)各顾客的到达时间与离去时间横轴表示的是5000个顾客的编号,纵轴表示的是每个顾客到达或离去的时间点(蓝线表示 的是到达的时间点,红线表示的是离去的时间点)。两条线均严格单调递增,原因是顾客按编号的顺序依次到来以及依次接受服务,在只有一个服务员的情况下,先到的顾客会先接受服务,因此也会先离去。两条线的差值表示的是顾客在系统中的时间,包括排队时间及服务时间,由于每个顾客在系统的时间相对于所有顾客总时间来说占很小一部分,因此两条线看起来基本重合O
29、2)系统顾客数分布DistributionofSvstemCustomerNumber0fl2OT040006000fiOOO1DOOO1200014000160001B000Time(Accumulated)横轴表示的是所有顾客的总时间,纵轴表示的是对应每个时间点的系统顾客数情况。由图可以看出,系统大部分时间,顾客数保持在02之间,与理论分析情况一致。3)各顾客在系统中的排队时间和等待时间QueueingTim书andWaitingTimefo-reachcustomer_ O S5 0 5 O 5 O 2211 1UIUF 5 三一而M/6u_urluno横轴表示的是5000个顾客的编号,
30、纵轴表示的是每个顾客排队或等待的时间点(蓝线表示的是排队时间,红线表示的是等待时间,两条线的差值表示的是服务时间)。实验三Floyd算法一实验内容实现Floyd算法,可对输入的邻接距离矩阵计算图中任意两点间的最短距离矩阵和路由矩阵,且能查询任意两点间的最短距离和路由。二实验原理1定理对于图?如果?郎表示端?到端?的可实现的距离,那么??表示端?到端?之间的最短距离当且仅当对于任意?有?7?w?;?+?(?)2 Floyd算法原理Floyd算法通过迭代运算消除不满足上述定理的情况。具体在实现中,Floyd算法使用两个矩阵表示:一个为距离矩阵,一个为路由矩阵。在迭代过冲中,路由矩阵依照距离矩阵变化
31、。3 Floyd算法步骤给定图?吸其边(?的权?/?(1wiwn,1wjwn),则?:初始化距离矩阵?(?)和路由矩阵?)为?(?)=?*)?,?X?)=?0?,*?X?其中???毋?,一,?00???0?=?r(o)=?v°°l,j0?:已求得?(?-?)和?-??依据下面的迭代求?(?)和?)(?(?-1)(?-1)(?-1)??????),?/?9?)+?,?)r(?)=仔)喘游?e?)(?-i)M?_5?=,g?-i)?:若k<n,重复;k=n,终止。三实验描述1实验思路1)求最短距离矩阵及路由矩阵初始化最短距离矩阵为输入矩阵?:=?;初始化路由矩阵??=?置
32、??=1;?1:?对每个?如果??%?+?劣?则更新??=?+1;如??>?转向步骤,否则停止。2)求最短路径最短路径为??=?置路径初始位置为?1)=?置??=1;如??转向步骤;??=?+1;查路由矩阵?令?=?令?=?转向步骤;?7?+1)=?2流程图3主要的函数1)求最短距离矩阵及路由矩阵functionW,R=floyd(M)n=size(M,1);W=MShortestPathmatrix%orderofmatrix%initializationofR=zeros(n,n);%Routingmatrixfori=1:nforj=1:nif(W(i,j)=inf)&(i
33、=j)R(i,j)=j;%initializationofRoutingmatrixendendendfork=1:nfori=1:nforj=1:nifW(i,k)+W(k,j)<W(i,j)W(i,j)=W(i,k)+W(k,j);%updateShortestPathmatrixR(i,j)=R(i,k);%uodateRoutingmatrixendendendend2)求最短路径functionX,D=found(W,R,i,j)D=;%initializationofpathmatrixD(1)=i;%startfromiX=W(i,j);%shortestdistancek
34、=1;while(R(i,j)=j)k=k+1;D(k)=R(i,j);%nextpathi=R(i,j);endD(k+1)=j;%endinjend四结果分析为了检验算法的正确性,我们以课本的例子进行了试验。输入的矩阵如下图所示:0InfInf1.20009.2000Infa.xomInf0IdF5.0000Inf3.10002.01WInFInf0TnfInf1.00001.50001.20005.0000Inf0氏7moInfInFfl.aowInfInf6.70W015.EOCOInfInf3.10004.0000Inf15.bOOO0Jnf0.50002.00001.冈00TnfI
35、nfInfa经过Floyd算法得到的最短距离矩阵以及路由矩阵与课本的答案一致,如下所示:»twr=nojdMQ2.5M02.00。L.20TO7.90005.6M00.50002.500003.50003.700010.400C3.10002.0000比(3000工500003.20009加0口-LOtMtOL.soao.20003.70003.200Q06.70006.8000L70007.0000J0.4000u.yooo6.7000QIJ.5000b.ioao5,6000工IWO4.0000&8(MX)13-500fl05.10Q00.50002.000C1.50001
36、.70008.40005.100000771177077767770777I1L0LJI141110442232202L;31120以下是求任意点间最短路径及其路由的实验,如下图所示:>>Dl=found(W.LL5)XI=&1000D1=»X2园=foundM.R,44)12=3.2000D2=3711结果与理论值一样,说明算法的正确性。实验四图的连通性分析一实验内容编写图的连通性判断算法,判断图是否连通以及连通分支的个数。二实验原理1 Warshall算法设矩阵?次判断矢I阵,???1表示从?到?连通,?私??0表示从?到?不连通。当?1即?到?连通时,若?=
37、1即?到?旗通,则?死1即?到?旗通。依次判断?硝每一行或每一列,对矩阵的值进行更新。2 MatrixPower算法对邻接矩阵?求哥,若?,万1,表示至少存在一个长度为到到勺链使到到?I通。三实验描述1实验思路1) Warshall算法置新矩阵?=?置?=1;对所有的??如果?1,则对?=1,2,?有?/?+1;如??转向步骤,否则停止。2) MatrxiPower算法置新矩阵?=0;置?=1;计算到到??=?+?+1;如??转向步骤,否则停止。2流程图3主要的函数1) Warshall算法functionG,S=Warshall(C)%initializationn=size(C,1);%o
38、rderofmatrixCG=zeros(1,n);%initializationofconnectedcomponentmatrixa=1;fori=1:nifsum(C(i,:)=0%ifiisanisolatedpointG(i)=a;a=a+1;elseforj=1:nifC(i,j)=1%ifiisconnectedtojifG(i)=G(j)%ifiandjareinapathifG(i)=0%ifdoesnotmarkG(i)G(i)=a;%setiandjinapathG(j)=a;a=a+1;endelse%ifiandjarenotinapathifG(i)=0G(i)=G(j);elseifG(j)=0G(j)=G(i);elsefork=1:nifG(k)=G(i)G(k)=G(j);%WarshellalgorithmendendendendendendendendS = 0;%initialization of number of connected componentfork1:a-1ifisemp
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 护理人文:促进医护患共同决策
- 护理质量评估与改进措施
- 护理查房中的跨学科合作
- 聚四氢呋喃装置操作工安全培训效果竞赛考核试卷含答案
- 重冶萃取工安全意识强化模拟考核试卷含答案
- 2026年新科教版高中高一数学上册第三单元指数对数运算应用卷含答案
- 平板显示膜回收工诚信水平考核试卷含答案
- 制药灭菌发酵工成果评优考核试卷含答案
- 2026年新科教版高中高二化学下册第一单元反应热计算综合应用卷含答案
- 焊剂烧结熔炼工成果竞赛考核试卷含答案
- 京瓷哲学的培训课件
- 淋膜基础知识培训课件
- 《电动汽车储能系统原理与维修》课件-项目四 北汽新能源EV200动力蓄电池
- 2023RDPAC行业行为准则
- 2025年云南省高考化学试题(学生版+解析版)
- 农药污染土壤的修复技术
- 2026届新疆乌鲁木齐市天山区中考数学对点突破模拟试卷含解析
- 装修工程施工安全管理措施
- 《养老社区停车空间选址及车位配建指标指南》
- 《文言文二则》(第1课时)教学课件
- 公司技术部工作管理制度
评论
0/150
提交评论