西欧5800计算器坐标正反算程序
西歐5800計(jì)算器坐標(biāo)正反算程序
?
講你個(gè)講?
1位粉絲?
?1樓
主程序 ? 坐標(biāo)正反算
程序名稱:ZBZFS
Lb1 ? A↙
30→Dim Z :"0=ZS,1=FS"?Z ↙
If ? Z=0:Then ? Goto B:IfEnd↙ ? ? (Z=0進(jìn)入里程點(diǎn)坐標(biāo)正算)
If ? Z=1:Then ? Prog"FSLCZ "↙ ? (Z=1進(jìn)入反算里程邊樁)
Lb1 B ? ↙
Prog”ZBZS” ↙
子程序反算里程樁 名稱:FSLCZ
Lb1 ? 1↙
"XK="?X:"YK="?Y↙(輸入任意測(cè)點(diǎn)的X、Y坐標(biāo))
“K=”?K ↙(試算里程,任意輸入標(biāo)段內(nèi)里程點(diǎn)即可,也可以輸入大致的估算里程加快速度)
Lb1 ? 2↙
Prog"SJK ":T-90 →W:W<0=>360+W→W:Abs((Y-Z[19])*Cos(W)-(X-Z[18])*Sin(W))→S↙
If ? S<0.0001:Then ? Goto ? 4:Else ? Goto 3:Ifend↙
Lb1 ? 3↙
K+S→K: Prog"SJK":T-90 →W:W<0=>360+W→W:Abs((Y-Z[19])*Cos W-(X-Z[18])*Sin (W)→Q↙
If ? Q<0.0001 :Then Q→S: Goto ? 4:Else if ? Q<S: Then ? K+Q→K: Goto ? 2 :Else if Q>S ? :Then K-Q→K:Goto ? 2:Ifend:Ifend:Ifend↙
Lb1 ? 4↙
Pol (X-Z[18],Y-Z[19]:
"DP(-Z+Y)=":I◢(偏距)
"K=":K+S→K◢(里程)
Goto 1↙
子程序坐標(biāo)正算 名稱:ZBZS
Lb1 ? 0 ↙
“XHS="?G(后視點(diǎn)X):"YHS="?L(后視點(diǎn)Y):"XZJ="?M(置鏡點(diǎn)X):"YZJ="?N(置鏡點(diǎn)Y):Pol(G-M,L-N):"DH=":I(后視距)◢J<0=>J+360→J:"FH=":JDMS◢(后視方位角)?
Lb1 ? 1↙
“K=”?K :(輸入所需計(jì)算里程)Prog"SJK "↙
XI : Z[18]↙ ?
YI: Z[19] ↙ ?
Pol(Z[18]-M,Z[19]-N): J<0=>J+360→J↙
“PJ=”?P↙ ? ? ?(輸入樁與線路夾角)
“PD=”?D↙ ? ? (輸入樁距中線的距離)
Z[18]+D*Cos(T+P) →Z[20] ↙
Z[19]+D*Sin(T+P) →Z[21] ↙
“X=”: Z[20] ◢ ? ? ?(放樣坐標(biāo)X)
“Y=”: Z[21] ◢ ? ? ?(放樣坐標(biāo)Y)
Pol(Z[20]-M,Z[21]-N):"D=":I◢(放樣距)J<0=>J+360→J:"F=":JDMS◢(放樣方位角)
Goto 1↙
子程序數(shù)據(jù)庫(kù) ? 名稱:SJK
if ? K<本段曲線終點(diǎn)里程 ? And ? K≥上段曲線終點(diǎn)里程 :Then ? 本段曲線終點(diǎn)里程→Z[1] : 上段曲線終點(diǎn)里程(第一段曲線輸起點(diǎn)的里程)→Z[2] :1→O (注:左偏曲線輸入-1→O,右偏曲線輸入1→O): 半徑→R : 曲線偏角→A:第一緩和曲線→Z[6] : 第二緩和曲線→Z[7] : 交點(diǎn) X→B :交點(diǎn) Y→C : 小里程向交點(diǎn)方位角→E : 交點(diǎn)向大里程方位角→F : Prog”JSPB”:Return: Ifend↙
if…………Prog”JSPB”:Return:Ifend(曲線段分段輸入)↙
補(bǔ)充直線段輸入如下 (只需輸線路的最后一段直線數(shù)據(jù))
if K<本段直線終點(diǎn)里程 And ? K≥本段直線起點(diǎn)里程:Then 本段直線終點(diǎn)里程→Z[3]:終點(diǎn)X→Z[16]:終點(diǎn)Y→Z[17]:方位角→E: Z[16]+ (K- Z[3])*Cos(E)→Z[18]:Z[17]+ (K- Z[3])*Sin(E)→Z[19] : Return:Ifend↙
子程序計(jì)算判別 名稱:JSPB
Lb1 ? 2 ↙(曲線要素計(jì)算)
Z[6]/2- Z[6]^3/(240*R^2)+ Z[6]^5/(34560*R^4) →Z[8] ↙ ? (M1)
Z[7]/2- Z[7]^3/(240*R^2)+ Z[7]^5/(34560*R^4) →Z[9] ↙ ? (M2)
Z[6]^2/(24*R)- Z[6]^4/(2688*R^3) →Z[10] ↙ ? (P1)
Z[7]^2/(24*R)- Z[7]^4/(2688*R^3) →Z[11] ↙ ? (P2)
?
2009-12-31 20:08?
回復(fù)?
?
?
講你個(gè)講?
1位粉絲?
?2樓
π*A*R/180+0.5*( Z[6]+ Z[7])→Z[25] ↙ ? ?(曲線總長(zhǎng))
90* Z[6]/(R*π) →Z[14] ↙ ? ? (第一緩和曲線總偏角)
90* Z[7]/(R*π) →Z[15] ↙(第二緩和曲線總偏角,可以省略)
Z[8]+(R+Z[10])Tan(A/2)-(Z[10]-Z[11] )/Sin( A)→Z[12]↙ ? ?(切線T1)
Z[9]+(R+Z[11])Tan(A/2)+(Z[10]-Z[11] )/Sin (A)→Z[13]↙ ? ?(切線T2)
B+ Z[12]*Cos (E+180)→ Z[16] ↙ ? (ZH點(diǎn)X)?
C+ Z[12]*Sin(E+180)→ Z[17] ↙ ? ?(ZH點(diǎn)Y)
Z[1]- Z[25]→Z[3] ↙ ? ? ? ?(ZH點(diǎn)里程)
Z[3]+ Z[6]→Z[4] ↙ ? ?(HY點(diǎn)里程)
Z[1]- Z[7]→Z[5] ↙ ? ?(YH點(diǎn)里程)
Goto 3 ↙
LB1 ? 3 ↙(判斷里程點(diǎn)與曲線關(guān)系)
if ? K≤Z[3] ? And ? K> Z[2] : Then ? Goto 4 : Ifend ↙
if ? K≤Z[4] ? And ? K> Z[3] : Then ? Goto ? 5 : Ifend ? ↙
if ? K≤Z[5] ? And ? K> Z[4] : Then ? Goto ? 6 : Ifend ↙
if K≤Z[1] ? And ? K> Z[5] : Then ? Goto ? 7 : Ifend ↙
Lb1 ? 4 ↙(里程小于直緩點(diǎn)直線獨(dú)立坐標(biāo))
K- Z[3] →Z[23] : 0→Z[24] : E→T : Goto ? 8↙
Lb1 ? 5 ↙(第一緩和曲線獨(dú)立坐標(biāo))
K- Z[3] →H ↙
H-H^5/(40*R^2* Z[6]^2)+H^9/(3456*R^4* Z[6]^4) →Z[23] ↙
H^3/(6*R* Z[6])-H^7/(336*R^3* Z[6]^3) →Z[24] ↙
90*H^2/( R*π* Z[6]) →T ↙
if ? O>0 ? :Then ? T +E→T : Eles ? E-T →T : T<0=>360+T→T : Ifend ↙?
Goto 8 ↙
Lb1 6 ↙(圓曲線獨(dú)立坐標(biāo))
K- Z[4] →H ↙
H*180/( R*π)+ Z[14]→T ↙
R*Sin(T)+ Z[8]→Z[23] ↙
R*(1-Cos(T))+ Z[10]→Z[24] ↙
if ? O>0 ? :Then ? T +E→T : Eles ? E-T →T : T<0=>360+T→T : Ifend ↙?
Goto 8 ↙
Lb1 7 ↙(第二緩和曲線獨(dú)立坐標(biāo))
Z[1] -K ? →H ↙
H-H^5/(40*R^2* Z[7]^2)+H^9/(3456*R^4* Z[7]^4) →U↙
H^3/(6*R* Z[7])-H^7/(336*R^3* Z[7]^3) →V ↙
90*H^2/( R*π* Z[7]) →T ↙
Z[13]Cos(A)+ Z[12]-U*Cos(A)-V*Sin(A)→Z[23] ↙
Z[13]*Sin(A)-U*Sin(A)+V*Cos(A)→Z[24] ? ↙
if ? O>0 ? :Then F-T→T : T<0=>360+T→T : Else F+T →T : Ifend ↙?
Goto ? 8 ↙
Lb1 ? ?8
if ? O<0 ? : Then ? - Z[24]→Z[24] : Ifend ↙
Z[16]+Z[23]*Cos(E) -Z[24]*Sin(E)→Z[18] ↙
Z[17]+Z[23]*Sin(E)+Z[24]*Cos(E)→Z[19] ↙
Return↙
?
?
總結(jié)
以上是生活随笔為你收集整理的西欧5800计算器坐标正反算程序的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 基于java实现bilibili视频爬虫
- 下一篇: 坐标反算用计算机怎么算,卡西欧5800计