估计水塔的水流量
1、问题提出:
某地区用水管理机构需要对居民的用水速度(单位时间的用水量) 和日总用水量进行估计。现有一居民区,其自来水是由一个圆柱形水塔提供,水塔高12.2m,塔的直径为17.4m。水塔是由水泵根据水塔中的水位自动加水,一般水泵每天工作两次,按照设计,当水塔中的水位降至最低水位,约8.2m时,水泵自动启动加水;当水位升高到最高水位,约10.8m时,水泵停止工作。
表1给出的是某一天的测量数据,测量了28个时刻的数据,但由于水泵正向水塔供水,有三个时刻无法测到水位(表中用—表示),试建立数学模型,来估计居民的用水速度和日用水量。
表1 水塔中水位原始数据
2、问题分析:
日用水量 用水速度 每个时刻水塔中水的体积
3、模型假设:
影响水从水塔中流出的流量的唯一因素是公众对水的传统要求; 水塔中的水位、气候条件、温度变化等不影响水流量的大小; 水泵充水速度水塔的水流量与水泵状态独立; 恒定,且远大于水塔的水流速度; 水流量曲线是一条连续光滑的曲线; 表1数据是准确的; 4、模型的建立与求解: (1)、 水塔中水的体积
其中,V ? ? r d ,(r为底面半径,d为水面高度) (2)在Matlab命令窗口直接运行(不包括未知三点)
>>t=[0,0.921,1.843,2.949,3.871,4.978,5.900,7.006,7.928,8.967,10.954,12.032,12.954,13.875,14.982,15.903,16.826,17.931,19.037,19.959,20.839,22.958,23.880,24.986,25.908];
>>v=[2301.1,2254,2213.3,2169.8,2135.8,2095.9,2065.4,2027.1,1994.6,1954.6,2572.9,2496.8,2427.8,2362.7,2295.4,2237.3,2182.9,2121.3,2059.7,2005.3,1954.6,2572.9,2518.4,2462.0,2420.7]; >> scatter(t,v) 得到
水塔中水体积的散点图
26002
2500240023002200210020001900051015202530
(3)在Matlab中编写脚本文件(不包括未知三点)
采用数值微分的一阶微商的两点公式(末位处近似为sd(n)=sd(n-1))
t=[0,0.921,1.843,2.949,3.871,4.978,5.900,7.006,7.928,8.967,10.954,12.032,12.954,13.875,14.982,15.903,16.826,17.931,19.037,19.959,20.839,22.958,23.880,24.986,25.908];
v=[2301.1,2254,2213.3,2169.8,2135.8,2095.9,2065.4,2027.1,1994.6,1954.6,2572.9,2496.8,2427.8,2362.7,2295.4,2237.3,2182.9,2121.3,2059.7,2005
.3,1954.6,2572.9,2518.4,2462.0,2420.7]; for i=1:9
sd(i)=abs((v(i+1)-v(i))/(t(i+1)-t(i))); end
sd(10)=sd(9); for i=11:20
sd(i)=abs((v(i+1)-v(i))/(t(i+1)-t(i))); end
sd(21)=sd(20); for i=22:24
sd(i)=abs((v(i+1)-v(i))/(t(i+1)-t(i))); end
sd(25)=sd(24); scatter(t,sd) hold on plot(t,sd)
得到
水塔中水流速度的散点图及光滑图
75706560555045403530051015202530
(4)预测水塔中的未知流速
[1]在Matlab中运行脚本文件(不包括未知三点):
采用数值微分的一阶微商的两点公式(末位处近似为sd(n)=sd(n-1))
t=[0,0.921,1.843,2.949,3.871,4.978,5.900,7.006,7.928,8.967,10.954,12.032,12.954,13.875,14.982,15.903,16.826,17.931,19.037,19.959,20.839,22.958,23.880,24.986,25.908];
v=[2301.1,2254,2213.3,2169.8,2135.8,2095.9,2065.4,2027.1,1994.6,1954.6,2572.9,2496.8,2427.8,2362.7,2295.4,2237.3,2182.9,2121.3,2059.7,2005.3,1954.6,2572.9,2518.4,2462.0,2420.7]; for i=1:9
sd(i)=abs((v(i+1)-v(i))/(t(i+1)-t(i)));
end
sd(10)=sd(9); for i=11:20
sd(i)=abs((v(i+1)-v(i))/(t(i+1)-t(i))); end
sd(21)=sd(20); for i=22:24
sd(i)=abs((v(i+1)-v(i))/(t(i+1)-t(i))); end
sd(25)=sd(24); sd 得到
速度(不包括未知三点)
sd =
Columns 1 through 9
51.1401 44.1432 39.3309 36.8764 36.0434 33.0803 34.6293 35.2495 38.4986 Columns 10 through 18
38.4986 70.5937 74.8373 70.6840 60.7949 63.0836 58.9382 55.7466 55.6962 Columns 19 through 25
59.0022 57.6136 57.6136 59.1106 50.9946 44.7939 44.7939
[2]采用拉格朗日插值法估计未知三点的速度: 在Matlab命令窗口直接运行 >> x0=[7.928,8.967];
>> y0=[38.4968,38.4968]; >> lglr3(x0,y0,9.981) ans =
38.4968
>> x0=[8.967,9.981];
>> y0=[38.4968,38.4968]; >> lglr3(x0,y0,10.925) ans =
38.4968
>> x0=[19.959,20.839]; >> y0=[57.6136,57.6136]; >> lglr3(x0,y0,22.015) ans =
57.6136
[3]在Matalb中运行脚本文件
t=[0,0.921,1.843,2.949,3.871,4.978,5.900,7.006,7.928,8.967,9.981,10.925,10.954,12.032,12.954,13.875,14.982,15.903,16.826,17.931,19.037,19.
959,20.839,22.015,22.958,23.880,24.986,25.908];
sd=[51.1401,44.1432,39.3309,36.8764,36.0434,33.0803,34.6293,35.2495,38.4986,38.4968,38.4968,38.4986,70.5937,74.8373,70.6840,60.7949,63.0836,58.9382,55.7466,55.6962,59.0022,57.6136,57.6136,57.6136,59.1106,50.9946,44.7939,44.7939]; scatter(t,sd) hold on plot(t,sd)
得到
水塔中水流速度的散点图及光滑图(new)
75706560555045403530051015202530
(4)a、通过曲线拟合,拟合出上述函数(f1)
b、通过数值积分(梯形,辛普森)求出用水量(f2) 5、模型检验:
应该另外测试一批数据检验模型(f1,f2) 6、模型分析:
(1) 4.(3)中末位处近似为sd(n)=sd(n-1)可以改进,比如先采用数值微分求1----(n-1)的速度,再采用拉格朗日插值法求末位n的速度;
(2) 拉格朗日插值可以改用其他更为精确的插值法
(3) 数值微分法可以采用其他的更为精确的方法(而不是一阶微商的两点公式) (4) 4.(4)中的两部暂时不会 (5) 模型假设处可能有一些瑕疵 7、附录: