由於羅盤標題的範圍從0-360度,所以平均標量風向數據會產生不準確的值,所以我已將列表轉換爲u和v分量已經有了大小和風向。使用lapply或ifelse計算風的U和V分量的風向
爲了背出正確的風向,用於平均目的,我需要開發某種應用,ifelse,爲3個以下場景功能:
V > 0...((180/pi) * atan((Ucomp/Vcomp)) + 180)
U and V < 0...((180/pi) * atan((Ucomp/Vcomp)) + 0)
U > 0 and V < 0...((180/pi) * atan((Ucomp/Vcomp)) + 360)
在數據集我期待Ucomp大於0且Vcomp小於零,但毫無疑問會出現所有3將泛出的情況,所以我需要一個函數來解析並迭代計算併爲每個時間步應用正確的公式。我之前沒有使用過lapply或功能,所以我和他們一起玩都沒用。
我在下面提供數據的樣本...
DateTime Wind.Spd Wind.Direction Air.Density Temp.C GEP.GE16XLE GCF.GE16XLE Ucomp Vcomp
1 1981 7.662370 248.3395 0.9148207 11.28967 597.7513 37.35946 5.253453 -0.7404972
2 1982 8.199412 251.6763 0.9172176 10.12751 678.8595 42.42872 5.867979 -0.6191475
3 1983 8.188782 251.7889 0.9162767 10.30619 667.9461 41.74663 5.777208 -1.0473982
4 1984 7.942632 246.7908 0.9174074 10.05093 642.6374 40.16484 5.415773 -0.6796723
5 1985 8.016558 252.7305 0.9171721 10.38414 654.2588 40.89117 5.649406 -0.9999082
6 1986 7.739984 249.6431 0.9158740 10.99859 607.0542 37.94089 5.305971 -0.9118965
美麗......感謝約翰......完美的作品。我在閱讀其他論壇時看過plyr軟件包,但都試圖用聚合標籤來貼合標籤,但對於這個問題我需要別的東西。我還在用一些精心製作的陳述,我不能完全弄明白。我很感謝 – RWJ 2011-12-29 21:15:20
的幫助,這會起作用,但是在很多計算上會很慢。 – John 2011-12-29 22:17:50
我只在30年的月平均數據和年平均數據上做這件事,所以它適用於我的目的。 – RWJ 2011-12-29 22:27:31