數(shù)學(xué)建模論文鉆井布局設(shè)計_第1頁
數(shù)學(xué)建模論文鉆井布局設(shè)計_第2頁
數(shù)學(xué)建模論文鉆井布局設(shè)計_第3頁
數(shù)學(xué)建模論文鉆井布局設(shè)計_第4頁
數(shù)學(xué)建模論文鉆井布局設(shè)計_第5頁
已閱讀5頁,還剩14頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、課 程 設(shè)計(論文)任務(wù)書專業(yè)班級: 應(yīng)用數(shù)學(xué)0801 學(xué)生姓名: 指導(dǎo)教師(簽名): 一、課程設(shè)計(論文)題目鉆井布局模型二、本次課程設(shè)計(論文)應(yīng)達到的目的課程設(shè)計(論文)是實踐教學(xué)環(huán)節(jié)的重要組成部分,其目的是通過課程設(shè)計(論文)加深學(xué)生對本課程基本知識的理解,提高綜合運用知識的能力;掌握本課程的主要內(nèi)容、工程設(shè)計或撰寫論文的步驟和方法;提高制圖能力,學(xué)會應(yīng)用有關(guān)設(shè)計資料進行設(shè)計計算和理論分析的方法,以提高學(xué)生獨立分析問題、解決問題的能力,逐步增強實際工程訓(xùn)練。三、本次課程設(shè)計(論文)任務(wù)的主要內(nèi)容和要求(包括原始數(shù)據(jù)、技術(shù)參數(shù)、設(shè)計要求等) 勘探部門在某地區(qū)找礦。初步勘探時期已零散地在若

2、干位置上鉆井,取得了地質(zhì)資料。進入系統(tǒng)勘探時期后,要在一個區(qū)域內(nèi)按縱橫等距的網(wǎng)格點來布置井位,進行“撒網(wǎng)式”全面鉆探。由于鉆一口井的費用很高,如果新設(shè)計的井位與原有井位重合(或相當(dāng)接近),便可利用舊井的地質(zhì)資料,不必打這口新井。因此,應(yīng)該盡量利用舊井,少打新井,以節(jié)約鉆探費用。 四、應(yīng)收集的資料及主要參考文獻: 收集資料:網(wǎng)格遍歷求解、窮舉算法、matlab編程 等參考文獻:1周承高, 廖園.優(yōu)化方法及應(yīng)用程序設(shè)計m. 北京: 中國鐵道出版社, 1989.2 張圣勤編著.matlab7.0實用教程m.北京:機械工業(yè)出版社,20093劉來福, 曾文藝.數(shù)學(xué)模型與數(shù)學(xué)建模m. 北京: 北京師范大學(xué)

3、出版社, 1997, 8.4 謝兆鴻編著.數(shù)學(xué)建模技術(shù)m.北京:中國水利水電出版社,2003五、審核批準(zhǔn)意見教研室主任(簽字) 目錄摘要 31 問題重述 42 模型建設(shè) 53 相關(guān)變量及其說明 54 模型的建立 54.1 問題1) 54.2 問題2) 64.3 鉆井布局算法實現(xiàn) 74.4 對問題3)的討論 105 參考文獻 126 致謝 137 附錄 14鉆井布局模型摘要勘探部門在某地區(qū)找礦。要在一個區(qū)域內(nèi)按縱橫等距的網(wǎng)格點來布置井位,進行“撒網(wǎng)式”全面鉆探。由于鉆一口井的費用很高,如果新設(shè)計的井位與原有井位重合(或相當(dāng)接近),便可利用舊井,不必打新井。因此應(yīng)該盡量利用舊井,少打新井,以節(jié)約鉆

