版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)
文檔簡介
1、數(shù)學(xué)建模作業(yè):自來水管道連接規(guī)劃模型自來水管道連接規(guī)劃模型【摘要】:生活中需要通過自來水管道將自來水運輸至各個用戶處,本文分析討論自來水管道連接規(guī)劃問題,即在自來水管道鋪設(shè)過程中在繞開障礙物的前提下的最優(yōu)路徑問題,使自來水管道將各個供水點用最短路徑鏈接。根據(jù)對100個目標(biāo)點的數(shù)據(jù)進行篩選與分析,得出在用面積法排除障礙區(qū)域的前提下,對剩余點采用Kruskal算法生成最優(yōu)路的方案。初始給定的100個供水點中存在位于障礙區(qū)域中的點,采用合理的方法排除障礙區(qū)域中的點,將對管道鏈接的效率、能耗、可行性起到?jīng)Q定性作用,是一個非常實際的問題。本文將采用面積分析的方法,提供一種解決障礙區(qū)域判定的切實可行的方法
2、,在二維坐標(biāo)系上標(biāo)定各點,障礙區(qū)域用由陰影覆蓋的凸多邊形表出,通過對點坐標(biāo)之間的向量運算判定各點是否位于陰影區(qū)域,最終通過MatlabR2010a編程實現(xiàn)。在確定并剔除障礙區(qū)中的點位后,采用Kruskal閉圈算法生成最優(yōu)路徑,對于通過陰影區(qū)域的線段,采用將其權(quán)值設(shè)定為(無窮大)的處理方法,最終通過MatlabR2010a編程、繪圖,給出管道最優(yōu)連接方案,解決本問題。最后我們對模型的可行性,合理性,科學(xué)性進行了闡述,得到對模型的整體評價以及需改進之處?!娟P(guān)鍵詞】:管道連接 面積法 障礙點篩選Kruskal算法 權(quán)值 最小生成樹一. 問題重述自來水是人們?nèi)粘I钪胁豢扇鄙俚纳钜?,然而自來水管網(wǎng)
3、的組建卻有很多問題需要解決。一般來說,我們假設(shè)管網(wǎng)中任意兩個用戶之間存在直線段相連,但是在連接過程中,有些區(qū)域是必須繞開的,這些必須繞開的區(qū)域我們稱為障礙區(qū)域。表1給出了若干個可能的用戶的地址的橫縱坐標(biāo),可能的用戶的含義是:如果用戶的地址不在障礙區(qū)域內(nèi),那么該用戶就是需要使用自來水的用戶(即有效用戶),否則如果用戶的地址在障礙區(qū)域內(nèi),那么該用戶就是無效用戶(即不要將該用戶連接在網(wǎng)絡(luò)中)。表2-表5是分別是4個障礙區(qū)域必須要覆蓋的點的坐標(biāo),而對應(yīng)障礙區(qū)域就是覆蓋這些要覆蓋的點的最小凸集。(1) 請您判定表1中那些用戶為有效用戶。(2) 請設(shè)計算法篩選有效用戶之間的有效線段。(3)請設(shè)計一個算法將
4、有效用戶用有效線段連接起來,并且連接的距離總和最小。表1(見附錄一)表2障礙區(qū)域1必須要覆蓋的點的坐標(biāo)頂點序號頂點的橫坐標(biāo)頂點的縱坐標(biāo)13.2060 12.9166217.457119.337734.7576 20表3障礙區(qū)域2必須要覆蓋的點的坐標(biāo)頂點序號頂點的橫坐標(biāo)頂點的縱坐標(biāo)150 30253.746548.4490346.922257.1195433.320739.8050543.112356.3187表4障礙區(qū)域3必須要覆蓋的點的坐標(biāo)頂點序號頂點的橫坐標(biāo)頂點的縱坐標(biāo)154.698270253.746590346.922280表5障礙區(qū)域4必須要覆蓋的點的坐標(biāo)頂點序號頂點的橫坐標(biāo)頂點的縱
5、坐標(biāo)190752809537080二模型假設(shè)1, 假設(shè)任意兩個用戶之間以直線連接;2, 不在障礙區(qū)中的用戶都通過自來水管道獲得自來水供應(yīng);3, 以所有管道總距離最小為目的;4, 障礙區(qū)域就是障礙頂點圍成的凸多邊形區(qū)域;5, 文中給出所有點的坐標(biāo)值準(zhǔn)確無誤;6, 在非障礙區(qū)用戶之間可確保用直線連接;7, 要保證在任意兩點間線段不過障礙區(qū)的情況下,求解連接形成的最短路徑;三符號說明表6 論文符號說明符號含義A記錄100個用戶點的坐標(biāo)信息B障礙區(qū)1的各頂點坐標(biāo)信息C障礙區(qū)2的各頂點坐標(biāo)信息D障礙區(qū)3的各頂點坐標(biāo)信息E障礙區(qū)4的各頂點坐標(biāo)信息SIGN記錄各用戶點是否在障礙區(qū),若在對應(yīng)位置記為1;若不在
6、,則對應(yīng)位置記為0OUTSIGN記錄在障礙區(qū)的用戶點的序號p記錄保留用戶點的個數(shù)NUM記錄任意兩用戶點之間可用線段連接起來且不過障礙區(qū)的線段DIS記錄不在障礙區(qū)各用戶點之間可用不過障礙區(qū)線段連接的線段的長度EE記錄生成的最小生成樹的各點及各線段信息sum表示產(chǎn)生的最小生成樹中所有管道的總長四問題分析解決問題的第一步是排除障礙區(qū)域的影響。如果用戶點位于障礙區(qū)域之外,則為有效用戶,否則,為無效線段。解決問題第二步,將任意兩個有效用戶用線段連接,如果任意兩個用戶點之間的線段通過障礙區(qū)域之內(nèi),則為無效線段,作剔除處理,篩選出有效線段。解決問題第三步,根據(jù)篩選出來的有效用戶點和有效線段生成最小生成樹連接
7、有效用戶點,畫出連接路線圖形,并計算生成樹長度。根據(jù)對模型的合理假設(shè),障礙區(qū)域即為已知若干障礙區(qū)頂點圍成的凸多邊形,故解決此問題的關(guān)鍵在于在已建立的二維坐標(biāo)系中,尋找到一種合理的算法能夠判定出點是否位于障礙區(qū)域中。通過直觀判斷,陰影區(qū)域的構(gòu)成由表7給出:表7 障礙區(qū)域構(gòu)成障礙區(qū)域編號構(gòu)成1由3個無效用戶坐標(biāo)點圍成的三角形2由5個無效用戶坐標(biāo)點圍成的凸五邊形3由3個無效用戶坐標(biāo)點圍成的三角形4由3個無效用戶坐標(biāo)點圍成的三角形通過設(shè)計運用面積法進行篩選點的程序,對所有點進行篩選,找到并排除障礙區(qū)域中的無效用戶,完成解決問題的第一步。接下來我們要做的是把任意兩個有效用戶點之間用線段連接,運用向量法設(shè)
8、計篩選線段的程序,篩選出所有不過障礙區(qū)的線段,完成解決問題的第二步。解決自來水管道連接問題的第三步需要我們設(shè)計一個程序,將所有有效用戶點連接起來,并使管道總距離最小。這是一個典型的最小生成樹問題,但相較以往最小生成樹問題又有著其特別之處,就是障礙區(qū)域的干擾,即管道無法穿過障礙區(qū),這使得坐標(biāo)系并非是一個連通區(qū)域,眾多算法無法直接使用。這就需要我們在對問題進行合理假設(shè)的前提下,對已有算法進行改良。我們通過對穿過障礙區(qū)的線段賦權(quán)值為無窮大的方法,利用Kruskal算法,生成最優(yōu)路徑。五模型的建立與求解: 5.1.問題一的模型建立和求解由問題分析可知,本問題的關(guān)鍵有二個:一是求確定各障礙區(qū)的面積以及用
9、戶點與各障礙區(qū)任意兩個定點構(gòu)成的三角形的面積之和;二是比較上面兩個面積,若相等,則該用戶點在障礙區(qū)內(nèi)為無效用戶,否則,用戶點不在障礙區(qū)內(nèi)為有效用戶。5.1.1運用向量的方法求解障礙區(qū)面積S若障礙區(qū)是三角形,對應(yīng)各頂點坐標(biāo)分別為(x1,y1),(x2,y2), (x3,y3)。則a=(x2-x1,y2-y1),b=(x3-x1,y3-y1)。由于三角形面積S=|a|*|b|*sin<a,b>/2,向量a,b外積的模長|a×b|=|a|*|b|*sin<a,b>則有S=|a×b|/2;若障礙區(qū)為五邊形,對應(yīng)點為(x1,y1),(x2,y2), (x3,y
10、3), (x4,y4),(x5,y5)。則劃分成三個三角形,各三角形的頂點分別為(x1,y1),(x2,y2), (x3,y3);(x3,y3), (x4,y4),(x5,y5);(x1,y1),(x3,y3), (x5,y5)。再用求三角形面積的方法求解即可。5.1.2運用向量的方法求用戶點與任意兩個同一障礙區(qū)的頂點構(gòu)成三角形的面積之和S1 該求解三角形面積的方法和5.1.1中求解三角形面積的方法相同。5.1.3判斷有效用戶 如果S=S1,則該用戶在障礙區(qū)內(nèi),為無效用戶。反之,為有效用戶。則篩選完畢的結(jié)果如下: 在障礙區(qū)的點的序號分別為:4 23 36 99。 無效用戶的信息為:(4.000
11、0,48.5982,33.3951);(23.0000,81.3166,87.4367); (36.0000,41.8649,41.1953); (99.0000,6.4781,17.0793);有效用戶的個數(shù)是:96。 100個點是否在障礙區(qū)的情況如下圖:5.2問題二的模型建立和求解 由問題分析可知,要篩選出有效用戶點之間的有效線段,主要有兩個問題需要解決:一是求出過任意兩個有效用戶點的直線m與過各障礙區(qū)中任意兩個頂點的直線L的交點坐標(biāo);二是運用向量法判斷該交點是否在以上述兩有效用戶點為端點上的線段m1和以上述障礙區(qū)頂點為端點的線段L1上,然后判斷過該兩個有效用戶點的線段是否為有效線段。5.
12、2.1運用矩陣的方法求解兩直線之間的交點坐標(biāo) 如果任意兩個有效用戶點的坐標(biāo)分別為A(x1,y1)、B(x2,y2),同一障礙區(qū)任意兩個頂點坐標(biāo)為M(x3,y3)、N(x4,y4)。則兩直線方程分別為:(1)(2);則由解線性方程組的方法有,線性方程組的的系數(shù)矩陣為: ;在運用Matlab求解該線性方程組時,不妨把 分別設(shè)為: 可以求得=A。5.2.2運用向量法判斷線段是否為有效線段若求得的交點坐標(biāo)為P(x,y),則通過向量關(guān)系PM=PN,可以求的。若0,則該線段為有效線段;若<0,則要考慮向量關(guān)系PA=PB,若0,則該線段為有效線段,否則,該線段為無效線段。5.3問題三的模型建立與求解若
13、要在N個用戶之間連接自來水管道,由于每一個用戶與其余N-1個用戶之間都可能連接自來水管道。因此,在N個用戶之間,最多可能連接N(N-1)/2條自來水管道然而,在連接N個用戶之間的管道時,最少只需連接N-1條管道。也就是說只需要N-1條管道線路就可以把N個用戶之間的自來水管道連通?,F(xiàn)在要考慮在連接N個用戶的自來水管道的同時要保證所有的管道長度之和最短,這就涉及了最優(yōu)化的問題。則顯然,要解決問題三需要兩個步驟:一是利用Kruskal算法思想設(shè)計Matlab程序進行最小生成樹所需邊的篩選;二是設(shè)計算法將篩選出來的構(gòu)成最小生成樹的各邊連接起來,求出最短路徑長度,并畫出連接圖形。5.3.1利用Krusk
14、al算法思想求解最小生成樹把用戶看作圖的頂點,把用戶之間的自來水管道看做邊,把連接各條線路的長度當(dāng)作權(quán)值賦給相應(yīng)的邊,這樣便構(gòu)成一個帶權(quán)的圖,即網(wǎng)。為了解決上述問題的數(shù)學(xué)模型就是求上述圖中的網(wǎng)狀圖的最小生成樹的問題。由問題一可知,有效用戶的個數(shù)為96,因此我們只需要考慮這96個點之間的連接,這96個點中任意兩點之間的的關(guān)系只有兩種,連接或不連接。我們可以先求出由96個用戶點中任意兩個用戶點之間的距離構(gòu)成的鄰接矩陣DIS,再根據(jù)問題二中求得的有效線段與無效線段對鄰接矩陣進行修改,將鄰接矩陣中對應(yīng)無效線段的位置的值修改為inf,可以得到一個新的鄰接矩陣DIS。接下來,用冒泡排序法對所有有效線段長度
15、按從小到大的順序進行排序。這時,需要借助Kruskal算法進行最小生成樹的計算。然后把最小生成樹對應(yīng)邊的線段長度、起點、終點信息記錄在矩陣EE中。生成最小生成樹時,從長度最短的邊開始選取,這就涉及如何防止在選擇過程中形成回路的問題。為了解決這個問題,首先不妨設(shè)一個1×96的標(biāo)記向量l用于記錄被選取的點的序號,初始狀態(tài)向量l的各元素依次為各用戶序號,在選取線段為邊后,將對應(yīng)兩點的序號m與n取最小值,并將向量l中所有與m位置元素相等的元素位置及所有與n位置的元素相等的元素位置都賦值為該最小值,如此循環(huán)知道向量l中所有元素均相等時停止;同時可以設(shè)一向量R來依次記錄被選點的序號,直到所有用戶
16、點被無重復(fù)地被記錄。在按線段長度從小到大的順序選擇邊時,設(shè)線段端點用戶的序號為m與n。這時需要考慮如下4種情況:<1>如果在向量R中m和n均沒有被記錄,則該線段可以被選為最小生成樹的邊,將對應(yīng)線段的信息記錄在矩陣EE中,同時在R中添加記錄m和n的值,并按照上述步驟更新向量l。<2>如果在向量R中m被記錄而n沒有被記錄,則該線段可以被選為最小生成樹的邊,將對應(yīng)線段的信息記錄在矩陣EE中,同時在R中添加記錄n的值,并按照上述步驟更新向量l。<3>如果在向量R中n被記錄而m沒有被記錄,則該線段可以被選為最小生成樹的邊,將對應(yīng)線段的信息記錄在矩陣EE中,同時在R中添
17、加記錄m的值,并按照上述步驟更新向量l。<4>如果在向量R中m和n均被記錄,則需要借助向量l來判斷是否該線段可以被選為最小生成樹的邊:a. 如果向量l中對應(yīng)的m位置與n位置的元素值相等,則該線段不是最小生成樹的邊,直接跳過到下一步判斷。b. 如果向量l中對應(yīng)的m位置與n位置的元素值不相等,則該線段是最小生成樹的邊,將對應(yīng)線段的信息記錄在矩陣EE中,同時只需要更新向量l。通過上述方法,即可產(chǎn)生最小生成樹,其各邊信息記錄在矩陣EE中。 5.3.2設(shè)計Matlab程序求出最小生成樹長度并將各邊連接起來要計算最小生成樹的長度,只需要借助for循環(huán)將EE矩陣中記錄長度相加即可。具體算發(fā)如下:
18、 sum=0;for i=1:p-1 sum=sum+EE(1,i);endsum可以求得最小生成樹的長度為:sum= 653.0196;最后,借助plot函數(shù)畫出最小生成樹的圖形。算法如下: hold on; for i=1:100 x=A(i,2); y=A(i,3); plot(x,y,'o')end for i=1:n-1 x1=AL(EE(2,i),2); y1=AL(EE(2,i),3); x2=AL(EE(3,i),2); y2=AL(EE(3,i),3); X=x1,x2; Y=y1,y2; plot(X,Y)endfor i=1:3 x1=B(i,2); y1
19、=B(i,3); x2=B(mod(i,3)+1,2); y2=B(mod(i,3)+1,3); X=x1,x2; Y=y1,y2; plot(X,Y,'m')endfor i=1:5 x1=C(i,2); y1=C(i,3); x2=C(mod(i,5)+1,2); y2=C(mod(i,5)+1,3); X=x1,x2; Y=y1,y2; plot(X,Y,'m')endfor i=1:3 x1=D(i,2); y1=D(i,3); x2=D(mod(i,3)+1,2); y2=D(mod(i,3)+1,3); X=x1,x2; Y=y1,y2; plot(
20、X,Y,'m')end for i=1:3 x1=E(i,2); y1=E(i,3); x2=E(mod(i,3)+1,2); y2=E(mod(i,3)+1,3); X=x1,x2; Y=y1,y2; plot(X,Y,'m')end連接形成的最小生成樹的圖形如下圖所示:由圖可知,該最小生成數(shù)是合理的。 六模型檢驗 首先可以通過對所畫最小生成樹圖形的觀察,看是否有回路,由圖易知圖形中無回路,則通過修改最小生成樹中任意邊的連接,計算修改后的最小生成樹的長度sum與sum進行比較。可得sum>sum,則該模型所生成的最小生成樹的長度最短,即運用該模型進行自來
21、水管道的連接所需要的自來水管長度最短。七模型的評價運用該模型進行最小生成樹的生成可以一步到位,不需要進行人工的修改。因為該模型在生成最小生成樹之前就已經(jīng)就進行了有效用戶與有效線段的篩選,所以,最小生成樹中所選擇的所有線段都是有效的不經(jīng)過障礙區(qū)的。但是由于模型的需要計算的信息量比較的,在設(shè)計程序的時候變量的運用比較混亂,不方便閱讀與修改,同時,由于算法設(shè)計繁瑣且反復(fù)運用for循環(huán),計算所需次數(shù)較多。如果在上述問題中多注意,則該模型將會更加完美。 八模型的推廣 可以在保證障礙區(qū)不變的情況下,任意改變用戶點的信息,運用該模型同樣可以求得連接自來水管道的最短長度。且不需要過多改動,不需要人工進行修改計
22、算的結(jié)果。但是在障礙區(qū)變化的情況下,則需要較大改動。同時該模型可以應(yīng)用到修建連接若干個地點之間的公路長度和最短的問題中。九參考書目1 姜啟源等,數(shù)學(xué)模型(第三版),北京:高等教育出版社,20032 薛定宇,陳陽泉,高等應(yīng)用數(shù)學(xué)問題的Matlab求解,清華大學(xué)出版社,20083 趙靜,但琦等,數(shù)學(xué)建模與數(shù)學(xué)實驗,高等教育出版社,2008十附錄附錄一:小組成員分工及數(shù)學(xué)建模過程感想分工:羅圣:負(fù)責(zé)符號說明、模型建立及求解、模型檢驗、算法設(shè)計及Matlab程序等部分的編寫。喬世?。贺?fù)責(zé)組織論文總體結(jié)構(gòu),及編寫摘要、問題重述、模型假設(shè)等部分。王博:負(fù)責(zé)構(gòu)思解決各問題的算法及編寫問題分析、模型推廣、參考
23、書目及附錄等部分。感想:羅圣:通過此次數(shù)學(xué)建模作業(yè)的完成過程,考驗了我分析問題、解決問題的能力,同時也考驗了我在不懂如何入手解決問題時是否具有堅持的耐心。我認(rèn)為能完成這次數(shù)學(xué)建模作業(yè)對我是一個極大鼓勵,讓我可以相信自己能在面臨一個陌生問題時可以獨立解決它。在編寫Matlab程序時遇到過很多問題,有很多問題需要自己的千方百計地思考才能解決,通過這次鍛煉,學(xué)會了很多函數(shù)的使用,提升了自己編寫程序解決實際問題的能力。從剛開始不知從何下手的煎熬到最后完成之后的滿足,享受了團隊合作的愉快,在這個過程中收獲了很多。喬世俊:這次數(shù)學(xué)建模,是對我分析解決問題方面能力的一個考驗,包括如何分析問題、如何查閱資料、
24、如何掌握模型結(jié)構(gòu)等。能完成這次數(shù)學(xué)建模,讓我信心倍增,我相信在以后遇到問題時,我可以更快得尋求到解決問題的方法。雖然這是第一次完成數(shù)學(xué)建模,但我相信它會是我的一次蛻變。王博:在剛接觸這個數(shù)學(xué)建模作業(yè)的時候,我不知道如何進行問題的分析,不知道從什么方面進行入手,為此我十分苦惱。為了擺脫這中困境,我積極查找資料,希望能尋求到一些幫助。在這個過程中,我慢慢地找到了解決問題的思路。直到最后能完整解決這個問題,我學(xué)到了很多東西,同時,體會到了團隊合作的重要性,整個過程我獲益匪淺。附錄二:若干個可能的用戶的地址的橫縱坐標(biāo)可能的用戶的序號可能的用戶橫坐標(biāo)可能的用戶縱坐標(biāo)1.000095.012958.279
25、22.000023.113942.34963.000060.684351.55124.000048.598233.39515.000089.129943.29076.000076.209722.59507.000045.646857.98078.00001.850476.03659.000082.140752.982310.000044.470364.052611.000061.543220.906912.000079.193737.981813.000092.181378.332914.000073.820768.084615.000017.626646.109516.000040.5706
26、56.782917.000093.547079.421118.000091.69045.918319.000041.027060.286920.000089.36505.026921.00005.789141.537522.000035.286830.499923.000081.316687.436724.00000.98611.500925.000013.889176.795026.000020.276597.084527.000019.872299.008328.000060.379278.886229.000027.218843.865930.000019.881449.831131.0
27、0001.527421.396332.000074.678664.349233.000044.509632.003634.000093.181596.009935.000046.599472.663236.000041.864941.195337.000084.622174.456638.000052.515226.794739.000020.264743.992440.000067.213793.338041.000083.811868.333242.00001.964021.256043.000068.127783.923844.000037.948162.878545.000083.17
28、9613.377346.000050.281320.713347.000070.947160.719948.000042.889262.988849.000030.461737.047750.000018.965457.514851.000019.343145.142552.000068.22234.389553.000030.27642.718554.000054.167431.268555.000015.08731.286356.000069.789838.396757.000037.837368.311658.000086.00129.284259.000085.36553.533860
29、.000059.356361.239561.000049.655260.854062.000089.97691.576063.000082.16291.635564.000064.491019.007565.000081.797458.691866.000066.02285.758167.000034.197136.756868.000028.972663.145169.000034.119471.763470.000053.407969.266971.000072.71138.407972.000030.929045.435573.000083.849644.182874.000056.80
30、7235.325075.000037.041415.360676.000070.274067.564577.000054.657169.921378.000044.488072.750979.000069.456747.838480.000062.131055.484281.000079.482112.104782.000095.684345.075483.000052.259071.588384.000088.014289.284285.000017.295627.310286.000097.974725.476987.000027.144786.560388.000025.232923.2
31、35089.000087.574280.487290.000073.730690.839891.000013.651923.189492.00001.175723.931393.000089.38984.975494.000019.91387.838495.000029.872364.081596.000066.144319.088797.000028.440984.386998.000046.922417.390099.00006.478117.0793100.000098.833599.4295附錄三:解決該自來水管道連接問題的Matlab程序:%問題一,進行有效點的篩選A=1.0000
32、95.0129 58.2792;2.0000 23.1139 42.3496;3.0000 60.6843 51.5512;4.0000 48.5982 33.3951;5.0000 89.1299 43.2907;6.0000 76.2097 22.5950;7.0000 45.6468 57.9807;8.0000 1.8504 76.0365;9.0000 82.1407 52.9823;10.0000 44.4703 64.0526;11.0000 61.5432 20.9069;12.0000 79.1937 37.9818;13.0000 92.1813 78.3329;14.00
33、00 73.8207 68.0846;15.0000 17.6266 46.1095;16.0000 40.5706 56.7829;17.0000 93.5470 79.4211;18.0000 91.6904 5.9183;19.0000 41.0270 60.2869;20.0000 89.3650 5.0269;21.0000 5.7891 41.5375;22.0000 35.2868 30.4999;23.0000 81.3166 87.4367;24.0000 0.9861 1.5009;25.0000 13.8891 76.7950;26.0000 20.2765 97.084
34、5;27.0000 19.8722 99.0083;28.0000 60.3792 78.8862;29.0000 27.2188 43.8659;30.0000 19.8814 49.8311;31.0000 1.5274 21.3963;32.0000 74.6786 64.3492;33.0000 44.5096 32.0036;34.0000 93.1815 96.0099;35.0000 46.5994 72.6632;36.0000 41.8649 41.1953;37.0000 84.6221 74.4566;38.0000 52.5152 26.7947;39.0000 20.
35、2647 43.9924;40.0000 67.2137 93.3380;41.0000 83.8118 68.3332;42.0000 1.9640 21.2560;43.0000 68.1277 83.9238;44.0000 37.9481 62.8785;45.0000 83.1796 13.3773;46.0000 50.2813 20.7133;47.0000 70.9471 60.7199;48.0000 42.8892 62.9888;49.0000 30.4617 37.0477;50.0000 18.9654 57.5148;51.0000 19.3431 45.1425;
36、52.0000 68.2223 4.3895;53.0000 30.2764 2.7185;54.0000 54.1674 31.2685;55.0000 15.0873 1.2863;56.0000 69.7898 38.3967;57.0000 37.8373 68.3116;58.0000 86.0012 9.2842;59.0000 85.3655 3.5338;60.0000 59.3563 61.2395;61.0000 49.6552 60.8540;62.0000 89.9769 1.5760;63.0000 82.1629 1.6355;64.0000 64.4910 19.
37、0075;65.0000 81.7974 58.6918;66.0000 66.0228 5.7581;67.0000 34.1971 36.7568;68.0000 28.9726 63.1451;69.0000 34.1194 71.7634;70.0000 53.4079 69.2669;71.0000 72.7113 8.4079;72.0000 30.9290 45.4355;73.0000 83.8496 44.1828;74.0000 56.8072 35.3250;75.0000 37.0414 15.3606;76.0000 70.2740 67.5645;77.0000 5
38、4.6571 69.9213;78.0000 44.4880 72.7509;79.0000 69.4567 47.8384;80.0000 62.1310 55.4842;81.0000 79.4821 12.1047;82.0000 95.6843 45.0754;83.0000 52.2590 71.5883;84.0000 88.0142 89.2842;85.0000 17.2956 27.3102;86.0000 97.9747 25.4769;87.0000 27.1447 86.5603;88.0000 25.2329 23.2350;89.0000 87.5742 80.48
39、72;90.0000 73.7306 90.8398;91.0000 13.6519 23.1894;92.0000 1.1757 23.9313;93.0000 89.3898 4.9754;94.0000 19.9138 7.8384;95.0000 29.8723 64.0815;96.0000 66.1443 19.0887;97.0000 28.4409 84.3869;98.0000 46.9224 17.3900;99.0000 6.4781 17.0793;100.0000 98.8335 99.4295;B=1 3.2060 12.9166;2 17.4571 19.3377
40、;3 4.7576 20;C=1 50 30;2 53.7465 48.4490;3 46.9222 57.1195;5 43.1123 56.3187;4 33.3207 39.8050;D=1 54.6982 70;2 53.7465 90;3 46.9222 80;E=1 90 75; 2 80 95; 3 70 80;%準(zhǔn)備用戶坐標(biāo)矩陣和障礙區(qū)坐標(biāo)矩陣SIGN=zeros(1,100);%生成1行100列的記錄矩陣,若點不在障礙區(qū)則對應(yīng)位置記為1,否則記為0for n=1:100a1=B(2,2)-B(1,2),B(2,3)-B(1,3),0;a2=B(3,2)-B(2,2),B(3,
41、3)-B(2,3),0;a3=B(1,2)-B(3,2),B(1,3)-B(3,3),0;S=norm(cross(a1,a2)/2;%該障礙區(qū)面積x=A(n,2);y=A(n,3);z1=x-B(1,2),y-B(1,3),0;z2=x-B(2,2),y-B(2,3),0;z3=x-B(3,2),y-B(3,3),0;s1=norm(cross(z1, a1)/2;s2=norm(cross(z2, a2)/2;s3=norm(cross(z3, a3)/2;S1=s1+s2+s3;%由用戶點和任意對應(yīng)兩個該障礙區(qū)頂點構(gòu)成的三角形面積之和if(S1=S)m1=0 ;else m1=1;end
42、%第一個障礙區(qū)內(nèi)的點判斷b1=C(2,2)-C(1,2),C(2,3)-C(1,3),0;b2=C(3,2)-C(2,2),C(3,3)-C(2,3),0;b3=C(4,2)-C(3,2),C(4,3)-C(3,3),0;b4=C(5,2)-C(4,2),C(5,3)-C(4,3),0;b5=C(1,2)-C(5,2),C(1,3)-C(5,3),0;s1=norm(cross(b1,b2)/2;s2=norm(cross(b3,b4)/2;s3=norm(cross(b1+b2,b3+b4)/2;S=s1+s2+s3;%該障礙區(qū)面積x=A(n,2);y=A(n,3);z1=x-C(1,2),
43、y-C(1,3),0;z2=x-C(2,2),y-C(2,3),0;z3=x-C(3,2),y-C(3,3),0;z4=x-C(4,2),y-C(4,3),0;z5=x-C(5,2),y-C(5,3),0;s1=norm(cross(z1,b1)/2;s2=norm(cross(z2,b2)/2;s3=norm(cross(z3,b3)/2;s4=norm(cross(z4,b4)/2;s5=norm(cross(z5,b5)/2;S1=s1+s2+s3+s4+s5;%由用戶點和任意對應(yīng)兩個該障礙區(qū)頂點構(gòu)成的三角形面積之和if(S1=S)m2=0;else m2=1;end%第二個障礙區(qū)內(nèi)的點
44、判斷c1=D(2,2)-D(1,2),D(2,3)-D(1,3),0;c2=D(3,2)-D(2,2),D(3,3)-D(2,3),0;c3=D(1,2)-D(3,2),D(1,3)-D(3,3),0;S=norm(cross(c1,c2)/2;%該障礙區(qū)面積x=A(n,2);y=A(n,3);z1=x-D(1,2),y-D(1,3),0;z2=x-D(2,2),y-D(2,3),0;z3=x-D(3,2),y-D(3,3),0;s1=norm(cross(c1,z1)/2;s2=norm(cross(c2,z2)/2;s3=norm(cross(c3,z3)/2;S1=s1+s2+s3;%由
45、用戶點和任意對應(yīng)兩個該障礙區(qū)頂點構(gòu)成的三角形面積之和if(S1=S)m3=0;else m3=1;end%第三個障礙區(qū)內(nèi)的點判斷d1=E(2,2)-E(1,2),E(2,3)-E(1,3),0;d2=E(3,2)-E(2,2),E(3,3)-E(2,3),0;d3=E(1,2)-E(3,2),E(1,3)-E(3,3),0;S=norm(cross(d1,d2)/2;%該障礙區(qū)面積x=A(n,2);y=A(n,3);z1=x-E(1,2),y-E(1,3),0;z2=x-E(2,2),y-E(2,3),0;z3=x-E(3,2),y-E(3,3),0;s1=norm(cross(d1,z1)/
46、2;s2=norm(cross(d2,z2)/2;s3=norm(cross(d3,z3)/2;S1=s1+s2+s3;%由用戶點和任意對應(yīng)兩個該障礙區(qū)頂點構(gòu)成的三角形面積之和if(S1=S)m4=0 ;else m4=1;end%第四個障礙區(qū)內(nèi)的點判斷if(m1&m2&m3&m4)SIGN(n)=1;else SIGN(n)=0;endendSIGN ;%以上判斷不在障礙區(qū)的點,其標(biāo)號記錄在SIGN矩陣中用1表示OUTSIGN=find(SIGN=0)%記錄在障礙區(qū)的用戶點p=0;for i=1:100 p=p+SIGN(i);endp%計算保留用戶點的個數(shù)p%問題二
47、,進行有效線段的篩選NUM=zeros(100,100);for i=1:100 for j=i+1:100 NUM(i,j)=1; endendb1=(B(1,3)-B(2,3)/(B(1,2)-B(2,2);bb1=(B(1,3)*B(2,2)-B(1,2)*B(2,3)/(B(1,2)-B(2,2);b2=(B(2,3)-B(3,3)/(B(2,2)-B(3,2);bb2=(B(2,3)*B(3,2)-B(2,2)*B(3,3)/(B(2,2)-B(3,2);b3=(B(3,3)-B(1,3)/(B(3,2)-B(1,2);bb3=(B(3,3)*B(1,2)-B(3,2)*B(1,3)/(B(3,2)-B(1,2);BB=b1 bb1;b2 bb2;b3 bb3;c1=(C(1,3)-C(2,3)/(C(1,2)-C(2,2);cc1=(C(
溫馨提示
- 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)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 航線配船方法課程設(shè)計
- 水利工程師水利工程設(shè)計與運維
- 營養(yǎng)科護士助健康飲食
- 科學(xué)實驗小班班級工作計劃
- 采礦工程行業(yè)工程師的工作總結(jié)
- 家庭用品行業(yè)采購工作總結(jié)
- 餐飲服務(wù)行業(yè)技術(shù)工作總結(jié)
- 醫(yī)藥健康領(lǐng)域科技整合顧問工作總結(jié)
- 冶金行業(yè)行政后勤工作總結(jié)
- 公務(wù)員工作總結(jié)工作成果與貢獻評價
- 第十二章 全等三角形 作業(yè)設(shè)計-2023-2024學(xué)年人教版八年級數(shù)學(xué)上冊
- 建筑結(jié)構(gòu)荷載規(guī)范DBJ-T 15-101-2022
- 制藥專業(yè)畢業(yè)設(shè)計開題報告
- 普通心理學(xué)智慧樹知到期末考試答案2024年
- 青少年涉毒問題監(jiān)測制度
- 征兵眼科科普知識講座
- 人工智能在醫(yī)療健康領(lǐng)域的應(yīng)用探索報告
- 高二上學(xué)期數(shù)學(xué)期末測試卷01-【好題匯編】備戰(zhàn)2023-2024學(xué)年高二數(shù)學(xué)上學(xué)期期末真題分類匯編(人教A版2019選擇性必修第一、二冊)(原卷版)
- 環(huán)評驗收方案
- 小學(xué)一年級數(shù)學(xué)口算題每天20道題
- 設(shè)備安全調(diào)試維修作業(yè)安全培訓(xùn)
評論
0/150
提交評論