結(jié)構(gòu)力學(xué)仿真軟件:OpenSees:結(jié)構(gòu)優(yōu)化設(shè)計與OpenSees_第1頁
結(jié)構(gòu)力學(xué)仿真軟件:OpenSees:結(jié)構(gòu)優(yōu)化設(shè)計與OpenSees_第2頁
結(jié)構(gòu)力學(xué)仿真軟件:OpenSees:結(jié)構(gòu)優(yōu)化設(shè)計與OpenSees_第3頁
結(jié)構(gòu)力學(xué)仿真軟件:OpenSees:結(jié)構(gòu)優(yōu)化設(shè)計與OpenSees_第4頁
結(jié)構(gòu)力學(xué)仿真軟件:OpenSees:結(jié)構(gòu)優(yōu)化設(shè)計與OpenSees_第5頁
已閱讀5頁,還剩25頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

結(jié)構(gòu)力學(xué)仿真軟件:OpenSees:結(jié)構(gòu)優(yōu)化設(shè)計與OpenSees1OpenSees簡介1.1OpenSees的歷史與發(fā)展OpenSees(OpenSystemforEarthquakeEngineeringSimulation)是一款開源的結(jié)構(gòu)力學(xué)仿真軟件,由加州大學(xué)伯克利分校的PacificEarthquakeEngineeringResearchCenter(PEER)開發(fā)。自1997年啟動以來,OpenSees不斷吸收結(jié)構(gòu)工程、地震工程和軟件工程領(lǐng)域的最新研究成果,逐漸發(fā)展成為結(jié)構(gòu)動力學(xué)和非線性結(jié)構(gòu)分析的領(lǐng)先工具。1.1.1發(fā)展歷程1997年:項目啟動,旨在開發(fā)一個靈活的、可擴展的結(jié)構(gòu)分析平臺。2000年:發(fā)布第一個版本,支持線性和非線性靜態(tài)分析。2005年:引入動力學(xué)分析功能,包括模態(tài)分析和時程分析。2010年:增加多處理器并行計算支持,提高大規(guī)模結(jié)構(gòu)分析的效率。2015年:引入Python接口,使用戶能夠利用Python的靈活性進行更復(fù)雜的建模和后處理。2020年:持續(xù)更新,增加更多材料模型和結(jié)構(gòu)元件,以適應(yīng)更廣泛的工程應(yīng)用。1.2OpenSees的主要功能與應(yīng)用領(lǐng)域OpenSees提供了豐富的功能,適用于多種結(jié)構(gòu)力學(xué)分析場景,包括但不限于:線性與非線性靜態(tài)分析:能夠處理結(jié)構(gòu)在各種荷載下的響應(yīng),包括預(yù)應(yīng)力、幾何非線性等。動力學(xué)分析:包括模態(tài)分析、頻譜分析和時程分析,適用于地震工程、風(fēng)工程等。材料與截面模型:支持多種材料模型,如鋼筋混凝土、鋼材、土等,以及復(fù)雜的截面組合。結(jié)構(gòu)元件庫:包括梁、柱、墻、板、連接件等,適用于橋梁、建筑、隧道等結(jié)構(gòu)的建模。并行計算:利用多處理器加速大規(guī)模結(jié)構(gòu)的分析,提高計算效率。Python接口:允許用戶使用Python進行建模、分析和后處理,提供更高級的編程能力。1.2.1應(yīng)用領(lǐng)域地震工程:評估結(jié)構(gòu)在地震荷載下的性能,進行抗震設(shè)計和優(yōu)化。風(fēng)工程:分析結(jié)構(gòu)在風(fēng)荷載下的響應(yīng),設(shè)計抗風(fēng)結(jié)構(gòu)。橋梁工程:模擬橋梁在各種荷載下的行為,優(yōu)化設(shè)計和維護策略。建筑結(jié)構(gòu):分析建筑結(jié)構(gòu)的穩(wěn)定性,進行結(jié)構(gòu)優(yōu)化和抗震加固。隧道與地下結(jié)構(gòu):評估地下結(jié)構(gòu)在地震、地下水壓力等條件下的安全性。1.2.2示例:OpenSeesPython接口進行簡單結(jié)構(gòu)分析#導(dǎo)入OpenSeesPy模塊

importopenseespy.openseesasops

#初始化OpenSees模型

ops.wipe()

ops.model('basic','-ndm',2,'-ndf',2)

#創(chuàng)建節(jié)點

ops.node(1,0.0,0.0)

ops.node(2,10.0,0.0)

#固定底部節(jié)點

ops.fix(1,1,1)

#創(chuàng)建梁單元

ops.element('elasticBeamColumn',1,1,2,1000.0,10000.0)

#創(chuàng)建荷載模式

ops.timeSeries('Linear',1)

ops.pattern('UniformExcitation',1,'-accel',0.1,'-dt',0.01)

#分析設(shè)置

ops.system('BandGeneral')

ops.numberer('RCM')

ops.constraints('Plain')

egrator('LoadControl',1.0)

ops.analysis('Static')

#進行分析

ops.analyze(1)

#輸出結(jié)果

print('Node2displacement:',ops.nodeDisp(2,1))代碼解釋:1.初始化模型:使用wipe和model命令創(chuàng)建一個二維模型。2.創(chuàng)建節(jié)點:定義兩個節(jié)點,一個位于原點,另一個位于(10.0,0.0)。3.固定底部節(jié)點:使用fix命令固定第一個節(jié)點的兩個自由度。4.創(chuàng)建梁單元:使用elasticBeamColumn命令創(chuàng)建一個彈性梁柱單元,連接兩個節(jié)點。5.荷載模式:定義一個線性時間序列和一個均勻激勵荷載模式,模擬節(jié)點2在x方向上受到0.1g的加速度。6.分析設(shè)置:選擇分析系統(tǒng)、編號器、約束、積分器和分析類型。7.進行分析:使用analyze命令進行靜態(tài)分析。8.輸出結(jié)果:打印節(jié)點2在x方向上的位移。通過上述代碼,我們能夠使用OpenSees的Python接口對一個簡單的結(jié)構(gòu)進行建模和分析,獲取其在特定荷載下的響應(yīng)。這僅為OpenSees強大功能的冰山一角,實際應(yīng)用中,OpenSees能夠處理更為復(fù)雜和精細的結(jié)構(gòu)力學(xué)問題。2OpenSees安裝與配置2.1在Windows上安裝OpenSees2.1.1安裝步驟下載安裝包:訪問OpenSees的官方網(wǎng)站或GitHub頁面,下載適用于Windows的最新版本安裝包。運行安裝程序:雙擊下載的安裝包,啟動安裝向?qū)?,按照屏幕上的指示完成安裝過程。環(huán)境變量配置:安裝完成后,需要將OpenSees的安裝目錄添加到系統(tǒng)環(huán)境變量中。右鍵點擊“計算機”->“屬性”->“高級系統(tǒng)設(shè)置”->“環(huán)境變量”,在“系統(tǒng)變量”中找到“Path”變量,編輯并添加OpenSees的安裝目錄。驗證安裝:打開命令提示符,輸入OpenSees命令,如果安裝成功,將顯示OpenSees的命令行界面。2.1.2示例代碼#驗證OpenSees是否安裝成功