4、探費用。本文根據(jù)鉆井布局的實際情況,對鉆進布局問題做了深入的研究。力求找到變化中的不變量。討論了在一個區(qū)域內(nèi)按縱橫等距的點來布置井位的問題,通過移動網(wǎng)格使舊井利用最多,采用網(wǎng)格遍歷求解的方法得到很好的計算精度。最后得到問題1)的解為:i=2,4,5,10時的舊井可以利用;經(jīng)分析可知問題1)是問題2)的特殊形式,故問題2)可采用類似的方法,求得的解為:i=1, 6, 7, 8, 9, 11的舊井可以利用。關(guān)鍵詞:網(wǎng)格遍歷法,結(jié)點,移動,覆蓋1 問題重述勘探部門在某地區(qū)找礦。要在一個區(qū)域內(nèi)按縱橫等距的網(wǎng)格點來布置井位,進行“撒網(wǎng)式”全面鉆探。由于鉆一口井的費用很高,如果新設(shè)計的井位與原有井位重合(

5、或相當(dāng)接近),便可利用舊井,不必打新井。因此應(yīng)該盡量利用舊井,少打新井,以節(jié)約鉆探費用。設(shè)平面上有n個點pi,其坐標(biāo)為(ai,bi),i=1,2,n,表示以有的n個井位。新布置的井位是一個正方形網(wǎng)格n的所有結(jié)點(所謂“正方形網(wǎng)格”是指每個格子都是正方形的網(wǎng)格;結(jié)點是指縱線和橫線的交叉點)。假定每個格子的邊長都是1單位。整個網(wǎng)格是可以在平面上任意移動的。若一個已知點pi與某個網(wǎng)格結(jié)點xi的距離不超過給定誤差=(0.05單位),則認為pi處的舊井資料可用,不必在結(jié)點xi處打新井。為進行輔助決策,勘探部門要求我們研究以下問題:1) 假定網(wǎng)格的橫向和縱向是固定的(比如東西南北),并規(guī)定兩點間的距離為其

6、橫向距離(橫坐標(biāo)之差絕對值)及縱向距離(縱坐標(biāo)之差絕對值)的最大值。在平面上平行移動網(wǎng)格n,使可利用的舊井?dāng)?shù)盡可能大。試提供數(shù)值計算方法,并對下面的數(shù)值例子用計算機進行計算。2) 在歐氏距離的誤差意義下,考慮網(wǎng)格的橫向和縱向不固定(可以旋轉(zhuǎn))的情形,給出算法及計算結(jié)果。3) 如果有n口舊井,給出判定這些井均可利用的條件和算法(你可以任意選定一種距離)。數(shù)值例子 n=12個點的坐標(biāo)如下表所示:i123456789101112ai0.501.413.003.373.404.724.725.437.578.388.989.50bi2.003.501.503.515.502.006.244.102.0

7、14.503.410.802 模型假設(shè)1) 正方形網(wǎng)格n可以覆蓋n個井位;2) 每個格子的邊長為1;3) 舊井位點pi(ai,bi)初始坐標(biāo)位于第一象限,網(wǎng)格n可以任意移動;4) 把舊井位點看作質(zhì)點;初始位置網(wǎng)格的某條橫線和縱線與坐標(biāo)軸重合,并記交點q與原點o重合3 相關(guān)變量及其說明1) pi(ai,bi) i=1,2,n:舊井位點的坐標(biāo);2) dpixi:pi到結(jié)點xi的距離;3) :誤差;4) (x1i,y1i),(x2i,y2i):pi所在方格對角線頂點坐標(biāo);(x1ix2i,y1iy2i);5) b:網(wǎng)格每次移動的步長 c:每次旋轉(zhuǎn)的角度;6) m,n:橫向與縱向移動的次數(shù)(橫向向右,縱

8、向向上);7) s:旋轉(zhuǎn)的次數(shù)(逆時針);8) q(p,q):變化后q點的坐標(biāo);9) 如果第pi個舊井可利用;則ti=1否則ti=0;10) nj=:第j個位置可利用舊井的總數(shù);如果平移,則j=1,2,mxn;如果旋轉(zhuǎn),則j=1,2,m x n x s;4 模型的建立4.1 問題1)1 計算移動后pi所在方格對角線頂點坐標(biāo),移動后,原對角線頂點 坐標(biāo)變?yōu)椋▁1i + m.b , y1i + n.b),(x2i + m.b , y2i + n.b)(其中:m.b,n.b=ai&y1i+nb=bi),則(x1i +mb-1,y1i+nb)(x2i,y2i).即將新坐標(biāo)作為pi所在方格的(x2i,y

9、2i)同理:如果(x1i+mbai&y1i+nbbi)則(x1i +mb-1,y1i+nb)(x1i,y1i).如果(x1i+mbbi)則(x1i +mb,y1i+nb-1)(x1i,y1i).如果(x1i+mb ai&y1i+nbbi)則(x1i +mb,y1i+nb)(x1i,y1i).2. 求dpixi.令d1=|x1i-ai|,d2=|ai-x2i|,d3=|y1i-bi|,d4=|bi-y2i|.則dpixi=mc(d1,d2,d3,d4) mc(di)指di中次小的.3. 判斷誤差并確定pi是否可用 如果dpixi,ti=04. 計算njnj= j=1,2,.,mn5. n=max

