最优捕鱼策略问题

为了保护人类赖以生存的自然环境,可再生资源(如渔业、林业资源)的开发必须适度。一种合理、简化的策略是,在实现可持续收获的前提下,追求最大产量或最佳效益。

考虑对鳀鱼的最优捕捞策略:假设这种鱼分4个年龄组,称为1龄鱼,2龄鱼,3龄鱼,4龄鱼。各年龄组每条鱼的平均质量分别为5.07、11.55、17.86、22.99(g),各年龄组的自然死亡率为0.8(1/年),这种鱼为季节性集中产卵繁殖,平均每条4龄鱼的产卵量为1.109×1011(个),3龄鱼的产卵量为这个数的一半,2龄鱼和1龄鱼不产卵,产卵和孵化期为每年的最后4个月,卵孵化并成活为1龄鱼,成活率(1龄鱼条数与产卵量n之比)为1.22×1011/(1.22×1011+n)。

渔业管理部门规定,每年只允许在产卵孵化期前的8个月进行捕捞作业。如果每年投入的捕捞能力(如渔船数、下网次数等)固定不变,这时单位时间捕捞量将与各年龄组鱼群条数成正比,比例系数不妨设为捕捞强度系数。通常使用13mm网眼的拉网,这种网只能捕捞3龄鱼和4龄鱼,其两个捕捞系数之比为0.42:1.渔业上称这种方式为固定努力量捕捞。

①建立数学模型分析如何实现可持续捕捞(即每年开始捕捞时渔场中各年龄组鱼群条数不变),并且在此前提下得到最高的年收获量(捕捞总质量)。

②某渔业公司承包这种鱼的捕捞业务5年,合同要求5年后鱼群的生产能力不能受到太大破坏。已知承包时各年龄组鱼群的数量分别为:122,29.7,10.1,3.29(×109条),如果仍用固定努力量的捕捞方式,该公司应采取怎样的策略才能使总收获量最高。

(1)问题的分析与模型的建立

问题假设

①鱼群总量的增加虽然是离散的,但对于大规模的鱼群而言,可设鱼群总量的变化随时间是连续的。

②据题目给出的条件,可设鱼群每年在8月底瞬间产卵完毕,卵在12月底全部孵化完毕。

③i龄鱼到第二年分别长一岁成为i+1龄鱼,i=1,2,3。

④4龄鱼在年末留存的数量占全部数量的比例很小,可假设全部死亡。

⑤持续捕获使各年龄组的鱼群数量呈周期变化,周期为1年,可以只考虑鱼群数量在1年内的情况。

问题分析

①符号说明。

xi(t)——在t时刻i龄鱼条数,i=1,2,3,4;

k——4龄鱼捕捞强度系数;

n——每年产卵量;

ai——每年初i龄鱼的数量,i=1,2,3,4。

②对死亡率的理解。题中给出鱼的自然死亡率为0.8(1/年),我们理解为平均死亡率,这是单位时间鱼群死亡数量与现有鱼群数量的比例系数,由假设可知,它是一个与环境等其他因素无关的常数。鱼群的数量是连续变化的,且1龄鱼、2龄鱼在全年及3龄鱼、4龄鱼在后4个月的数量只与死亡率有关,各龄鱼的数量满足

,t∈[0,1](i=1,2)

,t∈[2/3,1](i=3,4)

③捕捞强度系数的理解。单位时间4龄鱼捕捞量与4龄鱼群总数成正比,比例系数即为捕捞强度k,它是一定的,且只在捕捞期内(即每年的前8个月)捕捞3龄鱼,4龄鱼。所以,一方面捕捞强度系数决定了3龄鱼、4龄鱼在捕捞期内的数量,其变化规律为

,t∈[0,2/3]

,t∈[0,2/3]

另一方面也决定了t时刻捕捞3龄鱼、4龄鱼,其数量分别为0.42kx3(t)和kx4(t)。

④成活率的理解。由于只有3龄鱼、4龄鱼在每年8月底一次产卵,因此可将每年的产卵量n表示为

 

题目中已经说明成活率为,所以每年年初的1龄鱼的数量为

 

(2)Matlab模拟程序与结果

模型如下:

 

s.t

,t∈[0,1]

,t∈[0,1]

,t∈[0,2/3]

,t∈[2/3,1]

,t∈[0,2/3]

,t∈[2/3,1]

计算机程序模拟实验程序:先建立两个M-file。

%[buyu.m]最优捕鱼策略问题

function y=buyu(x)

global a10 a20 a30 a40 total k;

syms k a10;

x1=dsolve('Dx1=-0.8*x1','x1(0)=a10');

t=1;a20=subs(x1);

x2=dsolve('Dx2=-0.8*x2','x2(0)=a20');

t=1;a30=subs(x2);

x31=dsolve('Dx31=-(0.8+0.42*k)*x31','x31(0)=a30');

t=2/3;a31=subs(x31);

x32=dsolve('Dx32=-0.8*x32','x32(2/3)=a31');

t=1;a40=subs(x32);

x41=dsolve('Dx41=-(0.8+k)*x41','x41(0)=a40');

t=2/3;a41=subs(x41);

x42=dsolve('Dx42=-0.8*x42','x42(2/3)=a41');

nn=1.109*10^5*(0.5*a31+a41);

eq1=a10-nn*1.22*10^11/(1.22*10^11+nn);

S=solve(eq1,a10);a10=S(2);

syms t;

t3=subs(subs(int(0.42*k*x31,t,0,2/3)));

t4=subs(subs(int(k*a41,t,0,2/3)));

total=17.86*t3+22.99*t4;

k=x;

y=subs(-total);

 

%[buyu1.m]最优捕鱼策略问题

global a10 a20 a30 a40 total;

[k,mtotal]=fminbnd('buyu',16,18);

ezplot(total,0,25)

xlabel('捕捞强度系数')

ylabel('总收获量(g)')

title('捕捞强度——总收获量曲线图')

format long;

k

total=-mtotal

a10=eval(a10)

a20=eval(a20)

a30=eval(a30)

a40=eval(a40)

format short

clear

 

在Matlab中输入命令:buyu1,回车即得:

k = 17.86984648968516, total = 3.869962667986214e+011,

a10 = 1.192332637390619e+011, a20 = 5.357495888418817e+010

a30 = 2.407278077805501e+010, a40 = 7.262288087797806e+007

同时,还得到图形——图1。

当k=17.86984648968516时,最高年收获量为totalT=3.869962667986214e+011(g),此时每年年初四种龄鱼的数量分别为:

1.192332637390619e+011

5.357495888418817e+010

2.407278077805501e+010

7.262288087797806e+007

关于第二个问题的求解,在此略去。

 

参考文献

[1] 李志林,欧宜贵,数学建模及其典型案例分析,北京:化学工业出版社,2006.12

 

参考页码及索取号

[1] Page22; O141.4/L.Z.L

 

重点注意:用Matlab编程解决数学问题。

posted @ 2014-07-25 15:48  loving wenqure  阅读(2800)  评论(1编辑  收藏  举报