OpenSees2.2在Linux上安裝OpenSees2.2.1安裝步驟使用包管理器安裝:對于基于Debian的系統(tǒng)(如Ubuntu),可以使用apt-get命令安裝OpenSees。對于基于RedHat的系統(tǒng)(如Fedora),可以使用yum或dnf命令。編譯源代碼:如果需要定制功能,可以從源代碼編譯OpenSees。首先,下載源代碼,然后使用make命令進行編譯。環(huán)境變量配置:編譯完成后,將OpenSees的可執(zhí)行文件路徑添加到.bashrc或.bash_profile文件中。驗證安裝:打開終端,輸入OpenSees命令,如果安裝成功,將顯示OpenSees的命令行界面。2.2.2示例代碼#使用apt-get在Ubuntu上安裝OpenSees

sudoapt-getupdate

sudoapt-getinstallopensees

#從源代碼編譯OpenSees

gitclone/OpenSees/OpenSees.git

cdOpenSees

make

#配置環(huán)境變量

echo'exportPATH=$PATH:/path/to/OpenSees'>>~/.bashrc

source~/.bashrc

#驗證安裝

OpenSees2.3配置開發(fā)環(huán)境2.3.1開發(fā)環(huán)境需求Python環(huán)境:OpenSees提供了Python接口,因此需要安裝Python及其開發(fā)環(huán)境。文本編輯器或IDE:選擇一個支持Python和Markdown的編輯器或IDE,如VSCode、PyCharm等。OpenSeesPy:安裝OpenSees的Python接口,以便在Python環(huán)境中使用OpenSees。2.3.2示例代碼#安裝Python

sudoapt-getinstallpython3

#安裝OpenSeesPy

pipinstallopenseespy

#驗證OpenSeesPy安裝

python-c"importopenseespy.openseesasops;ops.wipe()"2.3.3代碼解釋pipinstallopenseespy:使用pip命令安裝OpenSeesPy模塊,這是OpenSees的Python接口。python-c"importopenseespy.openseesasops;ops.wipe()":運行Python命令,導(dǎo)入OpenSeesPy模塊并調(diào)用wipe函數(shù),wipe函數(shù)用于清除OpenSees的模型數(shù)據(jù),如果此命令執(zhí)行成功,說明OpenSeesPy已正確安裝。通過以上步驟,您可以在Windows和Linux系統(tǒng)上安裝并配置OpenSees,以及設(shè)置一個基本的開發(fā)環(huán)境,以便使用Python進行結(jié)構(gòu)力學(xué)仿真。3OpenSees基本操作3.1OpenSees命令行使用OpenSees是一個強大的結(jié)構(gòu)力學(xué)仿真軟件,它提供了命令行界面進行模型的創(chuàng)建和分析。通過命令行,用戶可以精確控制模型的每一個細節(jié),包括材料屬性、單元類型、邊界條件、荷載和分析步驟。下面將介紹如何使用OpenSees命令行進行基本操作。3.1.1創(chuàng)建模型在OpenSees中,模型的創(chuàng)建是通過一系列命令完成的。首先,需要定義模型的維度,然后創(chuàng)建節(jié)點、定義材料、創(chuàng)建單元、設(shè)置邊界條件和荷載,最后進行分析。示例代碼#創(chuàng)建一個2D模型

wipe

modelBasicBuilder-ndm2-ndf2

#創(chuàng)建節(jié)點

node10.00.0

node210.00.0

#定義材料

uniaxialMaterialElastic130000.0

#創(chuàng)建單元

elementtruss1121000.01.0

#設(shè)置邊界條件

fix111

#應(yīng)用荷載

timeSeriesLinear-tag1

patternPlain11{

load20.01000.0

}

#創(chuàng)建分析

systemBandGeneral

numbererRCM

constraintsPlain

testNormDispIncr1.0e-81001.0e20

algorithmLinear

integratorLoadControl0.01

analysisStatic

#進行分析

analyze103.1.2解釋wipe清除所有先前定義的模型數(shù)據(jù)。modelBasicBuilder-ndm2-ndf2定義一個2D模型,每個節(jié)點有兩個自由度。node命令用于創(chuàng)建節(jié)點,指定節(jié)點ID、x坐標(biāo)和y坐標(biāo)。uniaxialMaterial定義材料屬性,這里創(chuàng)建了一個彈性材料。element命令用于創(chuàng)建單元,這里創(chuàng)建了一個桁架單元。fix設(shè)置邊界條件,固定節(jié)點1的兩個自由度。timeSeries和pattern用于定義荷載的時間序列和荷載模式。load應(yīng)用荷載到節(jié)點2。system、numberer、constraints、test、algorithm、integrator和analysis用于定義分析的系統(tǒng)、編號、約束、收斂測試、算法、積分器和分析類型。analyze進行指定步數(shù)的分析。3.2OpenSeesPython接口介紹OpenSeesPython接口允許用戶使用Python語言來控制OpenSees,這為模型的創(chuàng)建和分析提供了更大的靈活性。Python接口可以調(diào)用OpenSees的所有命令,并且可以利用Python的編程能力進行更復(fù)雜的操作,如循環(huán)、條件判斷和數(shù)據(jù)處理。3.2.1示例代碼importopenseespy.openseesasops

#創(chuàng)建一個2D模型