10、(nj),同時記下m,n值及q(mb,nb).根據(jù)上述步驟,利用計算機計算(見附錄)可得最后結(jié)果為:可利用點為第2, 4, 5,10 點4.2 問題2)同一坐標(biāo)系下,將網(wǎng)格n旋轉(zhuǎn)相當(dāng)于將pi反方向旋轉(zhuǎn)每次旋轉(zhuǎn)的角度c=/r,r=max()所以 c 并且 s*c=x1i&bi=y2i),則(x1i,y1i)(x1i,y1i)如果(aix1i&biy2i),則(x1i-1,y1i)(x1i,y1i)如果(aiy2i),則(x1i-1,y1i+1)(x1i,y1i)3. 求 dpixid1=,d2=d3=,d4=則dpixi=min(d1,d2,d3,d4)4. 執(zhí)行問題1)的3,4,5根據(jù)以上步驟

11、,過程中取b=c=0.05,用計算機編程求得可利用點為6個,即第1, 6, 7, 8, 9, 11 點.4.3 鉆井布局算法實現(xiàn):我們研究的問題是:已知舊井的位置,確定可以重用舊井的最多的個數(shù)。假設(shè)有一網(wǎng)格可以在井分布的區(qū)域移動,這樣只要舊井與網(wǎng)格的某個節(jié)點距離=0.05那么認為這口舊井是可以重用的,具體計算機實現(xiàn)時我們考慮到網(wǎng)格的每個小方格是全等的,這樣我們在移動網(wǎng)格時只需整體上下移動1單位即可,另外我們是以一個參考點q(開始在原點)在一單位的小方格中移動來處理的。移動步長我們設(shè)定為0.01,即共要移動100*100次。在第二問,考慮旋轉(zhuǎn)的情況下,便于計算,我們移動的是原來的舊井而不是方格,

12、這樣便于處理,同時在第一問的基礎(chǔ)上每移動一次,我們都要對原來的舊井點坐標(biāo)逆時針旋轉(zhuǎn)90度(我們步長暫設(shè)定為1度,根據(jù)計算機實現(xiàn)情況,當(dāng)步長為1時運行時間已達到15分鐘左右),計算可以重用的舊井的個數(shù)。到了第三問,我們還是考慮到網(wǎng)格的全等對稱性,考慮將所有的舊井移動到近量小的范圍,我們用逆向思維考慮:將網(wǎng)格放在適當(dāng)?shù)奈恢?,如果舊井都可以重用的話,一定可以將這些井的橫縱坐標(biāo)加上m,n單位(n,m可以小于零)將所有的舊井移動到某個節(jié)點的周圍,并且新位置井位與這個節(jié)點的距離=0.05。這樣只要將原來的節(jié)點移動到點(1,1)周圍,做一個盡量小且能包圍所有新位置井位的圓,如果圓的直徑=2*0.05那么這些

13、舊井都可以重用。計算機實現(xiàn)流程圖如下:井點坐標(biāo)數(shù)據(jù)值顯示井點坐標(biāo)舊井點數(shù)數(shù)據(jù)值輸入程序入口處理結(jié)果數(shù)據(jù)處理選擇是否需要考慮旋轉(zhuǎn)可進行相應(yīng)處理紀(jì)錄未移動前pi所在方格的定點坐標(biāo)紀(jì)錄可重用井點變量加1,jnk1:=jnk1+1用md與0.05比較,若md0.05認為此舊井可以重用函數(shù)mind具體實現(xiàn)過程count具體實現(xiàn)求出pi到四個頂點的最短距離md求出網(wǎng)格移動后pii所在方格的定點坐標(biāo)x1,y1,x2,y2紀(jì)錄s,t的值s,t循環(huán)10000 返回循環(huán)s,t繼續(xù)移動網(wǎng)格的位置結(jié)果輸出:沒移動網(wǎng)格一次時,可重用舊井的個數(shù)及相應(yīng)網(wǎng)格的位置(q點的坐標(biāo)(s*0.01,t*0.01))以上是在沒有考慮旋

