MỤC LỤC
Trang
BẢNG TRA CỨU CÁC TỪ VIẾT TẮTiv
DANH MỤC BẢNG BIỂUx
DANH MỤC HÌNH VẼxi
CHƯƠNG 1: CÔNG NGHỆ WCDMA1
1.1. SỰ PHÁT TRIỂN CỦA HỆ THỐNG THÔNG TIN DI ĐỘNG1
1.1.1. Hệ thống thông tin di động thế hệ 1. 1
1.1.2. Hệ thống thông tin di động thế hệ 2. 2
1.1.2.1. Đa truy cập phân chia theo thời gian TDMA3
1.1.2.2. Đa truy cập phân chia theo mã CDMA4
1.2. HỆ THỐNG THÔNG TIN DI ĐỘNG THẾ HỆ BA (3G - THE THIRD GENERATION)6
1.3. YÊU CẦU ĐỐI VỚI HỆ THỐNG THÔNG TIN DI ĐỘNG THẾ HỆ BA7
1.4. SỰ KHÁC NHAU CƠ BẢN GIỮA WCDMA VÀ GIAO DIỆN VÔ TUYẾN THẾ HỆ THỨ 211
1.5. GIỚI THIỆU TỔNG QUAN MẠNG WCDMA12
1.5.1. Mô cấu trúc mạng WCDMA13
1.5.2. Mạng truy nhập vô tuyến UTRAN:16
1.5.2.1. Đặc trưng của UTRAN16
1.5.2.2. Bộ điều khiển mạng vô tuyến UTRAN17
1.5.2.3. Node B18
1.5.3. Giao diện vô tuyến. 18
1.5.3.1. Giao diện UTRAN – CN, IU. 18
1.5.3.2. Giao diện RNC – RNC, IUr19
1.5.3.3. Giao diện RNC – Node B, IUb. 20
1.6. CÁC LOẠI KÊNH TRONG UTRAN20
1.6.1. Các kênh lôgic. 20
1.6.2. Các kênh vật lý. 21
1.6.3. Các kênh truyền tải22
1.6.3.1. Kênh truyền tải riêng. 22
1.6.3.2. Các kênh truyền tải chung. 23
1.7. KỸ THUẬT TRẢI PHỔ TRONG WCDMA25
1.8. ĐIỀU KHIỂN CÔNG SUẤT TRONG WCDMA26
1.8.1. Điều khiển công suất vòng hở (OLPC). 27
1.8.2. Điều khiển công suất vòng kín (CLPC). 28
1.8.3. Các trường hợp điều khiển công suất đặc biệt29
CHƯƠNG 2: QUY HOẠCH MẠNG WCDMA40
2.1. KHỞI TẠO QUY HOẠCH (ĐỊNH CỠ MẠNG). 41
2.1.1. Sơ đồ khối quá trình định cỡ mạng. 42
2.1.2. Phân tích quỹ năng lượng đường truyền vô tuyến. 43
2.1.2.1. Quỹ năng lượng đường lên. 44
2.1.2.2. Quỹ năng lượng đường xuống. 47
2.1.2.3. Độ nhạy máy thu. 51
2.1.2.4. Độ lợi chuyển giao mềm và giới hạn hiệu ứng che tối52
2.1.3. Xác định bán kính và vùng phủ sóng cell53
2.1.4. Quy hoạch dung lượng và vùng phủ - lặp tối ưu. 54
2.1.5. Định cỡ RNC(Radio network Control). 56
2.2. QUY HOẠCH CHI TIẾT58
2.2.1. Phân tích suy hao đường truyền và các mô truyền dẫn. 59
2.2.2. Các mô truyền dẫn cơ bản. 59
2.2.2.1. Mô Hata-Okumura. 59
2.2.2.2. Mô Walfisch - Ikegami61
2.2.3. Lặp đường lên và đường xuống. 64
2.2.4. Hậu xử lý - Dự báo vùng phủ mạng và phân tích kênh chung. 65
2.3. TỐI ƯU MẠNG65
CHƯƠNG 3: CÁC GIẢI PHÁP TỐI ƯU MẠNG W-CDMA68
3.1. MÔ TẢ TOÁN HỌC CỦA VẤN ĐỀ TỐI ƯU HOÁ68
3.2.TỐI ƯU TRONG QUY HOẠCH VÀ THIẾT KẾ MẠNG BẰNG PHƯƠNG PHÁP DỰ BÁO LƯU LƯỢNG69
3.2.1. Quy trình dự báo lưu lượng. 69
3.2.2. Dự báo lưu lượng bằng phương pháp hồi quy tuyến tính. 70
3.2.3. Dự báo lưu lượng bằng phương pháp hồi quy đàn hồi72
3.3. CÁC CÔNG NGHỆ ĐỂ TĂNG DUNG LƯỢNG ĐƯỜNG TRUYỀN TRONG W-CDMA75
3.3.1. Phân tập dàn anten thích ứng. 75
3.3.2. Cấu phân tập dàn anten thích ứng. 77
CHƯƠNG 4: XÂY DỰNG BÀI TOÁN TÍNH BÁN KÍNH CELL VÀ TỔNG LƯU LƯỢNG TRONG HỆ THỐNG WCDMA81
4.1. LƯU ĐỒ TÍNH TOÁN81
4.1.1. Lưu đồ thuật toán tổng quát:81
4.1.2. Lưu đồ thuật toán chi tiết82
4.2. KẾT QUẢ CHƯƠNG TRÌNH84
4.2.1 Giao diện chính:84
4.2.2.Tính suy hao đường truyền. 84
4.2.3. Tính kích thước Cell85
4.2.4. Tính dung lượng kênh. 85
KẾT LUẬN VÀ HƯỚNG PHÁT TRIỂN CỦA ĐỀ TÀI. 87
TÀI LIỆU THAM KHẢO89
PHỤ LỤC A1
109 trang |
Chia sẻ: lvcdongnoi | Lượt xem: 2772 | Lượt tải: 1
Bạn đang xem trước 20 trang tài liệu Quy hoạch và tối ưu mạng wcdma, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
i của một RNC.
Lưu lượng cực đại tại giao diện Iub.
Số lượng và loại giao diện (ví dụ: STM-1, E1).
Ví dụ về dung lượng của một RNC với các cấu khác nhau:
2.3: Ví dụ về dung lượng của một RNC.
Cấu
Lưu lượng Iub
(Mbps)
Số BTS
Số cell
Các giao diện khác
STM-1
E1
1
48
128
384
4*4
6*16
2
85
192
576
4*4
8*16
3
122
256
768
4*4
10*16
4
159
256
960
4*4
12*16
5
196
384
1152
4*4
14*16
Số lượng RNC cần thiết để kết nối đến một số cell nhất định có thể được tính theo công thức sau:
numCells
cellsRNC . fillrate_1
(2.38)
numRNCs =
Trong đó:
numCells: số lượng cell của vùng đang thực hiện việc định cỡ.
cellsRNC: số lượng cell cực đại mà RNC có khả năng hỗ trợ.
fillrate_1: hệ số sử dụng để dự phòng cho dung lượng cực đại.
numBTSs
btsRNC . fillrate_2
(2.39)
Số lượng RNC cần thiết để kết nối đến một số BTS nhất định có thể được tính theo công thức sau:
numRNCs =
Trong đó:
numBTSs: số BTS trong khu vực cần định cỡ.
btsRNC: số BTS cực đại có thể kết nối đến RNC.
fillrate_2: hệ số sử dụng để dự phòng cho dung lượng cực đại.
Dựa trên dung lượng dự tính, có nhiều phương pháp định cỡ RNC như sau:
Lưu lượng hỗ trợ (giới hạn trên của định cỡ RNC): thể hiện dung lượng thiết bị quy hoạch mạng, thông thường được quy hoạch sao cho nó lớn hơn dung lượng yêu cầu.
Lưu lượng yêu cầu (giới hạn dưới của định cỡ RNC): là giá trị lưu lượng trung bình thực tế trên toàn mạng.
Giao diện truyền dẫn Iub: nếu định cỡ RNC để phục vụ N trạm, thì tổng dung lượng của giao diện truyền dẫn Iub phải lớn hơn N lần dung lượng của mỗi trạm.
2.2. QUY HOẠCH CHI TIẾT
Việc quy hoạch chi tiết được thực hiện sử dụng phần mềm quy hoạch mạng. Ở đây, ta phân tích phần mềm mô phỏng tĩnh, cho nên mặc dù thực tế các thuê bao không di động tuy nhiên các thuê bao có các tốc độ khác nhau.
Chương trình mô phỏng gồm có 3 phần cơ bản: Phần khởi tạo, phân tích tổng hợp đường lên và đường xuống, và phần hậu xử lý.
Pha khởi tạo
Pha hậu xử lý
Vòng lặp kết hợp UL/DL
Khởi tạo toàn bộ
Khởi tạo các vòng lặp
Bước lặp UL
Bước lặp DL
Hậu xử lý
Hiển thị đồ họa
Phân tích vùng phủ
Kết thúc
2.6: Tổng quan mô phỏng tĩnh.
2.2.1. Phân tích suy hao đường truyền và các mô truyền dẫn
Địa hình
Hình thái học
Hướng phố
Mô hình truyền sóng
Suy hao tuyến cơ bản
Độ cao hiệu dụng anten
Tham số điều chỉnh
LOS
NLOS
2.7: Các thành phần của mô truyền sóng.
Trong quá trình quy hoạch mạng, các mô truyền dẫn được sử dụng để tính cường độ trường tín hiệu của một máy phát trong vùng tính toán. Trong các cell vĩ mô, giả thiết rằng các máy phát ở trên đỉnh mái nhà và máy thu ở trên mặt đất. Sự truyền lan sóng vô tuyến từ bộ phát đến bộ thu tính toán không đơn giản vì nhiều trở ngại và cấu trúc kênh phức tạp. Trong cell vi mô, việc tính toán đơn giản hơn vì thường chỉ có một ít đường tín hiệu mạnh.
Trong quy hoạch cell vĩ mô, môi trường truyền dẫn phức tạp vì khoảng cách từ máy phát đến máy thu lớn và đường truyền sóng khó xác định. Trong điều kiện đó sử dụng mô thực nghiệm hoặc bán thực nghiệm có hiệu quả hơn. Những mô này sử dụng các tham số tự do và các hệ số điều chỉnh khác nhau có thể được điều chỉnh bằng số liệu đo. Các mô thực nghiệm được sử dụng có hiệu quả trong điều kiện môi trường gần máy phát ít ảnh hưởng đến truyền sóng.
2.2.2. Các mô truyền dẫn cơ bản
Phần này giới thiệu 2 mô truyền dẫn được sử dụng rộng rãi, đó là mô Hata-Okumura và Walfisch-Ikegami. Những mô thực nghiệm này là những phương tiện cơ bản cho việc tính toán suy hao truyền dẫn.
2.2.2.1. Mô Hata-Okumura
Mô Hata-Okumura là quan hệ thực nghiệm được rút ra từ báo cáo kỹ thuật của Okumura cho phép sử dụng các kết quả vào các công cụ tính toán. Báo cáo của Okumura bao gồm một chuỗi các lưu đồ được sử dụng để lập mô thông tin vô tuyến. Dựa trên các đo lường được thực hiện bởi Y.Okumura ở Tokyo tại tần số 1920 MHz, các đo lường này vừa khớp với mô toán học của M.Hata.
Trong mô này, ban đầu suy hao đường truyền được tính bằng cách tính hệ số điều chỉnh Anten cho các vùng đô thị là hàm của khoảng cách giữa trạm gốc, trạm di động và tần số. Hệ số này được đưa vào suy hao không gian tự do. Kết quả được điều chỉnh bằng các hệ số cho độ cao anten trạm gốc và trạm di động. Ngoài ra, các hệ số điều chỉnh được cấp cho hướng phố, các vùng ngoại ô, các vùng mở và các địa không đều.
Các biểu thức toán học được sử dụng trong mô Hata-Okumura để xác định tổn hao trung bình L:
Lp= 69,55 + 26,16lgfc – 13,82lghb – a(hm) + (44,9 – 6,55lghb)lgr dB (2.40)
Trong đó: fc: tần số hoạt động (MHz); Lp: tổn hao trung bình
hb: độ cao anten trạm gốc (m); hm: độ cao anten trạm di động (m)
r : bán kính cell (khoảng cách từ trạm gốc) (km)
a(hm): hệ số hiệu chỉnh cho độ cao anten di động (dB)
Dải thông số sử dụng được cho mô Hata là:
150 ≤ fc ≤ 1500 MHz; 30 ≤ hb ≤ 200 m; 1 ≤ hm ≤ 10 m; 1 ≤ r ≤ 20 km.
a(hm) tính như sau:
F Đối với thành phố nhỏ và trung bình:
a(hm) = (1,11lgfc -0,7)hm – (1,56lgfc – 0,8)dB (2.41)
Đối với thành phố lớn:
a(hm) = 8.29(lg1,54hm)2 – 1,1 dB fc ≥ 200 MHz (2.42)
hay: a(hm) = 3,2(lg11,75hm)2 – 4,97 dB fc ≥ 400 MHz (2.43)
Như vậy bán kính cell được tính :
(2.44)
F Vùng ngoại ô:
Với vùng ngoại ô hệ số hiệu chỉnh suy hao so với vùng thành phố là:
Lno = Lp - 2 (dB) (2.45)
F Vùng nông thôn:
Với vùng nông thôn hệ số hiệu chỉnh suy hao so với vùng thành phố là:
Lnt(dB) = Lp – 4,78.(lgfc)2 +18,33(lgfc) - 40,94 (dB) (2.46)
2.2.2.2. Mô Walfisch - Ikegami
+ Mô Walfisch-Ikegami (hay COST 231) được sử dụng để đánh giá tổn hao đường truyền ở môi trường thành phố cho hệ thống thông tin tổ ong (cellular) ở dải tần 800-2000 MHz. Mô này đã được sử dụng ở châu Âu cho hệ thống GSM và một số mô truyền ở Mỹ. Mô Walfisch-Ikegami chứa 3 phần tử: tổn hao không gian tự do; nhiễu xạ mái nhà-phố và tổn hao tán xạ; tổn hao do nhiều vật chắn.
d
hm
Anten trạm di động
Mặt đường
Tòa nhà
w
b
hr
Hướng di chuyển
f
Sóng tới
Máy di động
hb
+ Mô Walfisch-Ikegami dựa vào giả thiết rằng sự truyền lan sóng được truyền trên mái nhà bằng quá trình nhiễu xạ. Các tòa nhà nằm trên đường thẳng giữa máy phát và máy thu.
2.8: Các tham số trong mô Walfisch-Ikegami
Các biểu thức sử dụng cho mô này như sau:
Lp= Lf + Lrts + Lmsd (2.47)
hay Lp = Lf khi Lrts + Lmsd ≤ 0 (2.48)
trong đó: Lf : tổn hao không gian tự do
Lrts: nhiễu xạ mái nhà - phố và tổn hao tán xạ
Lmsd: tổn hao các vật che chắn.
Tổn hao không gian tự do Lf được xác định:
Lf = 32,4 +20lgr + 20lgfc (dB) (2.49)
- Nhiễu xạ mái nhà - phố và tổn hao phân tán tính như sau:
Lrts = (-16,7) -10lgW + 10lgfc + 20lg∆hm + Lori (dB) (2.50)
Lori =
trong đó: W: độ rộng phố (m); ∆hm= hr - hm (m);
-9,646 (dB) 0 ≤ Ф ≤ 55 (độ)
2,5 + 0,075(Ф-55) (dB) 55 ≤ Ф ≤ 90 (độ)
Trong đó: Ф là góc đến so với trục phố.
- Tổn hao các vật che chắn:
Lmsd = Lbsh + ka + kdlgr + kflgfc – 9lgb (2.51)
Trong đó: b: khoảng cách giữa tòa nhà dọc theo đường truyền vô tuyến (m).
ka =
với thành phố lớn.
với thành phố trung bình.
Với trường hợp tia nhìn thẳng (LOS):
Lp = 42,6 + 26lgr + 20lgfc (2.52)
Với trường hợp tia không nhìn thẳng (NLOS):
Lp = 32,4 + 20lgr + 20lgfc + Lrts + Lmsd (2.53)
Như vậy bán kính cell tính theo mô Walfisch – Ikegami là :
(2.54)
Dải thông số cho mô Walfisch-Ikegami phải thỏa mãn:
800 ≤ fc ≤ 2000 MHz; 4 ≤ hb ≤ 50 m; 1 ≤ hm ≤ 3 m; 0,02 ≤ r ≤ 5 km
Có thể sử dụng các giá trị mặc định sau cho mô :
b = 20 ÷ 50m; W = b/2; Ф = b/2.
Nóc nhà = 3 m cho nóc nhà có độ cao và 0 m cho nóc nhà phẳng.
hr = 3 x (số tầng) + nóc nhà
Ta tính toán tổn hao đường truyền từ mô Hata và Walfisch-Ikegami theo các số liệu dưới đây và so sánh kết quả:
fc = 880 MHz hr = 30 m
hm = 1,5 m Ф = 90 độ
hb = 30 m b = 30 m
nóc nhà = 0 m W = 15 m
Bảng2.4: So sánh tổn hao đường truyền từ mô Hata và Walfisch-Ikegami.
Khoảng cách (km)
Tổn hao đường truyền, dB
Mô Hata
Mô Walfisch-Ikegami
1
2
3
4
5
126,16
136,77
142,97
147,37
150,79
139,45
150,89
157,58
162,33
166,01
Tổn hao đường truyền dự đoán theo mô Hata thấp hơn 13-16 dB so với mô Walfisch-Ikegami. Tuy nhiên, mô Hata bỏ qua ảnh hưởng của độ rộng đường phố, nhiễu xạ phố và các tổn hao tán xạ. Các ảnh hưởng này được xét đến ở mô Walfisch-Ikegami.
2.2.3. Lặp đường lên và đường xuống
Ở đây, ta phân tích các phương pháp và thuật toán trong phân tích lặp trong pha quy hoạch chi tiết của mạng vô tuyến 3G bao gồm: các yêu cầu đa dịch vụ và Q0S, điều khiển công suất phát nhanh ở đường lên và xuống, chuyển giao mềm và mềm hơn, chuyển giao kết hợp, kênh truyền dẫn đa đường, tốc độ của đầu cuối.
Mục đích của quá trình lặp đường lên là để cấp phát công suất phát cho trạm di động để mức tạp âm, xuyên âm và các giá trị độ nhạy trạm gốc hội tụ. Các công suất phát trung bình của các trạm gốc tới mỗi trạm di động được xác định sao cho đáp ứng yêu cầu Eb/N0 tại trạm gốc. Các công suất phát trung bình của các trạm di động dựa trên độ nhạy của các trạm gốc, dữ liệu và tốc độ của trạm di động, các suy hao tuyến tới các trạm di động. Các công suất phát này được so sánh với các công suất cho phép phát của các MS, nếu vượt quá giới hạn này coi như vượt ngưỡng (ngừng thông tin). Sau đó dự tính lại nhiễu, giá trị tải mới và độ nhạy mới cho từng BS được ấn định. Nếu hệ số tải đường lên cao hơn giới hạn được thiết lập, các MS chuyển dịch một cách ngẫu nhiên ở cell có tải cao đến một sóng mang khác hoặc bị vượt ngưỡng.
Một cách để xác định các vấn đề của công nghệ WCDMA trong lặp UL là xem chúng phụ thuộc như thế nào vào các BS mà MS được nối tới, để chọn lựa một BS phục vụ tốt nhất. Tương tự UL, mục đích của lặp DL là gán công suất phát BS cho mỗi kết nối sử dụng bởi một MS, cho đến khi tất cả các MS nhận tín hiệu.
2.2.4. Hậu xử lý - Dự báo vùng phủ mạng và phân tích kênh chung
Phần này sẽ thực hiện việc đánh giá xác suất vùng phủ và phân tích các kênh chung và riêng trong UMTS:UL DCH, DL DCH, P-CPICH,BCH, FACH và PCH. Trong tất cả các phân tích được thực hiện với giả thiết trạng thái nhiễu là cố định. Điều này có nghĩa là một phân bố lưu lượng xác định đã được giả thiết và các lặp DL và UL đã hội tụ. Một MS kiểm tra được di chuyển qua tất cả các điểm bên trong vùng và tất cả các MS khác đã được phục vụ đang đóng góp vào nhiễu. MS kiểm tra không ảnh hưởng lên trạng thái nhiễu, do đó tỷ số nhiễu cell khác / nội cell sẽ không thay đổi và tổng công suất phát của BS phục vụ vẫn như trước vòng lặp.
2.3. TỐI ƯU MẠNG
Tối ưu mạng là quá trình phân tích cấu và hiệu năng mạng nhằm cải thiện chất lượng mạng tổng thể và đảm bảo tài nguyên của mạng được sử dụng một cách có hiệu quả.
Giai đoạn đầu của quá trình tối ưu là định nghĩa các chỉ thị hiệu năng chính. Chúng gồm các kết quả đo ở hệ thống quản lý mạng và số liệu đo thực tế để xác định chất lượng dịch vụ. Với sự giúp đỡ của hệ thống quản lý mạng ta có thể phân tích hiệu năng quá khứ, hiện tại và dự báo tương lai.
Mục đích của phân tích chất lượng mạng là cung cấp cho nhà khai thác một cái nhìn tổng quan về chất lượng và hiệu năng của mạng, bao gồm việc lập kế hoạch về trường hợp đo tại hiện trường và đo bằng hệ thống quản lý mạng để lập báo cáo điều tra. Đối với hệ thống 2G, chất lượng dịch vụ gồm: thống kê các cuộc gọi bị rớt và phân tích nguyên nhân, thống kê chuyển giao và kết quả đo các lần gọi thành công. Còn các hệ thống 3G có các dịch vụ rất đa dạng nên cần đưa ra các định nghĩa mới về chất lượng dịch vụ.
Trong hệ thống thông tin di động thế hệ ba việc tối ưu hóa mạng rất quan trọng vì mạng thế hệ ba cung cấp nhiều dịch vụ đa dạng. Điều chỉnh tự động phải cung cấp câu trả lời nhanh cho các điều khiển thay đổi lưu lượng trong mạng. Trong giai đoạn đầu của quá trình xây dựng mạng WCDMA chỉ có một số thông số là được điều chỉnh tự động và vì thế cần phải duy trì quá trình tối ưu hóa của hệ thống GSM.
F Tổng kết chương 2:
Chương này đã trình bày 3 pha trong quá trình quy hoạch mạng WCDMA: Khởi tạo quy hoạch (định cỡ mạng), quy hoạch chi tiết mạng, vận hành và tối ưu hóa mạng. Trong đó, phần định cỡ mạng được phân tích cụ thể và đưa ra sơ đồ khối quá trình định cỡ, cũng như các công thức tính toán, phân tích quỹ năng lượng đường truyền vô tuyến, bán kính và diện tích cell, quy hoạch dung lượng và vùng phủ. Ngoài ra, trong phần quy hoạch chi tiết cũng đã đề cập đến 2 mô truyền dẫn cơ bản được sử dụng rộng rãi, đó là mô Hata-Okumura và Walfisch-Ikegami.
CHƯƠNG 3: CÁC GIẢI PHÁP TỐI ƯU MẠNG W-CDMA
Tối ưu mạng là quá trình phân tích cấu và hiệu năng mạng nhằm cải thiện chất lượng mạng tổng thể và đảm bảo tài nguyên của mạng được sử dụng một cách có hiệu quả. Giai đoạn đầu của quá trình tối ưu là định nghĩa các chỉ thị hiệu năng chính. Chúng gồm các kết quả đo ở hệ thống quản lý mạng và số liệu đo thực tế để xác định chất lượng dịch vụ. Với sự giúp đỡ của hệ thống quản lý mạng ta có thể phân tích hiệu năng quá khứ, hiện tại và tương lai. Ta có thể phân tích hiệu năng của các thuật toán quản lý tài nguyên vô tuyến và các thông số của chúng bằng cách sử dụng các kết quả của chỉ thị hiệu năng chính.
3.1. MÔ TẢ TOÁN HỌC CỦA VẤN ĐỀ TỐI ƯU HOÁ
Về mặt toán học, vấn đề tối ưu hoá thực chất là quá trình đi tìm điểm cực trị (cực tiểu hoặc cực đại) của một hàm số diển tả mục tiêu cần đạt tới. Các vấn đề tối ưu hoá trong thực tế rất đa dạng và phong phú, song chúng đều có thể quy về một dạng tổng quát.Chúng ta gọi bài toán dưới đây là vấn đề tối ưu hoá dạng chuẩn.
Ký hiệu x là véc tơ n chiều chừa các biến tự do. Cho f(x), hi(x) với i = 1, 2,…, p và gj(x) với j = 1, 2,…, q là các hàm vô hướng phụ thuộc x. Tìm giá trị cực tiểu của f(x) với điều kiện hi(x) ≤ 0 và gj = 0
Hàm f(x) gọi là hàm mục tiêu (objective function), tuỳ theo từng lĩnh vực cụ thể mà biến x xó tên gọi khác nhau. Trong lý thuyết quyết định x được gọi là biến quyết định (decision variable). Trong thiết kế tối ưu x được gọi là véc tơ tham số thiết kế (design parameter vector). Trong lý thuyết hệ thống tối ưu x được gọi là biến trạng thái (state variable). Thuât ngữ biến quyết định được dùng chủ yếu. Điều kiện hi(x) ≤ gọi là điều kiện ràng buộc dạng bất đẳng thức (inequality contraints), điều kiện gj(x) = 0 gọi là điều kiệu ràng buộc dạng đẳng thức (equality constraints).
Vấn đề tối ưu hoá dạng chuẩn có thể phát biểu ngắn gọn như sau:
Cực tiểu f(x) với điều kiện hi(x) ≤ 0, i = 1, 2,…, p ;
gj(x) = 0, j = 1, 2,…, q; x
Như đã biết, với mọi hàm f(x) ta có max{ f(x)} = min{ -f(x)} nên vấn đề cực đại hoá luôn luôn có thể chuyển về vấn đề cực tiểu hoá. Tương tự, điều kiện hi(x) ≥ 0 có thể chuyển thành –hi(x) ≤ 0 nên trong bài toán chuẩn không chứa điều kiện hi(x) ≥ 0.
3.2.TỐI ƯU TRONG QUY HOẠCH VÀ THIẾT KẾ MẠNG BẰNG PHƯƠNG PHÁP DỰ BÁO LƯU LƯỢNG
Dự báo lưu lượng ước tính tổng số lưu lượng tại một tần số nhất định, với quy định rằng nhu cầu điện thoại đã được dự báo. Kết quả của dự báo lưu lượng được sử dụng để lập kế hoạch quản lý, và để nghiên cứu lý thuyết về mạng tối ưu làm cho lưu lượng có chi phí thấp nhất. Dự báo lưu lượng cũng được sử dụng để tính số lượng thiết bị (ví dụ: mạch trung kế và thiết bị thông dụng cho thiết bị trạm). Để tính số lượng thiết bị, cần có số liệu lưu lượng chi tiết cho mỗi mạch và cho mỗi trạm.
3.2.1. Quy trình dự báo lưu lượng
Lưu lượng được dự báo theo các bước sau đây:
Bước 1: Xác định mục đích và đối tượng dự báo. Xác định mục tiêu của dự báo, lưu lượng và năm được dự báo.
Bước 2: Thu thập số liệu và xác định giả thiết.
Xác định các giả thiết của dự báo ( hệ thống giá và các dự án phát triển địa phương có thể có). Lựa chọn và phân tích số liệu biểu thị xu hướng của nhu cầu lưu lượng.
Bước 3: Nghiên cứu xu hướng lưu lượng
Ghi chép và phân tích các đặc tính lưu lượng. Gồm có: xu hướng chuỗi thời gian của lưu lượng, phân tích xu hướng lưu lượng nội hạt và đường dài trong nước,các nhân tố chính ảnh hưởng dến lưu lượng, mối quan hệ giữa sự phát triển vùng và lưu lượng,sự phân bố lưu lượng theo thời gian
Bước 4: Lựa chọn phương pháp dự báo. Phương pháp thích hợp nhất được lựa chọn qua việc xem xét các đặc tính của lưu lượng và các nhân tố dao động.
Bước 5: Tính toán lưu lượng cơ bản.
Tính toán lưu lượng trung bình hàng năm cho năm tham khảo
Bước 6: Dự báo lưu lượng
Dự báo thực hiện bằng cách sử dụng phương pháp chuỗi thời gian, hoặc nhân tỉ lệ tăng lưu lượng với lưu lượng cơ bản.
Bước 7: Đánh giá/xác định dự báo
Xem xét các đặc tính của các nhân tố dao động sử dụng trong dự báo, dự báo so sánh xu hướng lưu lượng toàn cầu và số liệu lưu lượng của từng nước.
Bước 8: Tính toán lưu lượng tham khảo
Lưu lượng tham khảo được tính theo giả thuyết về sự dao động trong dự báo(lưu lượng trung bình hàng năm).
Bước 9: Biên soạn các báo cáo các báo cáo mà chúng ta đưa ra các số liệu cơ sở cho dự báo lưu lượng ( lưu lượng cơ sở và số thuê bao), dự báo, các giả thiết cho dự báo, và cơ sở để đánh giá/xác định dự báo được soạn thảo.
Bước 10: Hoàn thiện dự báo
Bằng việc tiếp tục so sánh dự báo với các số liệu thưc tế,cải tiến phương pháp dự báo để đạt được sự chính xác cao hơn.
3.2.2. Dự báo lưu lượng bằng phương pháp hồi quy tuyến tính
Tập hợp số liệu:
Tập hợp lại những số liệu sau đây. Sử dụng lại những số lượng này,dự báo mật độ lưu lượng từ năm 2010 đến 2015.
3.1: Số liệu thực tế.
Năm
2003
2004
2005
2006
2007
2008
2009
Lưu lượng
1010.3
1074.7
1127.5
1150.7
1196.6
1231.8
1253.3
Số thuê bao
11348
12497
13422
14033
14592
15207
15667
Lựa chọn phưong trình mẫu:
Chọn phương trình mẫu có thể áp dụng đối với xu hướng quá khứ
Hồi quy tuyến tính: y = ax + b (3.1)
x : là số thuê bao
y : là lưu lượng (erl)
Phương trình: ∑y = a.n + b∑x (3.2)
∑xy = a∑x + b∑x2 (3.3)
Tính toán:
3.2: Tính toán.
Năm
Lưu lượng(x)
Thuê bao (y)
x.y
x2
2003
1010.3
11348
11464884.4
1020706.09
2004
1074.7
12497
13430525.9
1154980.09
2005
1127.5
13422
15133305
1271256.25
2006
1150.7
14033
16147773.1
1324110.49
2007
1196.6
14592
17460787.2
1431851.56
2008
1231.8
15207
18731982.6
1517331.24
2009
1253.3
15667
19635451.1
1570760.89
∑
8044.9
96766
112004709.3
9290996.61
∑y = a.n + b∑x suy ra: 96766 = 7*a + 8044.9*b
∑xy = a∑x + b∑x2 suy ra: 112004709.3= 8044.9*7*a + 9290996.61*b
Giải các phương trình:
a = 5.190920289 b=12.02372479
y = 5.190920289.x + 12.02372479 (3.4)
(4) Tính giá trị thuê bao:
Những giá trị sau đây là giá trị dự báo số thuê bao. Suy ra giá trị dự báo lưu lượng:
3.3: Tính giá trị thuê bao.
Năm
2010
2011
2012
2013
2014
2015
Số thuê bao
16137
16621
17120
17642
18215
18723
Mật độ lưu lượng
83777.90443
86290.31
88880.58
91590.23946
94564.63679
97201.6243
3.2.3. Dự báo lưu lượng bằng phương pháp hồi quy đàn hồi
Tập hợp số liệu
Tập hợp đựơc những số liệu sau:
3.4: Số liệu thực tế
Năm
2003
2004
2005
2006
2007
2008
2009
Lưu lượng
1010.3
1074.7
1127.5
1150.7
1196.6
1231.8
1253.3
Số thuê bao
11348
12497
13422
14033
14592
15207
15667
Lựa chọn phương trình mẫu có thể được áp dụng với xu hướng quá khứ. Hồi quy đàn hồi:
(3.5)
x : tỷ lệ tăng số thuê bao
y : tỷ lệ tăng lưu lượng
: giá trị đàn hồi
log(y) = log(a) + log(x) (3.6)
∑ log(y) = n log(a) + ∑log(x) (3.7)
∑ log(x).log(y) = n log(a). ∑log(x) + ∑log(x)2 (3.8)
Tính toán:
3.5: Tính toán
Năm
L.Lượng
(y)
Thuê bao(X)
(x)
log(y)
log(x)
log(y).log
(logx)2
(Y)
(x)
2003
1010.3
1
11480
1
0
0
0
0
2004
1074.7
1.064
12497
1.089
0.02694
0.03703
0.001
0.00137
2005
1127.5
1.116
13422
1.169
0.04766
0.06782
0.00323
0.0046
2006
1150.7
1.139
14033
1.222
0.05652
0.08707
0.00492
0.00758
2007
1196.6
1.184
14592
1.271
0.07335
0.10415
0.00764
0.01085
2008
1231.8
1.219
15207
1.325
0.086
0.12222
0.01051
0.01494
2009
1253.3
1.241
15667
1.365
0.09377
0.13513
0.01267
0.01826
∑
8044.9
7.963
96898
8.441
0.38426
0.55341
0.03997
0.0576
(a) Tỷ lệ tăng lưu lượng:
y : 2004 : 1074.7 - 1010.3 = 1.064
2005 : 1127.5 - 1010.3 = 1.116
…….
2009 : 1253.3 - 1010.3 = 7.963
(b) : Tỷ lệ tăng thuê bao: (tương tự)
(c) : Tính logy,logx,…
(d) : Giải hồi quy đàn hồi:
0.38426 = 7. log(a) + 0.55341
0.03997 = 7. log(a). 0.55341 + .0.0576
Suy ra: log(a) = 0.000099 = 0.693104
log(y) = 0.000099 + 0.693104.log(x) (3.9)
Tính giá trị dự báo:
3.6: Tính giá trị dự báo
Năm
2009(thực tế)
2010
2011
2012
2013
2014
2015
Thuê bao
Dự báo
15667
16137
16621
17120
17642
18215
18723
(a)
1.000
1.030
1.0609
1.0927
1.1253
1.1572
1.1834
Lưu lượng
(b)
1.000
1.021
1.042
1.0636
1.0872
1.1213
1.1465
1253.3
1280
1333.76
1418.5871
1542.2879
1729.3675
1982.7198
Tỷ lệ tăng thuê bao
Tỷ lệ tăng lưu lượng tính theo phương pháp hồi quy
Giá trị dự báo lưu lượng
Giá trị dự báo lưu lượng = (Số liệu lưu lượng thực tế)x(Tỷ lệ tăng lưu lượng)
2010 : 1253.3 x 1.021 = 1280 (erl)
3.3. CÁC CÔNG NGHỆ ĐỂ TĂNG DUNG LƯỢNG ĐƯỜNG TRUYỀN TRONG W-CDMA
W-CDMA có một giao diện vô tuyến cho phép ứng dụng các thiết bị triệt nhiễu và các công nghệ thu vμ phát phân tập dμn anten thích ứng để tăng hơn nữa dung lượng truyền dẫn trong tương lai. ở đường lên, việc giảm MAI là rất quan trọng để tăng dung lượng đường truyền, kết hợp với việc sử dụng TPC nhanh-một biện pháp hiệu quả nhằm giảm công suất phát của MS để kéo dài tuổi thọ của pin và mở rộng vùng phủ sóng. Mặt khác, ở đường xuống, yêu cầu tăng dung lượng đường truyền mạnh hơn ở đường lên vì việc tải xuống (downloading) số liệu tốc độ cao trên Internet và các dịch vụ quảng bá chắc chắn sẽ được ứng dụng rộng rãi. MAI từ các thuê bao tốc độ cao sẽ gây nhiễu cực kỳ lớn đến các thuê bao tốc độ thấp (ví dụ như thông tin thoại). Do đó, việc tăng hơn nữa dung lượng ở đường truyền xuống là một nhiệm vụ rất quan trọng. Các công nghệ để thực hiện điều này bao gồm công nghệ sử dụng các thiết bị triệt nhiễu (thiết bị triệt nhiễu đa đường) hoặc công nghệ thu phân tập dàn anten thích ứng trong MS và công nghệ phân tập phát dàn anten thích ứng ở BS. Trong số đó, công nghệ phân tập phát dàn anten thích ứng là một công nghệ có tính thực tế và hiệu quả để tăng hơn nữa dung lượng đường truyền xuống, nó không yêu cầu phải thay đổi đáng kể chức năng của MS và có thể được thực hiện qua việc xử lý phần phát tại phía BS.
3.3.1. Phân tập dàn anten thích ứng
Như trình bày trong 3.1, phân tập dàn anten thích ứng bao gồm việc lắp một máy thu phát cho một dàn anten thích ứng trong BS và nhân các tín hiệu thu được từ các anten đường lên với hệ số tải trọng tối ưu sau đó kết hợp các tín hiệu lại. Phương pháp này đem lại một mẫu bức xạ định hướng có một búp sóng chính ở hướng mà các tín hiệu cần thu đếnvà một chùm sóng ở hướng mà các sóng nhiễu đến nhằm làm vô hiệu các sóng nhiễu cho phép tăng tối đa SIR thu. Nhờ phương pháp này giúp giảm MAI và tăng dung lượng hệ thống ở đường lên. Ở đường xuống phương pháp này bao gồm việc phân hệ số tải trọng anten phát đã được tạo ra một cách thích hợp tại BS cho mỗi thuê bao với các tín hiệu phát của mỗi thuê bao, nhằm tạo ra một búp sóng chính ở hướng có các tín hiệu cần thu của thê bao và thực hiện truyền theo cách giảm nhiễu ở hướng của các thuê bao khác. Điều này cho phép tăng dung lượng hệ thống ở đường xuống.
3.1: Nguyên lý của phương pháp phân tập dàn anten thích nghi
Dung lượng mạng C được tạo bởi :
(3.10)
Trong đó : là số kênh khả dụng trong mạng
là số xuyên nhiễu trong cùng 1 cell
là tỷ số tín hiệu trên xuyên nhiễu
n là số mũ tổn hao đường truyền, phụ thuộc vào loại địa như nhà cao tần, cây cối,… thường chọn n = 4,38
Nếu một anten thích nghi làm giảm sự đóng góp xuyên nhiễu được biểu diễn quan bởi một hệ số cải thiện anten thích nghi là tức là thì sự tăng dung lượng từ C đến C’ là :
(3.11)
Nếu sử dụng n = 4,38 thì dung lượng mạng tăng lên một hệ số là 1,88 ( C’ = 1.88C)
3.3.2. Cấu phân tập dàn anten thích ứng
Phân tập dμn anten thích ứng là một công nghệ xử lý quá trình thu thích ứng (đường lên) và phát thích ứng ( đường xuống) tại BS và được xây dựng theo cách để có thể ứng dụng được cho giao diện vô tuyến W-CDMA được qui định bởi 3 GPP. Phân tập phát dàn anten thích ứng tạo ra hệ số tải trọng anten phát bằng cách thực hiện theo hệ số tải trọng anten thu đã tạo ra tại khối thu BS: (1) Kiểm định mạch RF, thực hiện bù các độ lệch biên độ và pha giữa các nhánh trong các mạch thu phát RF và (2) kiểm định tần số sóng mang, thực hiện bù cho những giá trị xê dịch trong hệ số tải trọng của anten phát ở hướng búp sóng chính và búp sóng vô hiệu gây ra bởi sự khác nhau trong tần số sóng mang giữa đường lên và đường xuống ( đặc biệt trong FDD, tần số sóng là không giống nhau đối với đường lên và đường xuống). 3.2 trình bày cấu khối của BS thực hiện phân tập thu và phát dàn anten thích ứng. Các tín hiệu thu được bởi mỗi anten ở đường lên được giới hạn về độ rộng băng tần và được khuyếch đại nhờ một mạch thu RF và sau đó được điều chỉnh hệ số tải trọng bằng hệ số tải anten thu phức hợp và được kết hợp tại khối thu phân tập dàn anten thích ứng nhất quán. Sau đó tín hiệu sẽ được đưa tới quá trình ước tính các dao động về pha và biên độ gây ra bởi pha đinh trong mỗi đường truyền và kết hợp RAKE. Sau đó, các tín hiệu đã kết hợp RAKE được đưa tới phần giải xen kẽ và giải mã sữa lỗi để khôi phục chuỗi số liệu phát. Mặt khác, tại khối máy phát của BS, các tín hiệu sẽ được mã hoá kênh (FEC), xen kẽ, điều chế QPSK và nhân với các hệ số tải trọng anten phát phức hợp rồi đưa đến quá trình trải phổ. Sau đó, tín hiệu sẽ được đổi tần và khuyếch đại tại khối phát RF để phát đi.
3.2: Sơ đồ khối tổng quát hệ thống phân tập dàn anten thích nghi.
F Tổng kết chương 3:
Trong hệ thống thông tin di động thế hệ ba việc tối ưu hóa mạng rất quan trọng vì mạng thế hệ ba cung cấp nhiều dịch vụ đa dạng. Điều chỉnh tự động phải cung cấp câu trả lời nhanh cho các điều khiển thay đổi lưu lượng trong mạng. Vì vậy cần phải có phương pháp dự doán lưu lượng nhanh chóng và chính xác, đồng thời cần phải tối ưu hoá thiết bị nhằm tăng dung lượng đường truyền phù hợp với xu hướng phát triển thuê bao và nhu cầu dịch vụ ngày càng cao.
CHƯƠNG 4: XÂY DỰNG BÀI TOÁN TÍNH BÁN KÍNH CELL VÀ TỔNG LƯU LƯỢNG TRONG HỆ THỐNG WCDMA
Sau khi tìm hiểu tổng quát về kiến trúc mạng, các bước quy hoạch, tối ưu mạng WCDMA, ta tiến hành mô phỏng. Trong phần này sẽ giới thiệu lưu đồ thuật toán mô phỏng - tính toán các bước quy hoạch mạng di động và cùng các cửa sổ giao diện chương trình mô phỏng viết bằng ngôn ngữ Visual Basic 6.0.
4.1. LƯU ĐỒ TÍNH TOÁN
4.1.1. Lưu đồ thuật toán tổng quát:
Sai
Bắt đầu
Thực hiện tính toán
Kiểm tra thông số nhập
Đúng
In kết quả
Kết thúc
Nhập các thông số yêu cầu
4.1:Lưu đồ thuật toán tổng quát.
4.1.2. Lưu đồ thuật toán chi tiết
Bắt đầu
- Tính bán kính Cell
- Tính diện tích Cell
In kết quả
Kiểm tra thông số nhập
Sai
Đúng
Kiểm tra thông số nhập
Sai
Đúng
Tính suy hao đường truyền cho phép đối với vùng phủ của cell
In kết quả
Nhập các thông số truyền sóng (chọn mô hình truyền sóng Walfisch-Ikegami cho Tp nhỏ và trung bình)
Nhập:
- Thông số truyền dẫn
- Thông số trạm BTS
- Thông số trạm MS
4.2: Lưu đồ thuật toán chi tiết.
4.2. KẾT QUẢ CHƯƠNG TRÌNH
4.2.1 Giao diện chính:
4.3: Chương trình chính.
4.2.2.Tính suy hao đường truyền
4.4: Giao diện tính suy hao đường truyền.
4.2.3. Tính kích thước Cell
4.5: Giao diện tính kích thước Cell.
4.2.4. Tính dung lượng kênh
4.6: Giao diện tính dung lượng kênh.
Tổng kết chương 4:
Để thấy rõ quá trình tính toán quy hoạch mạng W-CDMA ta tiến hành mô phỏng với các giao diện tính suy hao đường truyền, tính kích thước cell, tính dung lượng kênh dựa vào ErlangB. Chương trình mô phỏng giúp chúng ta có cái nhìn tổng quan và thực tế hơn trong quá trình tính toán quy hoạch mạng W-CDMA
KẾT LUẬN VÀ HƯỚNG PHÁT TRIỂN CỦA ĐỀ TÀI
Ở Việt Nam, các hệ thống thông tin di động thế hệ thứ ba cũng đã được nhanh chóng triển khai. Đối với các nhà khai thác mạng di động thì cái đích là triển khai nhanh và hiệu quả các hệ thống thông tin di động CDMA băng rộng (WCDMA) theo chuẩn IMT-2000. Xuất phát từ định hướng này, em đã thực hiện đề tài “QUY HOẠCH VÀ TỐI ƯU MẠNG WCDMA”.
Thành công của đề tài
Đã giới thiệu tổng quan về sự phát triển mạng di động WCDMA
Tìm hiểu tổng quan về phần cứng của mạng WCDMA
Tìm hiểu về đường truyền dẫn vô tuyến, về phương pháp trải phổ, các kênh vô tuyến, các kiểu lập lịch gói trong WCDMA
Tìm hiểu về các thuật toán tối ưu, thông qua việc tối ưu bằng thuật toán dự báo lưu lượng và công nghệ tăng dung lượng vùng phủ bằng phương pháp phân tập dàn anten thích ứng.
Phân tích được những yêu cầu và nguyên tắc thực hiện quy hoạch mạng WCDMA ứng với đặc trưng, cấu trúc địa lý từng vùng cụ thể, đưa ra các công thức tính toán dung lượng, vùng phủ và đánh giá chất lượng dịch vụ với 2 mô thực nghiệm cụ thể Hata-Okumura và Walfisch-Ikegami.
Thành công lớn nhất của đề tài đã thiết kế được phần mềm mô phỏng tính được suy hao đường truyền, phần mềm tính kích thước cell, phần mềm mô phỏng tính dung lượng kênh.
Hạn chế của đề tài
- Trong phần tối ưu mạng, việc tăng dung lượng mạng bằng phương pháp phân tập dàn anten thích ứng chỉ đưa ra trên cơ sở lý thuyết, chưa tính toán cụ thể chi tiết.
- Hạn chế lớn nhất của đề tài đó là ứng dụng cho bài toán cụ thể, ngoài việc lấy một số tham số của nhà cung cấp thiết bị, một phần lớn các tham số khác còn lấy theo các giá trị điển . Điều này dẫn đến kết quả thiết kế dừng ở mức định cỡ mạng sơ bộ.
- Ngoài ra, việc tính toán sử dụng mô Walfisch-Ikegami chưa tính đến các tổn hao do lá cây và chưa xét cho môi trường trong nhà (indoor) và kết quả chưa tính cho dịch vụ truyền dữ liệu.
Hướng phát triển của đề tài
Trong thực tế việc triển khai một hệ thống thông tin luôn cần có thêm bước chạy thử, hiệu chỉnh dựa trên các kết quả đo đạc thực tế.
Trong thời gian tới, em sẽ tiếp tục nghiên cứu, tìm hiểu tiếp những hạn chế trên từ đó tìm ra cách khắc phục tối ưu nhất để nâng cao chất lượng dịch vụ mạng .
TÀI LIỆU THAM KHẢO
Tài liệu tiếng Việt:
[1]. Vũ Ngọc Phàn (2004), Tối ưu hoá cơ sở lý thuyết và ứng dụng trong công nghệ bưu chính viễn thông, Nhà xuất bản Bưu Điện Hà Nội.
[2]. Vũ Đức Thọ (2003), Tính toán mạng thông tin di động số cellular, Nhà xuất bản Giáo Dục Hà Nội.
[3]. Đỗ Quốc Trinh, Vũ Thanh Hải (2006), Kỹ thuật trải phổ và ứng dụng, Nhà xuất bản Học viện kỹ thuật quân sự Hà Nội.
[4]. Trần Anh Tấn (2005), Tối ưu mạng GSM , Nhà xuất bản Học viện kỹ thuật quân sự Hà Nội.
[5]. Ks. Nguyễn Văn Thuận (2004), Hệ thống thông tin di đông W-CDMA, Nhà xuất bản Học viện công nghệ bưu chính viễn thông Hà Nội.
[6]. TS. Nguyễn Xuân Vinh (2005), Quy hoạch phát triển mạng viễn thông, Nhà xuất bản Khoa Học Và Kỹ Thuật Hà Nội.
Tài liệu tiếng Anh:
[7]. Jaana Laiho and Achim Wacker (2006) Radio network planning and optimisation for umts, John Wiley and Sons, LTD.
[8]. McGraw Hill (2002), W-CDMA AND CDMA 2000, M.R. Karim and Lucent Technologies.
PHỤ LỤC
PHẦN MÔ PHỎNG
1. Phần giao diện chính
Private Sub Command1_Click()
frmKientrucmang.Show
End Sub
Private Sub Command2_Click()
frmLoss.Show
End Sub
Private Sub Command3_Click()
frmMofCell.Show
End Sub
Private Sub Command4_Click()
frmCap.Show
End Sub
2.Phần tính suy hao đường truyền
Option Explicit
Private Sub sbfor_Click(Index As Integer)
On Error Resume Next
Dim i As Integer
Select Case Index
Case 0
Unload Me
frmMofCell.Show
frmchinh.Enabled = False
Case 1
Unload Me
frmchinh.Enabled = True
Case 2
Unload Me
frmchinh.Enabled = True
Case 3
For i = 0 To 13
tsnhapsh(i) = Val(txtloss(i).Text)
Next
EIRP = tsnhapsh(0) - tsnhapsh(1)
mdtapam = tsnhapsh(2) + tsnhapsh(3)
cstapam = mdtapam + 10 * Lg10(tsnhapsh(6) * 1000000)
tongnhieugt = cstapam + tsnhapsh(7)
doloixuli = 10 * Lg10(tsnhapsh(6) * 1000 / tsnhapsh(9))
donhay = cstapam - doloixuli - tsnhapsh(7) + tsnhapsh(8) + tsnhapsh(3)
suyhaochophep = tsnhapsh(4) - tsnhapsh(5) - tsnhapsh(12) - tsnhapsh(10) + tsnhapsh(11) + EIRP - donhay - tsnhapsh(13)
lblLossRes(0).Caption = Format(EIRP, "0.######") + " dB"
lblLossRes(1).Caption = Format(mdtapam, "0.######") + " dB/Hz"
lblLossRes(2).Caption = Format(cstapam, "0.######") + " dBm"
lblLossRes(3).Caption = Format(doloixuli, "0.#####") + " dB"
lblLossRes(4).Caption = Format(donhay, "0.######") + " dBm"
lblLossRes(5).Caption = Format(suyhaochophep, "0.######") + " dBm"
lblLossRes(6).Caption = Format(tongnhieugt, "0.######") + " dBm"
lstBitRate.AddItem txtloss(9).Text + " KBps"
lstLoss.AddItem lblLossRes(5).Caption
Case 4
txtloss(0).Text = "21"
txtloss(1).Text = "3"
txtloss(2).Text = "-174"
txtloss(3).Text = "5"
txtloss(4).Text = "14"
txtloss(5).Text = "2"
txtloss(6).Text = "3.84"
txtloss(7).Text = "3"
txtloss(8).Text = "5"
txtloss(9).Text = "12.2"
txtloss(10).Text = "9"
txtloss(11).Text = "4"
txtloss(12).Text = "8"
lblLossRes(0).Caption = ""
lblLossRes(1).Caption = ""
lblLossRes(2).Caption = ""
lblLossRes(3).Caption = ""
lblLossRes(4).Caption = ""
lblLossRes(5).Caption = ""
lstBitRate.Clear
lstLoss.Clear
Case 5
txtloss(0).SetFocus
txtloss(0).Text = ""
txtloss(1).Text = ""
txtloss(2).Text = ""
txtloss(3).Text = ""
txtloss(4).Text = ""
txtloss(5).Text = ""
txtloss(6).Text = ""
txtloss(7).Text = ""
txtloss(8).Text = ""
txtloss(9).Text = ""
txtloss(10).Text = ""
txtloss(11).Text = ""
txtloss(12).Text = ""
lblLossRes(0).Caption = ""
lblLossRes(1).Caption = ""
lblLossRes(2).Caption = ""
lblLossRes(3).Caption = ""
lblLossRes(4).Caption = ""
lblLossRes(5).Caption = ""
lstBitRate.Clear
lstLoss.Clear
End Select
End Sub
Private Sub tmCheckInput_Timer()
If (txtloss(0).Text = "" Or txtloss(1).Text = "" Or txtloss(2).Text = "" _
Or txtloss(3).Text = "" Or txtloss(4).Text = "" Or txtloss(5).Text = "" _
Or txtloss(6).Text = "" Or txtloss(6).Text = "" Or txtloss(7).Text = "" _
Or txtloss(8).Text = "") Then
sbfor(3).Enabled = False
Else
sbfor(3).Enabled = True
End If
End Sub
Private Sub txtLoss_KeyPress(Index As Integer, KeyAscii As Integer)
Dim found As Integer
Select Case KeyAscii
Case vbKeyBack, vbKeyRight, vbKeyLeft
'do nothing
Case Asc("0") To Asc("9")
'do nothing
Case Asc("-")
If txtloss(Index).Text "" Then
Beep
KeyAscii = 0
End If
Case Asc(".")
If txtloss(Index).Text "" Then
found = InStr(1, txtloss(Index).Text, ".", vbTextCompare)
If found 0 Then
Beep
KeyAscii = 0
End If
End If
Case Else
Beep
KeyAscii = 0
End Select
End Sub
Private Sub Form_QueryUnload(Cancel As Integer, UnloadMode As Integer)
frmchinh.Enabled = True
End Sub
3.Phần tính dung lượng
Option Explicit
Private Sub cmdReport_Click()
Me.Hide
frmchinh.Enabled = False
frmReport.Show
End Sub
Private Sub cmd1_Click()
dlccdl = Val(txtdlcc(1).Text)
hssdtkdl = dlccdl * 100 / sokenhdlen
lblResultl(2).Caption = Format(hssdtkdl, "0.#") + "%"
kgcdl = (tsnhapcap(4) + 1) * sokenhdlen
kgcdl = Round(kgcdl)
lblResultl(3).Caption = Format(kgcdl, "0.")
MsgBox "Tra bang Erlang tu so kenh gop chung sau do nhap vao o 'dung luong chung' roi bam nut '>>' de tinh tiep!"
End Sub
Private Sub cmd2_Click()
dlcdl = Val(txtdlc(1).Text)
dlcmdl = dlcdl / (1 + tsnhapcap(4))
lblResultl(5).Caption = Format(dlcmdl, "0.####")
dlmdl = ((dlcmdl / dlccdl) - 1) * 100
lblResultl(6).Caption = Format(dlmdl, "0.##") + "%"
stbpvdl = dlcmdl / dungluongMS
lblResultl(7).Caption = Format(stbpvdl, "0.")
End Sub
Private Sub cmd3_Click()
dlccdx = Val(txtdlcc(0).Text)
hssdtkdx = dlccdx * 100 / sokenhdxuong
lblResultx(2).Caption = Format(hssdtkdx, "0.#") + "%"
kgcdx = (tsnhapcap(4) + 1) * sokenhdxuong
kgcdx = Round(kgcdx)
lblResultx(3).Caption = Format(kgcdx, "0.")
MsgBox "Tra bang Erlang tu so kenh gop chung sau do nhap vao o 'dung luong chung' roi bam nut '>>' de tinh tiep!"
End Sub
Private Sub cmd4_Click()
dlcdx = Val(txtdlc(0).Text)
dlcmdx = dlcdx / (1 + tsnhapcap(4))
lblResultx(5).Caption = Format(dlcmdx, "0.####")
dlmdx = ((dlcmdx / dlccdx) - 1) * 100
lblResultx(6).Caption = Format(dlmdx, "0.##") + "%"
stbpvdx = dlcmdx / dungluongMS
lblResultx(7).Caption = Format(stbpvdx, "0.")
End Sub
Private Sub cmderl_Click()
frmerlang.Show
End Sub
Private Sub cmderlangB_Click()
TinhErlangB.Show
End Sub
Private Sub Form_Load()
Dim i As Integer
Dim j As Integer
txtData(0).Text = "0.02"
txtData(1).Text = "1"
txtData(2).Text = "210"
If tsnhapsh(7) = 0 Then
txtData(3).Text = "50"
Else
hesotai = (1 - (1 / 10 ^ (tsnhapsh(7) / 10))) * 100
txtData(3).Text = Format(hesotai, "0.#")
End If
txtData(4).Text = "0.55"
txtData(5).Text = "0.67"
If tsnhapsh(8) = 0 Then
txtData(6).Text = "4"
Else
txtData(6).Text = Format(tsnhapsh(8), "0.##")
End If
txtData(7).Text = "0.4"
If tsnhapsh(6) = 0 Then
txtData(8).Text = "3.84"
Else
txtData(8).Text = Format(tsnhapsh(6), "0.##")
End If
If tsnhapsh(9) = 0 Then
txtData(9).Text = "12.2"
Else
txtData(9).Text = Format(tsnhapsh(9), "0.##")
End If
lblResultkq.Caption = ""
lblResultl(0).Caption = ""
lblResultx(0).Caption = ""
For i = 2 To 3
lblResultl(i).Caption = ""
lblResultx(i).Caption = ""
Next
For i = 5 To 7
lblResultl(i).Caption = ""
lblResultx(i).Caption = ""
Next i
End Sub
Private Sub sbfor_Click(Index As Integer)
Dim i As Integer
For i = 0 To 9
tsnhapcap(i) = Val(txtData(i).Text)
Next
On Error Resume Next
Select Case Index
Case 0
Unload Me
frmchinh.Enabled = False
frmBTS.Show
Case 1
Unload Me
frmchinh.Enabled = False
frmMofCell.Show
Case 2
Unload Me
frmchinh.Enabled = True
Case 3
dungluongMS = tsnhapcap(1) * tsnhapcap(2) / 3600
lblResultkq.Caption = Format(dungluongMS, "0.####") + " Erlang"
sokenhdlen = tsnhapcap(3) * (tsnhapcap(9) / tsnhapcap(8)) / ((1 + tsnhapcap(4)) * (10 ^ ((tsnhapcap(6)) / 10)) * tsnhapcap(5))
sokenhdlen = Round(sokenhdlen)
lblResultl(0).Caption = Format(sokenhdlen, "0.")
sokenhdxuong = tsnhapcap(3) * (tsnhapcap(9) / tsnhapcap(8)) / ((1 - tsnhapcap(7) + tsnhapcap(4)) * (10 ^ ((tsnhapcap(6)) / 10)) * tsnhapcap(5))
sokenhdxuong = Round(sokenhdxuong)
lblResultx(0).Caption = Format(sokenhdxuong, "0.")
txtdlcc(1).SetFocus
MsgBox "Tra bang Erlang tu so kenh trung binh sau do nhap vao o 'dung luong chan cung' roi bam nut '>>' de tinh tiep!"
txtdlcc(1).SetFocus
Case 4
txtData(0).Text = "0.02"
txtData(1).Text = "1"
txtData(2).Text = "210"
txtData(3).Text = "50"
txtData(4).Text = "0.55"
txtData(5).Text = "0.67"
txtData(6).Text = "4"
txtData(7).Text = "0.4"
txtData(8).Text = "3.84"
txtData(9).Text = "12.2"
lblResultl(0).Caption = ""
lblResultx(0).Caption = ""
lblResultkq.Caption = ""
For i = 0 To 1
txtdlcc(i).Text = ""
txtdlc(i).Text = ""
Next i
For i = 2 To 3
lblResultl(i).Caption = ""
lblResultx(i).Caption = ""
Next
For i = 5 To 7
lblResultl(i).Caption = ""
lblResultx(i).Caption = ""
Next i
Case 5
For i = 0 To 9
txtData(i).Text = ""
Next i
For i = 0 To 1
txtdlcc(i).Text = ""
txtdlc(i).Text = ""
Next i
lblResultkq.Caption = ""
lblResultl(0).Caption = ""
lblResultx(0).Caption = ""
For i = 2 To 3
lblResultl(i).Caption = ""
lblResultx(i).Caption = ""
Next
For i = 5 To 7
lblResultl(i).Caption = ""
lblResultx(i).Caption = ""
Next i
End Select
End Sub
Private Sub Timer1_Timer()
If txtdlcc(1).Text = "" Then
cmd1.Enabled = False
Else
cmd1.Enabled = True
End If
End Sub
Private Sub Timer2_Timer()
If txtdlcc(0).Text = "" Then
cmd3.Enabled = False
Else
cmd3.Enabled = True
End If
End Sub
Private Sub Timer3_Timer()
If txtdlc(1).Text = "" Then
cmd2.Enabled = False
Else
cmd2.Enabled = True
End If
End Sub
Private Sub Timer4_Timer()
If txtdlc(0).Text = "" Then
cmd4.Enabled = False
Else
cmd4.Enabled = True
End If
End Sub
Private Sub timerCheck_Timer()
Dim i As Integer
If txtData(0).Text = "" Or txtData(1).Text = "" Or _
txtData(2).Text = "" Or txtData(3).Text = "" Or _
txtData(4).Text = "" Or txtData(4).Text = "" Or _
txtData(5).Text = "" Or txtData(6).Text = "" Or _
txtData(7).Text = "" Or txtData(8).Text = "" Or _
txtData(9).Text = "" Then
sbfor(3).Enabled = False
Else
sbfor(3).Enabled = True
End If
End Sub
Private Sub txtData_KeyPress(Index As Integer, KeyAscii As Integer)
Dim found As Integer
Select Case KeyAscii
Case vbKeyBack, vbKeyRight, vbKeyLeft
'do nothing
Case Asc("0") To Asc("9")
'do nothing
Case Asc("-")
If txtData(Index).Text "" Then
Beep
KeyAscii = 0
End If
Case Asc(".")
If txtData(Index).Text "" Then
found = InStr(1, txtData(Index).Text, ".", vbTextCompare)
If found 0 Then
Beep
KeyAscii = 0
End If
End If
Case Else
Beep
KeyAscii = 0
End Select
End Sub
Private Sub Form_QueryUnload(Cancel As Integer, UnloadMode As Integer)
frmchinh.Enabled = True
End Sub
Private Sub txtdlc_KeyPress(Index As Integer, KeyAscii As Integer)
Dim found As Integer
Select Case KeyAscii
Case vbKeyBack, vbKeyRight, vbKeyLeft
'do nothing
Case Asc("0") To Asc("9")
'do nothing
Case Asc("-")
Case Asc(".")
Case Else
Beep
KeyAscii = 0
End Select
End Sub
Private Sub txtdlcc_KeyPress(Index As Integer, KeyAscii As Integer)
Dim found As Integer
Select Case KeyAscii
Case vbKeyBack, vbKeyRight, vbKeyLeft
'do nothing
Case Asc("0") To Asc("9")
'do nothing
Case Asc("-")
Case Asc(".")
Case Else
Beep
KeyAscii = 0
End Select
End Sub
4. Phần tính kíck thước cell
Private Sub optHata_Click()
cboKieuvungHata.Visible = True
cboKieuvungWalf.Visible = False
End Sub
Private Sub optWalf_Click()
cboKieuvungHata.Visible = False
cboKieuvungWalf.Visible = True
End Sub
Private Sub sbfor_Click(Index As Integer)
On Error Resume Next
Dim i As Byte
For i = 0 To 7
tsnhapkt(i) = Val(txtCell(i).Text)
Next i
Select Case Index
Case 0
Unload Me
frmMain.Enabled = False
frmCap.Show
Case 1
Unload Me
frmMain.Enabled = False
frmLoss.Show
Case 2
Unload Me
frmMain.Enabled = True
Case 3
If optHata.Value = True Then
Select Case cboKieuvungHata.ListIndex
Case 0:
lstvt.AddItem lblvt(0).Caption
If tanso > 400 Then
HesoHieuchinh = (3.2 * ((Lg10(11.75 * tsnhapkt(3))) ^ 2) - 4.97)
Else
HesoHieuchinh = (8.28 * ((Lg10(1.54 * tsnhapkt(3))) ^ 2) - 1.1)
End If
RofCell = (tsnhapkt(0) - 69.55 - 26.16 * Lg10(tsnhapkt(1)) + 13.82 * Lg10(tsnhapkt(2)) + HesoHieuchinh) / (44.9 - 6.55 * Lg10(tsnhapkt(2)))
Case 1:
lstvt.AddItem lblvt(1).Caption
HesoHieuchinh = tsnhapkt(3) * (1.1 * Lg10(tsnhapkt(1)) - 0.7) - 1.56 * Lg10(tsnhapkt(1)) + 0.8
RofCell = (tsnhapkt(0) - 69.55 - 26.16 * Lg10(tsnhapkt(1)) + 13.82 * Lg10(tsnhapkt(2)) + HesoHieuchinh) / (44.9 - 6.55 * Lg10(tsnhapkt(2)))
Case 2:
lstvt.AddItem lblvt(2).Caption
HesoHieuchinh = tsnhapkt(3) * (1.1 * Lg10(tsnhapkt(1)) - 0.7) - 1.56 * Lg10(tsnhapkt(1)) + 0.8
RofCell = (tsnhapkt(0) - 69.55 - 26.16 * Lg10(tsnhapkt(1)) + 13.82 * Lg10(tsnhapkt(2)) + HesoHieuchinh + 2 * ((Lg10(tsnhapkt(1) / 28)) ^ 2) + 5.4) / (44.9 - 6.55 * Lg10(tsnhapkt(2)))
Case 3:
lstvt.AddItem lblvt(3).Caption
HesoHieuchinh = tsnhapkt(3) * (1.1 * Lg10(tsnhapkt(1)) - 0.7) - 1.56 * Lg10(tsnhapkt(1)) + 0.8
'bankinho = (suyhaochophep - 69.55 - 26.16 * Lg10(tanso) + 13.82 * Lg10(docaoBS) + hesohieuchinh + 8) / (44.9 - 6.55 * Lg10(docaoBS))
RofCell = (tsnhapkt(0) - 69.55 - 26.16 * Lg10(tsnhapkt(1)) + 13.82 * Lg10(tsnhapkt(2)) + HesoHieuchinh + (4.78 * (Lg10(tsnhapkt(1))) ^ 2) - 19.33 * Lg10(tsnhapkt(1)) + 40.49) / (44.9 - 6.55 * Lg10(tsnhapkt(2)))
End Select
Kichthuoc = 10 ^ RofCell
lblRcell.Caption = Format(Kichthuoc, "0.######") + " km"
DientichCell = 2.6 * Kichthuoc ^ 2
lbldientich.Caption = Format(DientichCell, "0.######") + " km2"
lstR.AddItem lblRcell.Caption
lstdt.AddItem lbldientich.Caption
lstsh.AddItem Format(tsnhapkt(0), "0.######") + " dB"
lstmh.AddItem optHata.Caption
End If
If optWalf.Value = True Then
Select Case cboKieuvungWalf.ListIndex
Case 0:
lstvt.AddItem lblvt(0).Caption
If (tsnhapkt(5) >= 0) And (tsnhapkt(5) tsnhapkt(4)) Then
Lo = -9.646
Lbsh = (-18 * Lg10(1 + (tsnhapkt(2) - tsnhapkt(4))))
Ka = 54
Kd = (18 - 15 * (tsnhapkt(2) - tsnhapkt(4)) / (tsnhapkt(4) - tsnhapkt(3)))
End If
If (tsnhapkt(5) >= 35) And (tsnhapkt(5) tsnhapkt(4)) Then
Lo = (2.5 + 0.075 * (tsnhapkt(5) - 35))
Lbsh = (-18 * Lg10(1 + (tsnhapkt(2) - tsnhapkt(4))))
Ka = 54
Kd = 18
End If
If (tsnhapkt(5) >= 55) And (tsnhapkt(5) tsnhapkt(4)) Then
Lo = (4 - 0.114 * (tsnhapkt(5) - 55))
Lbsh = (-18 * Lg10(1 + (tsnhapkt(2) - tsnhapkt(4))))
Ka = 54
Kd = 18
End If
If (tsnhapkt(5) >= 0) And (tsnhapkt(5) <= 35) And (tsnhapkt(2) <= tsnhapkt(4)) Then
Lo = -9.646
Lbsh = 0
Ka = (54 - 0.8 * tsnhapkt(2))
Kd = (18 - 15 * (tsnhapkt(2) - tsnhapkt(4)) / (tsnhapkt(4) - tsnhapkt(3)))
End If
If (tsnhapkt(5) >= 35) And (tsnhapkt(5) <= 55) And (tsnhapkt(2) <= tsnhapkt(4)) Then
Lo = (2.5 + 0.075 * (tsnhapkt(5) - 35))
Lbsh = 0
Ka = (54 - 0.8 * tsnhapkt(2))
Kd = (18 - 15 * (tsnhapkt(2) - tsnhapkt(4)) / (tsnhapkt(4) - tsnhapkt(3)))
End If
If (tsnhapkt(5) >= 55) And (tsnhapkt(5) <= 90) And (tsnhapkt(2) <= tsnhapkt(4)) Then
Lo = (4 - 0.114 * (tsnhapkt(5) - 55))
Lbsh = 0
Ka = (54 - 0.8 * tsnhapkt(2))
Kd = (18 - 15 * (tsnhapkt(2) - tsnhapkt(4)) / (tsnhapkt(4) - tsnhapkt(3)))
End If
Kf = (4 + 1.5 * tsnhapkt(1) / 925 - 1.5)
Lp = (Lo + 10 * Lg10(tsnhapkt(1)) - 10 * Lg10(tsnhapkt(7)) - 16.9 + 20 * Lg10(tsnhapkt(4) - tsnhapkt(3)))
Lf = 32.4 + 20 * Lg10(tsnhapkt(1))
Lvc = (Lbsh + Ka + Kf * Lg10(tsnhapkt(1)) - 9 * Lg10(tsnhapkt(6)))
RofCell = (tsnhapkt(0) - Lf - Lvc - Lp) / (20 + Kd)
Case 1:
lstvt.AddItem lblvt(4).Caption
If (tsnhapkt(5) >= 0) And (tsnhapkt(5) tsnhapkt(4)) Then
Lo = -9.646
Lbsh = (-18 * Lg10(1 + (tsnhapkt(2) - tsnhapkt(4))))
Ka = 54
Kd = (18 - 15 * (tsnhapkt(2) - tsnhapkt(4)) / (tsnhapkt(4) - tsnhapkt(3)))
End If
If (tsnhapkt(5) >= 35) And (tsnhapkt(5) tsnhapkt(4)) Then
Lo = (2.5 + 0.075 * (tsnhapkt(5) - 35))
Lbsh = (-18 * Lg10(1 + (tsnhapkt(2) - tsnhapkt(4))))
Ka = 54
Kd = 18
End If
If (tsnhapkt(5) >= 55) And (tsnhapkt(5) tsnhapkt(4)) Then
Lo = (4 - 0.114 * (tsnhapkt(5) - 55))
Lbsh = (-18 * Lg10(1 + (tsnhapkt(2) - tsnhapkt(4))))
Ka = 54
Kd = 18
End If
If (tsnhapkt(5) >= 0) And (tsnhapkt(5) <= 35) And (tsnhapkt(2) <= tsnhapkt(4)) Then
Lo = -9.646
Lbsh = 0
Ka = (54 - 0.8 * tsnhapkt(2))
Kd = (18 - 15 * (tsnhapkt(2) - tsnhapkt(4)) / (tsnhapkt(4) - tsnhapkt(3)))
End If
If (tsnhapkt(5) >= 35) And (tsnhapkt(5) <= 55) And (tsnhapkt(2) <= tsnhapkt(4)) Then
Lo = (2.5 + 0.075 * (tsnhapkt(5) - 35))
Lbsh = 0
Ka = (54 - 0.8 * tsnhapkt(2))
Kd = (18 - 15 * (tsnhapkt(2) - tsnhapkt(4)) / (tsnhapkt(4) - tsnhapkt(3)))
End If
If (tsnhapkt(5) >= 55) And (tsnhapkt(5) <= 90) And (tsnhapkt(2) <= tsnhapkt(4)) Then
Lo = (4 - 0.114 * (tsnhapkt(5) - 55))
Lbsh = 0
Ka = (54 - 0.8 * tsnhapkt(2))
Kd = (18 - 15 * (tsnhapkt(2) - tsnhapkt(4)) / (tsnhapkt(4) - tsnhapkt(3)))
End If
Kf = (4 + 0.7 * tsnhapkt(1) / 925 - 1.5)
Lp = (Lo + 10 * Lg10(tsnhapkt(1)) - 10 * Lg10(tsnhapkt(7)) - 16.9 + 20 * Lg10(tsnhapkt(4) - tsnhapkt(3)))
Lf = 32.4 + 20 * Lg10(tsnhapkt(1))
Lvc = (Lbsh + Ka + Kf * Lg10(tsnhapkt(1)) - 9 * Lg10(tsnhapkt(6)))
RofCell = (tsnhapkt(0) - Lf - Lvc - Lp) / (20 + Kd)
End Select
Kichthuoc = 10 ^ RofCell
lblRcell.Caption = Format(Kichthuoc, "0.######") + " km"
DientichCell = 2.6 * Kichthuoc ^ 2
lbldientich.Caption = Format(DientichCell, "0.######") + " km2"
lstR.AddItem lblRcell.Caption
lstdt.AddItem lbldientich.Caption
lstsh.AddItem Format(tsnhapkt(0), "0.######") + " dB"
lstmh.AddItem optWalf.Caption
End If
Case 4
txtCell(1).Text = "880"
txtCell(2).Text = "30"
txtCell(3).Text = "1.5"
txtCell(4).Text = "30"
txtCell(6).Text = "15"
txtCell(5).Text = "90"
txtCell(7).Text = "20"
lstsh.Clear
lstmh.Clear
lstR.Clear
lstdt.Clear
lstvt.Clear
If suyhaochophep = 0 Then
txtCell(0).Text = ""
Else
txtCell(0).Text = Format(suyhaochophep, "0.######")
End If
txtCell(0).SetFocus
Case 5
txtCell(0).Text = ""
txtCell(1).Text = ""
txtCell(2).Text = ""
txtCell(3).Text = ""
txtCell(4).Text = ""
txtCell(6).Text = ""
txtCell(5).Text = ""
txtCell(7).Text = ""
lblRcell.Caption = ""
lbldientich.Caption = ""
txtCell(0).SetFocus
lstsh.Clear
lstmh.Clear
lstR.Clear
lstdt.Clear
lstvt.Clear
End Select
End Sub
Private Sub tmCheckInput_Timer()
If (txtCell(0).Text = "" Or txtCell(1).Text = "" _
Or txtCell(2).Text = "" _
Or txtCell(3).Text = "" _
Or txtCell(4).Text = "" _
Or txtCell(6).Text = "" _
Or txtCell(5).Text = "") Then
sbfor(3).Enabled = False
Else
sbfor(3).Enabled = True
End If
End Sub
Private Sub Form_Load()
txtCell(1).Text = "880"
txtCell(2).Text = "30"
txtCell(3).Text = "1.5"
txtCell(4).Text = "30"
txtCell(6).Text = "30"
txtCell(5).Text = "90"
txtCell(7).Text = "15"
lblRcell.Caption = ""
lbldientich.Caption = ""
frmchinh.Enabled = False
If suyhaochophep = 0 Then
txtCell(0).Text = ""
Else
txtCell(0).Text = Format(suyhaochophep, "0.######")
End If
optHata.Value = True
cboKieuvungHata.ListIndex = 0
cboKieuvungWalf.ListIndex = 0
End Sub
Private Sub Form_QueryUnload(Cancel As Integer, UnloadMode As Integer)
frmchinh.Enabled = True
End Sub
Private Sub txtCell_KeyPress(Index As Integer, KeyAscii As Integer)
Dim found As Integer
Select Case KeyAscii
Case vbKeyBack, vbKeyRight, vbKeyLeft
'do nothing
Case Asc("0") To Asc("9")
'do nothing
Case Asc("-")
If txtCell(Index).Text "" Then
Beep
KeyAscii = 0
End If
Case Asc(".")
If txtCell(Index).Text "" Then
found = InStr(1, txtCell(Index).Text, ".", vbTextCompare)
If found 0 Then
Beep
KeyAscii = 0
End If
End If
Case Else
Beep
KeyAscii = 1
End Select
End Sub
Các file đính kèm theo tài liệu này:
- Vuong1.doc