ops.wipe()

ops.model('basic','-ndm',2,'-ndf',2)

#創(chuàng)建節(jié)點

ops.node(1,0.0,0.0)

ops.node(2,10.0,0.0)

#定義材料

ops.uniaxialMaterial('Elastic',1,30000.0)

#創(chuàng)建單元

ops.element('truss',1,1,2,1000.0,1.0)

#設(shè)置邊界條件

ops.fix(1,1,1)

#應(yīng)用荷載

ops.timeSeries('Linear',1)

ops.pattern('Plain',1,1)

ops.load(2,0.0,1000.0)

#創(chuàng)建分析

ops.system('BandGeneral')

ops.numberer('RCM')

ops.constraints('Plain')

ops.test('NormDispIncr',1.0e-8,100,1.0e20)

ops.algorithm('Linear')

egrator('LoadControl',0.01)

ops.analysis('Static')

#進行分析

ops.analyze(10)3.2.2解釋importopenseespy.openseesasops導(dǎo)入OpenSeesPython接口。ops.wipe()清除所有先前定義的模型數(shù)據(jù)。ops.model('basic','-ndm',2,'-ndf',2)定義一個2D模型,每個節(jié)點有兩個自由度。ops.node()命令用于創(chuàng)建節(jié)點,指定節(jié)點ID、x坐標(biāo)和y坐標(biāo)。ops.uniaxialMaterial()定義材料屬性,這里創(chuàng)建了一個彈性材料。ops.element()命令用于創(chuàng)建單元,這里創(chuàng)建了一個桁架單元。ops.fix()設(shè)置邊界條件,固定節(jié)點1的兩個自由度。ops.timeSeries()和ops.pattern()用于定義荷載的時間序列和荷載模式。ops.load()應(yīng)用荷載到節(jié)點2。ops.system()、ops.numberer()、ops.constraints()、ops.test()、ops.algorithm()、egrator()和ops.analysis()用于定義分析的系統(tǒng)、編號、約束、收斂測試、算法、積分器和分析類型。ops.analyze(10)進行指定步數(shù)的分析。通過以上介紹,我們可以看到OpenSees命令行和OpenSeesPython接口在創(chuàng)建和分析結(jié)構(gòu)模型方面的基本操作。使用這些工具,結(jié)構(gòu)工程師和研究人員可以進行詳細的結(jié)構(gòu)力學(xué)仿真,以優(yōu)化設(shè)計和評估結(jié)構(gòu)性能。4結(jié)構(gòu)建?;A(chǔ)4.1OpenSees中的節(jié)點與單元在OpenSees中,結(jié)構(gòu)建模始于定義節(jié)點和單元。節(jié)點是結(jié)構(gòu)中的幾何點,而單元則是連接這些節(jié)點的結(jié)構(gòu)構(gòu)件,如梁、柱或墻。節(jié)點和單元的正確定義是進行結(jié)構(gòu)分析的基礎(chǔ)。4.1.1節(jié)點定義節(jié)點在OpenSees中通過node命令創(chuàng)建,格式如下:node(nodeTag,*nodeCoord)nodeTag:節(jié)點的唯一標(biāo)識符。nodeCoord:節(jié)點的坐標(biāo),可以是二維或三維。例如,創(chuàng)建一個位于(0,0)和(10,0)的兩個節(jié)點:#創(chuàng)建節(jié)點

node(1,0.0,0.0)

node(2,10.0,0.0)4.1.2單元定義單元定義涉及選擇適當(dāng)?shù)膯卧愋停鏴lasticBeamColumn用于梁柱單元。單元通過element命令創(chuàng)建,格式如下:element(elementType,elementTag,*nodes,**kwargs)elementType:單元類型。elementTag:單元的唯一標(biāo)識符。nodes:構(gòu)成單元的節(jié)點標(biāo)識符。kwargs:單元的其他屬性,如截面和材料。例如,定義一個彈性梁柱單元:#定義截面

section('Elastic',1,1000000,100)

#創(chuàng)建梁柱單元

element('elasticBeamColumn',1,1,2,1)4.2材料模型與截面定義材料模型描述了材料的力學(xué)行為,而截面定義則結(jié)合了材料模型和截面幾何信息,用于單元的屬性定義。4.2.1材料模型OpenSees提供了多種材料模型,如Elastic、Steel01和Concrete01。這些模型通過uniaxialMaterial命令定義。Elastic材料模型uniaxialMaterial('Elastic',materialTag,E,eta)materialTag:材料的唯一標(biāo)識符。E:彈性模量。eta:可選,表示材料的阻尼比。例如,定義一個彈性材料:uniaxialMaterial('Elastic',1,1000000,0.05)4.2.2截面定義截面定義結(jié)合了材料模型和截面幾何信息。例如,使用rectangularSection命令定義一個矩形截面:section('Rectangular',sectionTag,width,height,materialTag)sectionTag:截面的唯一標(biāo)識符。width:截面的寬度。height:截面的高度。materialTag:材料模型的標(biāo)識符。例如,定義一個寬度為100mm,高度為200mm的矩形截面:section('Rectangular',1,100,200,1)4.2.3結(jié)合單元與截面一旦定義了截面,就可以將其應(yīng)用于單元。例如,將上述定義的截面應(yīng)用于梁柱單元:element('elasticBeamColumn',1,1,2,1)這里,1是截面的標(biāo)識符,表示將定義的截面應(yīng)用于單元。4.3示例:簡單梁的建模下面是一個使用OpenSees建模簡單梁的完整示例:#導(dǎo)入OpenSeesPy

importopenseespy.openseesasops

#創(chuàng)建OpenSees模型

ops.wipe()

#定義材料

ops.uniaxialMaterial('Elastic',1,1000000,0.05)

#定義截面

ops.section('Rectangular',1,100,200,1)

#創(chuàng)建節(jié)點

ops.node(1,0.0,0.0)

ops.node(2,10.0,0.0)

#創(chuàng)建梁柱單元

ops.element('elasticBeamColumn',1,1,2,1)

#定義邊界條件

ops.fix(1,1,1)

ops.fix(2,0,1)

#定義荷載

ops.load(2,-1000,0)

#分析模型

ops.system('BandGeneral')

ops.numberer('RCM')

ops.constraints('Plain')