14、轉(zhuǎn)時的流程圖,對于考慮旋轉(zhuǎn)時的情況,只需改變一下count過程和mind函數(shù)即可,還需要增加一層循用來考慮旋轉(zhuǎn)90度的情況,解決解決方案與不考慮旋轉(zhuǎn)時大同小異。 用程序解決問題一,我們將運行結(jié)果存到文件jieguo.xls中經(jīng)分析知在我們的精確度范圍內(nèi)最多可以重用井的個數(shù)是4個,相應(yīng)網(wǎng)格的位置是:祥見jieguo.xls。在算法優(yōu)化的基礎(chǔ)上我們還可以對這兩個點的周圍區(qū)域在進行循環(huán)查找看看是否有更多的舊井可以重用。 最后我們分析一下我們的算法復(fù)雜度,這對于優(yōu)化算法,提高程序的執(zhí)行效率是非常重要的。解決問題一時總的運行次數(shù)大約是n*10000次,若考慮旋轉(zhuǎn)時運行次數(shù)更是龐大的驚人:n*900000

15、,因此程序執(zhí)行時間是比較長的,大約需要8s左右,分析輸出的數(shù)據(jù)知,很多結(jié)果是沒用的或者不需要程序循環(huán),因此,我們可以這樣優(yōu)化程序:開始的時候我們的循環(huán)步值適當(dāng)大些,這樣可以粗略的找到合適的網(wǎng)格位置,我們再在這個位置上進行細化最終得到最終最優(yōu)結(jié)果,這樣處理我們的程序循環(huán)次數(shù)會減少到至少0.1倍,同樣在考慮旋轉(zhuǎn)的情況下 我們也作這樣的處理以便優(yōu)化程序、提高運行效率、減少運行時間。4.4 對問題 3)的討論1 根據(jù)題意,n口舊井均可利用的條件是由n口舊井的位置決定的,也就是說,n口舊井在滿足一定位置關(guān)系的條件下都是可以重用的。我們要計算的就是這種關(guān)系。2. 如果舊井pi(ai,bi)可利用,則pi(

16、ai+m,bi+n)也可利用。由此,可把所有的舊井位點移到某個點的周圍。令d=max(pi pj)(問題1)中的距離)。 pi pj:表示移動后舊井位點任意兩點的距離,如果d=0.5并且yi=0.5 那么新坐標(biāo)是(xi,yi)(xi,yi);(2)、xi=0.5 那么新坐標(biāo)是(xi+1,yi)(xi,yi);(3)、xi=0.5并且yi0.5 那么新坐標(biāo)是(xi,yi+1)(xi,yi);(4)、xi0.5并且yi0.5 那么新坐標(biāo)是(xi+1,yi+1)(xi,yi);4. 接下來要求pipj的最大距離d(問題1)中的距離)。令u1=min(xi),u2=max(xi);v1=min(yi)

17、,v2=max(yi);(i=1,2,n)則d=max(u2-u1,v2-v1)由此可得所有舊井均可利用的條件:d=2。5 參考文獻1周承高, 廖園.優(yōu)化方法及應(yīng)用程序設(shè)計m. 北京: 中國鐵道出版社, 1989.2 張圣勤編著.matlab7.0實用教程m.北京:機械工業(yè)出版社,20093劉來福, 曾文藝.數(shù)學(xué)模型與數(shù)學(xué)建模m. 北京: 北京師范大學(xué)出版社, 1997, 8.4 謝兆鴻編著.數(shù)學(xué)建模技術(shù)m.北京:中國水利水電出版社,20036 致謝本篇論文的創(chuàng)作,離不開老師耐心而正確的指導(dǎo),離不開各類參考資料給予的啟發(fā)和幫助。在此,我表示鄭重的感謝。同時對在本篇論文創(chuàng)作過程中給予過我無私幫助

18、的學(xué)長和各位同學(xué)表示誠摯的感謝。另外,由于時間緊迫和水平有限,本篇論文難免有所錯誤和疏漏,請您批評指正,不吝賜教。7 附錄:7.1 問題1)的源程序:(1)、自定義過程及函數(shù) function mind(k:integer): real;var secondd:array1.4 of real; i,j:integer; l:real;/做交換中間變量begin/求的pi點與所在方框四個點即距離 secondd1:=abs(x1k-pk1);secondd2:=abs(y1k-pk2); secondd3:=abs(x2k-pk1);secondd4:=abs(y2k-pk2); for i:

