İçindekiler:
2025 Yazar: John Day | [email protected]. Son düzenleme: 2025-01-13 06:58
Bu projenin amacı, bir Akıllı Aynanın görüntü görüntüleme işlevselliğini yaratmaktır. Ayna, tahminleri (güneşli, parçalı güneşli, bulutlu, rüzgarlı, yağmur, gök gürültüsü ve kar) ve -9999° ile 9999° arasındaki sıcaklık değerlerini görüntüleyebilir. Tahmin ve sıcaklık değerleri, bir hava durumu API'sinden ayrıştırılmalarını taklit etmek için sabit kodlanmıştır.
Proje, FreeRTOS çalıştıran bir Zynq-Zybo-7000 kartı kullanıyor ve donanımı tasarlamak ve programlamak için Vivado 2018.2 kullanıyor.
Parçalar:
Zynq-Zybo-7000 (FreeRTOS ile)
19 LCD (640x480)
VGA kablosu
12" x 18" akrilik ayna
1. Adım: Vivado'yu Yapılandırma
Xilinx'ten Vivado 2018.2'yi indirin ve Webpack lisansını kullanın. Vivado ve "Create New Project"i başlatın ve ona bir isim verin. Ardından "RTL Projesi"ni seçin ve "Şu anda kaynakları belirtme" seçeneğini işaretleyin. Bir parça seçerken, "xc7z010clg400-1" öğesini seçin ve sonraki sayfada "Son" düğmesine basın.
2. Adım: VGA Sürücüsü IP'sini Paketleme
vga_driver.sv dosyasını Tasarım Kaynaklarına ekleyin. Ardından, "Araçlar"ı tıklayın ve "Yeni IP Oluştur ve Paketle"yi seçin. "Mevcut projenizi paketleyin"i seçin. Ardından bir IP konumu seçin ve ".xci dosyalarını dahil edin". Açılır pencerede "Tamam" ı ve ardından "Son" u tıklayın.
"Paketleme Adımları"nda "İnceleme ve Paketleme"ye gidin ve "IP Paketi"ni seçin.
Şimdi vga_driver bir IP bloğu olarak mevcut olmalıdır.
3. Adım: Zynq IP
"IP Entegratörü" bölümünün altında "Blok Tasarımı Oluştur"u seçin. "ZYNQ7 İşleme Sistemini" ekleyin ve bloğa çift tıklayın. "XPS Ayarlarını İçe Aktar"ı tıklayın ve ZYBO_zynq_def.xml dosyasını yükleyin.
Ardından, "PS-PL Yapılandırması" altında "AXI Güvenli Olmayan Etkinleştirme" açılır menüsünü açın ve "M AXI GP0 arabirimi"ni işaretleyin.
Ardından, "MIO Konfigürasyonu" altında, "Uygulama İşlemci Birimi" açılır menüsünü açın ve "Zamanlayıcı 0" ve "İzleyici"yi kontrol edin.
Son olarak, "Saat Konfigürasyonu" altında "PL Yapı Saatler" açılır menüsünü açın ve "FCLK_CLK0" ve 100 MHz'de kontrol edin.
Adım 4: GPIO IP
Blok Tasarımına iki GPIO bloğu ekleyin. GPIO'lar, piksel adresini ve piksellerin RGB bileşenlerini kontrol etmek için kullanılacaktır. Blokları yukarıdaki resimlerde gösterildiği gibi yapılandırın. Her iki bloğu da ekleyip yapılandırdıktan sonra "Bağlantı Otomasyonunu Çalıştır" ı tıklayın.
GPIO 0 - Kanal 1 piksel adresini kontrol eder ve Kanal 2 kırmızı rengi kontrol eder.
GPIO 1 - Kanal 1 yeşil rengi kontrol eder ve Kanal 2 mavi rengi kontrol eder.
Adım 5: Belleği Engelle
Blok Tasarımına bir Blok Bellek Oluşturucu IP ekleyin ve yukarıda gösterildiği gibi yapılandırın. Piksel renkleri, daha sonra VGA sürücüsü tarafından okunan bellek adreslerine yazılır. Adres satırının kullanılan piksel miktarıyla eşleşmesi gerekir, bu nedenle 16 bit olması gerekir. 16 renk biti olduğu için içindeki veriler de 16 bittir. Herhangi bir onay bitini okumakla ilgilenmiyoruz.
6. Adım: Diğer IP
Ekli pdf, tamamlanmış Blok Tasarımını göstermektedir. Eksik IP'yi ekleyin ve bağlantıları tamamlayın. Ayrıca VGA renkli çıkışlar ve dikey ve yatay senkronizasyon çıkışları için "Harici Yapın".
xlconcat_0 - Blok RAM'e beslenen bir 16 bit RGB sinyali oluşturmak için ayrı renkleri birleştirir.
xlconcat_1 - VGA sürücüsünden gelen sütun ve satır sinyallerini birleştirir ve Blok RAM'in B Bağlantı Noktasına beslenir. Bu, VGA sürücüsünün piksel renk değerlerini okumasını sağlar.
VDD - Sabit YÜKSEK, Blok RAM'in yazma etkinleştirmesine bağlı, böylece her zaman doğru olabiliriz.
xlslice_0, 1, 2 - Dilimler, RGB sinyalini VGA sürücüsüne beslenebilecek ayrı R, G ve B sinyallerine bölmek için kullanılır.
Blok Tasarımı tamamlandığında, bir HDL sarmalayıcı oluşturun ve kısıtlamalar dosyasını ekleyin.
*Blok Tasarımı benlin1994 tarafından yazılan öğreticiye dayanmaktadır*
7. Adım: SDK
Bu Blok Tasarımını çalıştıran kod aşağıda yer almaktadır. Init.c, çizimi işleyen işlevleri içerir (tahminler, sayılar, derece sembolü vb.). main.c'deki ana döngü, kart programlandığında çalıştırılan şeydir. Bu döngü, tahmin ve sıcaklık değerlerini ayarlar ve ardından init.c'deki çizim işlevlerini çağırır. Şu anda yedi tahminin tümü arasında dolaşıyor ve birbiri ardına görüntüleniyor. Her görüntüyü görebilmeniz için 239 satırına bir kesme noktası eklemeniz önerilir. Kod yorumlanır ve size daha fazla bilgi verir.
Adım 8: Sonuç
Mevcut projeyi geliştirmek için, COE dosyaları biçimindeki önceden yüklenmiş tahmin görüntüleri Block Memory Generators'a yüklenebilir. Yani tahminleri C kodunda yaptığımız gibi manuel olarak çizmek yerine, resimler okunabilir. Bunu yapmaya çalıştık ama çalıştıramadık. Piksel değerlerini okuyabildik ve çıktılarını alabildik ama RAM'e yüklediklerimize hiç benzemeyen dağınık görüntüler yarattı. Block Memory Generator veri sayfasını okumak yararlıdır.
Proje, internet bağlantısı yönü eksik olduğu için esasen yarım bir Akıllı Aynadır. Bunu eklemek, eksiksiz bir Akıllı Ayna verecektir.