egrator('LoadControl',1.0)

ops.analysis('Static')

ops.analyze(1)在這個示例中,我們首先定義了材料和截面,然后創(chuàng)建了兩個節(jié)點,并使用elasticBeamColumn元素類型創(chuàng)建了一個梁柱單元。我們還定義了邊界條件和荷載,最后進行了靜態(tài)分析。通過以上步驟,我們可以看到OpenSees中結(jié)構(gòu)建模的基本流程,從節(jié)點和單元的定義,到材料模型和截面的設(shè)置,再到邊界條件和荷載的施加,最后進行結(jié)構(gòu)分析。這為更復(fù)雜的結(jié)構(gòu)優(yōu)化設(shè)計提供了基礎(chǔ)。5結(jié)構(gòu)分析方法在結(jié)構(gòu)力學(xué)仿真軟件中,OpenSees是一個強大的工具,用于進行結(jié)構(gòu)分析和設(shè)計。本教程將深入探討OpenSees中的三種主要分析方法:靜力分析、動力分析和非線性分析。5.1靜力分析5.1.1原理靜力分析是結(jié)構(gòu)力學(xué)中最基礎(chǔ)的分析類型,它假設(shè)結(jié)構(gòu)在荷載作用下處于平衡狀態(tài),不考慮荷載作用的時間效應(yīng)。在OpenSees中,靜力分析通常用于線性或非線性結(jié)構(gòu)的初步設(shè)計和校核。5.1.2內(nèi)容線性靜力分析:適用于結(jié)構(gòu)在小變形和小應(yīng)變條件下的分析。非線性靜力分析:考慮材料非線性、幾何非線性和邊界條件非線性,適用于大變形和大應(yīng)變條件下的結(jié)構(gòu)分析。5.1.3示例代碼#OpenSeesPythonScriptforLinearStaticAnalysis

importopenseespy.openseesasops

#創(chuàng)建一個新的模型

ops.wipe()

ops.model('basic','-ndm',2,'-ndf',2)

#定義節(jié)點

ops.node(1,0.0,0.0)

ops.node(2,10.0,0.0)

#定義單元

ops.element('ElasticBeamColumn',1,1,2,1000.0,10000.0,0.0)

#定義邊界條件

ops.fix(1,1,1)

ops.fix(2,0,1)

#定義荷載

ops.load(2,0.0,-1000.0)

#定義分析類型

ops.system('BandGeneral')

ops.numberer('RCM')

ops.constraints('Plain')

egrator('LoadControl',1.0)

ops.analysis('Static')

#進行分析

ops.analyze(1)此代碼創(chuàng)建了一個簡單的二維彈性梁柱模型,并進行了線性靜力分析。5.2動力分析5.2.1原理動力分析考慮了荷載作用的時間效應(yīng),包括慣性和阻尼效應(yīng)。在OpenSees中,動力分析可以用于模擬地震、風(fēng)荷載等動態(tài)荷載對結(jié)構(gòu)的影響。5.2.2內(nèi)容模態(tài)分析:用于確定結(jié)構(gòu)的固有頻率和振型。瞬態(tài)分析:考慮時間歷程荷載,如地震波,對結(jié)構(gòu)的影響。隨機振動分析:用于評估結(jié)構(gòu)在隨機荷載下的響應(yīng)。5.2.3示例代碼#OpenSeesPythonScriptforModalAnalysis

importopenseespy.openseesasops

#創(chuàng)建模型

ops.wipe()

ops.model('basic','-ndm',2,'-ndf',2)

#定義節(jié)點

ops.node(1,0.0,0.0)

ops.node(2,10.0,0.0)

#定義單元

ops.element('ElasticBeamColumn',1,1,2,1000.0,10000.0,0.0)

#定義邊界條件

ops.fix(1,1,1)

#定義質(zhì)量

ops.mass(2,1000.0)

#定義分析類型

ops.system('BandGeneral')

ops.numberer('RCM')

ops.constraints('Plain')

ops.analysis('Modal')

#進行模態(tài)分析

ops.eigen('-fullGenLapack',3)此代碼執(zhí)行了一個模態(tài)分析,計算了結(jié)構(gòu)的前三個固有頻率和振型。5.3非線性分析5.3.1原理非線性分析考慮了結(jié)構(gòu)在荷載作用下的非線性行為,包括材料非線性、幾何非線性和接觸非線性。在OpenSees中,非線性分析是進行結(jié)構(gòu)優(yōu)化設(shè)計和評估結(jié)構(gòu)在極端荷載下性能的關(guān)鍵工具。5.3.2內(nèi)容材料非線性:如鋼筋混凝土的塑性行為。幾何非線性:考慮大變形對結(jié)構(gòu)剛度的影響。接觸非線性:模擬結(jié)構(gòu)部件之間的接觸和摩擦。5.3.3示例代碼#OpenSeesPythonScriptforNonlinearStaticAnalysis

importopenseespy.openseesasops

#創(chuàng)建模型

ops.wipe()

ops.model('basic','-ndm',2,'-ndf',2)

#定義節(jié)點

ops.node(1,0.0,0.0)

ops.node(2,10.0,0.0)

#定義單元

ops.uniaxialMaterial('Hardening',1,10000.0,1000.0,0.001)

ops.element('ForceBeamColumn',1,1,2,1000.0,1.0,1.0,'-integration','Lobatto',3,1)

#定義邊界條件

ops.fix(1,1,1)

#定義荷載

ops.load(2,0.0,-1000.0)

#定義分析類型

ops.system('BandGeneral')

ops.numberer('RCM')

ops.constraints('Plain')

egrator('LoadControl',0.01)

ops.test('NormUnbalance',1.0e-8,10)

ops.algorithm('Newton')

ops.analysis('Static')

#進行非線性靜力分析

