Tài liệu Luận văn Xây dựng hệ thống quản lý cân động ứng dụng trong hệ thống cân tàu hỏa: ĐẠI HỌC THÁI NGUYÊN
KHOA CÔNG NGHỆ THÔNG TIN
LUẬN VĂN CAO HỌC
Đề tài
Xây dựng hệ thống quản lý cân động
ứng dụng trong hệ thống cân tàu hỏa
Chuyên ngành : Khoa học máy tính
Người hướng dẫn : PGS.TS. Đoàn Văn Ban
Học viên thực hiện : Nguyễn Tuấn Anh
Mã số : 60.48.01
Thái nguyên, tháng 8 năm 2009
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Mục lục
1 Khảo sát hiện trạng hệ thống cân động vật thể 1
1.1 Thực trạng tập đoàn than - khoáng sản Việt Nam-TKV 1
1.2 Mô tả nghiệp vụ của hệ thống hiện hành . . . . . . . . . 4
1.3 Mô tả, xác định mục tiêu và yêu cầu của hệ thống mới . 4
1.4 Tổng kết chương . . . . . . . . . . . . . . . . . . . . . . 5
2 Thiết kế tổng thể hệ thống cân động vật thể 6
2.1 Thiết kế phần cứng . . . . . . . . . . . . . . . . . . . . . 6
2.1.1 Các phương án thiết kế phần cứng hệ thống . . . 7
2.1.2 Sơ đồ tổng thể . . . . . . . . . . . . . . . . . . . 10
2.1.3 Ý nghĩa và yêu cầu kỹ thuật của từng khối . . . . 10
2.2 Thiết kế phần mềm . . . . ....
81 trang |
Chia sẻ: hunglv | Lượt xem: 1361 | Lượt tải: 0
Bạn đang xem trước 20 trang mẫu tài liệu Luận văn Xây dựng hệ thống quản lý cân động ứng dụng trong hệ thống cân tàu hỏa, để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên
ĐẠI HỌC THÁI NGUYÊN
KHOA CÔNG NGHỆ THÔNG TIN
LUẬN VĂN CAO HỌC
Đề tài
Xây dựng hệ thống quản lý cân động
ứng dụng trong hệ thống cân tàu hỏa
Chuyên ngành : Khoa học máy tính
Người hướng dẫn : PGS.TS. Đoàn Văn Ban
Học viên thực hiện : Nguyễn Tuấn Anh
Mã số : 60.48.01
Thái nguyên, tháng 8 năm 2009
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Mục lục
1 Khảo sát hiện trạng hệ thống cân động vật thể 1
1.1 Thực trạng tập đoàn than - khoáng sản Việt Nam-TKV 1
1.2 Mô tả nghiệp vụ của hệ thống hiện hành . . . . . . . . . 4
1.3 Mô tả, xác định mục tiêu và yêu cầu của hệ thống mới . 4
1.4 Tổng kết chương . . . . . . . . . . . . . . . . . . . . . . 5
2 Thiết kế tổng thể hệ thống cân động vật thể 6
2.1 Thiết kế phần cứng . . . . . . . . . . . . . . . . . . . . . 6
2.1.1 Các phương án thiết kế phần cứng hệ thống . . . 7
2.1.2 Sơ đồ tổng thể . . . . . . . . . . . . . . . . . . . 10
2.1.3 Ý nghĩa và yêu cầu kỹ thuật của từng khối . . . . 10
2.2 Thiết kế phần mềm . . . . . . . . . . . . . . . . . . . . . 12
2.2.1 Xác định các yêu cầu và phân tích hệ thống . . . 13
2.2.2 Phân tích hệ thống hướng đối tượng . . . . . . . 14
2.2.3 Thiết kế hệ thống hướng đối tượng . . . . . . . . 15
2.2.4 Lập trình hướng đối tượng . . . . . . . . . . . . . 16
2.3 Tổng kết chương . . . . . . . . . . . . . . . . . . . . . . 17
3 Thiết kế chi tiết hệ thống cân động vật thể 18
3.1 Thiết kế phần cứng hệ thống . . . . . . . . . . . . . . . . 18
3.1.1 Khối cảm biến . . . . . . . . . . . . . . . . . . . . 21
3.1.2 Khối chuyển đổi ADC . . . . . . . . . . . . . . . 23
3.1.3 Khối truyền thông . . . . . . . . . . . . . . . . . 27
3.1.4 Khối nguồn . . . . . . . . . . . . . . . . . . . . . 30
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2] . . . . 30
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
MỤC LỤC ii
3.2.1 Khảo sát, xác định các yêu cầu . . . . . . . . . . 32
3.2.2 Phân tích hệ thống . . . . . . . . . . . . . . . . . 33
3.2.3 Thiết kế hệ thống . . . . . . . . . . . . . . . . . . 33
3.2.4 Lập trình và kiểm tra hệ thống . . . . . . . . . . 40
3.2.5 Vận hành và bảo trì hệ thống . . . . . . . . . . . 47
3.3 Tổng kết chương . . . . . . . . . . . . . . . . . . . . . . 47
4 Xây dựng hệ thống cân động vật thể 48
4.1 Giới thiệu về ngôn ngữ lập trình cho phần cứng nhúng . 48
4.2 Giới thiệu về ngôn ngữ lập trình phần mềm: C# . . . . . 49
4.3 Các chức năng của chương trình . . . . . . . . . . . . . . 51
4.4 Màn hình giao diện chức năng . . . . . . . . . . . . . . . 51
4.5 Lập kế hoạch triển khai thực tế . . . . . . . . . . . . . . 55
4.6 Xác định rủi ro . . . . . . . . . . . . . . . . . . . . . . . 58
4.7 Đánh giá kết quả thử nghiệm . . . . . . . . . . . . . . . 59
A Vi điều khiển PIC 67
A.1 Từ Vi xử lý đến Vi điều khiển . . . . . . . . . . . . . . . 67
A.2 Vi điều khiển họ PIC . . . . . . . . . . . . . . . . . . . . 68
A.3 Lập trình cho PIC . . . . . . . . . . . . . . . . . . . . . 69
A.4 Một vài đặc tính của PIC . . . . . . . . . . . . . . . . . 69
B Ứng dụng mạch khuếch đại thuật toán 71
B.1 Ứng dụng mạch tuyến tính . . . . . . . . . . . . . . . . . 71
B.2 Các ứng dụng phi tuyến . . . . . . . . . . . . . . . . . . 76
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Chương 1
Khảo sát hiện trạng hệ thống cân
động vật thể
Giới thiệu về Tập đoàn Công nghiệp Than – Khoáng sản Việt Nam, giới
thiệu về phương pháp cân than trên tàu hỏa, đưa ra tính năng cần có của
hệ thống cân động mới.
1.1 Thực trạng tập đoàn than - khoáng sản Việt Nam-TKV
Chặng đường phát triển của Tập đoàn Công nghiệp Than –
Khoáng sản Việt Nam
Tập đoàn Công nghiệp Than – Khoáng sản Việt Nam (trước đây là
Tổng công ty Than việt Nam) được thành lập ngày 10/10/1994 theo
quyết định số 563/QĐ.TTg của Thủ tướng Chính phủ. Thực hiện nhiệm
vụ quan trọng mà Đảng và Nhà nước giao, ngay từ khi mới đi vào hoạt
động, Tập đoàn đã xây dựng đề án “Đổi mới tổ chức, quản lý, nâng
cao hiệu quả sản xuất kinh doanh”, lựa chọn chiến lược “phát triển kinh
doanh đa ngành trên nền công nghiệp than” và phương châm “cùng phát
triển với bạn hàng”. Từ mục tiêu chiến lược đã đề ra, Tập đoàn Công
nghiệp Than – Khoáng sản Việt Nam (TKV) đã thay đổi hẳn về cơ chế
quản lý, về mô hình tổ chức sản xuất và tiêu thụ sản phẩm, về cơ chế
quản lý tài chính, tích cực đầu tư, đổi mới công nghệ trong khai thác
than, đầu tư cải tạo hoàn thiện dây chuyền công nghệ trong khai thác
than, sàng tuyển, bến rót tiêu thụ.
Trên nền sản xuất than, Tập đoàn TKV đã mạnh dạn sử dụng nguồn
nhân lực sẵn có được tạo ra từ than để đầu tư các ngành nghề khác như
phát triển mạnh mẽ ngành cơ khí mỏ theo hướng hiện đại hóa cơ khí sửa
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
1.1 Thực trạng tập đoàn than - khoáng sản Việt Nam-TKV 2
Hình 1.1: Công ty than khoáng sản Việt Nam - TKV
chữa, phát triển cơ khí chế tạo, lắp ráp, sản xuất xe tải, đóng tàu thủy;
xây dựng các nhà máy nhiệt điện; tích cực đầu tư nâng cao sản lượng
khai thác khoáng sản; sản xuất vật liệu nổ công nghiệp, xi măng, vật
liệu xây dựng; công tác nghiên cứu, ứng dụng khoa học công nghệ, bảo
vệ môi trường được chú trọng; thương mại dịch vụ và các ngành nghề
khác đều được đầu tư phát triển.
Trong suốt chặng đường 12 năm hoạt động, công nhân, cán bộ Tập
đoàn Công nghiệp Than – Khoáng sản Việt Nam đã không ngừng nỗ
lực, chủ động, sáng tạo, đã khẳng định sức mạnh của mình bằng tinh
thần đoàn kết, quyết tâm vượt khó, phấn đấu vươn lên, liên tiếp hoàn
thành toàn diện các chỉ tiêu kế hoạch, năm sau cao hơn năm trước.
Năm 2003 đã khai thác và tiêu thụ 18 triệu tấn than, là đơn vị kinh tế
đầu tiên của cả nước đã hoàn thành và vượt kế hoạch trước 2 năm trong
mục tiêu kế hoạch 5 năm (2001 – 2005) mà Đại hội Đảng toàn quốc lần
thứ IX đã đề ra (Từ 14-16 triệu tấn).
Năm 2006, năm kỷ niệm 70 năm Truyền thống công nhân vùng mỏ -
Truyền thống Ngành Than, Tập đoàn Công nghiệp Than – Khoáng sản
Việt Nam tiếp tục chuyển đổi cơ chế quản lý mới, với mục tiêu chiến
lược “Từ tài nguyên khoáng sản và nguồn nhân lực đi lên giàu mạnh”
với phương châm “Phát triển hài hòa và thân thiện với môi trường, với
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
1.1 Thực trạng tập đoàn than - khoáng sản Việt Nam-TKV 3
địa phương và cộng đồng; với đối tác và bạn hàng và hài hòa trong nội
bộ”, Tập đoàn cùng các công ty thành viên đã tập trung các nguồn lực,
đã sản xuất và tiêu thụ 37 triệu tấn than, vượt mục tiêu quy hoạch đến
năm 2010 (là 23 – 24 triệu tấn) do Thủ tướng Chính phủ phê duyệt.
12 năm, một hành trình đầy gian nan thử thách, song trong mỗi bước
đi của mình, Ngành Than – Khoáng sản Việt Nam luôn luôn được sự
quan tâm của Đảng, Nhà nước, Chính phủ, các cấp ủy Đảng, chính
quyền và nhân dân các địa phương. Sự quan tâm đó chính là nguồn cổ
vũ lớn lao, tiếp thêm sức mạnh để công nhân, cán bộ ngành Than –
Khoáng sản Việt Nam vững bước đi lên, lao động sáng tạo, trong khó
khăn, bản lĩnh người thợ mỏ càng được thể hiện và khẳng định, luôn
hăng hái đi đầu và hoàn thành xuất sắc mọi nhiệm vụ được giao. Phẩm
chất và sức sống của thợ mỏ trong suốt chặng đường hình thành và phát
triển là tinh thần “Kỷ luật và đồng tâm”, là bề dày truyền thống đã được
các thế hệ cán bộ, công nhân thợ mỏ kế tiếp giữ gìn và phát huy, lập
nhiều thành tích vẻ vang, xây dựng Tập đoàn phát triển nhanh, mạnh,
hiệu quả, vị thế ngày càng được nâng cao (theo [13]).
Công ty than Uông Bí là thành viên của tập đoàn than khoáng
sản TKV, chuyên cung cấp than cho nhà máy nhiệt điện Uông Bí, và
một số đơn vị khác. Hàng ngày, than được chở từ công ty than Uông Bí
đến nhà máy nhiệt điện để sản xuất điện năng cung cấp cho lưới điện
quốc gia.
Mỗi ngày, công ty than Uông Bí cung cấp cho nhà máy nhiệt điện phả
lại khoảng 4 chuyến tàu chở than, mỗi chuyến dài khoảng 5 đến 30 toa,
chất đầy than.
Có rất nhiều cách để xác định khối lượng than trên toa tàu, nhưng
thực tế, cho đến nay, tất cả vẫn là ước lượng, tính toán trọng lượng than
bán ra thị trường theo cách xác định khối lượng chứ không phải là trọng
lượng.
Phương pháp họ đang sử dụng là lấy mẫu than (Do KCS làm), xác
định khối lượng riêng, rồi đưa ra tỷ trọng của than. Nhân viên cân than
chỉ việc đo khối lượng rồi nhân với tỷ trọng sẽ được khối lượng ước tính
Trên thực tế, có rất nhiều vấn đề nảy sinh trong quá trình xác định
khối lượng, như khi KCS lấy mẫu, độ ẩm của than khác với độ ẩm khi
bán, điều đó có nghĩa là nếu trời mưa hoặc nắng thì than sẽ có khối
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
1.2 Mô tả nghiệp vụ của hệ thống hiện hành 4
lượng khác đi so với ước tính. Do vậy bên bán và bên mua sẽ tính khối
lượng một chuyến hàng thường khác nhau.
1.2 Mô tả nghiệp vụ của hệ thống hiện hành
Phương pháp xác định khối lượng, hiện nay quy trình tính toán
khối lượng của công ty than theo các bước sau đây, giả sử quá trình
xuất hàng của công ty:
• Than sẵn sàng xuất khỏi công ty, được KCS kiểm tra đánh giá về
chất lượng than, bao gồm khối lượng riêng, độ ẩm, độ bột (than
viên/cám),...
• KCS đưa ra công thức tính khối lượng than theo thể tích. Với V
(m3) than, với tỷ trọng k. Như vậy, khối lượng là m = V ∗ k(kg).
• Các bên liên quan đến mua bán than chứng kiến việc xác định thể
tích của tàu than, và ký kết vào phiếu cân.
• Phiếu cân được sao thành nhiều bản, mỗi bên liên quan giữ một
bản.
• Căn cứ vào phiếu cân, bên nhận than sẽ kiểm tra lại thể tích thực
của than mà mình được nhận, sau đó xác định lại tỷ trọng k của
than tại thời điểm nhận than, rồi tính ra khối lượng thực mà mình
nhận được.
• Hai bên thỏa thuận lại sai lệch rồi chấp nhận khối lượng thực theo
thỏa thuận.
1.3 Mô tả, xác định mục tiêu và yêu cầu của hệ thống mới
Phân tích ưu - nhược điểm của hệ thống hiện tại:
Hệ thống hiện tại hoàn toàn do con người chủ động, nên không thể chính
xác được. Đôi khi nắng mưa ảnh hưởng đến độ ẩm của than, làm cho tỷ
trọng khác với khi lấy mẫu, dẫn đến khi than bắt đầu xuất kho bên bán
có một khối lượng, khi than nhập kho của bên mua, sẽ có khối lượng
khác. Do hai bên mua và bán than đều muốn mình có lợi, cho nên xảy
ra mâu thuẫn và tranh chấp.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
1.4 Tổng kết chương 5
Mục tiêu của hệ thống mới:
Hệ thống mới phải khắc phục được các nhược điểm của hệ thống hiện
hành, và có các tính năng:
• Cân bằng thiết bị điện tử và máy tính.
• Xác định chính xác trọng lượng thực của than.
• Cân trong khi tàu đang chạy với vận tốc từ 3-15Km/h.
• Dải cân chính xác cho mỗi toa có khối lượng từ 100kg đến 120 tấn.
• Sai số cho phép nằm trong khoảng 0.5%
• Mất điện trong một khoảng thời gian nhất định, vẫn cân bình
thường.
• Lưu trữ được kết quả mỗi lần cân trong khoảng thời gian theo ý
muốn.
• Phân biệt và loại bỏ được đầu tàu.
• Phát hiện và cảnh báo toa rỗng (Toa không có hàng)
• Khối lượng không phụ thuộc KCS.
• Không phải trải qua các cuộc đàm phán về triết khấu khối lượng
theo thời tiết.
• Giao diện trên máy tính thân thiện.
• In trực tiếp phiếu cân từ phần mềm cho mỗi lần cân.
• Tống hợp được lượng than bán ra trong tháng / quý / năm.
1.4 Tổng kết chương
Khảo sát hiện trạng của hệ thống cũ là điều rất cần thiết, qua đó ta xác
định được hệ thống đang hoạt động như thế nào, quá trình vận hành hệ
thống ra sao, có những ưu nhược điểm gì,...
Từ đó, ta xây dựng lên hệ thống mới, có tính hiệu quả cao hơn so với
hệ thống cũ, và phương pháp vận hành hệ thống có tính thừa kế.
Trong chương này, tất cả các đặc điểm của hệ thống mới đã được xác
lập, từ đó, làm nền tảng để thiết kế ở các chương tiếp theo.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Chương 2
Thiết kế tổng thể hệ thống cân
động vật thể
Thiết kế tổng thể cả hệ thống dưới dạng sơ đồ khối: thiết kế phần cứng và
phần mềm, nêu đặc điểm, yêu cầu kỹ thuật của mỗi khối, phương pháp
giao tiếp, mức tín hiệu vào ra,...
2.1 Thiết kế phần cứng
Có rất nhiều cách thiết kế phần cứng, mục tiêu là làm sao phải đạt được
các tiêu chí sau:
• Hiệu quả, chính xác: Mỗi toa tàu, có thể nặng đến 120 tấn, (hoạt
động bình thường tại công ty than Uông bí là 50-60 tấn), với sai số
yêu cầu là không quá 0.5%, tức là: sai số m ≤ 0.0005∗120, 000(kg) =
60(kg)cho mỗi toa. Yêu cầu Loadcell (Cảm biến đo khối lượng) phải
chịu được sức nặng lên đến 120 tấn, bộ khuếch đại nằm trong dải
0 − 10v hoặc 4 − 20mA (Tín hiệu theo chuẩn công nghiệp) và bộ
chuyển đổi tín hiệu tương tự sang số (ADC) phải thỏa mãn yêu cầu
theo sai số như trên.
• Nhanh chóng : Tốc độ tàu yêu cầu khi cân là 3− 15km/h, có nghĩa
là trong thời gian đó, phải thu thập đủ dữ liệu để có thể tính toán.
Tính toán được khối lượng của mỗi toa bằng cách tính tổng khối
lượng trên 2 trục bánh. Muốn tính được khối lượng, ta phải dùng
thuật toán như lọc, FFT, xác định đỉnh ,... Tất cả các thuật toán
trên đều cần nhiều mẫu mới có thể làm được. Tiêu chí đặt ra là ít
nhất, cần có khoảng ≥ 100 mẫu/một cụm bánh.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
2.1 Thiết kế phần cứng 7
• Ổn định: Trong môi trường cân, có rất nhiều yếu tố ảnh hưởng đến
hệ thống, như mưa gió, sấm sét, mất điện, nhiễu,... Các yếu tố đó
trực tiếp hoặc gián tiếp gây mất ổn định cho hệ thống. Yêu cầu cần
phải hạn chế tối đa sự tác động của ngoại cảnh đến hệ thống,...
Vậy có những phương pháp nào có thể xây dựng phần cứng mà có thể
đạt được các yêu cầu trên?
2.1.1 Các phương án thiết kế phần cứng hệ thống
Sơ đồ khối của hệ thống như hình 2.1. Trong đó, phần quan trọng nhất
là modul điều khiển trung tâm, có rất nhiều phương án thiết kế modul
điều khiển trung tâm, mỗi phương án đó, sẽ phải thiết kế các modul còn
lại sao cho phù hợp.
Dưới đây, chúng ta thiết kế và lựa chọn modul điều khiển trung tâm
(như trong hình 2.1), khi chọn được phương án hợp lý, sẽ đi thiết kế hệ
thống.
Hiển thị
Điều khiển
trung tâmPhím điều khiển Máy tính
Khuếch đại
Cảm biến khối lượng
Nguồn nuôi
Hình 2.1: Sơ đồ khối tổng thể
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
2.1 Thiết kế phần cứng 8
Phương án 1:
Sử dụng card chuyển đổi ghép nối máy tính qua khe cắm PCI làm bộ
chuyển đổi tín hiệu: Card chuyển đổi vào ra số, tương tự của Advantech
có các tính năng sau:
• Vào/ra số 16 bit với mức logic 1 là 5v, mức logic 0 là 0v.
• 16 kênh vào tương tự 12 bit với ngưỡng vào điện áp là 0 ÷5v.
• 2 kênh ra tương tự 12 bit.
• Tốc độ chuyển đổi ADC tối đa của card là 200kbps (Kilobit Per
Second).
• Có tính năng khuếch đại mềm
• Lựa chọn đọc 1 kênh hoặc nhiều kênh từ bộ đệm chuyển đổi.
• Card ghép nối sử dụng driver khi đọc tín hiệu từ Windows, khi đọc
trong DOS thì không cần driver.
Phương án 2:
Sử dụng PLC làm modul điều khiển trung tâm Phương án này rất được
sự tin tưởng bởi đã được kiểm nghiệm của công ty danh tiếng, các sản
phẩm của họ đã trải qua sự kiểm tra khắc nghiệt khi làm việc với môi
trường công nghiệp. Có thể kể ra đây các tính năng của PLC như sau:
• Ổn định
• Số lượng tín hiệu vào/ra tùy chọn
• Tín hiệu số ra được điều khiển trực tiếp qua rơle nội.
• Tín hiệu số vào: +24v
• Tín hiệu vào tương tự: 0− 10v hoặc 4− 20mA
• Tín hiệu ra tương tự: 0− 10v
• Truyền thông với PC bằng cáp MPI hoặc PPI chuyên dụng, giao
thức RS232, RS485, ProfiBus, USB
• Phần mềm lập trình nhúng và phần mềm lập trình điều khiển được
hỗ trợ bởi hãng sản xuất.
• Giá thành tùy từng chủng loại, số lượng modul.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
2.1 Thiết kế phần cứng 9
Phương án 3:
Tự thiết kế card chuyển đổi ADC ghép nối USB. Tất cả các tính năng
được thiết kế phù hợp nhất với hệ thống.
• Độ phân dải chuyển đổi ADC
• Tốc độ chuyển đổi
• Số lượng tín hiệu vào/ra
• Mức tín hiệu vào/ra
• Khả năng chống nhiễu
• Khả năng khuếch đại tín hiệu
• Tốc độ xử lý
• Giao diện ghép nối
• Phương thức truyền thông
Phương án lựa chọn: Phương án 3
Phân tích:
Tốc độ tàu đi tối đa là 15(km/h) ≈ 4.12(m/s). Khoảng cách giữa hai
điểm gần nhất trên 2 cụm trục liên tiếp là 2.27m, khoảng cách giữa 2
điểm tiếp xúc ray là 2.27m. Như vậy, thời gian mỗi cụm trục đi qua
khoảng 0.5s, trong thời gian này, ta phải lấy được ít nhất khoảng 300
mẫu khối lượng. Đối với phương án 1, độ phân dải chuyển đổi là 12 bit
4096 mức. Nếu dùng để cân, thì bước nhảy sẽ là: 120 tấn 4096 mức, hay
1 bước nhảy = 120,000(kg)4096(mức) = 29.296875(kg). Nếu tín hiệu đọc về không có
bit lỗi, nếu 1 bit hàng đơn vị bị lỗi thì sai số tăng lên gấp 10 lần. Đó
là sai số tính trên 1 toa nếu tính tổng cả đoàn tàu thì sai số sẽ lớn hơn
nữa.
Đối với phương án 2, dùng PLC với ADC 16 bit, phương án này hoàn
toàn khả thi, nhưng những modul ADC 16 bit tại Việt Nam rất khó
kiếm, giá thành rất cao.
Nếu ta tự thiết kế một modul theo phương án 3 thì giá thành sẽ hạ
xuống rất nhiều, mặt khác ta lại làm chủ công nghệ, bảo hành bảo trì
thuận tiện, và thiết kế sẽ bám sát các yêu cầu cụ thể của bài toán.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
2.1 Thiết kế phần cứng 10
2.1.2 Sơ đồ tổng thể
C
ả
m
b
iế
n
K
h
u
ế
ch
ñ
ạ
i
L
ọ
c
&
C
h
u
yể
n
ñ
ổ
i A
D
C
V
i ñ
iề
u
k
h
iể
n
n
h
ú
n
g
P
o
w
e
r
sy
st
e
m
E
m
b
e
d
d
e
d
M
ic
ro
co
n
tr
o
lle
r
C
o
m
m
u
n
ic
a
tio
n
in
te
rf
a
ce
T
ru
yề
n
t
h
ô
n
g
P
h
ầ
n
m
ề
m
q
u
ả
n
lý
N
g
u
ồ
n
n
u
ô
i
B
à
n
p
h
ím
H
iể
n
t
h
ị
1
2
3
4
5
Hình 2.2: Sơ đồ khối tổng thể được chọn
Trong sơ đồ khối tổng thể cả hệ thống (hình 2.2)bao gồm các modul
sau:
Bộ cảm biến khối lượng (Loadcell), Bộ lọc (Fillter), Khuếch đại (Ampli
Gain), Chuyển đổi ADC, Bộ vi điều khiển nhúng, Hiển thị, Truyền thông,
Nguồn nuôi.
2.1.3 Ý nghĩa và yêu cầu kỹ thuật của từng khối
1. Khối cảm biến khối lượng (Loadcell): Khối này là khối quan
trọng nhất trong phần cảm biến. Nó quyết định vai trò chịu lực của
vật đặt lên cân. Cần phải chọn loại Loadcell sao khả năng chịu lực
của bàn cân phải lớn hơn (thường là gấp rưỡi) tổng khối lượng lớn
nhất đặt lên bàn cân.
Về bản chất, khối này là một bộ, tập hợp của nhiều Loadcell, bố trí
trên bàn cân sao cho tổng khối lượng phân bố đều nhất.
Tín hiệu vào là: +10v, tín hiệu ra là vi sai cầu trở, tạo điện áp lệnh
giữa hai đầu ra để đưa đến bộ khuếch đại.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
2.1 Thiết kế phần cứng 11
2. Bộ lọc (Fillter): Khi được cấp điện áp, Modul cảm biến sẽ đưa tín
hiệu về tỉ lệ với khối lượng đặt lên đầu cân. Tín hiệu có ích rất yếu,
điều đó có nghĩa là ảnh hưởng của môi trường rất lớn lên tín hiệu,
hay nói cách khác, nhiễu sẽ rất cao.
Để giảm thiểu nhiễu, cần có một bộ lọc, lọc bỏ hết tất cả các tần số
nhiễu nằm ngoài dải, chỉ giữ lại tín hiệu thuộc tần số cần thiết.
3. Khuếch đại: Tín hiệu đầu cân là tín hiệu vi sai, tùy theo loại cảm
biến, nhưng trong công nghiệp, các loại loadcell thường có các tham
số như: 20mV/V, có nghĩa là khi chịu tải tối đa, khối cảm biến đưa
tín hiệu về là 20mV. Chúng ta cần khuếch đại tín hiệu đó lên đến
giá trị max của bộ chuyển đổi ADC, thường thì bộ chuyển đổi chấp
nhận dải 0..10v, có nghĩa là nhiệm vụ của bộ khuếch đại làm tăng
hệ số khuếch đại lên 500 lần
4. Bộ chuyển đổi ADC: Khi có tín hiệu đầu vào sau bộ khuếch đại,
trong modul này, cũng có thể thiết kế thêm bộ khuếch đại lặp, nhằm
đảm bảo tín hiệu đưa vào chuyển đổi là chuẩn nhất.
Xét về độ chính xác, modul này rất quan trọng, nó quyết định sai
số của hệ thống. Nếu chúng ta chọn độ phân dải thấp thì bước nhảy
của kết quả sẽ rất lớn, tức là sai số nhiều, và ngược lại, độ phân dải
của hệ thống càng cao thì càng cho kết quả chính xác [10].
Ví dụ: Nếu chúng ta cần cân 900kg
• Nếu chọn đọ phân dải là 2 bit, thì chúng ta có các giá trị số: 0,
1, 2, 3 và các giá trị khối lượng tương ứng là: 0, 300, 600, 900
(kg). Bước nhảy và cũng là sai số có thể xảy ra là ≈ 300(kg).
• Nếu chúng ta chọn độ phân dải là 3 bit,thì bước nhảy sẽ là: 0,
1, 2, 3, 4, 5, 6, 7 và giá trị bước nhảy của cân tương ứng sẽ là:
900/7 ≈ 128.57(kg). Có nghĩa là nếu độ phân dải là 3 bit, thì sẽ
chính xác hơn nhiều so với dùng độ phân dải 2 bit.
Từ đó, theo sai số cho phép là 0.5% của 120 tấn:
Sai số = 0.5% ∗ 120(tấn) = 0.6(tấn)
chúng ta sẽ tính toán được độ phân dải cần thiết sẽ là:
600(kg) ∗X(bước nhảy) = 120.000(kg)
X =
120.000
600
= 200 = 2n
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
2.2 Thiết kế phần mềm 12
n = log2(200) . 8(bit)
Trong đó: X: Số bước nhảy, n: Số bit (độ phân dải).
Để tăng độ chính xác, ta nâng cao độ phân dải lên 12 bit, thì sai số
phép cân sẽ là:
212 = 4096(Bước nhảy)
Sai số =
120.000
4096
= 29.296875(kg)
Tương tự, nếu dùng độ phân dải là 13 bit, thì sai số sẽ là: 14.6484375(kg);
nếu dùng độ phân dải 14bit, sai số sẽ là: 7.32421875(kg)
Với độ phân dải 14bit, ta thấy sai số là rất nhỏ, và hoàn toàn khả
thi, vậy ta chọn độ phân dải chuyển đổi ADC là 14 bit.
Một điều rất quan trọng nữa là tốc độ chuyển đổi. Nếu thời gian
chuyển đổi quá lâu thì lượng mẫu lấy được sẽ ít, dẫn tới việc tính
toán không được chính xác. Như vậy, cần phải chọn được bộ chuyển
đổi sao cho phải đảm bảo lượng mẫu có ích thu được là hơn 100
mẫu/s (theo thuật toán tính khối lượng) mới đảm bảo cân chính
xác.
5. Bộ vi điều khiển nhúng: là một hệ vi xử lý, có khả năng điều
khiển quá trình chuyển đổi AD, truyền thông với PC và giao tiếp
với các modul mở rộng như bàn phím (dùng để chỉnh zero, calib
động,...) và modul hiển thị trực tiếp (không thông qua PC). Một
phần rất quan trọng nữa, đó là giao tiếp được với máy tính, để giao
tiếp với máy tính, có thể tùy chọn các chuẩn truyền thông: USB,
RS232, RS485, ProfiBus,...
6. Hiển thị: Hiển thị giá trị đọc được theo thời gian thực của giá trị
cân, nhằm xác định được trạng thái hoạt động của hệ thống.
7. Truyền thông: Là một modul riêng, kết nối giữa máy tính với
PC, tuân thủ theo chuẩn truyền thông giữa PC và Bộ vi điều khiển
nhúng.
8. Nguồn nuôi: Cung cấp nguồn cho toàn bộ hệ thống: 220v, 0v, 5v,
10v, 12v, 24v,...
2.2 Thiết kế phần mềm
UML là ngôn ngữ mô hình hoá, trước hết nó mô tả ký pháp thống nhất,
ngữ nghĩa các định nghĩa trực quan tất cả các thành phần của mô hình.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
2.2 Thiết kế phần mềm 13
UML được sử dụng để hiển thị, đặc tả, tổ chức, xây dựng và làm tài liệu
các vật phẩm (artifacts) của tất cả các giai đoạn trong quá trình phát
triển phần mềm hướng đối tượng, đặc biệt là hai giai đoạn chính phân
tích, thiết kế dưới dạng các báo cáo, biểu đồ, bản mẫu hay các trang
web, v.v. UML là ngôn ngữ mô hình hoá độc lập với các công nghệ phát
triển phần mềm [2]
Nói cách khác, UML là ngôn ngữ mô hình hoá, ngôn ngữ đặc tả và
ngôn ngữ xây dựng mô hình trong quá trình phát triển phần mềm, đặc
biệt là trong phân tích và thiết kế hệ thống hướng đối tượng. UML là
ngôn ngữ hình thức, thống nhất và chuẩn hoá mô hình hệ thống một
cách trực quan. Nghĩa là các thành phần trong mô hình được thể hiện
bởi các ký hiệu đồ hoạ, biểu đồ và thể hiện đầy đủ mối quan hệ giữa các
chúng một cách thống nhất và có logic chặt chẽ.
2.2.1 Xác định các yêu cầu và phân tích hệ thống
Từ các yêu cầu của khách hàng, chúng ta xác định được các mục tiêu
của phần mềm cần phát triển. Thường đó là các yêu cầu chức năng về
những gì mà hệ thống phải thực hiện, nhưng chưa cần chỉ ra các chức
năng đó thực hiện như thế nào. Việc xác định đúng và đầy đủ các yêu
cầu của bài toán là nhiệm vụ rất quan trọng, nó làm cơ sở cho tất cả các
bước tiếp theo trong dự án phát triển phần mềm. Muốn vậy, thì phải
thực hiện đặc tả chi tiết các yêu cầu của hệ thống. UML cung cấp biểu
đồ ca sử dụng để đặc tả các yêu cầu của hệ thống. Tài liệu đặc tả các
yêu cầu được sử dụng để:
• Làm cơ sở để trao đổi với người sử dụng, để thảo luận giữa các
nhóm thành viên trong dự án phát triển phần mềm về những gì mà
hệ thống sẽ phải thực hiện (và cả những gì nó không cần thực hiện).
• Làm căn cứ cơ bản để kiểm tra, thử nghiệm trong các bước tiếp theo
của quá trình phát triển phần mềm.
Muốn đạt được các mục tiêu trên thì quá trình phải thực hiện:
• Xác định và hiểu rõ miền, phạm vi của bài toán: Những người phát
triển sẽ xây dựng hệ thống theo sự hiểu biết của họ như thế nào về
những yêu cầu của khách hàng và những khái niệm cơ sở của bài
toán ứng dụng.
• Nắm bắt các yêu cầu: Người phân tích phải nắm bắt được tất cả các
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
2.2 Thiết kế phần mềm 14
nhu cầu của khách hàng bằng cách phải trao đổi với mọi người có
liên quan đến dự án, tham khảo các tài liệu liên quan. Thông qua
việc thảo luận, trao đổi với khách hàng, các chuyên gia của lĩnh vực
ứng dụng và những người đã, đang sử dụng những hệ thống có sẵn,
ta có thể phát hiện và nắm bắt được các yêu cầu của họ. Phương
pháp trừu tượng hoá giúp ta dễ dàng nắm bắt được các yêu cầu của
hệ thống.
• Phân loại: Vấn đề quan trọng nhất trong giai đoạn này là phải hiểu
rõ các yêu cầu đã được xác định. Muốn vậy, ta phải tìm cách phân
loại chúng theo tầm quan trọng, hay chức năng chính của những
người sử dụng và của khách hàng.
• Thẩm định: Kiểm tra xem các yêu cầu có thống nhất với nhau và
đầy đủ không, đồng thời tìm cách giải quyết các mối mâu thuẫn giữa
các yêu cầu nếu có.
• Nghiên cứu tính khả thi: Tính khả thi của một dự án tin học phải
được thực hiện dựa trên các yếu tố bao gồm các khía cạnh tài chính,
chiến lược, thị trường, con người, đối tác, kỹ thuật, công nghệ và
phương pháp mô hình hoá, v.v. Nói chung, không có một qui tắc
hướng dẫn cụ thể để biết khi nào công việc phân tích các yêu cầu
sẽ kết thúc và quá trình phát triển có thể chuyển sang bước tiếp
theo. Nhưng có thể dựa vào các câu trả lời cho những câu hỏi sau
để chuyển sang bước tiếp theo.
• Khách hàng, người sử dụng (NSD) và những người phát triển đã
hiểu hoàn toàn hệ thống chưa?
• Đã nêu được đầy đủ các yêu cầu về chức năng (dịch vụ), đầu vào /
ra và những dữ liệu cần thiết chưa?
Bức tranh chung trong pha phân tích các yêu cầu của hệ thống có thể
mô tả như trong hình 2.3 Vấn đề xác định đúng và đầy đủ các yêu cầu
của hệ thống là rất quan trọng, nó ảnh hưởng rất lớn tới chất lượng của
sản phẩn sau này.
2.2.2 Phân tích hệ thống hướng đối tượng
Phân tích hướng đối tượng (OOA): là một giai đoạn của quá trình phát
triển phần mềm, trong đó mô hình khái niệm được mô tả chính xác
thông qua các đối tượng thực và các khái niệm của bài toán ứng dụng.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
2.2 Thiết kế phần mềm 15
N
gư
ời
p
há
t
tr
iể
n
hệ
th
ốn
g
K
há
ch
h
àn
g,
C
ác
c
hu
yê
n
gi
a
hệ
th
ốn
g
N
gư
ời
s
ử
dụ
ng
(N
S
D
)
H
iể
u
rõ
cá
c
yê
u
cầ
u
N
ắm
b
ắt
cá
c
yê
u
cầ
u
T
ài
li
ệu
ñ
ặc
tả
y
êu
c
ầu
và
b
ướ
c
ti
ếp
th
eo
N
gh
iê
n
cứ
u
tín
h
kh
ả
th
i
T
hẩ
m
ñ
ịn
h
P
hâ
n
lo
ại
M
ô
tả
cá
c
yê
u
cầ
u
Hình 2.3: Mối quan hệ giữa các công việc trong pha phân tích các yêu cầu
Phân tích hướng đối tượng tập trung vào việc tìm kiếm các đối tượng,
khái niệm trong lĩnh vực bài toán và xác định mối quan hệ của chúng
trong hệ thống.
Nhiệm vụ của khâu phân tích là nghiên cứu kỹ các yêu cầu của hệ
thống và phân tích các thành phần của hệ thống cùng các mối quan hệ
của chúng. Trong khâu phân tích hệ thống chủ yếu trả lời câu hỏi:
• Hệ thống gồm những thành phần, bộ phận nào?
• Hệ thống cần thực hiện những cái gì?
Kết quả chính của pha phân tích hệ thống hướng đối tượng là biểu
đồ lớp, biểu đồ trạng thái, biểu đồ trình tự, biểu đồ cộng tác và biểu đồ
thành phần.
2.2.3 Thiết kế hệ thống hướng đối tượng
Dựa vào các đặc tả yêu cầu và các kết quả phân tích (các biểu đồ nêu
trên) để thiết kế hệ thống. Thiết kế hướng đối tượng (OOD) là một giai
đoạn trong quá trình phát triển phần mềm, trong đó hệ thống được tổ
chức thành tập các đối tượng tương tác với nhau và mô tả được cách để
hệ thống thực thi nhiệm vụ của bài toán ứng dụng. Trong khâu thiết kế
hệ thống hướng đối tượng chủ yếu trả lời câu hỏi:
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
2.2 Thiết kế phần mềm 16
• Làm như thế nào?
• Trong hệ thống có những lớp đối tượng nào, trách nhiệm của chúng
là gì?
• Các đối tượng tương tác với nhau như thế nào?
• Các nhiệm vụ mà mỗi lớp đối tượng phải thực hiện là gì?
• Dữ liệu nghiệp vụ và các giao diện được xây dựng như thế nào?
• Kiến trúc và cấu hình của hệ thống?
Nhiệm vụ chính của thiết kế hệ thống là:
• Xây dựng các thiết kế chi tiết mô tả các thành phần của hệ thống ở
mức cao hơn khâu phân tích, thiết kế giao diện để phục vụ cho việc
cài đặt. Nghĩa là, các lớp đối tượng được định nghĩa chi tiết gồm
đầy đủ các thuộc tính, các thao tác phục vụ cho việc cài đặt bằng
ngôn ngữ lập trình hướng đối tượng được lựa chọn ở các bước sau.
• Đồng thời đưa ra được kiến trúc (là trọng tâm) của hệ thống để đảm
bảo cho hệ thống có thể thay đổi, có tính mở, dễ bảo trì, thân thiện
với NSD, v.v. Nghĩa là tổ chức các lớp thành các gói hoặc các hệ
thống con theo một kiến trúc phù hợp với nhu cầu phát triển của
công nghệ (mạng, phân tán, v.v.) đồng thời phù hợp với xu thế phát
triển của lĩnh vực ứng dụng.
• Thiết kế CSDL, có thể chọn mô hình quan hệ hay mô hình đối tượng.
Bởi vì tồn tại nhiều mô hình dữ liệu khác nhau, nên khi xây dựng hệ
thống phần mềm lớn chúng ta phải thiết kế các phương án tích hợp
dữ liệu từ nhiều nguồn khác nhau, nghĩa là những khả năng chuyển
đổi, kết hợp các mô hình dữ liệu đó với nhau.
Những kết quả trên được thể hiện trong các biểu đồ: biểu đồ lớp (chi
tiết), biểu đồ hành động, biểu đồ thành phần và biểu đồ triển khai.
Tất cả các kết quả thiết kế phải được ghi lại thành các hồ sơ, tài liệu
cho hệ thống. Trong các tài liệu thiết kế phải mô tả cụ thể những thành
phần nào, làm những gì và làm như thế nào.
2.2.4 Lập trình hướng đối tượng
Trong giai đoạn này, mỗi thành phần đã được thiết kế sẽ được lập trình
bằng ngôn ngữ lập trình hướng đối tượng được lựa chọn thành những
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
2.3 Tổng kết chương 17
Thiết kế chi tiết:
Làm mịn dần các thành phần,
Cách thực hiện của mỗi thành phần
Thiết kế các mối quan hệ
Kiến trúc
tổng quát và
trừu tượng hoá
Mô hình khái niệm,
Đặc tả các yêu cầu
Thiết kế logic:
Phân chia các thành phần,
Nhiệm vụ các thành phần
Quan hệ giữa các thành phần
Kiến trúc chi tiết, cụ thể và
phụ thuộc vào vài đặt:
khung của hệ thống
Hình 2.4: Thiết kế logic và thiết kế chi tiết
mô đun chương trình (chương trình con). Mỗi mô đun này sẽ được kiểm
định hoặc thử nghiệm theo các tài liệu đặc tả của giai đoạn thiết kế.
Công việc này được mô tả như sau:
Lập trình
(Xây dựng các lớp)
Đặc tả thiết kế
Tập các mô đun
chương trình
Hình 2.5: Lập trình tập trung xây dựng lớp
Hiện nay có một số công cụ hỗ trợ cho quá trình phân tích, thiết kế
và có thể sinh mã tự động cho những thành phần chính của mô hình
như: Rose [4], hay Visual Studio .NET của Microsoft, v.v.
2.3 Tổng kết chương
Khâu thiết kế tổng thể là khâu rất quan trọng, ta phải thiết kế ở dạng
sơ đồ khối, chia bài toán thành nhiều module, mỗi module đảm nhận
một chức năng.
Ở chương này, ta chỉ xét đến chức năng các module, các yêu cầu đầu
vào/ra, sự liên kết giữa các module, phân chia công việc giữa phần mềm
và phần cứng, yêu cầu kỹ thuật,các điều kiện giới hạn của module,...
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Chương 3
Thiết kế chi tiết hệ thống cân động
vật thể
Thiết kế chi tiết cả hệ thống, dựa vào yêu cầu được đưa ra từ phần thiết
kế tổng thể, chương này triển khai chi tiết :
Về phần cứng: triển khai thiết kế mạch, đưa ra sơ đồ nguyên lý, phân
tích sự hoạt động của mạch, đưa ra thuật toán điều khiển, mã nguồn
điều khiển, và mã nguồn dùng để kiểm tra sự hoạt động của mạch
Về phần mềm: phân tích, thiết kế hướng đối tượng phần mềm cần có.
3.1 Thiết kế phần cứng hệ thống
Sau khi đã nghiên cứu ký lưỡng, chi tiết, tỉ mỉ về yêu cầu của hệ thống
mới, chúng ta có thể đưa ra được sơ đồ nguyên lý dạng chi tiết đến từng
linh kiện. Như hình 3.3, đó là phần mạch nguyên lý hệ thống. Chưa có
phần ngoại vi như: bộ biến đổi điện áp, cơ cấu gá lắp Loadcell, cáp và
cách chọn cáp tín hiệu,...
Để chi tiết hơn, dưới đây tôi xin trình bày về phần cơ khí trước.
Xem hình 3.1, trong đó: Ray tàu là hai đường thẳng song song, được
gá lên các tà vẹt. Tuy ngành đường sắt cũng đã rất cố gắng để trong
quá trình tàu chạy, các tà vẹt không nún, nhưng chỉ bằng phương pháp
trải đá 34 thì không thể tránh khỏi hiện tượng là các tà vẹt vẫn nún khi
có tàu chạy qua, đặc biệt là tàu chở đầy hàng.Để không bị nún khi cân,
chúng ta cần thiết kế một bàn cân. Bàn cân được thiết kế bằng bê tông,
đúc dày đặc khoảng 50cm, rộng gấp đôi khoảng cách giữa 2 tà vẹt, và
dài gấp đôi khoảng cách tiếp đất của 2 bánh tàu trên cùng một trục.
Bánh tàu cho mỗi toa được chia làm hai cụm, (xem hình 3.2), trong
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.1 Thiết kế phần cứng hệ thống 19
Chiều dài bàn cân
Hình 3.1: Thiết kế cơ khí gá lắp Loadcell
L
Hình 3.2: Khoảng cách 2 bánh tàu trên một trục
đó L là khoảng cách giữa hai bánh trên một cụm, L = 2.27m. Như vậy,
chiều dài bàn cân, tối thiểu phải là 4.54m. Để đảm bảo an toàn, ta chọn
chiều dài bàn cân là 6m. Do khoảng cách giữa hai điểm gần nhất của
hai bánh tàu là 9.5m, nên hoàn toàn yên tâm.
Độ dày của khối bê tông, phải đủ lớn để đảm bảo đặt toa tàu có khối
lượng 120 tấn lên thường xuyên mà không bị hỏng. Vấn đề sức bền cơ
khí, sẽ có một kỹ sư cơ khí thiết kế theo ý tưởng trên.
Từ thiết kế sơ đồ khối tổng thể, ta xác định đầu vào/ra và thiết kế
được sơ đồ chi tiết như hình 3.3.
Trong sơ đồ này, ta xác định được đầu vào/ra, mạch nguồn vào, bàn
phím chỉnh định, module khuếch đại, hai module hiển thị, giao tiếp với
PC,...
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.1 Thiết kế phần cứng hệ thống 20
11
22
33
44
D
D
C
C
B
B
A
A
*
C
ao
h
oc
K
6
D
H
K
TC
N
Th
ai
N
gu
ye
n
*
*
*
*
7/
28
/2
00
9
11
:4
3:
53
A
M
E:
\P
ro
du
ct
s\C
B0
90
50
4
D
es
ig
n\
Im
po
rte
d
CB
09
05
04
.P
RJ
PC
B\
K
D
&
H
T.
Sc
hD
oc
Ti
tle
Si
ze
:
N
um
be
r:
D
at
e:
Fi
le:
Re
vi
sio
n:
Sh
ee
t
of
Ti
m
e:
A4
D
es
ig
ne
d
by
T
uÊ
n
A
nh
. W
eb
si
te
: h
ttp
://
P
IC
A
T
.d
ie
uk
hi
en
.n
et
B7
B6 M
CL
R
B7
B6
D5
9 1
N4
14
8
1
LK6
CON1
ST
_C
P
SH
_C
P
D
O
V
CC
G
N
D
D
I
D
W
eig
ht
D
isp
lay
.S
ch
Do
c
S+ S-
To
P
IC
d
isp
la
y
To
M
ai
n
A
D
D
A
Sp
ee
d
in
Sp
ee
d
to
P
IC
-1
2V
G
N
D
+1
2V
+1
0V
B1 Kh
ue
ch
d
ai.
Sc
hD
oc
1
2
3
wr
5
5K
C6 22
4
R6
6
47
0
ST
_C
P
SH
_C
P
D
O
V
CC
G
N
D
D
I
D3
Sp
ee
d
dis
pla
y.
Sc
hD
oc
C1
2
10
4
R6
2
R
C1
1
10
4
R6
5
47
0
R6
0
R
R6
8
47
0
1 2 3 4 5 6 7 8 9 10 11
J6
5
HE
AD
ER
1
1
R2
1
4K
7
R2
3
24
0
1 2 3 4 5
J5
6
IC
SP
R6
4
10
k
1
LK1
CON1
D1
1234
J6
6
HE
AD
ER
4
1
LK3
CON1
R5
9
10
k
R6
3
R
M
CL
R
1
RA
0-
A
N
0
2
RA
1-
A
N
1
3
RA
2-
A
N
2
4
RA
3-
A
N
3
5
RA
4
6
RA
5-
A
N
4
7
V
SS
8
O
SC
1
9
O
SC
2
10
RC
0
11
RC
1
12
RC
2
13
V
U
SB
14
D
- -
R
C4
15
D
+
- R
C5
16
TX
-
RC
6
17
SD
O
-
RX
-
RC
7
18
V
SS
19
V
D
D
20
SD
A
/I
- I
N
T0
-
A
N
12
-
RB
0
21
SC
L/
K
-
IN
T1
-
A
N
10
-
RB
1
22
IN
T2
-
A
N
8
- R
B2
23
A
N
9
- R
B3
24
A
N
11
-
RB
4
25
PG
M
-
RB
5
26
PG
C
- R
B6
27
PG
D
-
RB
7
28
M
CU
P1
8f
25
50
R6
7
47
0
1
LK4
CON1
R6
1
R
C8 4.
7u
V
IN
3
V
O
U
T
2
ADJ
1
U2
LM
31
7
1
LK5
CON1
C7
10
0u
1
LK2
CON1
W
ei
gh
t d
isp
M
ai
n
A
D
D
A
W
ei
gh
t d
isp
D
I
SH
_C
P
ST
_C
P
D
O S
H
_C
P
ST
_C
P
D
O
M
ai
n
A
D
D
A
Sp
ee
d
fro
m
IN
V
Sp
ee
d
fro
m
IN
V
Sp
ee
d
2
PI
C
Sp
ee
d
2
PI
C
M
CL
R
M
CL
R
S+ S-
S+ S
-
D
I
SH
_C
P
ST
_C
P
Ch
e
do
Ta
ng
G
ia
m
X
on
g
Ch
e
do
Ta
ng
G
ia
m
X
on
g
+1
0V
+1
2V
+1
0V
V
CC
V
CC
+1
2V
-1
2V
-1
2V
+1
2V
V
CC
V
CC
V
CC
V
CC
V
CC
+1
0V
T
ªn
s
¶n
p
hÈ
m
: C
B
09
05
04
PI
22
p5
01
PI
22
p5
02
CO
22
p5
PI
22
p60
1
PI
22
p60
2
CO
22
p6
PIC601 PIC602
CO
C6
PIC701 PIC702
CO
C7
PIC801 PIC802
CO
C8
PIC1101 PIC1102
CO
C1
1
PIC1201 PIC1202
CO
C1
2
PID101 PID102
CO
D1
PI
D5
90
1
PI
D5
90
2
C
O
D
59
P
I
J
5
6
0
1
P
I
J
5
6
0
2
P
I
J
5
6
0
3
P
I
J
5
6
0
4
P
I
J
5
6
0
5
CO
J5
6
P
I
J
6
5
0
1
P
I
J
6
5
0
2
P
I
J
6
5
0
3
P
I
J
6
5
0
4
P
I
J
6
5
0
5
P
I
J
6
5
0
6
P
I
J
6
5
0
7
P
I
J
6
5
0
8
P
I
J
6
5
0
9
P
I
J
6
5
0
1
0
P
I
J
6
5
0
1
1
CO
J6
5
P
I
J
6
6
0
1
P
I
J
6
6
0
2
P
I
J
6
6
0
3
P
I
J
6
6
0
4C
OJ
66
PILK101
COLK1
PILK201
COLK2
PILK301
COLK3
PILK401
COLK4
PILK501
COLK5
PILK601
COLK6
P
I
M
C
U
0
1
P
I
M
C
U
0
2
P
I
M
C
U
0
3
P
I
M
C
U
0
4
P
I
M
C
U
0
5
P
I
M
C
U
0
6
P
I
M
C
U
0
7
P
I
M
C
U
0
8
P
I
M
C
U
0
9
P
I
M
C
U
01
0
P
I
M
C
U
0
1
1
P
I
M
C
U
0
1
2
P
I
M
C
U
0
1
3
P
I
M
C
U
0
1
4
P
I
M
C
U
0
1
5
P
I
M
C
U
0
1
6
P
I
M
C
U
0
1
7
P
I
M
C
U
0
1
8
P
I
M
C
U
0
1
9
P
I
M
C
U
0
2
0
P
I
M
C
U
02
1
P
I
M
C
U
0
2
2
P
I
M
C
U
02
3
P
I
M
C
U
02
4
P
I
M
C
U
02
5
P
I
M
C
U
0
2
6
P
I
M
C
U
0
2
7
P
I
M
C
U
02
8
C
O
M
C
U
PIR2101 PIR2102
CO
R2
1
PIR2301PIR2302
CO
R2
3
PIR5901 PIR5902
CO
R5
9
PIR6001 PIR6002
CO
R6
0
PIR6101 PIR6102
C
O
R
61
PIR6201 PIR6202
C
O
R
62
PIR6301 PIR6302
CO
R6
3
PI
R6
40
1
PI
R6
40
2
CO
R6
4
PI
R65
01
PI
R65
02
CO
R6
5
PI
R6
60
1
PI
R6
60
2
CO
R6
6
PI
R6
70
1
PI
R6
70
2
CO
R6
7
PI
R6
80
1
PI
R6
80
2
CO
R6
8
PIS
W34
01
PIS
W34
02
C
O
S
W
3
4
PI
SW
350
1
PI
SW
35
02
C
O
S
W
3
5
PI
SW
360
1
PI
SW
36
02
C
O
S
W
3
6
PI
SW
370
1
PI
SW
37
02
C
O
S
W
3
7
PIU201
PI
U2
02
PI
U2
03C
OU
2
PIwr501
PI
wr
50
2
PIwr503
CO
wr
5
PIXtal12M501PIXtal12M502
CO
Xt
al
12
M5
PIC601
PIC701
P
I
J
6
5
0
1
PIR2101
PIR2302
PI
U2
02
PIC801
P
I
J
6
5
0
1
0
PI
U2
03
P
I
J
6
5
0
8 P
I
J
5
6
0
1
P
I
M
C
U
0
2
7
NLB
6
P
I
J
5
6
0
2
P
I
M
C
U
02
8
NL
B7
P
O
D
O
P
I
M
C
U
02
1
P
O
D
I
PI
22
p5
01
PI
22
p60
1
PIC602
PIC702
PIC802
PIC1102
PIC1202
PID102
P
I
J
5
6
0
3
P
I
J
6
5
0
2
P
I
J
6
5
0
6
P
I
J
6
5
0
1
1
P
I
M
C
U
0
1
9
PI
R6
40
2
PIS
W34
01
PI
SW
350
1
PI
SW
360
1
PI
SW
370
1
PIwr501
P
I
J
5
6
0
5N
LM
CL
R
PI
22
p5
02
P
I
M
C
U
0
9
PIXtal12M502
PI
22
p60
2
P
I
M
C
U
01
0
PIXtal12M501
PID101PIR2102
PI
D5
90
1
PIR5902
P
I
J
6
6
0
1
P
I
M
C
U
0
1
5P
I
J
6
6
0
2
P
I
M
C
U
0
1
6P
I
J
6
6
0
3
P
I
M
C
U
0
1
7P
I
J
6
6
0
4
P
I
M
C
U
0
1
8
PILK101P
ILK201PILK
301PILK401
PILK501PIL
K601
PI
D5
90
2
P
I
M
C
U
0
1
P
O
M
C
L
R
P
I
M
C
U
0
4
P
I
M
C
U
0
5
P
I
M
C
U
0
6
P
I
M
C
U
0
7
P
I
M
C
U
0
8
P
I
M
C
U
0
1
1
PI
R6
80
2
P
O
X
o
n
g
P
I
M
C
U
0
1
2
PI
R6
70
2
P
O
G
i
a
m
P
I
M
C
U
0
1
3
PI
R6
60
2
P
O
T
a
n
g
P
I
M
C
U
0
1
4
PI
R65
02
P
O
C
h
e
do
P
I
M
C
U
02
4
P
I
M
C
U
02
5
P
I
M
C
U
0
2
6
PI
R6
40
1
PIR2301
PIU201
PI
wr
50
2
PIwr503
PIR6002
PI
R65
01
PIS
W34
02
PIR6102
PI
R6
60
1
PI
SW
35
02
PIR6202
PI
R6
70
1
PI
SW
36
02
PIR6302
PI
R6
80
1
PI
SW
37
02
P
I
J
6
5
0
3
P
O
S
0
P
I
J
6
5
0
4
P
O
S
0
P
I
M
C
U
0
2
2
P
O
S
H
0
C
P
P
I
J
6
5
0
7
PO
Sp
ee
d
fr
om
I
NV
P
I
M
C
U
0
3
PO
Sp
ee
d
2
PI
C
P
I
M
C
U
02
3
P
O
S
T
0
C
P
P
I
J
6
5
0
5
PO
Ma
in
A
DD
A
P
I
M
C
U
0
2
PO
We
ig
ht
d
is
p
PIC1101
PIC1201
P
I
J
5
6
0
4
P
I
J
6
5
0
9
P
I
M
C
U
0
2
0
PIR5901
PIR6001
PIR6101
PIR6201
PIR6301
P
OC
HE
D
O
P
O
D
I
P
O
D
O
P
O
G
I
A
M
P
O
M
A
I
N
A
D
D
A
P
O
M
C
L
R
P
O
S
0
PO
SH
0C
P
PO
SP
EE
D
2
PI
C
PO
SP
EE
D
FR
OM
I
NV
PO
ST
0C
P
P
O
T
A
N
G
PO
WE
IG
HT
D
IS
P
P
O
X
O
N
G
H
ìn
h
3.
3:
T
hi
ết
kế
ch
i
ti
ết
ph
ần
cứ
ng
hệ
th
ốn
g
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.1 Thiết kế phần cứng hệ thống 21
3.1.1 Khối cảm biến
Sơ đồ khối cảm biến, không được thể hiện đầy đủ trong hình 3.3, thiết
kế đầy đủ khối cảm biến bao gồm: Loadcell, khuếch đại. Tín hiệu ra phải
ở dạng chuẩn công nghiệp: 0..10v [11]
R
RR
R
S+
S-
+10v
GND
Hình 3.4: Sơ đồ nguyên lý Loadcell
Hình 3.4 là sơ đồ nguyên lý của hầu hết các loại Loadcell. Bản chất
vấn đề chính là mạch cầu trở, theo sơ đồ đó, khi có một lực kéo hay nén
tác động lên Loadcell, cầu trở sẽ mất cân bằng, làm cho điện áp chảy
qua mạch thay đổi.
S+ và S- là hai đầu ra của mạch. Nếu cầu trở cân bằng thì VS+ = VS−,
khi cầu không cân bằng thì VS+ 6= VS−
Tín hiệu ra S+ và S- tùy thuộc vào mỗi lại Loadcell nhưng hầu hết trong
công nghiệp thường chọn loại 20mV/V, hoặc 4÷ 20mA. Có nghĩa là nếu
chúng ta dùng Loadcell loại 15 tấn, và chúng ta đặt khối lượng là 15 tấn
lên Loadcell thì đầu ra (vi sai) giữa S+ và S- là 20mv hoặc 20mA, còn
khi bỏ lửng Loadcell thì đầu ra là 0mV hay 4mA.
Theo những đặc tính trên thì ta thiết kế được một bộ khuếch đại, như
hình 3.5.
Trong sơ đồ 3.5, có đầy đủ các thành phần sao cho kết quả đầu ra
là 0..10V hoặc 0..5v, vì một số dòng chuyển đổi ADC mới hiện nay chỉ
chấp nhận tín hiệu đầu vào trước khi chuyển đổi là 0..5v.
Phân tích nguyên lý hoạt động của mạch: Chân S+ và S- là hai
tín hiệu vào từ Loadcell, trong quá trình truyền dẫn, có thể tín hiệu về
đến bộ khuếch đại không thực sự cân bằng, hoặc do khối lượng bì,... làm
cho tín hiệu về lệch sẵn một khoảng, vậy ta cần phải chỉnh cân bằng1
bởi WR1. Tín hiệu sau đó được lọc nhiễu sơ bộ rồi qua mạch khuếch đại
âm, lọc và khuếch đại đảo lại để lấy tín hiệu (+) tại đầu ra. Tín hiệu ra
1chỉnh cân bằng, hay còn gọi là chỉnh không, chỉnh zero
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.1 Thiết kế phần cứng hệ thống 22
1
1
2
2
3
3
4
4
DD
CC
BB
AA
*
HOLIA
No 103, Ga luu xa street
Phu xa
Thai Nguyen
Viet Nam *
*
**
7/31/200910:52:00 PM
D:\Cao hoc\LVTN\Pictures\CB090504\Khuech dai.SchDoc
Title
Size:Number:
Date:
File:
Revision:
Sheetof Time:
A4
Designed by TuÊn Anh. Website:
T3
R5
C3
R15
-
+
3
2
6
71
45
Sp1
1
2
3
wr2
1
2
3
wr5
R6 R4
R7
R12
C5
R3
-
+
10
9
8
4
11
U1C
R16
R10R11
C1
R8
1
2
3
wr4
R2
-
+
3
2
1
4
11
U1A
R13
C4
-
+
12
13
14
4
11
U1D
-
+
5
6
7
4
11
U1B
R1
1
2
3
WR1
C2
R14
1
2
3
WR3
R9
To PIC display
To Main ADDA
S-
S+
+12V
GND
-12V
Speed in
Speed to PIC
+10V
+10V
+12V
-12V
-12V
+12V
-12V
+12V
+10V
KhuÕch ®¹i
Max 10v
T4
H
ìn
h
3.
5:
Sơ
đồ
ng
uy
ên
lý
m
ạc
h
kh
uế
ch
đạ
i
L
oa
dc
el
l
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.1 Thiết kế phần cứng hệ thống 23
nằm trong dải 0..10v, được chia làm hai ngả: lặp 0..10v và giảm áp, lặp
xuống còn 0..5v [10]
Tín hiệu ra sẽ được đưa đến module chuyển đổi AD. Trong mạch còn dự
phòng sẵn một mạch lọc và lặp áp độc lập nhằm xác định vận tốc nếu
cần.
Khối này không có sự can thiệp của phần mềm.
3.1.2 Khối chuyển đổi ADC
Khối chuyển đổi AD (AD: Analog to Digital; ADC: Analog to Digital
Converter) có nhiều phương án thiết kế, song ta cần chọn phương án
đơn giản nhất, đảm bảo hiệu quả, tốc độ, độ ổn định và tương thích tín
hiệu với toàn hệ thống. Sơ đồ tổng thể nằm trên hình 3.3.
Sơ đồ này tổng hợp cả các module khác, vậy nên ta tách ra cho dễ nhìn,
như hình 3.6.
MCLR1
RA0-AN02
RA1-AN13
RA2-AN24
RA3-AN35
RA46
RA5-AN47
8
MCU
Weight disp
Speed 2 PIC
Hình 3.6: Sơ đồ nguyên lý khối AD
Khối ADC được nhúng vào vi điều khiển nên cần có thuật toán đọc
AD. Trong khối này, ta có đưa vào 2 tín hiệu là khối lượng và tốc độ.
Thuật toán đọc tín hiệu tương tự - số như hình 3.7.
Vi điều khiển ta chọn phải là loại tốc độ cao, trong họ vi điều khiển
8 bit, có vi mạch PIC18F4550. Vi điều khiển PIC18F4550 có tốc độ xử
lý lên đến 48MHz do vậy về tốc độ xử lý ta hoàn toàn yên tâm, không
cần lo lắng!
Chọn ngôn ngữ C để lập trình cho PIC, vì C là ngôn ngữ có cấu trúc
rất rõ ràng, và sát với ngôn ngữ bậc thấp, hỗ trợ nhiều thư viện,....
Theo thuật toán trên, ta viết phần mềm nhúng cho PIC, chương trình
con đọc dữ liệu ADC như sau: Mã nguồn:
unsigned int ADC_Read(unsigned char ch){
unsigned int value=0;
setup_adc( ADC_CLOCK_INTERNAL );
setup_adc_ports( ALL_ANALOG );
set_adc_channel(ch);
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.1 Thiết kế phần cứng hệ thống 24
Begin ADC
Kênh cần đọc: ch
- Chọn kênh (ch)
- Phát tín hiệu bắt đầu chuyển đổi
Chuyển đổi xong ?
_
- Đọc tín hiệu số
+
Tín hiệu số
END
Hình 3.7: Sơ đồ thuật toán đọc ADC
value = read_adc();
return value;
}
Ví dụ sau dùng để kiểm tra sự hoạt động của ADC:
#include
unsigned int adc_rd;
void main() {
TRISA = 0xFF; // PORTA is input
ANSEL = 0x07; // Configure as analog
TRISC = 0x00; // Pins PORTC are outputs
TRISB = 0x00; // PORTB is output
do {
temp_res = ADC_Read(2); // Get results of AD conversion
PORTB = temp_res; // Send lower 8 bits to PORTB
PORTC = temp_res >> 8; // Send most significant bits to PORTC
} while(1);
}
Mạch hiển thị
Trong khối này (hình 3.8), còn cần phải có hiển thị thông tin, các thông
tin đọc được từ khối cảm biến sẽ được thể hiện trên khối hiển thị và
truyền lên PC.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.1 Thiết kế phần cứng hệ thống 25
Nguyên lý hoạt động của khối này là dùng phương pháp chuyển đổi tín
hiệu nối tiếp sang song song, dựa trên thanh di dịch 74595. Phương pháp
này rất hay, ở chỗ là nó có thể vừa là bộ chuyển đổi nối tiếp sang song
song, vừa là bộ chốt đệm dữ liệu hiển thị, làm cho ảnh hiển thị tĩnh và
sáng đều.
A
B
C
D
E
F
G
H
A
4
B
5
C
9
D
7
E
6
F
2
G
1
H
10
+2
,5
v
8
+2
.5
v
3Led8
LE
D
7
T
H
A
N
H
(
D
O
N
,
12
.5
X
19
)
R25
270R
R26
270R
A
B
C
D
E
F
G
H
A
4
B
5
C
9
D
7
E
6
F
2
G
1
H
10
+2
,5
v
8
+2
.5
v
3Led6
LE
D
7
T
H
A
N
H
(
D
O
N
,
12
.5
X
19
)
G
N
D
8
SDO 9
C
L
R
10
O
E
13
SDI14
V
C
C
16
SH
_C
P
11
ST
_C
P
12
Q
A
15
Q
B
1
Q
C
2
Q
D
3
Q
E
4
Q
F
5
Q
G
6
Q
H
7
U7
74hc595
R27
270R
G
N
D
8
SDO 9
C
L
R
10
O
E
13
SDI14
V
C
C
16
SH
_C
P
11
ST
_C
P
12
Q
A
15
Q
B
1
Q
C
2
Q
D
3
Q
E
4
Q
F
5
Q
G
6
Q
H
7
U8
74hc595
R24
270R
A
B
C
D
E
F
G
H
A
4
B
5
C
9
D
7
E
6
F
2
G
1
H
10
+2
,5
v
8
+2
.5
v
3Led7
LE
D
7
T
H
A
N
H
(
D
O
N
,
12
.5
X
19
)A
B
C
D
E
F
G
H
A
4
B
5
C
9
D
7
E
6
F
2
G
1
H
10
+2
,5
v
8
+2
.5
v
3Led5
LE
D
7
T
H
A
N
H
(
D
O
N
,
12
.5
X
19
)
G
N
D
8
SDO 9
C
L
R
10
O
E
13
SDI14
V
C
C
16
SH
_C
P
11
ST
_C
P
12
Q
A
15
Q
B
1
Q
C
2
Q
D
3
Q
E
4
Q
F
5
Q
G
6
Q
H
7
U9
74hc595
G
N
D
8
SDO 9
C
L
R
10
O
E
13
SDI14
V
C
C
16
SH
_C
P
11
ST
_C
P
12
Q
A
15
Q
B
1
Q
C
2
Q
D
3
Q
E
4
Q
F
5
Q
G
6
Q
H
7
U6
74hc595
ST_CP
SH_CP
DO
VCC
GND
DI
SDI3
SH
_C
P
ST
_C
P
SDI2
SH
_C
P
SDI4
ST
_C
P
SDI3
SH
_C
P
ST
_C
P
SDI4
SDI2
SH
_C
P
ST
_C
P
VCC
VCC
VCC
VCC
VCC
VCC
VCC
VCC
VCC
PILed501 PILed502
PILed503
PILed504 PILed505 PILed506PILed507
PILed508
PILed509PILed5010
COLed5
PILed601 PILed602
PILed603
PILed604 PILed605 PILed606PILed607
PILed608
PILed609PILed6010
COLed6
PILed701 PILed702
PILed703
PILed704 PILed705 PILed706PILed707
PILed708
PILed709PILed7010
COLed7
PILed801 PILed802
PILed803
PILed804 PILed805 PILed806PILed807
PILed808
PILed809PILed8010
COLed8
PIR2401
PIR2402
COR24
PIR2501
PIR2502
COR25
PIR2601
PIR2602
COR26
PIR2701
PIR2702
COR27
PIU601 PIU602 PIU603 PIU604 PIU605 PIU606 PIU607
PIU608
PIU609
PIU6010PIU6011 PIU6012 PIU6013
PIU6014
PIU6015
PIU6016
COU6
PIU701 PIU702 PIU703 PIU704 PIU705 PIU706 PIU707
PIU708
PIU709
PIU7010PIU7011 PIU7012 PIU7013
PIU7014
PIU7015
PIU7016
COU7
PIU801 PIU802 PIU803 PIU804 PIU805 PIU806 PIU807
PIU808
PIU809
PIU8010PIU8011 PIU8012 PIU8013
PIU8014
PIU8015
PIU8016
COU8
PIU901 PIU902 PIU903 PIU904 PIU905 PIU906 PIU907
PIU908
PIU909
PIU9010PIU9011 PIU9012 PIU9013
PIU9014
PIU9015
PIU9016
COU9
PO D
POS 0CP
POS 0CP
PO I POSDI2 POSDI3
PODO
POSDI4
POV C
PO PO 3 PO 4
POSH0CPPOST0CP
Hình 3.8: Sơ đồ nguyên lý mạch hiển thị
Hình 3.9: Mạch hiển thị khối lượng và tốc độ
Chương trình con hiển thị dữ liệu từ bộ đệm ra LED 7 thanh:
// Display Buffer array to LED
void LED7Display(){
const int8 L7[12]={
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.1 Thiết kế phần cứng hệ thống 26
0x88,0xEB,0x4C,0x49,0x2B,0x19,0x18,0xCB,0x8,0x9,0x7F,0xFF
};
#define black 11
#define negative 10
#define clock {output_bit(SH_CP,0);output_bit(SH_CP,1);}
#define out1bit output_bit(DI,buffer[k]&1);
#define ST_CP PIN_B2
#define SH_CP PIN_B1
#define DI PIN_B0
int8 k,k1,so0;
buffer[7]=L7[(W /1000)%10];
buffer[6]=L7[(W / 100)%10];
buffer[5]=L7[(W / 10)%10];
buffer[4]=L7[(W )%10];
buffer[3]=L7[(SP/1000)%10];
buffer[2]=L7[(SP/ 100)%10];
buffer[1]=L7[(SP/ 10)%10];
buffer[0]=L7[(SP )%10];
so0=1;
if((buffer[7]==L7[0])&&(so0)){buffer[7]=L7[black];}else so0=0;
if((buffer[6]==L7[0])&&(so0)){buffer[6]=L7[black];}else so0=0;
if((buffer[5]==L7[0])&&(so0)){buffer[5]=L7[black];}
so0=1;
if((buffer[3]==L7[0])&&(so0)){buffer[3]=L7[black];}else so0=0;
if((buffer[2]==L7[0])&&(so0)){buffer[2]=L7[black];}else so0=0;
if((buffer[1]==L7[0])&&(so0)){buffer[1]=L7[black];}
for(k=0;k<8;k++){
for(k1=0;k1<8;k1++){
out1bit clock buffer[k]>>=1;
}}
output_bit(ST_CP,0);
output_bit(ST_CP,1);
}
Hình 3.10: Bàn phím chỉnh tham số gốc
Phím bấm
Phím bấm dùng để nhập các thông
tin đầu vào ngay trên khối chuyển
đổi, có thể nhập các tham số như
thay đổi số lượng mẫu cần lấy, calib
động, bù nhiệt,... Để đọc được giá trị
của phím bấm, ta sử dụng thuật toán
quét từng hàng và đọc từng cột, nếu
có sự khác biệt so với mặc định là có
phím được bấm.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.1 Thiết kế phần cứng hệ thống 27
3.1.3 Khối truyền thông
Khối truyền thông sẽ được thiết kế sao cho hoạt động nhanh nhất, ít lỗi
nhất đảm bảo được truyền thông với lượng mẫu theo yêu cầu của thuật
toán.
Có rất nhiều phương pháp lựa chọn truyền thông, như truyền thông
RS232, RS485, ProfiBus,.... Nhưng cách hợp lý nhất chính là truyền
thông USB. Sơ đồ ghép nối như hình 3.11, trong đó, cap truyền thông
không nên vượt quá 15m [15]
Hình 3.11: Truyền thông USB
Để truyền thông được qua giao thức USB, chúng ta dùng chuẩn HID,
tốc độ hoạt động của chip phải là 48MHz (với truyền thông USB 2.0,
full speed) [14]
Phần mềm nhúng truyền thông USB, cần có các hàm: Hid Enable,
Hid Read, Hid Write, Hid Disable.
Với cấu trúc:
Hid Enable
Khai báo: void Hid Enable(unsigned readbuff, unsigned writebuff);
Trả về: không
Diễn tả: Cho phép giao tiếp USB HID. Tham số readbuff và writebuff
là Buffer Đọc và Viết Buffer, tương ứng, mà được sử dụng để giao tiếp
HID.
Chức năng này cần phải được gọi trước khi sử dụng các hàm khác của
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.1 Thiết kế phần cứng hệ thống 28
thư viện USB HID.
Yêu cầu: Không
Ví dụ: Hid Enable(&rd, &wr);
Hid Read
Khai báo: unsigned char Hid Read(void);
Trả về: Số lượng các ký tự trong Đọc Buffer nhận được từ các máy chủ.
Diễn tả: Nhận được tin nhắn từ máy chủ và lưu nó trong bộ đệm đọc.
Hàm trả về số lượng các ký tự nhận được trong bộ đệm đọc.
Yêu cầu: USB HID cần phải được kích hoạt trước khi sử dụng chức năng
này.
Ví dụ: get = Hid Read();
Hid Write
Khai báo: unsigned short Hid Write(unsigned writebuff, unsigned short
len);
Trả về: Nếu việc truyền dữ liệu đã không thành công, hàm trả về 0. Nếu
không, nó trả về số lượng byte truyền được
Diễn tả: Hàm gửi dữ liệu từ Buffer Viết writebuff đến máy chủ. Viết
Buffer có cùng một tham số như được sử dụng trong khởi tạo; xem
Hid Enable. Len tham số cần để xác định chiều dài của dữ liệu sẽ được
truyền
Yêu cầu: USB HID cần phải được kích hoạt trước khi sử dụng chức năng
này.
Ví dụ:
// Thử đến khi thành công:
while (!HID Write(writebuff, 1));
Hid Disable
Khai báo: void Hid Disable(void);
Trả về: không
Diễn tả: Ngắt giao tiếp USB
Yêu cầu: USB HID cần phải được kích hoạt trước khi sử dụng chức năng
này.
Ví dụ: Hid Disable();
Đoạn mã nguồn dùng để kiểm tra việc truyền thông:
Ví dụ sau liên tục gửi các số 0 .. 255 đến PC qua USB(Universal Serial Bus). usbdsc.c phải được bao
gồm trong dự án.
unsigned short m, k;
unsigned short userRD_buffer[64];
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.1 Thiết kế phần cứng hệ thống 29
unsigned short userWR_buffer[64];
void interrupt() {
asm CALL _Hid_InterruptProc
asm nop
}
void Init_Main() {
// Disable all interrupts
// Disable GIE, PEIE, TMR0IE, INT0IE,RBIE
INTCON = 0;
INTCON2 = 0xF5;
INTCON3 = 0xC0;
// Disable Priority Levels on interrupts
RCON.IPEN = 0;
PIE1 = 0;
PIE2 = 0;
PIR1 = 0;
PIR2 = 0;
// Configure all ports with analog function as digital
ADCON1 |= 0x0F;
// Ports Configuration
TRISA = 0;
TRISB = 0;
TRISC = 0xFF;
TRISD = 0xFF;
TRISE = 0x07;
LATA = 0;
LATB = 0;
LATC = 0;
LATD = 0;
LATE = 0;
// Clear user RAM
// Banks [00 .. 07] ( 8 x 256 = 2048 Bytes )
asm {
LFSR FSR0, 0x000
MOVLW 0x08
CLRF POSTINC0, 0
CPFSEQ FSR0H, 0
BRA $ - 2
}
// Timer 0
T0CON = 0x07;
TMR0H = (65536-156) >> 8;
TMR0L = (65536-156) & 0xFF;
INTCON.T0IE = 1; // Enable T0IE
T0CON.TMR0ON = 1;
}
/** Main Program Routine **/
void main() {
Init_Main();
Hid_Enable(&userRD_buffer, &userWR_buffer);
do {
for (k = 0; k < 255; k++) {
// Prepare send buffer
userWR_buffer[0] = k;
// Send the number via USB
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2] 30
Hid_Write(&userWR_buffer, 1);
}
} while (1);
Hid_Disable();
}
//————————————————-
3.1.4 Khối nguồn
Khối nguồn là khối cần đến sự ổn định của điện áp, đảm bảo điện áp
đúng thiết kế để cung cấp cho toàn bộ mạch. Khối nguồn được thiết kế
theo sơ đồ hình 3.12[15] .
Hình 3.12: Khối nguồn
Nguồn ở đây đã là nguồn điện áp thấp, đầu vào sau bộ biến áp có giá
trị từ 8-16v, qua nắn dòng bởi diode mắc hình cầu.
Nếu cần nguồn có mức điện áp khác, ta có thể dùng LM78xx (giá trị
điện áp ra sau ổn áp, ví dụ: 05, 08, 12,..) với điện áp dương và LM79xx
với điện áp âm, trong đó có thể dùng nguồn máy tính.
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2]
Phần mềm là một sản phẩm được phát triển hay được kỹ nghệ hoá và
được chế tạo tương tự như các sản phẩm công nghiệp (phần cứng) khác.
Phát triển phần mềm và chế tạo phần cứng cũng có những điểm tương
đồng: đều là sản phẩm và chất lượng của chúng phụ thuộc nhiều vào
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2] 31
Hình 3.13: Mô phỏng tín hiệu điện của khối nguồn
thiết kế, hơn nữa lại phụ thuộc cơ bản vào con người. Tuy nhiên phần
mềm và phần cứng lại có nhiều điểm đặc trưng rất khác nhau.
• Qui trình và phương pháp tổ chức thực hiện để sản xuất ra chúng
rất khác nhau,
• Các giai đoạn chế tạo ra phần cứng có thể xác định và có khả năng
điều chỉnh được chất lượng của sản phẩm còn đối với phần mềm thì
không dễ gì thay đổi được,
• Mối quan hệ giữa người sử dụng và công việc cần thực hiện với từng
loại sản phẩm là hoàn toàn khác nhau,
• Cách tiếp cận để xây dựng, chế tạo các sản phẩm cũng khác nhau.
Khả năng nhân bản của chúng là hoàn toàn trái ngược nhau. Việc
bảo vệ bản quyền sản phẩm phần mềm là cực kỳ khó khăn vì khả
năng sao chép thành nhiều bản giống nhau là có thể thực hiện được
(tương đối dễ).
• Phần mềm khác hẳn với phần cứng là không bị hư hỏng theo thời
gian, không bị tác động của môi trường (thời tiết, nhiệt độ, điều
kiện, v.v. . . ). Do vậy, đối với phần cứng việc bảo hành là đảm bảo
nó hoạt động được như mới còn đối với phần mềm thì lại khác hẳn.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2] 32
Bảo hành, bảo trì phần mềm là bảo đảm cho hệ thống hoạt động
đúng với thiết kế và đáp ứng yêu cầu sử dụng của khách hàng. Chính
vì thế mà công bảo hành phần mềm là rất tốn kém, do đó đòi hỏi
phải tập trung nhiều hơn vào khâu phân tích, thiết kế hệ thống.
Mọi hệ thống phần mềm cũng như các hệ thống khác không thể tồn tại
độc lập mà nó luôn hoạt động và tồn tại trong một môi trường, tương
tác với thế giới xung quanh. Như vậy, một hệ thống có thể xem như là
hệ thống con của một hệ thống khác và bản thân nó lại có thể chứa một
số các hệ thống con khác nhỏ hơn.
Công nghệ phần cứng phát triển nhanh cả về chất lượng và tốc độ xử
lý với giá thành ngày một hạ trong khi giá phần mềm lại rất cao. Để
phát triển được những hệ thống phần mềm đáp ứng được những yêu cầu
trên thì đòi hỏi phải áp dụng lý thuyết, kỹ nghệ, phương pháp và công
cụ mới để tạo ra một qui trình phát triển phần mềm thống nhất. Như
vậy, công nghệ phần mềm (CNPM) là đề cập đến các lý thuyết, phương
pháp luận và các công cụ cần thiết để phát triển phần mềm. Mục đích
của CNPM là làm ra những phần mềm chất lượng cao, tin cậy với một
hạn chế về nguồn lực, theo đúng một lịch trình đặt trước, phù hợp với
ngân sách dự kiến và đáp ứng các yêu cầu người dùng. Hơn nữa, CNPM
không chỉ là phải làm ra hệ thống phần mềm mà phải làm được các hồ
sơ, tài liệu như các tài liệu thiết kế, tài liệu hướng dẫn sử dụng, v.v. làm
cơ sở để bảo trì và mở rộng, phát triển hệ thống sau này.
Tóm lại, để xây dựng được những hệ thống phần mềm đáp ứng những
yêu cầu trên, chúng ta cần phải:
• Có một qui trình phát triển phần mềm thống nhất gồm các bước
thực hiện rõ ràng, mà sau mỗi bước đều phải có các sản phẩm cụ
thể;
• Có các phương pháp và kỹ nghệ phù hợp với từng pha thực hiện
phát triển phần mềm;
• Có công cụ để làm ra sản phẩm phần mềm theo yêu cầu.
3.2.1 Khảo sát, xác định các yêu cầu
Công tác khảo sát và xác định yêu cầu đã nêu rất kỹ trong chương 1. Ở
đây chỉ chú trọng đến thiết kế phần mềm.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2] 33
3.2.2 Phân tích hệ thống
Từ yêu cầu của công ty về các thông tin cần có của mỗi chuyến hàng,
và từ các mẫu biểu thu được trong quá trình khảo sát, ta đưa ra được
các thông tin cần thiết sau:
STT Tên trường Ghi chú
1 Số hiệu đoàn tàu
2 Lần cân thứ
3 mã toa
4 Tốc độ km/h
5 Loại than
6 Khối lượng tổng kg
7 Khối lượng bì kg
8 Khối lượng than kg
9 Vận tốc Max
10 Vận tốc min
11 Người vận hành
12 Địa điểm giao nhận
13 Đơn vị giao hàng
14 Đơn vị nhận hàng
15 Đơn vị giám định
16 Thời gian Thời gian tại thời điểm cân
3.2.3 Thiết kế hệ thống
Thiết kế hệ thống được thực hiện lần lượt theo các bước sau:
• Mô tả bài toán
• Biểu đồ ca sử dụng
• Biểu đồ lớp
• Biểu đồ trình tự
• Biểu đồ cộng tác
• Thiết kế lớp chi tiết
• Biểu đồ thành phần
• Biểu đồ triển khai
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2] 34
Dưới đây, chúng ta phát triển hệ thống từng bước:
1. Mô tả bài toán:
Hệ thống cân động gồm có 4 bộ phận chính: Bộ phận bán hàng, bộ
phận mua hàng, bộ phận cân, giám định và hệ thống phần cứng +
phần mềm đáp ứng các yêu cầu cân động.
Bộ phận bán hàng có nhiệm vụ cung cấp than theo yêu cầu của bên
mua hàng, khi tàu cập trạm, cần có một tổ chịu trách nhiệm xúc
than đầy các toa. Xuất hoá đơn bán hàng cùng phiếu cân có xác
nhận của tổ giám định hai bên.
Bộ phận mua hàng có nhiệm vụ thanh toán theo hoá đơn đã được
thoả thuận trước. Bốc dỡ than xuống khỏi tàu. Cử cán bộ giám định
để giám định cùng với bên bán than tại cị trí cân.
Hệ thống của chúng ta gồm cả phần cứng và phần mềm. Nên việc
xây dựng hệ thống phần mềm cần gắn liền với hệ thống phần cứng.
Người vận hành có thể phải hiểu được cách vận hành của cả phần
cứng lẫn phần mềm.
Bộ phận dám định chính là cán bộ của phòng KCS của cả hai công
ty. Bộ phận này có nhiệm vụ là xác định những thông tin ghi trên
phiếu cân là chính xác.
Hệ thống phần cứng và phần mềm có nhiệm vụ: khi tàu đến bàn
cân, cần xác định được tàu đi theo hướng nào (Hướng từ ga đi có
hàng hay hướng về ga không hàng), xác định được đầu tàu, xác định
được khối lượng của từng toa, xác định được mã toa, xác định được
toa rỗng,....
Khi tàu đến bàn cân, Loadcell dưới gầm của ray sẽ chịu trách nhiệm
chuyển khối lượng của các toa tàu thành tín hiệu điện vi sai trong
thời gian thực, và tỷ lệ với khối lượng của toa.
Tín hiệu điện vi sai được chuyển đến bộ khuếch đại tín hiệu theo
chuẩn đầu vào của hệ thống chuyển đổi ADC, lọc nhiễu rồi đưa
thẳng đến bộ chuyển đổi ADC.
Bộ chuyển đổi ADC có chức năng chuyển tín hiệu điện tương tự
thành tín hiệu số, đóng gói rồi truyền về máy tính.
Máy tính nhận dữ liệu, giải mã rồi đưa vào modul lọc nhiễu, rồi đưa
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2] 35
đến bộ nhớ chung. Trong bộ nhớ chung, có nhiều tiến trình chia sẻ
thông tin này, như: tính khối lượng, hiển thị lên giao diện,...Bước
cuối cùng là lưu dữ liệu vào CSDL.
Khi người vận hành yêu cầu báo cáo, hệ thống sẽ lấy dữ liệu tại
CSDL theo truy vấn của người vận hành, điền vào phiếu cân và in
ra theo yêu cầu
Nếu cần báo cáo theo tháng, theo quý, theo năm, hệ thống sẽ dựa
theo truy vấn và tính toán rồi đưa ra kết quả tổng kết.
2. Biểu đồ ca sử dụng:
• Các tác nhân : Bằng những khảo sát hệ thống theo thực tế,
quá trình xây dựng và thiết kế tổng thể hệ thống, ta xác định
được các tác nhân như sau:
– Bên bán hàng: Có trách nhiệm cung cấp hàng theo nhu cầu
bên mua .
– Bên mua hàng: Nhận hàng từ bên bán, trả tiền theo hợp đồng.
– Hệ thống cân: Xác định chính xác lượng hàng hoá vận chuyển
qua.
– Bên giám định: Xác định, thống nhất thông tin giữa hệ thống,
bên bán và bên mua.
• Các ca sử dụng : chúng ta xác định ca sử dụng (những công
việc) hệ thống cần phải thực hiện như sau:
– Tàu chạy vào bàn cân: lái tàu cần cho tàu chạy đúng vận tốc
quy định (từ 3km/h đến 15km/h).
– In phiếu cân: in phiếu cân hiện tại của chuyến tàu vừa đi qua.
– Vấn tin: truy vấn thông tin theo ngày, tuần, quý, năm để phục
vụ thống kê.
• Biểu đồ ca sử dụng: Qua cách phân tích như trên, ta có biểu
đồ ca sử dụng như hình 3.14.
3. Biểu đồ lớp:
• Xác định các lớp đối tượng:
Trên cơ sở phân tích các hoạt động của hệ thống cân động, chúng
ta dễ nhận thấy có những lớp đối tượng sau:
– Cảm biến: chuyển đổi khối lượng thành tín hiệu số tỷ lệ thuận.
Khi tàu đến, cần chuyển đổi tín hiệu trọng lượng thành tín
hiệu số và truyền lên máy tính. Trong khâu này cần thi hành
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2] 36
Thống kê
tháng
In phiếu cân Tính khối
lượng
Chuyển ñổi
Nhân
viên
vận
hành
Tàu và
nhân
viên
lái tàu
Hình 3.14: Biểu đồ ca sử dụng
các nhiệm vụ: nếu tàu đến (trọng lượng vượt ngưỡng) thì bắt
đầu đọc liên tục tín hiệu từ đầu cân, chuyển đổi thành tín
hiệu số, đóng gói thành dạng tin ngắn nhất, an toàn nhất,
khả năng phát hiện lỗi cao và nhanh nhất, rồi truyền lên máy
tính.
– Truyền thông : trên phần mềm, module này có nhiệm vụ nhận
tín hiệu được truyền lên từ phần nhúng, giải mã tín hiệu, kiểm
tra lỗi, lọc nhiễu và đưa tín hiệu vào bộ nhớ chung.
– Thuật toán: module này áp dụng một thuật toán tối ưu cho
bài toán này, tính toán khối lượng từ thông tin nhận được tại
bộ nhớ chung, xác định có bao nhiêu toa, mỗi toa bao nhiêu
kg, tính vận tốc của tàu, hướng tàu. Trả lại kết quả cho bộ
nhớ chung.
– Trung tâm: tính toán khối lượng tổng, xác định vận tốc max,
min, toa rỗng, đầu tàu; lưu thông tin vào CSDL
– Màn hình: lấy thông tin từ bộ nhớ chung để hiển thị lên giao
diện.
– Báo cáo: căn cứ vào câu truy vấn, theo thông tin từ bộ nhớ
chung (nếu truy vấn dữ liệu hiện tại) và CSDL, module này
sẽ tìm kiếm và điền đầy đủ thông tin cho báo cáo.
• Biểu đồ lớp và mối quan hệ giữa các lớp: được chỉ rõ như
hình 3.15.
4. Biểu đồ trình tự: Để hiểu rõ hoạt động của hệ thống, với mỗi ca sử
dụng cần phải xây dựng biểu đồ trình tự mô tả việc trao đổi thông
điệp giữa các đối tượng theo trục thời gian.
• Cập nhật thông tin: Bình thường, khi không có tàu, hệ thống
làm việc dạng dò thông tin. Mỗi khi tàu đến gần, mức tín hiệu
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2] 37
Hình 3.15: Biểu đồ lớp
vượt ngưỡng, hệ thống bắt đầu làm việc hết công suất. Liên tục
chuyển đổi ADC (phần chuyển đổi tín hiệu tương tự vi sai sang
điện áp tương tự theo chuẩn của bộ ADC + lọc nhiễu đã có phần
cứng đảm nhiệm), đóng gói và truyền lên máy tính. Máy tính liên
tục cập nhật thông tin mới vào bộ nhớ chung; được diễn tả theo
hình 3.16.
Hình 3.16: Biểu đồ trình tự: "Cập nhật thông tin"
• Khi in thông tin, có 2 lý do để in là in phiếu cân của chuyến gần
nhất và in báo cáo, được mô tả như hình 3.17.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2] 38
Hình 3.17: Biểu đồ trình tự: "In phiếu cân"
5. Biểu đồ cộng tác:
Tương tự như biểu đồ trình tự, biểu đồ cộng tác tập trung mô tả
sự trao đổi tương tác giữa các đối tượng theo ngữ cảnh công việc,
không quan tâm tới yêu tố thời gian.
Biểu đồ cộng tác cho hệ thống được mô tả như hình 3.18
Hình 3.18: Biểu đồ cộng tác
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2] 39
6. Thiết kế lớp chi tiết:
Nhiệm vụ tiếp theo là xác định các thuộc tính và các thao tác của
các lớp đối tượng trong biểu đồ 3.15.
• Các thuộc tính được xác định thông qua việc phân tích các chức
năng và nhiệm vụ mà mỗi đối tượng phải thực hiện.
• Các thao tác: dựa chủ yêu vào các biểu đồ trình tự, biểu đồ cộng
tác và các mẫu gán trách nhiệm để xác định.
Từ hai cách thực hiện như trên chúng ta có biểu đồ lớp chi tiết như
hình 3.19.
Hình 3.19: Biểu đồ lớp chi tiết
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2] 40
3.2.4 Lập trình và kiểm tra hệ thống
Qua quá trình phân tích bài toán trên đây, ta có thể xây dựng được một
hệ thống hoàn hảo, gồm cả phần cứng, phần mềm nhúng và phần mềm.
Để xây dựng phần cứng, ta phải nắm rõ thêm được một số phần mềm
CAD (Computer-Aided Design) như Altium Designer, OrCAD,...[9] nhằm
xây dựng mạch in cho hệ thống. Sau khi thiết kế mạch in, sản phẩm của
chúng ta có thể như hình 3.20
CB090504
Hình 3.20: Mạch in thành phẩm
Phần mềm nhúng được lập trình trên nền vi điều khiển họ PIC, đoạn
mã nguồn có thể như sau:
Mã nguồn của đoạn chương trình đọc ADC:
unsigned int ReadADC(unsigned char ch){
unsigned int value=0;
setup_adc( ADC_CLOCK_INTERNAL );
setup_adc_ports( ALL_ANALOG );
set_adc_channel(ch);
value = read_adc();
return value;
}
Mã nguồn đoạn chương trình thiết lập và thử nghiệm truyền thông:
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2] 41
unsigned short m, k;
unsigned short userRD_buffer[64];
unsigned short userWR_buffer[64];
void interrupt() {
asm CALL _Hid_InterruptProc
asm nop
}
void Init_Main() {
// Disable all interrupts
// Disable GIE, PEIE, TMR0IE, INT0IE,RBIE
INTCON = 0;
INTCON2 = 0xF5;
INTCON3 = 0xC0;
// Disable Priority Levels on interrupts
RCON.IPEN = 0;
PIE1 = 0;
PIE2 = 0;
PIR1 = 0;
PIR2 = 0;
// Configure all ports with analog function as digital
ADCON1 |= 0x0F;
// Ports Configuration
TRISA = 0;
TRISB = 0;
TRISC = 0xFF;
TRISD = 0xFF;
TRISE = 0x07;
LATA = 0;
LATB = 0;
LATC = 0;
LATD = 0;
LATE = 0;
// Clear user RAM
// Banks [00 .. 07] ( 8 x 256 = 2048 Bytes )
asm {
LFSR FSR0, 0x000
MOVLW 0x08
CLRF POSTINC0, 0
CPFSEQ FSR0H, 0
BRA $ - 2
}
// Timer 0
T0CON = 0x07;
TMR0H = (65536-156) >> 8;
TMR0L = (65536-156) & 0xFF;
INTCON.T0IE = 1; // Enable T0IE
T0CON.TMR0ON = 1;
}
/** Main Program Routine **/
void main() {
Init_Main();
Hid_Enable(&userRD_buffer, &userWR_buffer);
do {
for (k = 0; k < 255; k++) {
// Prepare send buffer
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2] 42
userWR_buffer[0] = k;
// Send the number via USB
Hid_Write(&userWR_buffer, 1);
}
} while (1);
Hid_Disable();
}
Mã nguồn đoạn chương trình hiển thị LED 7 thanh:
// Display Buffer array to LED
void LED7Display(){
const int8 L7[12]={
0x88,0xEB,0x4C,0x49,0x2B,0x19,0x18,0xCB,0x8,0x9,0x7F,0xFF
};
#define black 11
#define negative 10
#define clock {output_bit(SH_CP,0);output_bit(SH_CP,1);}
#define out1bit output_bit(DI,buffer[k]&1);
#define ST_CP PIN_B2
#define SH_CP PIN_B1
#define DI PIN_B0
int8 k,k1,so0;
buffer[7]=L7[(W /1000)%10];
buffer[6]=L7[(W / 100)%10];
buffer[5]=L7[(W / 10)%10];
buffer[4]=L7[(W )%10];
buffer[3]=L7[(SP/1000)%10];
buffer[2]=L7[(SP/ 100)%10];
buffer[1]=L7[(SP/ 10)%10];
buffer[0]=L7[(SP )%10];
so0=1;
if((buffer[7]==L7[0])&&(so0)){buffer[7]=L7[black];}else so0=0;
if((buffer[6]==L7[0])&&(so0)){buffer[6]=L7[black];}else so0=0;
if((buffer[5]==L7[0])&&(so0)){buffer[5]=L7[black];}
so0=1;
if((buffer[3]==L7[0])&&(so0)){buffer[3]=L7[black];}else so0=0;
if((buffer[2]==L7[0])&&(so0)){buffer[2]=L7[black];}else so0=0;
if((buffer[1]==L7[0])&&(so0)){buffer[1]=L7[black];}
for(k=0;k<8;k++){
for(k1=0;k1<8;k1++){
out1bit clock buffer[k]>>=1;
}}
output_bit(ST_CP,0);
output_bit(ST_CP,1);
}
Đoạn mã nguồn nhận dữ liệu trên PC:
private void COM1_DataReceived(object sender,
System.IO.Ports.SerialDataReceivedEventArgs e)
{
try
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2] 43
{
startByte = COM1.ReadByte();
str = COM1.ReadTo("\n").ToString();
//startByte = Convert.ToSByte(str.Substring(0, 1));
DAT[dau] = str;
if (++dau > Nmax) dau = 0;
blink = !blink;
}
catch { }
}
Đoạn chương trình xác định khối lượng toa tàu và lưu dữ liệu lên file:
private void timer1_Tick(object sender, EventArgs e)
{
com_data_receiv.Visible = blink;
if (mathe != "") { mathe_lst.Items.Insert(0,mathe.Substring
(0,mathe.Length -1)); mathe = ""; }
if (cuoi != dau)
{
while (cuoi != dau)
{
if (DAT[cuoi].Length >7)
{
A_old = A; B_old = B;
Conv(DAT[cuoi], out A, out B);
A += Convert.ToInt32(Zero1_txt.Text);
B += Convert.ToInt32(Zero2_txt.Text);
Can1_disp.Text = A.ToString();
Can2_disp.Text = B.ToString();
if (A > 30000) A = A_old;
if (B > 30000) B = B_old;
//-------------------------------------------------------
switch (startByte)
{
case 1: // data
TrongTruc_old1 = TrongTruc1;
TrongTruc_old2 = TrongTruc2;
vuotnguong_buf1[vuotnguong_buf1_cnt] =
A > Convert.ToUInt16(NguongKohang_txt.Text);
if (Huongtau_lbl.Text.Equals("Từ ga đi"))
vuotnguong_buf1[vuotnguong_buf1_cnt] =
A > Convert.ToUInt16(NguongCoHang_txt.Text);
vuotnguong_buf2[vuotnguong_buf2_cnt] =
B > Convert.ToUInt16(NguongKohang_txt.Text);
if (Huongtau_lbl.Text.Equals("Từ ga đi"))
vuotnguong_buf2[vuotnguong_buf2_cnt] =
B > Convert.ToUInt16(NguongCoHang_txt.Text);
VuotNguong1 = true;
for (byte k = 0; k < 5; k++)
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2] 44
if (vuotnguong_buf1[k] == false)
{ VuotNguong1 = false; break; }
vuotnguong_buf1_cnt++;
if (vuotnguong_buf1_cnt > 4) vuotnguong_buf1_cnt = 0;
VuotNguong2 = true;
for (byte k = 0; k < 5; k++)
if (vuotnguong_buf2[k] == false)
{ VuotNguong2 = false; break; }
vuotnguong_buf2_cnt++;
if (vuotnguong_buf2_cnt > 4)
vuotnguong_buf2_cnt = 0;
if (VuotNguong1)
{
DAT_ILDE_cnt1 = 10; dat_cnt =
Convert.ToInt64(Tauquahan_txt.Text);
if (Huongtau_lbl.Text == "")
{
Huongtau_lbl.Text = "Từ ga đi";
huongtau_muiten.Text = "-->>";
DB_di.Rows.Clear();
}
}
if (VuotNguong2)
{
DAT_ILDE_cnt2 = 10; dat_cnt =
Convert.ToInt64(Tauquahan_txt.Text);
if (Huongtau_lbl.Text == "")
{
Huongtau_lbl.Text = "Đi về ga";
huongtau_muiten.Text = "<<--";
DB_ve.Rows.Clear();
}
}
if (DAT_ILDE_cnt1 > 0) DAT_ILDE_cnt1--;
if (DAT_ILDE_cnt2 > 0) DAT_ILDE_cnt2--;
//Tàu ngoài cân, xóa hướng tàu,
//xóa bộ đệm của mỗi toa:
if (dat_cnt > 0)
{
dat_cnt--;
DBtemp.Rows.Add();
DBtemp.Rows[DBtemp.RowCount - 1].Cells[0].Value = A;
DBtemp.Rows[DBtemp.RowCount - 1].Cells[1].Value = B;
DBtemp.Rows[DBtemp.RowCount - 1].Cells[2].Value =
DateTime.Now ;
Disp1[Disp1_cuoi++] = A;
if (Disp1_cuoi > Disp_max) Disp1_cuoi = 0;
Disp2[Disp2_cuoi++] = B;
if (Disp2_cuoi > Disp_max) Disp2_cuoi = 0;
TongSomau.Text = DBtemp.RowCount.ToString ();
}
if (dat_cnt == 0) Huongtau_lbl.Text = "";
// Ngoài đoàn tàu:
if (dat_cnt == 1)
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2] 45
{
OleDbConnection cnn = new OleDbConnection(strConn);
cnn.Open();
OleDbCommand cmd = new OleDbCommand(strSQL, cnn);
TAfunctions ta = new TAfunctions();
if(Cumcan1_opt.Checked )
Caculate(0);// tính cụm 0=A, 1=B
else
Caculate(1);// tính cụm 0=A, 1=B
// lưu vào CSDL:
//Tinh_btn_Click(sender,e);
//FileStream fs = new FileStream();
MaxValue_cnt = MaxValue("‘Lần cân thứ‘",
"TrainTime");
string filename= "DAT" +
DateTime.Today.Year.ToString() +
DateTime.Today.Month.ToString() +
DateTime.Today.Day.ToString() +
DateTime.Now.Hour.ToString() +
DateTime.Now.Minute.ToString();
string SQL = "Create table " + filename +
" (Cum1 Integer ,Cum2 Integer , Thoigian datetime)";
cmd.CommandText = SQL;
cmd.ExecuteNonQuery();
for (int r = 0; r < DBtemp.RowCount; r++)
{
SQL = "INSERT INTO " + filename +
" (Cum1,Cum2,Thoigian)
VALUES (" +
(DBtemp.Rows[r].Cells[0].Value) + "," +
(DBtemp.Rows[r].Cells[1].Value) + ",’" +
DBtemp.Rows[r].Cells[2].Value + "’)";
cmd.CommandText = SQL;
cmd.ExecuteNonQuery();
}
for (int r = 0; r < DB_di.RowCount-1; r++)
{
try
{
SQL = "INSERT INTO TrainData_tien (STT,‘Lần cân thứ‘,
‘Mã toa‘,‘Tốc độ (Km/h)‘,‘KL Tổng (Kg)‘)
VALUES (" +
DB_di.Rows[r].Cells["STT"].Value + "," +
MaxValue_cnt + ",’" +
DB_di.Rows[r].Cells["Mã toa"].Value + "’," +
DB_di.Rows[r].Cells["Tốc độ (Km/h)"].Value + "," +
DB_di.Rows[r].Cells["KL Tổng (Kg)"].Value + ")";
cmd.CommandText = SQL;
cmd.ExecuteNonQuery();
}
catch
{
}
}
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.2 Thiết kế hướng đối tượng phần mềm hệ thống [2] 46
for (int r = 0; r < DB_ve.RowCount-1; r++)
{
try
{
SQL = "INSERT INTO TrainData_lui (STT,‘Lần cân thứ‘,
‘Mã toa‘,‘Tốc độ (Km/h)‘,‘KL Tổng (Kg)‘)
VALUES (" +
DB_ve.Rows[r].Cells["STT"].Value + "," +
MaxValue_cnt + ",’" +
DB_ve.Rows[r].Cells["Mã toa"].Value + "’," +
DB_ve.Rows[r].Cells["Tốc độ (Km/h)"].Value + "," +
DB_ve.Rows[r].Cells["KL Tổng (Kg)"].Value + ")";
cmd.CommandText = SQL;
cmd.ExecuteNonQuery();
}
catch { }
}
SQL = "INSERT INTO TrainTime (" +
"‘Lần cân thứ‘,‘Hướng tàu‘," +
"‘Thời gian‘,‘Số hiệu đoàn tàu‘," +
"‘KL Tổng(Kg)‘,‘Tên file dữ liệu gốc‘)VALUES (" +
MaxValue_cnt + ",’" +
Huongtau_lbl.Text + "’,’" +
System.DateTime.Now + "’,’" +
Sohieudoantau_txt.Text + "’,’" +
KLTong_txt.Text + "’,’" +
filename + "’)";
cmd.CommandText = SQL;
cmd.ExecuteNonQuery();
cnn.Close();
VuotNguong1 = false;
VuotNguong2 = false;
}
//----------------------------------------------
Tauqua_lbl.Text = dat_cnt.ToString();
break;
case 2:
Tocdo_lbl.Text =
Convert.ToString(Convert.ToSingle(A)/1000);
if (B == 11)
{
Huongtau_lbl.Text = "Từ ga đi";
huongtau_muiten.Text = "==>>";
}
if (B == 10)
{
Huongtau_lbl.Text = "Đi về ga";
huongtau_muiten.Text = "<<==";
}
break;
case 3: // Thông báo: phát hiện thấy đầu tàu=> hủy
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3.3 Tổng kết chương 47
// label19.Text = "Đầu tàu=11";
break;
case 4:
break;
}
}
if (++cuoi > Nmax) cuoi = 0;
}
}
}
3.2.5 Vận hành và bảo trì hệ thống
Hệ thống bao gồm cả phần cứng và phần mềm, do vậy, khi thiết kế cần
phải xác định rõ thời gian hệ thống hoạ động ổn định nhất để có phương
án bảo hành bải trì.
Trong sau khi thiết kế, hệ thống đã được kiểm thử tại công ty than
Vàng danh Uông bí, Quảng ninh.
Các mẫu thử khi có tàu chạy qua khá ổn, gần như không có nhiễu, dữ
liệu hoàn toàn như mong đợi. Nhìn các hình của mẫu (hình 4.4, 4.5, hình
4.6, hình 4.8) chúng ta có thể thấy rõ từng mẫu tín hiệu được gửi về.
3.3 Tổng kết chương
Chương này thiết kế chi tiết cả phần cứng và phần mềm.
Về phần cứng, thiết kế được chi tiết các thành phần của từng module,
các tín hiệu đầu vào, đầu ra theo đúng như yêu cầu trong phần thiết kế
tổng thể, đảm bảo các module có thể hoạt động tốt trong phạm vi thiết
kế và có thể ghép nối giao tiếp với nhau an toàn.
Về phần mềm nhúng, đưa ra được các module dùng để kiểm tra sự
hoạt động độc lập từng module và module phần mềm dùng trong quá
trình vận hành hệ thống thực tế.
Về phần mềm, đã thiết kế đạt yêu cầu, phân tích phần mềm hướng
đối tượng, phân tích từng quá trình, để lập trình viên dễ dàng hình dung
được sự vận hành của toàn bộ hệ thống, quá trình gia lệnh điều khiển,
cũng như luồng dữ liệu.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Chương 4
Xây dựng hệ thống cân động vật
thể
Giới thiệu về môi trường các ngôn ngữ lập trình:
• Firmware
• Software
Thiết kế chương trình, giao diện chức năng và một số mẫu dữ liệu thực
tế thu thập được.
4.1 Giới thiệu về ngôn ngữ lập trình cho phần cứng nhúng
Phần cứng đơn thuần, chỉ hoạt động theo thiết kế cố định ban đầu, nó
không thể linh động, không thể thay đổi các thông số, không thể đáp
ứng được các bài toán cần truyền thông theo quy chuẩn và không thể
áp dụng các thuật toán,...
Qua đó, để khắc phục được những nhược điểm trên chúng ta dùng
phần nhúng. Hệ thống nhúng là hệ thống có phần mềm nhúng trong
phần cứng. Có rất nhiều phần cứng hỗ trợ hệ nhúng, ví dụ: thông dụng
như Hệ vi điều khiển onchip 8051, PIC, AVR, ARM, PSoC, DSP,...
Mỗi nền phần cứng nhúng, sẽ đi kèm là một trình biên dịch, hỗ trợ
ngôn ngữ ASM và một số ngôn ngữ bậc cao khác. Trong hệ thống của
chúng ta, để thuận tiện, ta lập trình cho hệ nhúng bằng ngôn ngữ C.
Ngôn ngữ C là ngôn ngữ lập trình bậc cao, đã hỗ trợ hầu hết các chương
trình con thông dụng, có cấu trúc rõ ràng, mạch lạc, dễ hiểu và dễ lập
trình.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
4.2 Giới thiệu về ngôn ngữ lập trình phần mềm: C# 49
Trong số các chương trình dịch C cho vi điều khiển, cũng có nhiều loại
(dị bản) C khác nhau, không tuân thủ thống nhất là dùng ANSI C, vậy
nên có đôi điều chúng ta cần phải nói đến. Ngôn ngữ C cho PIC được
CCS phát triển, dựa trên nền tảng C, nhưng các phương pháp vào/ra,
thay vì dùng thẳng các thanh ghi thì CCS lại sử dụng hàm. Ví dụ, để
xuất giá trị ra cổng RB, High-Tech (ngôn ngữ C theo chuẩn ANSI C)
viết lệnh là: PORTB=value; (với value là giá trị cần xuất); thì trong
CCS lại sử dụng hàm: output_ B(value);
Thay vì sử dụng các thanh ghi làm phương pháp vào/ra, CCS chuyển
hết thành dùng hàm như vậy, đôi khi cũng khó hiểu cho người mới tiếp
cận; song lại là một phương pháp viết lệnh tốt khi chúng ta cần chuyển
đổi chương trình dịch vì một lý do nào đó.
CCS là một hãng phát triển C cho PIC khá toàn diện, luôn cập nhật,
hỗ trợ những dòng vi điều khiển mới, làm cho người lập trình dễ dàng
tiếp cận với các vi điều khiển mới mà không gặp chút khó khăn nào;
CCS dùng phương pháp lập trình tương đồng cho các dòng vi điều khiển
khác nhau, chính vì vậy mà khi muốn thay đổi phần cứng thì phần mềm
không phải thay đổi nhiều.
Vì là lập trình C, nên CCS cũng hỗ trợ hầu hết các cấu trúc của C,
như khai báo biến, các toán tử, các phương pháp thực hiện biểu thức,
cấu trúc lặp, rẽ nhánh, con trỏ,... vậy nên, ta có thể dùng các kỹ năng
lập trình C cho phần mềm máy tính để lập trình cho hệ vi điều khiển.
Khi lập trình xong, ta có thể dịch ra mã *.Hex (một mã dạng mã
máy, nhưng là chuẩn để nạp vào PIC), sau đó dùng một chương trình
mô phỏng để mô phỏng lại hoạt động của hệ thống, cụ thể là lập trình
cho PIC, sau đó, nạp mã Hex đó vào phần cứng, kiểm thử xem hệ thống
hoạt động ổn chưa, nếu chưa thực sự ổn so với mong đợi, có thể sửa mã
nguồn, dịch rồi nạp lại.
4.2 Giới thiệu về ngôn ngữ lập trình phần mềm: C#
Ngôn ngữ C# khá đơn giản, chỉ khoảng 80 từ khóa và hơn mười mấy
kiểu dữ liệu được xây dựng sẵn. Tuy nhiên, ngôn ngữ C# có ý nghĩa cao
khi nó thực thi những khái niệm lập trình hiện đại. C# bao gồm tất cả
những hỗ trợ cho cấu trúc, thành phần component, lập trình hướng đối
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
4.2 Giới thiệu về ngôn ngữ lập trình phần mềm: C# 50
tượng. Những tính chất đó hiện diện trong một ngôn ngữ lập trình hiện
đại. Và ngôn ngữ C# hội đủ những điều kiện như vậy, hơn nữa nó được
xây dựng trên nền tảng của hai ngôn ngữ mạnh nhất là C++ và Java.
Ngôn ngữ C# được phát triển bởi đội ngũ kỹ sư của Microsoft, trong
đó người dẫn đầu là Anders Hejlsberg và Scott Wiltamuth. Cả hai người
này điều là những người nổi tiếng, trong đó Anders Hejlsberg được biết
đến là tác giả của Turbo Pascal, một ngôn ngữ lập trình PC phổ biến.
Và ông đứng đầu nhóm thiết kế Borland Delphi, một trong những thành
công đầu tiên của việc xây dựng môi trường phát triển tích hợp (IDE)
cho lập trình client/server. Phần cốt lõi hay còn gọi là trái tim của bất
cứ ngôn ngữ lập trình hướng đối tượng là sự hỗ trợ của nó cho việc định
nghĩa và làm việc với những lớp. Những lớp thì định nghĩa những kiểu
dữ liệu mới, cho phép người phát triển mở rộng ngôn ngữ để tạo mô hình
tốt hơn để giải quyết vấn đề. Ngôn ngữ C# chứa những từ khóa cho việc
khai báo những kiểu lớp đối tượng mới và những phương thức hay thuộc
tính của lớp, và cho việc thực thi đóng gói, kế thừa, và đa hình, ba thuộc
tính cơ bản của bất cứ ngôn ngữ lập trình hướng đối tượng. Trong ngôn
ngữ C# mọi thứ liên quan đến khai báo lớp điều được tìm thấy trong
phần khai báo của nó. Định nghĩa một lớp trong ngôn ngữ C# không
đòi hỏi phải chia ra tập tin header và tập tin nguồn giống như trong
ngôn ngữ C++. Hơn thế nữa, ngôn ngữ C# hỗ trợ kiểu XML, cho phép
chèn các tag XML để phát sinh tự động các document cho lớp.
C# cũng hỗ trợ giao diện interface, nó được xem như một cam kết
với một lớp cho những dịch vụ mà giao diện quy định. Trong ngôn ngữ
C#, một lớp chỉ có thể kế thừa từ duy nhất một lớp cha, tức là không
cho đa kế thừa như trong ngôn ngữ C++, tuy nhiên một lớp có thể
thực thi nhiều giao diện. Khi một lớp thực thi một giao diện thì nó sẽ
hứa là nó sẽ cung cấp chức năng thực thi giao diện. Trong ngôn ngữ
C#, những cấu trúc cũng được hỗ trợ, nhưng khái niệm về ngữ nghĩa
của nó thay đổi khác với C++. Trong C#, một cấu trúc được giới hạn,
là kiểu dữ liệu nhỏ gọn, và khi tạo thể hiện thì nó yêu cầu ít hơn về
hệ điều hành và bộ nhớ so với một lớp. Một cấu trúc thì không thể kế
thừa từ một lớp hay được kế thừa nhưng một cấu trúc có thể thực thi
một giao diện. Ngôn ngữ C# cung cấp những đặc tính hướng thành
phần (component-oriented), như là những thuộc tính, những sự kiện.
Lập trình hướng thành phần được hỗ trợ bởi CLR cho phép lưu trữ
metadata với mã nguồn cho một lớp. Metadata mô tả cho một lớp, bao
gồm những phương thức và những thuộc tính của nó, cũng như những
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
4.3 Các chức năng của chương trình 51
sự bảo mật cần thiết và những thuộc tính khác. Mã nguồn chứa đựng
những logic cần thiết để thực hiện những chức năng của nó.. Do vậy,
một lớp được biên dịch như là một khối self-contained, nên môi trường
hosting biết được cách đọc metadata của một lớp và mã nguồn cần thiết
mà không cần những thông tin khác để sử dụng nó. Một lưu ý cuối cùng
về ngôn ngữ C# là ngôn ngữ này cũng hỗ trợ việc truy cập bộ nhớ trực
tiếp sử dụng kiểu con trỏ của C++ và từ khóa cho dấu ngoặc [] trong
toán tử. Các mã nguồn này là không an toàn (unsafe). Và bộ giải phóng
bộ nhớ tự động của CLR sẽ không thực hiện việc giải phóng những đối
tượng được tham chiếu bằng sử dụng con trỏ cho đến khi chúng được
giải phóng.
Tại sao phải sử dụng ngôn ngữ C#
Nhiều người tin rằng không cần thiết có một ngôn ngữ lập trình mới.
Java, C++, Perl, Microsoft Visual Basic, và những ngôn ngữ khác được
nghĩ rằng đã cung cấp tất cả những chức năng cần thiết. Ngôn ngữ C#
là một ngôn ngữ được dẫn xuất từ C và C++, nhưng nó được tạo từ nền
tảng phát triển hơn. Microsoft bắt đầu với công việc trong C và C++
và thêm vào những đặc tính mới để làm cho ngôn ngữ này dễ sử dụng
hơn. Nhiều trong số những đặc tính này khá giống với những đặc tính
có trong ngôn ngữ Java. Không dừng lại ở đó, Microsoft đưa ra một số
mục đích khi xây dựng ngôn ngữ này.
4.3 Các chức năng của chương trình
Chức năng của hệ thống được cài đặt là thu thập dữ liệu, lưu trữ dữ liệu
đầy đủ của lần cân cuối cùng, thống kê, báo cáo, cài đặt cổng kết nối,
cài đặt phương pháp lọc lấy khối lượng toa.
4.4 Màn hình giao diện chức năng
Màn hình của hệ thống được thiết kế thân thiện với người sử dụng, hầu
hết là tự động, chỉ có in ấn, báo cáo thì cán bộ vận hành mới phải thao
tác. Xem hình 4.1 Trong màn hình giao diện chức năng, hình 4.1, có các
thành phần sau đây:
• Dạng sóng tín hiệu cân: Biểu thị tín hiệu nhận được ở dạng sóng
của toàn bộ đoàn tàu. từ dạng sóng này ta có thể dễ dàng nhìn ra
trạng thái của các toa tàu
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
4.4 Màn hình giao diện chức năng 52
Hình 4.1: Giao diện màn hình
• Chỉ số cân: Có hai cân cùng cân trên hệ thống, chỉ số cân biểu thị
giá trị số đọc được trên mỗi cân. Chỉ số cân chính là dữ liệu đầu vào
dùng để tính toán khối lượng.
• Thông tin vận hành: Là các thông tin ít thay đổi, như người vận
hành hệ thống, địa điểm giao nhận,... dùng để lưu vào mỗi ca làm
việc và trình bày trong mẫu hóa đơn cân.
• Các thông số : Biểu thị tốc độ đoàn tàu, hướng đi hay về ga, mã
toa,...
• Số liệu sử lý hiện thời : Là các số liệu thu được ngay tại thời điểm
tàu đang chạy, tính toán và xử lý số liệu trực tiếp và đưa ra thông
tin cần thiết.
Với hình 4.2, trong phần mềm, người sử dụng có thể in báo cáo theo thời
gian, hoặc có thể tìm theo tất cả các thông tin lưu trong CSDL.
Tại sao phải làm như vậy?
Bởi vì, có những chuyến hàng, được chở đi đều đặn, nhưng đến khi tổng
kết, người ta thấy cần kiểm tra lại thông tin, vậy nên, có thể báo cáo lại
tất cả những chuyến hàng đã được cân.
Thông tin về thời gian, dùng để chọn báo cáo theo khoảng thời gian,
như báo cáo theo tuần, báo cáo theo tháng hay theo năm,...
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
4.4 Màn hình giao diện chức năng 53
Hình 4.2: Giao diện màn hình báo cáo
Phương pháp thực hiện: Chọn khoảng thời gian cần báo cáo: Chọn
ngày bắt đầu trong mục từ ngày, ngày kết thúc: trong mục đến ngày, rồi
chọn nút bấm: OK.
Kết quả nhận được: Báo cáo theo danh sách các chuyến đã cân trong
khoảng thời gian được chọn.
Ở hình 4.3, trong TAB giao diện này, người dùng có thể tùy chọn các
thông số cài đặt, như: Thời gian chờ tàu qua, cấu hình tùy chọn cổng
COM cho dữ liệu và cho thẻ, cũng như sử dụng cụm cân nào để cân và
có bù hay không (bù sai do ảnh hưởng của thời tiết)...
Trong TAB này cũng sử dụng để cấu hình mã toa và tên toa.
Cách thức thực hiện:
• Đặt thời gian chờ tàu qua hẳn: nhập số (phần trăm giây).
Kết quả: sau khi tàu chạy qua, quá thời gian đặt, hệ thống sẽ hiểu
là đã hết toa.
• Chọn cổng COM cho dữ liệu và đầu đọc thẻ tại: Sử dụng cổng dữ
liệu, sử dụng cổng đọc thẻ.
Kết quả: Hệ thống sẽ hiểu cổng nào là cổng dữ liệu vào, cổng nào là
cổng đọc thẻ phân biệt các toa.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
4.4 Màn hình giao diện chức năng 54
Hình 4.3: Giao diện màn hình cài đặt
• Chọn tham số lọc
Kết quả: ảnh hưởng đến kết quả cân. Trong các trường hợp kết cấu
cơ khí còn tốt thì chọn Lọc theo chiều cao tín hiệu, nếu kết cấu cơ
khí kém, sinh ra nhiều tạp nhiễu thì chọn Lọc theo dải tín hiệu
• Chọn cụm cân
Kết quả: thay đổi bàn cân (dùng trong trường hợp bảo dưỡng, thay
thế bàn cân)
• Tham số bù
Kết quả: Bù nhiễu theo thời tiết, nếu lượt đi và lượt về có thời tiết
hoàn toàn khác nhau thì thay đổi hệ số bù.
• Mã toa: Cập nhật thông tin về các toa có trong công ty
Cách thực hiện: Bấm vào dấu * để thêm toa mới; chọn cả hàng
ngang, bấm DEL để xoá toa
Kết quả: Thay đổi tên hiện thị trong báo cáo thay vì mã. Nếu không
có tên, báo cáo sẽ hiển thị mã toa.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
4.5 Lập kế hoạch triển khai thực tế 55
4.5 Lập kế hoạch triển khai thực tế
Sau khi thiết kế xong hệ thống, cần triển khai trên thực tế để có thể
thực nghiệm và lập trình chính xác được. Trong quá trình nghiên cứu,
hệ thống đã được cài đặt thử nghiệm tại công ty than Vàng danh - Uông
bí - Quảng Ninh.
Mỗi đầu tàu, nặng trung bình là 56 tấn (loại to), và 27 tấn (loại nhỏ);
toa hàng không có hàng, nặng 17.5 tấn; toa hàng chở đầy hàng, nặng
bình quân là 50-55 tấn.Dưới đây là một số mẫu thu được từ thực tế.
-
20
000
20
00
40
00
60
00
80
00
10
00
0
12
00
0
14
00
0
16
00
0
1
35
69
10
3
13
7
17
1
20
5
23
9
27
3
30
7
34
1
37
5
40
9
44
3
47
7
51
1
54
5
Hình 4.4: Nhóm dữ liệu toa tàu có hàng
Hình 4.4 là một đoạn dữ liệu thu thập được của nhóm toa tàu có hàng.
Tham số trên trục tung là biên độ nhận được do chuyển đổi tương tự số,
đỉnh của các vùng là giá trị lớn nhất khi bánh tàu đè lên Loadcell. Mỗi
cụm có hai đỉnh, chính là hai bánh gắn liền trục. Phần bụng sâu chính
là phần thân toa, phần này có khoảng cách giữa hai bánh lớn nên giá trị
tiến về 0. Phần bụng cao (giá trị >0 và <2000 chính là phần ngăn cách
các toa, phần này có khoảng cách các bánh lớn hơn so với khoảng cách
của 2 bánh trên một trục nhưng lại nhỏ hơn so với khoảng cách giữa hai
cụm bánh trong cùng một toa. Chính vì vậy mà nó có độ sâu gần như
>0.
Hình 4.5 là dữ liệu của một đoàn tàu có 11 toa, có chở hàng, khối
lượng các toa gần như nhau.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
4.5 Lập kế hoạch triển khai thực tế 56
-
20
000
20
00
40
00
60
00
80
00
10
00
0
12
00
0
14
00
0
1
12
6
25
1
37
6
50
1
62
6
75
1
87
6
10
01
11
26
12
51
13
76
15
01
16
26
17
51
18
76
20
01
21
26
22
51
23
76
25
01
26
26
27
51
28
76
30
01
31
26
Hình 4.5: Dữ liệu một chuyến tàu có hàng, 11 toa cả đầu tàu
-
20
000
20
00
40
00
60
00
80
00
10
00
0
12
00
0
14
00
0
1
12
6
25
1
37
6
50
1
62
6
75
1
87
6
10
01
11
26
12
51
13
76
15
01
16
26
17
51
18
76
20
01
21
26
22
51
23
76
25
01
26
26
27
51
28
76
30
01
31
26
Hình 4.6: Dữ liệu một chuyến tàu có hàng, 11 toa gồm cả đầu tàu
Và hình 4.6 được vẽ lại của hình 4.5 cho dễ nhìn.
Hình 4.7 là dữ liệu của một chuyến tàu, đầu tàu loại nhỏ (bên trái)
và các toa loại trung bình. Hình 4.8 là dữ liệu của một đoàn tàu không
hàng, đầu tàu cao trội lên, các toa khác không có hàng, tuy rằng khối
lượng gần như nhau, nhưng thực tế, khối lượng các toa không bằng nhau.
Hình 4.9 là ảnh thật của sản phẩm cân động như đã thiết kế.
Sản phẩm được đặt tên là CB090504, có hai hàng LED 7 thanh, hàng
trên thể hiện giá trị của cụm cân 1, hàng dưới thể hiện giá trị cụm cân
2.
Hình 4.9 dưới là hình nhóm sản phẩm gồm 6 cụm chuyển đổi, trên
thực tế, chỉ cần 01 bộ hoạt động tại một thời điểm, nhưng do đưa sản
phẩm vào ứng dụng, nên cần phải đảm bảo hệ thống hoạt động liên tục,
nên tác giả đã quyết định lắp 06 bộ trong một tủ, để thay thế ngay khi
cần thiết.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
4.5 Lập kế hoạch triển khai thực tế 57
Se
ria
l l
a
n
ca
n
th
u
11
0
0.
1
0.
2
0.
3
0.
4
0.
5
0.
6
0.
7
0.
8
0.
9
1
70
13
9
20
8
27
7
34
6
41
5
48
4
55
3
62
2
69
1
76
0
82
9
89
8
96
7
10
36
11
05
Hình 4.7: Dữ liệu một chuyến tàu có hàng, đầu tàu loại nhỏ
Về
kh
ôn
g
hà
n
g
-
20
000
20
00
40
00
60
00
80
00
10
00
0
12
00
0
14
00
0
16
00
0
1
19
3
38
5
57
7
76
9
96
1
11
53
13
45
15
37
17
29
19
21
21
13
23
05
24
97
26
89
28
81
30
73
Hình 4.8: Dữ liệu một chuyến tàu không hàng, 11 toa cả đầu tàu
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
4.6 Xác định rủi ro 58
4.6 Xác định rủi ro
Hệ thống cân là hệ thống điện tử, do vậy không tránh khỏi những rủi
ro.
Rủi ro có thể xác định bởi các nguyên nhân sau:
1. Thiên tai: Thiên tai có thể là lũ lụt gây ngập, hỏng loadcell, sét
đánh gây cháy nổ hệ thống.
Phương án đưa ra là đào mương, rãnh thoát nước dọc theo bàn cân;
thiết kế hệ thống chống sét đảm bảo độ an toàn và tin cậy.
2. Nún, sụt nền bàn cân, bàn cân bị rung lắc: Trước khi thi công,
cần phải làm chắc chắn vị trí đất xung quanh bàn cân, đổ bê tông
cốt thép liên kết trong toàn bộ bàn cân, làm cọc đóng sâu xuống
nền đất nếu thấy cần thiết.
Chọn vị trí làm bàn cân sao cho không nằm cạnh đường tàu khác.
3. Độ bền linh kiện theo thời gian: Tuổi thọ của linh kiện là có
hạn, vậy nên khi thi công, cần phải dự phòng linh kiện, đề phòng
trường hợp xấu xảy ra.
4. Nguồn nuôi không đảm bảo: Nguồn cung cấp cho hệ thống là vô
cùng quan trọng. Điện áp khu vực cân cần phải được đảm bảo chắc
chắn sẵn sàng và ổn định. Cần thiết phải thêm một hệ thống gồm
có bộ lưu điện công suất khoảng ≥ 2Kw và một bộ ổn định điện áp
lắp sau bộ lưu điện.
5. Cấu hình sai hệ thống: Khi vận hành, đôi khi chính người vận
hành nắm không vững quy trình vận hành hoặc các tham số vận
hành, làm cho hệ thống chạy không được như mong muốn. Giải
pháp đưa ra là trước khi chuyển giao công nghệ cho cán bộ vận
hành, cần tổ chức khoá huấn luyện kỹ lưỡng phương pháp vận hành
hệ thống. Khi nào thấy hệ thống có vấn đề lạ, cần reset lại các tham
số như mặc định.
6. Chỉnh định không theo hướng dẫn vận hành: Khi chỉnh định
cân không theo hướng dẫn vận hành, thì dẫn đến các sai số không
đáng có, như mùa đông (trời lạnh, ray co) hệ thống lại làm việc theo
mùa hè (trời nóng, ray dãn nở).
7. Hỏng, nhiễu đường truyền do đặt gần đối tượng gây nhiễu:
Khi đường truyền tín hiệu bị đặt gần đối tượng gây nhiễu như động
cơ, máy khò hàn,... thì có thể dẫn đến hỏng đường truyền, hay nhẹ
hơn là nhiễu tín hiệu.
Luận văn: Thiết kế hệ thống cân động. Nguyễn Tuấn Anh
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
4.7 Đánh giá kết quả thử nghiệm 59
Khi phát hiện thấy tín hiệu nhận được không bình thường, đề nghị
các cán bộ vận hành kiểm tra đường truyền tín hiệu.
Không nên để máy tính quá xa tủ đo lường và khuếch đại tín hiệu,
khoảng cách an toàn nên để là ≤ 1.5m
4.7 Đánh giá kết quả thử nghiệm
Sau khi chương trình được hoàn thiện, phần mềm được đưa vào thực tế
để thử nghiệm. Sau một số lần thử nghiệm thực tế, phần mềm dần dần
lấy lại được tính đúng đắn và chính xác theo tính toán. Giao diện thân
thiện với người vận hành;
Mỗi người vận hành được đào tạo một khoảng thời gian ngắn là có
thể sử dụng tốt chương trình. Mỗi khi tàu qua, các module làm việc rồi
ghi lại kết quả, đưa kết luận về khối lượng ra phiếu cân và đưa vào CSDL.
Thực tế cho thấy, sai số do môi trường là khó tránh khỏi, ví dụ như
tàu chạy ban đêm, nhiệt độ thấp, ray tàu lạnh rồi cứng lại, ép xuống
bàn cân dẫn đến lệch kết quả so với ban ngày trời nắng, ray dãn nở.
Chính vì vậy, phải có hệ số bù lệch (bù zero). Sau khi bù lệch, kết quả
đúng như tính toán, sai số
Các file đính kèm theo tài liệu này:
- 32LV09_CNTT_KHMTNguyenTuanAnh.pdf