19、=1 to 3 do for j:=i+1 to 4 do begin if seconddiseconddj then begin l:=seconddi; seconddi:=seconddj; seconddj:=l; end; end; result:=secondd3;end;function mindk(k:integer): real;var secondd:array1.4 of real;/存儲四個點的即距離 i,j:integer; l:real;begin /求的pi點與所在方框四個點即距離secondd1:=sqrt(pk1-x1k)*(pk1-x1k)+(pk2-y1

20、k)*(pk2-y1k);secondd2:=sqrt(pk1-x1k)*(pk1-x1k)+(pk2-y2k)*(pk2-y2k);secondd3:=sqrt(pk1-x2k)*(pk1-x2k)+(pk2-y1k)*(pk2-y1k);secondd4:=sqrt(pk1-x2k)*(pk1-x2k)+(pk2-y2k)*(pk2-y2k);/對距離進行排序,同時返回最小值 for i:=1 to 3 do for j:= 1 to 4 do begin if seconddia then boo1:=true else boo1:=false; if yb then boo2:=tru

21、e else boo2:=false; / 求出坐標(biāo) if boo1 and boo2 then begin x2k:=x1k; y2k:=y1k; x1k:=x1k-1;y1k:=y1k-1; end; if boo1 and not boo2 then begin x2k:=x1k-1; y2k:=y1k+1; end; if not boo1 and boo2 then begin x2k:=x1k+1; y2k:=y1k-1; end;end;procedure tform1.countk(a:real;b:real;x:real;y:real;k:integer);varboo1,b

22、oo2:boolean;begin boo1:=ay; / 求出坐標(biāo) if boo1 and boo2 then begin end; if not boo1 and boo2 then begin x2k:=x1k+1; y2k:=y1k+1; end; if not boo1 and not boo2 then begin x2k:=x1k+1; y2k:=y1k-1; end; if boo1 and not boo2 then begin x2k:=x1k-1; y2k:=y1k-1; end;end;(2)、變量定義部分 var form1: tform1; p,p1:array o

23、f ar;/存儲舊井的坐標(biāo) jn:array1.10000 of ar1; /存儲結(jié)果 x1,y1,x2,y2:array of real; /存儲某個p點所在的方格對角線的倆頂點的坐標(biāo) jw:array1.10000 of string; /不考慮旋轉(zhuǎn)的情況結(jié)果 i:integer; n:integer; /舊井的個數(shù) s,t:integer;/s,t網(wǎng)格移動部數(shù)(3)、程序?qū)崿F(xiàn)部分 var k:integer; md:real;/存儲最短距離 mess:string;begin for s:=0 to 99 do for t:=0 to 99 do begin for k:=1 to n

24、do begin x1k:=int(pk1); y1k:=int(pk2); x2k:=x1k+1+0.01*s; y2k:=y1k+1+0.01*t; x1k:=x1k+0.01*s; y1k:=y1k+0.01*t; count(pk1,pk2,x1k,y1k,k);/求得i所在的方格的對郊縣的兩頂點的坐標(biāo) md:=mind(k); if md0.05 then begin jns*100+t+11:=jns*100+t+11+1;/如果最小距離小與0.05 那么可用井的個數(shù)jns*t+11加1; jws*100+t+1:=jws*100+t+1+ +inttostr(k); end; e

25、nd; jns*100+t+12:=s; jns*100+t+13:=t; mess:=floattostr(jns*100+t+11)+個+char(9)+floattostr(jns*100+t+12*0.01)+char(9)+floattostr(jns*100+t+13*0.01)+char(9)+jws*100+t+1; memo1.lines.add(mess); end;7.2 問題2)的源程序: var k,o:integer;/k,循環(huán)n次計算n各界點;o 循環(huán)90次 mdk:real;/存儲最短距離 mess:string; f_x,f_y,bi:real;beginfor k:=1 to n do for o:=1 to 2 do p1ko:=pko; /初始化p1k 用于初始化 for s:=0 to 99 do for t:=0 to 100 do begin for k:=1 to n do/初始化pk for o:=1 to 2 do pko:=p1ko; /旋轉(zhuǎn)90度步長1度 for o:=1 to 89 do begin

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論