ops.analyze(100)此代碼創(chuàng)建了一個具有材料非線性的二維模型,并進行了非線性靜力分析。以上示例展示了如何使用OpenSees進行不同類型的結(jié)構(gòu)分析。通過調(diào)整模型參數(shù)和分析設(shè)置,可以模擬各種復(fù)雜的結(jié)構(gòu)行為,為結(jié)構(gòu)優(yōu)化設(shè)計提供有力支持。6結(jié)構(gòu)優(yōu)化設(shè)計原理6.1優(yōu)化設(shè)計概述結(jié)構(gòu)優(yōu)化設(shè)計是一種工程方法,旨在通過調(diào)整結(jié)構(gòu)的幾何形狀、材料屬性或拓?fù)浣Y(jié)構(gòu),以最小化或最大化特定目標(biāo),如成本、重量或剛度,同時確保結(jié)構(gòu)滿足所有設(shè)計約束。在結(jié)構(gòu)工程中,優(yōu)化設(shè)計可以顯著提高結(jié)構(gòu)的效率和性能,減少材料浪費,降低建造成本。6.1.1目標(biāo)函數(shù)目標(biāo)函數(shù)是優(yōu)化過程的核心,它定義了優(yōu)化的目標(biāo)。例如,在減輕結(jié)構(gòu)重量的優(yōu)化設(shè)計中,目標(biāo)函數(shù)可能是結(jié)構(gòu)的總重量。優(yōu)化算法將嘗試找到一組設(shè)計變量,使得目標(biāo)函數(shù)的值最小。6.1.2設(shè)計變量設(shè)計變量是優(yōu)化過程中可以調(diào)整的參數(shù)。這些變量可以是結(jié)構(gòu)的尺寸、形狀、材料類型或厚度等。在優(yōu)化過程中,設(shè)計變量的值將被算法調(diào)整,以達到目標(biāo)函數(shù)的最佳值。6.1.3約束條件約束條件限制了設(shè)計變量的取值范圍,確保優(yōu)化后的結(jié)構(gòu)仍然滿足安全性和功能性的要求。約束可以是應(yīng)力限制、位移限制、材料屬性限制等。6.2結(jié)構(gòu)優(yōu)化的目標(biāo)與約束在結(jié)構(gòu)優(yōu)化設(shè)計中,目標(biāo)和約束的定義至關(guān)重要。正確設(shè)定這些參數(shù)可以確保優(yōu)化過程不僅追求效率,而且保證結(jié)構(gòu)的安全性和功能性。6.2.1目標(biāo)示例:最小化結(jié)構(gòu)重量假設(shè)我們正在設(shè)計一座橋梁,目標(biāo)是最小化其總重量。我們可以定義目標(biāo)函數(shù)為:defobjective_function(design_variables):

#假設(shè)設(shè)計變量包括橋梁的寬度、厚度和材料密度

width,thickness,density=design_variables

#計算橋梁的總重量

total_weight=width*thickness*density*bridge_length*bridge_height

returntotal_weight6.2.2約束示例:應(yīng)力限制橋梁設(shè)計還必須滿足應(yīng)力限制,以確保結(jié)構(gòu)的安全性。我們可以定義一個應(yīng)力約束函數(shù):defstress_constraint(design_variables):

#假設(shè)設(shè)計變量包括橋梁的寬度和厚度

width,thickness=design_variables

#計算橋梁的最大應(yīng)力

max_stress=load/(width*thickness)

#確保最大應(yīng)力不超過材料的允許應(yīng)力

returnmax_stress-allowable_stress在優(yōu)化過程中,我們使用這些目標(biāo)和約束函數(shù)來指導(dǎo)算法。例如,使用Python的scipy.optimize庫,我們可以設(shè)置一個優(yōu)化問題:fromscipy.optimizeimportminimize

#設(shè)計變量的初始值

initial_design=[10,0.5,7800]#寬度,厚度,密度

#優(yōu)化目標(biāo):最小化結(jié)構(gòu)重量

defminimize_weight(design):

returnobjective_function(design)

#約束條件:應(yīng)力限制

defstress_limit(design):

returnstress_constraint(design)

#設(shè)置約束

constraints=({'type':'ineq','fun':stress_limit})

#進行優(yōu)化

result=minimize(minimize_weight,initial_design,constraints=constraints)通過調(diào)整設(shè)計變量,優(yōu)化算法將找到滿足所有約束條件下的最小結(jié)構(gòu)重量。這種優(yōu)化設(shè)計方法在現(xiàn)代工程設(shè)計中非常普遍,可以顯著提高結(jié)構(gòu)的經(jīng)濟性和性能。6.2.3數(shù)據(jù)樣例為了更好地理解上述代碼,我們假設(shè)以下數(shù)據(jù)樣例:bridge_length=100米bridge_height=10米load=1000000牛頓allowable_stress=100兆帕這些數(shù)據(jù)將用于計算目標(biāo)函數(shù)和約束函數(shù)的具體值,從而指導(dǎo)優(yōu)化過程。6.2.4結(jié)構(gòu)優(yōu)化的挑戰(zhàn)盡管結(jié)構(gòu)優(yōu)化設(shè)計可以帶來顯著的效益,但它也面臨一些挑戰(zhàn)。例如,優(yōu)化算法可能陷入局部最優(yōu)解,而不是全局最優(yōu)解。此外,復(fù)雜的結(jié)構(gòu)和約束可能需要大量的計算資源和時間。因此,選擇合適的優(yōu)化算法和參數(shù)設(shè)置對于成功實現(xiàn)結(jié)構(gòu)優(yōu)化至關(guān)重要。在實際應(yīng)用中,結(jié)構(gòu)工程師通常會使用專業(yè)的仿真軟件,如OpenSees,來模擬結(jié)構(gòu)的性能,并結(jié)合優(yōu)化算法進行結(jié)構(gòu)優(yōu)化設(shè)計。OpenSees提供了強大的結(jié)構(gòu)分析功能,可以準(zhǔn)確計算結(jié)構(gòu)在不同設(shè)計變量下的響應(yīng),從而為優(yōu)化設(shè)計提供關(guān)鍵數(shù)據(jù)支持。7使用OpenSees進行結(jié)構(gòu)優(yōu)化7.1OpenSees優(yōu)化模塊介紹OpenSees,作為一款強大的結(jié)構(gòu)力學(xué)仿真軟件,不僅能夠進行復(fù)雜的非線性動力分析,還提供了結(jié)構(gòu)優(yōu)化設(shè)計的功能。優(yōu)化模塊允許用戶通過定義目標(biāo)函數(shù)和約束條件,尋找結(jié)構(gòu)設(shè)計的最優(yōu)解。這一模塊特別適用于尋求結(jié)構(gòu)在滿足特定性能指標(biāo)下的最小成本或重量的設(shè)計方案。7.1.1目標(biāo)函數(shù)與約束條件在OpenSees中進行結(jié)構(gòu)優(yōu)化,首先需要定義目標(biāo)函數(shù),這通常是結(jié)構(gòu)的總成本或總重量。其次,設(shè)定約束條件,包括但不限于結(jié)構(gòu)的位移限制、應(yīng)力限制或頻率限制。這些條件確保優(yōu)化后的結(jié)構(gòu)不僅成本或重量最小,同時也能滿足工程設(shè)計的安全性和功能性要求。7.1.2優(yōu)化算法OpenSees支持多種優(yōu)化算法,包括但不限于梯度下降法、遺傳算法、粒子群優(yōu)化算法等。用戶可以根據(jù)問題的復(fù)雜性和求解效率選擇合適的算法。例如,對于非線性問題,遺傳算法可能更為適用,因為它能夠全局搜索最優(yōu)解,而梯度下降法則更適合于求解具有連續(xù)可微目標(biāo)函數(shù)的問題。7.2編寫優(yōu)化腳本在OpenSees中進行結(jié)構(gòu)優(yōu)化設(shè)計,通常需要編寫腳本來定義結(jié)構(gòu)、目標(biāo)函數(shù)、約束條件以及選擇優(yōu)化算法。下面通過一個具體的例子來說明如何編寫這樣的腳本。7.2.1示例:最小化結(jié)構(gòu)重量假設(shè)我們有一個簡單的兩跨連續(xù)梁結(jié)構(gòu),目標(biāo)是通過調(diào)整梁的截面尺寸來最小化結(jié)構(gòu)的總重量,同時確保梁的中點位移不超過特定限制。定義結(jié)構(gòu)#OpenSees腳本示例:定義結(jié)構(gòu)

