Talaan ng mga Nilalaman:
2025 May -akda: John Day | [email protected]. Huling binago: 2025-01-23 15:13
Tulad ng marahil na makukuha mo mula sa pamagat, ang layunin ng proyektong ito ay upang makagawa ng isang Image Enhancement System gamit ang ZYNQ ApSOC. Mas partikular, nais naming bumuo ng isang system na maaaring i-clear ang hamog mula sa mga imahe o video. Ang sistemang ito ay kukuha ng hindi magandang kondisyon na visual data bilang input, iproseso ito gamit ang mga diskarte sa pagpapahusay ng imahe at pagkatapos ay i-output ang resulta.
Ang proyekto ay binuo at nasubukan sa Digilent Zybo Board ngunit ang iba pang mga aparatong ZYNQ ay dapat ding gumana.
Hahatiin namin ang proyektong ito sa 3 bahagi:
1) INPUT = Input na Imahe sa pamamagitan ng Ethernet mula sa Computer / Camera
2) PROSESO = Iproseso ang Imahe
3) OUTPUT = I-output ang Imahe sa pamamagitan ng isang HDMI interface
Sa isang napaka-counterintuitive fashion magsisimula kami sa output na bahagi ng proyekto (bibigyan kami nito ng mas mahusay na mga posibilidad ng pag-debug kasama ang paraan) magpatuloy sa pag-input at tapusin ang bahagi ng pagproseso.
Hakbang 1: Mga Kagamitan
Upang makumpleto ang proyektong ito kakailanganin mo:
HARDWARE
- Ang anumang ZYNQ Board na may HDMI at Ethernet ay dapat na gumana / Gumagamit ako ng Digilent Zybo
- USB A hanggang micro B USB cable
- HDMI cable
- Ethernet cable
- Ipakita na may HDMI input
SOFTWARE
- Xilinx Vivado
- Xilinx SDK
Hakbang 2: OUTPUT - VGA Controller Bahagi 1
Kami ay maglalabas ng aming visual data gamit ang HDMI port na naroroon sa board. Ang HDMI port ay konektado sa bahagi ng PL (Programmable Logic = FPGA) ng ZYNQ at kakailanganin naming mag-disenyo ng isang controller sa VHDL para dito. Kung nakadesenyo ka ba ng isang VGA controller ay mahahanap mo ito katulad. Ang mga oras para sa HDMI at VGA ay talagang pareho, sa katunayan maaari kang bumuo sa isang mayroon nang VGA controller upang makakuha ng isang HDMI controller.
Para sa isang mas mahusay na pag-unawa sa kung ano talaga ang nangyayari ay magdidisenyo muna kami ng isang VGA controller
Nais naming ipakita sa isang resolusyon ng 1920x1080.
Ang VGA controller ay responsable para sa paglilipat ng data ng pixel (sa format na RGB) nang sunud-sunod, pixel ayon sa pixel sa display. Sa labas ng aktwal na lugar ng lugar ng pagpapakita ng 1920x1080 mayroon ding ilang mga "hangganan" na lugar, lalo: front porch, back porch at retrace. Ang laki sa mga pixel ng mga lugar na ito ay pamantayan at tukoy sa bawat resolusyon. Ang mga lugar na ito ay HINDI talagang lilitaw sa screen ngunit sapilitan ang mga ito at ang kulay ng mga pixel sa lugar na ito ay dapat na itim. Ang isang wastong tanong ay bakit kailangan ang mga labis na lugar na ito. Ang katanungang ito ay lumalaban sa layunin ng pagtuturo na ito ngunit kung ikaw ay may kuryoso ay hihimokin kita na gumawa ng karagdagang pagsasaliksik sa online.
Ito ay isang magandang video na nagpapaliwanag ng interface ng VGA
Sa aming kaso nais naming ipakita sa isang resolusyon ng 1920 * 1080, at ito ang mga oras:
Pahalang na Lugar ng Display = 1920 na mga pixel
Pahalang na Fron Porch = 88 mga pixel
Pahalang na Back Porch = 148 mga pixel
Pahalang na Retrace = 44 na mga pixel
Vertical Display Area = 1080 pixel
Vertical Front Porch = 4 na mga pixel
Vertical Back Porch = 36 mga pixel
Vertical Retrace = 5 mga pixel
(Dito maaari kang makahanap ng mga oras para sa iba pang mga resolusyon
Kaya ang aming aktwal na resolusyon ay magiging 2200 x 1125. Gusto namin ng 60 fps (mga frame bawat segundo) kaya ang aming pixel na orasan ay 60 * 2200 * 1125 = 148.5 MHz. Sa Zybo Board isang 125 Mhz na orasan ang ibinigay. Gumagamit kami ng isang MMCM IP upang makabuo ng 148.5 MHz Pixel Clock na kailangan namin.
Hakbang 3: OUTPUT - VGA Controller Bahagi 2
Gamit ang teoretikal na background mula sa nakaraang hakbang dapat mong ma-disenyo ang pagmamay-ari mo ng VGA controller. Bibigyan kita ng isang proyekto ng Vivado na ginagawa iyon ngunit pinapayuhan ko kayo na kahit papaano ay subukang gawin ito sa iyong sarili muna.
Karamihan sa mga port ng VGA ay hindi nagbibigay sa iyo ng 8 piraso bawat kulay ng channel bawat pixel (tingnan ang imahe sa itaas) kaya kakailanganin mong iakma ang disenyo sa bilang ng mga pin bawat kulay na ibinibigay ng Lupon (hindi ito isang problema para sa HDMI).
Ipapinta ng Disenyo ang buong screen asul, maliban sa tuktok na kaliwang pixel na magiging pula. Dapat pansinin na ang proyektong ito ay gumagamit ng mga hadlang para sa ZYBO Board. Kaya kung nais mong patakbuhin ang proyektong ito sa isa pang Lupon dapat mong i-update ang mga hadlang na file at iakma ang bilang ng mga pin bawat kulay.
Tingnan ang figure nr. 2. Alalahanin na habang ang aming VGA Controller ay naglabas ng 5/6 bits bawat kulay, ang mga bit na iyon ay nai-convert sa isang analogue signal para sa bawat color channel (Red, Green at Blue) bago dumaan sa cable.
Hakbang 4: OUTPUT - HDMI Controller Bahagi 1
Ngayon alam na namin kung paano gumagana ang VGA controller at mayroon kaming isang gumaganang disenyo maaari naming ipagpatuloy ang HDMI controller. Talagang gagamitin ng HDMI controller ang lahat ng code na binuo namin sa VGA controller. Gumagamit ang HDMI at VGA ng parehong oras at parehong signal. Lumilitaw ang pagkakaiba sa mga pin ng ouput.
Habang ang VGA ay gumagamit ng isang kawad para sa bawat kulay at nagpapadala ng isang signal ng analogue sa tapat nito, ipinapadala ng HDMI ang data nang digital nang 1 bit sa bawat oras para sa bawat kulay at gumagamit ng pagkakaiba sa pagbibigay ng senyas. Ang pagkakaiba-iba ng pagbibigay ng senyas ay nangangahulugang para sa bawat bit ang HDMI ay mayroong 2 mga pin na may isa kabaligtaran ng isa pa. Kaya kung nais naming magpadala ng isang senyas na '1' magpapadala kami ng '1' sa isang kawad at '1' na na-negate sa iba pang kawad. Tinitiyak nito ang integridad ng signal at maaari mong mabasa ang tungkol dito dito https://goo.gl/6CPCzB. Mayroon kaming isa sa mga channel na ito para sa bawat kulay, PULA, GREEN at BLUE at isa para sa orasan. Dahil sa mga detalye ng pagkakaiba sa pag-sign ng mga signal na ipinapadala namin sa pamamagitan ng HDMI ay dapat na balanseng DC na nangangahulugang ang bilang ng 1 at 0 ay dapat na halos pantay sa isang tiyak na window ng oras. Upang magawa ito gagamitin namin ang 8b / 10b encoding. Marami kang maaaring matutunan tungkol sa kung paano gumagana ang pagkakaiba sa pag-signaling at 8b / 10b na pag-encode mula sa pagtutukoy ng DVI dito https://goo.gl/hhh8Ge (ang DVI at HDMI ay gumagamit ng parehong mga signal ng video).
Hakbang 5: OUTPUT - HDMI Controller Bahagi 2
Sapat na teorya, hinahayaan na makarating sa aming proyekto. Habang sa VGA Controller nakawala kami gamit ang isang 148.5 MHz na orasan, narito kailangan naming magbigay ng 10 beses na dalas dahil nais naming magpadala ng 8 bits para sa bawat kulay at gamitin ang 8b / 10b encoding na isinalin sa 10 bits per pixel at 10 * 148.5MHz = 1485MHz Iyon ay isang malaking dalas na hindi maaaring makuha sa Zybo Board. Sa kabutihang palad nakuha namin ang ilang mga trick up ang aming manggas. Maaari naming pamahalaan ang 5 * 148.5MHz = 742.5MHz at gagamit kami ng isang OSERDES (serializer) IP upang maipadala ang data kapwa sa tumataas at bumabagsak na gilid ng 742.5Mhz na orasan, kaya talagang makukuha namin ang data sa 1485MHz. Bibigyan kami ng Vivado ng ilang mga babala sa tiyempo at maaari kang laging pumunta para sa isang mas mababang resolusyon na may isang mas maliit na orasan, ngunit dahil gumagana ito, hindi namin talaga ito alintana sa ngayon (ang mga babala ay nauugnay sa ang katunayan na ang mga buffer ng orasan ay hindi opisyal mas mataas ang suporta ng mga frequency kaysa sa 464MHz).
Kaya ang kailangan nating gawin ay i-encode ang data mula sa aming output ng VGA Controller sa 8b / 10b format at pagkatapos ay i-serialize ito tulad ng nabanggit sa itaas. Kakailanganin din naming magdagdag ng isa pang MMCM sa proyekto upang makabuo ng 742.5MHz na orasan para sa serialization.
Inilakip ko sa ibaba ang mga vhdl file para sa encoder at serializer. Dapat mo munang i-encode ang mga RGB channel at pagkatapos ay i-serialise ang mga ito.
Halimbawa para sa pulang channel:
TMDS_encoder_RED: TMDS_encoder
mapa ng port (clk148, red_channel_8bits, c_red, video_on, encoded_red_10bits);
Serialiser_RED: Serialiser10_1
mapa ng port (clk148, clk742, naka-encode_red_10bits, i-reset, red_serial_1bit);
Ang "c" input sa TMDS_encoder ay "00" para sa pula at berde at "vsync & hsync" para sa asul (bahagi ito ng pagtutukoy ng DVI
Hakbang 6: Pagpapakita ng Mga Larawan Mula sa RAM
Ang layunin ng control ng HDMI ay upang ipakita ang naprosesong mga imahe. Ngayon, sa pagpapatupad ng controller at handa nang pumunta dapat nating isipin ang tungkol sa pagpapakain sa controller na ito ng data. Dahil sa maraming proseso ng pagpapahusay ng imahe ay magaganap sa PS (Processing System = ARM Processor) at ang mga imahe na nagresulta ay manatili sa DDR RAM. Kaya kailangan namin ng isang paraan upang makuha ang data mula sa RAM papunta sa HDMI controller.
Upang magawa ito kakailanganin mo ang 3 mga IP:
1) VDMA (Video Direct Memory Access)
2) VTC (Video timing Controller)
3) Mag-stream sa Video Out (tatawagin namin itong S2VO mula ngayon)
Magbibigay talaga ang S2VO ng isang signal na RGB 24BIT sa output at kinakailangang signal ng HSYNC at VSYNC. Kaya't maiiwan natin ang bahaging iyon ng HDMI controller.
Dapat mong idagdag ang mga IP na ito sa iyong disenyo, i-configure ang mga ito at gawin ang wastong mga koneksyon.
Sa wakas dapat kang makakuha ng isang bagay na kahawig ng eskematiko sa itaas.
Hakbang 7: OUTPUT - SDK END
Sa lahat ng pag-set up ng hardware at handa nang pumunta kailangan na nating itayo ang software sa PS. I-export namin ang hardware at ang bitstream at ilulunsad ang SDK.
1) File -> Export -> Export Hardware -> Suriin ang Isama ang Bitstream at Pindutin ang OK
2) File -> Ilunsad ang SDK
Sa SDK lumikha ng isang bagong proyekto sa aplikasyon.
3) File -> Bago -> Application Project
4) Pumili ng isang pangalan para sa iyong proyekto at pindutin ang Susunod
5) Piliin ang template na "Hello World" at pindutin ang Tapusin
Ang aplikasyon sa SDK ay kailangang i-program ang VDMA. Mayroong ilang mga karaniwang pag-andar na ginamit upang makamit ito (pupunta ako sa mga detalye kapag mayroon akong oras).
Upang masubukan ang aming disenyo gagamitin namin ang tampok na SDK Restore (Xilinx Tools -> Dump / Restore) upang maglagay ng isang imahe sa memorya ng DDR RAM at ipakita ito gamit ang aming HDMI Controller. Maaari mong mai-load ang imahe kahit saan mo gusto (maliban sa ilang maliit na mga pinaghihigpitan na lugar sa simula ng memorya). Para sa aming halimbawa pinili namin ang address 16777216 at ang laki ng file 8294400 = 1920 * 1080 * 4 (4 channel = RGB + alpha).
Gumagana siya !
Itutuloy
Inirerekumendang:
Pagpoproseso ng Imahe Gamit ang Raspberry Pi: Pag-install ng OpenCV at Paghihiwalay ng Kulay ng Imahe: 4 na Hakbang
Pagpoproseso ng Imahe Gamit ang Raspberry Pi: Pag-install ng OpenCV at Paghihiwalay ng Kulay ng Imahe: Ang post na ito ay ang una sa maraming mga tutorial sa pagproseso ng imahe na susundan. Masusing pagtingin namin sa mga pixel na bumubuo ng isang imahe, matutunan kung paano i-install ang OpenCV sa Raspberry Pi at nagsusulat din kami ng mga script ng pagsubok upang makuha ang isang imahe at c
Paggawa ng Mga Imahe ng Seamless Horizontally o Vertically Only (para sa "The GIMP").: 11 Mga Hakbang (na may Mga Larawan)
Paggawa ng Mga Imahe ng Seamless Horizontally o Vertically Only (para sa "The GIMP") .: Kung susubukan mo ang "Make seamless" plug-in sa GIMP, gagawin nitong seamless ang imahe sa parehong pahalang at patayo nang sabay. Hindi ka papayag na gawin itong seamless sa isang dimensyon lamang. Makatuturo ang makakatulong sa iyo na makagawa ng ima
Imahe sa Imahe sa Tubig: 4 na Hakbang (na may Mga Larawan)
Pagpapaginhawa ng Imahe sa Tubig: Napansin mo ba kung paano dumidilim ang tubig habang lumalalim, ngunit ang mababaw na tubig ay mas malinaw? Nagtrabaho ako sa pagkontrol sa hindi pangkaraniwang bagay na iyon upang makagawa ng mga imahe. Ginagawa ito sa pamamagitan ng paglikha ng isang kaluwagan batay sa intensity ng isang imahe, at pag-machining ng kaluwagan na ito sa
I-render ang Mga Imahe ng 3D ng Iyong Mga PCB Gamit ang Eagle3D at POV-Ray: 5 Hakbang (na may Mga Larawan)
I-render ang Mga Imahe ng 3D ng Iyong Mga PCB Gamit ang Eagle3D at POV-Ray: Paggamit ng Eagle3D at POV-Ray, maaari kang gumawa ng makatotohanang mga pag-render ng 3D ng iyong mga PCB. Ang Eagle3D ay isang script para sa EAGLE Layout Editor. Lilikha ito ng isang ray tracing file, na ipapadala sa POV-Ray, na sa paglaon ay lalabas ang pinal na im
Murang Pagpapahusay ng Mga Naka-print na Larawan: 4 na Hakbang (na may Mga Larawan)
Murang Pagpapahusay ng Mga Naka-print na Larawan: Ang murang mga printer ay gumagana nang mahusay, ngunit ang mga naka-print na larawan ay napaka-sensitibo: ang anumang patak ng tubig ay sumisira sa kanila. Ang papel na "larawan" upang mag-print ng mga larawan ay napakamahal. Ang normal na papel ay nagbibigay ng regular na mga resulta. Gumamit ako ng normal na papel na 75g A4 para sa