importopenseespy.openseesasops

#創(chuàng)建一個OpenSees模型

ops.wipe()

ops.model('basic','-ndm',2,'-ndf',2)

#定義節(jié)點

ops.node(1,0.0,0.0)

ops.node(2,5.0,0.0)

ops.node(3,10.0,0.0)

#定義固定支座

ops.fix(1,1,1)

ops.fix(3,1,1)

#定義梁單元

ops.element('elasticBeamColumn',1,1,2,10000.0,1000.0)

ops.element('elasticBeamColumn',2,2,3,10000.0,1000.0)

#定義荷載

ops.timeSeries('Linear',1)

ops.pattern('Plain',1,1)

ops.load(2,0.0,-1000.0)定義目標(biāo)函數(shù)和約束條件#定義目標(biāo)函數(shù):結(jié)構(gòu)總重量

defobjective_function():

#獲取所有梁單元的截面尺寸

section_areas=[ops.getSection('area',i)foriinrange(1,3)]

#計算結(jié)構(gòu)總重量

total_weight=sum(section_areas)*7850.0#假設(shè)材料密度為7850kg/m^3

returntotal_weight

#定義約束條件:梁中點位移限制

defconstraint_function():

#獲取梁中點的位移

mid_deflection=ops.nodeDisp(2,1)

#返回位移與限制的差值

returnmid_deflection-0.01#假設(shè)位移限制為0.01m選擇優(yōu)化算法#使用遺傳算法進行優(yōu)化

frompyOptimportOptimization,NSGA2

#創(chuàng)建優(yōu)化問題實例

opt_prob=Optimization('MinimizeWeight',objective_function,constraints=[constraint_function])

opt_prob.addVar('area1','c',value=1000.0,lower=100.0,upper=2000.0)

opt_prob.addVar('area2','c',value=1000.0,lower=100.0,upper=2000.0)

#創(chuàng)建并運行優(yōu)化算法

optimizer=NSGA2(opt_prob)

solution=optimizer(opt_prob)解釋與分析在上述腳本中,我們首先定義了一個兩跨連續(xù)梁的結(jié)構(gòu)模型,并在梁的中點施加了一個垂直荷載。接著,我們定義了目標(biāo)函數(shù)和約束條件,目標(biāo)函數(shù)計算結(jié)構(gòu)的總重量,約束條件確保梁中點的位移不超過0.01米。最后,我們使用了遺傳算法(NSGA2)來尋找滿足約束條件下的最小結(jié)構(gòu)重量。通過運行優(yōu)化腳本,我們可以得到優(yōu)化后的梁截面尺寸,從而實現(xiàn)結(jié)構(gòu)的優(yōu)化設(shè)計。在實際應(yīng)用中,可能需要根據(jù)具體問題調(diào)整優(yōu)化算法的參數(shù),以獲得更精確的優(yōu)化結(jié)果。7.2.2結(jié)論OpenSees的優(yōu)化模塊為結(jié)構(gòu)工程師提供了一個強大的工具,能夠幫助他們在滿足工程設(shè)計要求的同時,尋找結(jié)構(gòu)設(shè)計的最優(yōu)解。通過編寫腳本來定義結(jié)構(gòu)、目標(biāo)函數(shù)、約束條件以及選擇優(yōu)化算法,用戶可以靈活地進行結(jié)構(gòu)優(yōu)化設(shè)計,提高設(shè)計效率和結(jié)構(gòu)性能。8案例分析與實踐8.1簡單結(jié)構(gòu)優(yōu)化設(shè)計案例在結(jié)構(gòu)優(yōu)化設(shè)計中,OpenSees提供了強大的工具來模擬和分析結(jié)構(gòu)的力學(xué)行為。下面,我們將通過一個簡單的梁優(yōu)化設(shè)計案例來展示如何使用OpenSees進行結(jié)構(gòu)優(yōu)化。8.1.1案例背景假設(shè)我們有一座簡支梁,需要在滿足強度和剛度要求的前提下,最小化其材料成本。梁的長度為10米,承受均布荷載10kN/m。我們希望通過優(yōu)化梁的截面尺寸來達到目標(biāo)。8.1.2OpenSees建模與分析首先,我們需要在OpenSees中建立梁的模型。以下是一個基本的OpenSees腳本,用于創(chuàng)建和分析該梁:#OpenSees腳本:創(chuàng)建和分析簡支梁

importopenseespy.openseesasops

#清除模型

ops.wipe()

#創(chuàng)建節(jié)點

ops.node(1,0,0)

ops.node(2,10,0)

#固定支座

ops.fix(1,1,1)

ops.fix(2,1,1)

#創(chuàng)建梁單元

ops.element('ElasticBeamColumn',1,1,2,10000,200000000,100000000,0.001)

#創(chuàng)建荷載模式

ops.timeSeries('Linear',1)

ops.pattern('Plain',1,1)

#施加均布荷載

ops.load(2,0,-10)

#創(chuàng)建約束處理

ops.constraints('Plain')

#創(chuàng)建系統(tǒng)

ops.system('BandGeneral')

#創(chuàng)建測試

ops.test('NormDispIncr',1e-6,100)

#創(chuàng)建算法

ops.algorithm('Newton')

#創(chuàng)建分析器

egrator('LoadControl',0.01)

#創(chuàng)建分析器

ops.analysis('Static')

#進行分析

ops.analyze(100)8.1.3結(jié)構(gòu)優(yōu)化為了優(yōu)化梁的截面尺寸,我們可以使用Python的優(yōu)化庫,如scipy.optimize。下面是一個使用scipy.optimize的示例,通過調(diào)整梁的截面慣性矩和截面面積來最小化材料成本:importnumpyasnp

fromscipy.optimizeimportminimize

#定義優(yōu)化目標(biāo)函數(shù)

defcost_function(x):

#x[0]是截面慣性矩,x[1]是截面面積

ops.wipe()

ops.node(1,0,0)

ops.node(2,10,0)

ops.fix(1,1,1)

ops.fix(2,1,1)

ops.element('ElasticBeamColumn',1,1,2,x[1],200000000,x[0],0.001)

ops.timeSeries('Linear',1)

ops.pattern('Plain',1,1)

ops.load(2,0,-10)

ops.constraints('Plain')

ops.system('BandGeneral')

ops.test('NormDispIncr',1e-6,100)

ops.algorithm('Newton')

egrator('LoadControl',0.01)

ops.analysis('Static')

ops.analyze(100)

#假設(shè)材料成本與截面面積和慣性矩成正比

returnx[0]+x[1]

#定義約束條件

defconstraint(x):

#確保梁的位移不超過允許值

ops.wipe()

ops.node(1,0,0)

ops.node(2,10,0)

ops.fix(1,1,1)

ops.fix(2,1,1)

ops.element('ElasticBeamColumn',1,1,2,x[1],200000000,x[0],0.001)

ops.timeSeries('Linear',1)

ops.pattern('Plain',1,1)

ops.load(2,0,-10)

ops.constraints('Plain')

ops.system('BandGeneral')

ops.test('NormDispIncr',1e-6,100)

ops.algorithm('Newton')

egrator('LoadControl',0.01)

ops.analysis('Static')

ops.analyze(100)

returnops.nodeDisp(2,1)-0.01

#初始猜測

x0=np.array([100000000,10000])

#進行優(yōu)化

res=minimize(cost_function,x0,method='SLSQP',constraints={'type':'ineq','fun':constraint})

#輸出優(yōu)化結(jié)果

print('優(yōu)化后的截面慣性矩:',res.x[0])

print('優(yōu)化后的截面面積:',res.x[1])8.1.4結(jié)果解釋上述代碼中,我們定義了成本函數(shù)cost_function和約束函數(shù)constraint。成本函數(shù)計算了給定截面尺寸下的材料成本,而約束函數(shù)確保梁的位移不超過允許值。通過scipy.optimize.minimize函數(shù),我們找到了滿足約束條件下的最小成本截面尺寸。8.2復(fù)雜結(jié)構(gòu)優(yōu)化設(shè)計案例對于更復(fù)雜的結(jié)構(gòu),如多層建筑或橋梁,OpenSees的建模和分析能力同樣強大。下面,我們將通過一個多層建筑的優(yōu)化設(shè)計案例來展示如何使用OpenSees進行結(jié)構(gòu)優(yōu)化。8.2.1案例背景假設(shè)我們有一座三層的建筑,需要在滿足地震安全要求的前提下,最小化其結(jié)構(gòu)成本。建筑的每層高度為3米,每層樓板面積為100平方米。我們希望通過優(yōu)化柱的截面尺寸和樓板的厚度來達到目標(biāo)。8.2.2OpenSees建模與分析首先,我們需要在OpenSees中建立建筑的模型。以下是一個基本的OpenSees腳本,用于創(chuàng)建和分析該建筑:#OpenSees腳本:創(chuàng)建和分析多層建筑

importopenseespy.openseesasops

#清除模型

ops.wipe()

#創(chuàng)建節(jié)點

foriinrange(4):

ops.node(i+1,0,i*3)

#固定支座

ops.fix(1,1,1)

#創(chuàng)建柱單元

foriinrange(3):

ops.element('ElasticBeamColumn',i+1,i+1,i+2,10000,200000000,100000000,0.001)

#創(chuàng)建樓板單元

foriinrange(3):

ops.element('ShellMITC4',i+4,i+1,i+2,i+3,i+4,10000,200000000,100000000,0.001)

#創(chuàng)建荷載模式

ops.timeSeries('Linear',1)

ops.pattern('Plain',1,1)

#施加地震荷載

foriinrange(2,5):

ops.load(i,0,-10)

#創(chuàng)建約束處理

ops.constraints('Plain')

#創(chuàng)建系統(tǒng)

ops.system('BandGeneral')

#創(chuàng)建測試

ops.test('NormDispIncr',1e-6,100)

#創(chuàng)建算法

ops.algorithm('Newton')

#創(chuàng)建分析器

egrator('LoadControl',0.01)

#創(chuàng)建分析器

ops.analysis('Static')

#進行分析

ops.analyze(100)8.2.3結(jié)構(gòu)優(yōu)化為了優(yōu)化柱的截面尺寸和樓板的厚度,我們可以使用Python的優(yōu)化庫,如scipy.optimize。下面是一個使用scipy.optimize的示例,通過調(diào)整柱的截面慣性矩、截面面積和樓板的厚度來最小化結(jié)構(gòu)成本:importnumpyasnp

fromscipy.optimizeimportminimize

#定義優(yōu)化目標(biāo)函數(shù)

defcost_function(x):

#x[0]是柱截面慣性矩,x[1]是柱截面面積,x[2]是樓板厚度

ops.wipe()

foriinrange(4):

ops.node(i+1,0,i*3)

ops.fix(1,1,1)

foriinrange(3):

ops.element('ElasticBeamColumn',i+1,i+1,i+2,x[1],200000000,x[0],0.001)

foriinrange(3):

ops.element('ShellMITC4',i+4,i+1,i+2,i+3,i+4,x[2],200000000,100000000,0.001)

ops.timeSeries('Linear',1)

ops.pattern('Plain',1,1)

foriinrange(2,5):

ops.load(i,0,-10)

ops.constraints('Plain')

ops.system('BandGeneral')

ops.test('NormDispIncr',1e-6,100)

ops.algorithm('Newton')

egrator('LoadControl',0.01)

ops.analysis('Static')

ops.analyze(100)

#假設(shè)結(jié)構(gòu)成本與柱截面尺寸和樓板厚度成正比

returnx[0]+x[1]+x[2]

#定義約束條件

defconstraint(x):

#確保建筑的位移不超過允許值

ops.wipe()

foriinrange(4):

ops.node(i+1,0,i*3)

ops.fix(1,1,1)

foriinrange(3):

ops.element('ElasticBeamColumn',i+1,i+1,i+2,x[1],200000000,x[0],0.001)

foriinrange(3):

ops.element('ShellMITC4',i+4,i+1,i+2,i+3,i+4,x[2],200000000,100000000,0.001)

ops.timeSeries('Linear',1)

ops.pattern('Plain',1,1)

foriinrange(2,5):

ops.load(i,0,-10)

ops.constraints('Plain')

ops.system('BandGeneral')

ops.test('NormDispIncr',1e-6,100)

ops.algorithm('Newton')

egrator('LoadControl',0.01)

ops.analysis('Static')

ops.analyze(100)

returnops.nodeDisp(4,1)-0.05

#初始猜測

x0=np.array([100000000,10000,0.1])

#進行優(yōu)化

res=minimize(cost_function,x0,method='SLSQP',constraints={'type':'ineq','fun':constraint})

#輸出優(yōu)化結(jié)果

print('優(yōu)化后的柱截面慣性矩:',res.x[0])

print('優(yōu)化后的柱截面面積:',res.x[1])

print('優(yōu)化后的樓板厚度:',res.x[2])8.2.4結(jié)果解釋在復(fù)雜結(jié)構(gòu)優(yōu)化設(shè)計案例中,我們同樣定義了成本函數(shù)cost_function和約束函數(shù)constraint。成本函數(shù)計算了給定柱截面尺寸和樓板厚度下的結(jié)構(gòu)成本,而約束函數(shù)確保建筑的位移不超過允許值。通過scipy.optimize.minimize函數(shù),我們找到了滿足約束條件下的最小成本結(jié)構(gòu)參數(shù)。通過這兩個案例,我們可以看到OpenSees在結(jié)構(gòu)優(yōu)化設(shè)計中的應(yīng)用潛力。它不僅能夠精確模擬結(jié)構(gòu)的力學(xué)行為,還能夠與Python的優(yōu)化庫無縫集成,實現(xiàn)結(jié)構(gòu)參數(shù)的優(yōu)化。這為工程師提供了一個強大的工具,能夠在設(shè)計階段就考慮到結(jié)構(gòu)的經(jīng)濟性和安全性。9OpenSees高級應(yīng)用9.1自定義材料模型在結(jié)構(gòu)力學(xué)仿真中,材料模型是模擬結(jié)構(gòu)行為的關(guān)鍵。OpenSees提供了多種內(nèi)置材料模型,但有時這些模型可能無法完全滿足特定工程需求。因此,自定義材料模型成為了一種必要的技能,允許用戶根據(jù)實際材料的性能來精確建模。9.1.1原理自定義材料模型在OpenSees中通常通過擴展UniaxialMaterial類或NDMaterial類來實現(xiàn)。這些類提供了基本的框架和接口,用戶需要實現(xiàn)特定的應(yīng)力-應(yīng)變關(guān)系、本構(gòu)關(guān)系或損傷累積算法等。9.1.2內(nèi)容實現(xiàn)步驟繼承材料類:從UniaxialMaterial或NDMaterial繼承。定義構(gòu)造函數(shù):設(shè)置材料參數(shù)。實現(xiàn)計算方法:如getStress、getTangent等。注冊材料:確保OpenSees能夠識別并使用自定義材料。示例代碼//自定義材料模型示例:線性彈性材料

#include<UniaxialMaterial.h>

#include<Information.h>

classCustomLinearElasticMaterial:publicUniaxialMaterial{

public:

CustomLinearElasticMaterial(inttag,doubleE,doubleeps0);

~CustomLinearElasticMaterial();

intgetTag(void)const;

constchar*getType(void)const;

intsetTrialStrain(doublestrain);

doublegetStrain(void);

doublegetStress(void);

doublegetTangent(void);

intcommitState(void);

intrevertToLastCommit(void);

intrevertToStart(void);

UniaxialMaterial*getCopy(void);

intsendSelf(intcTag,Channel&theChannel);

intrecvSelf(intcTag,Channel&theChannel,FEM_ObjectBroker&theBroker);

voidPrint(OPS_Stream&s,intflag);

intparameterID(int);

intupdateParameter(int,Information&);

intactivateParameter(int);

protected:

doubleYoungsModulus;

doublestrain;

doublestress;

};

CustomLinearElasticMaterial::CustomLinearElasticMaterial(inttag,doubleE,doubleeps0)

:UniaxialMaterial(tag,OPS_TAG_CustomLinearElasticMaterial),YoungsModulus(E),strain(0.0),stress(0.0){

if(eps0<0.0){

opserr<<"WARNINGnegativestrainvaluepassedtoCustomLinearElasticMaterialconstructor\n";

strain=0.0;

}else{

strain=eps0;

}

}

CustomLinearElasticMaterial::~CustomLinearElasticMaterial(){}

intCustomLinearElasticMaterial::setTrialStrain(doublestrain){

this->strain=strain;

this->stress=strain*YoungsModulus;

return0;

}

doubleCustomLinearElasticMaterial::getStrain(void){

returnstrain;

}

doubleCustomLin

溫馨提示

  • 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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論