伦伦影院久久影视,天天操天天干天天射,ririsao久久精品一区 ,一本大道香蕉大久在红桃,999久久久免费精品国产色夜,色悠悠久久综合88,亚洲国产精品久久无套麻豆,亚洲香蕉毛片久久网站,一本一道久久综合狠狠老

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

基于深度學習自動化的前端開發解析

zhKF_jqr_AI ? 來源:未知 ? 作者:佚名 ? 2018-04-11 10:00 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

作者:Ashwin Kumar編譯:weakish

編者按:Ashwin Kumar之前是Sway Finance的聯合創始人,Sway Finance是Y Combinator孵化的一家初創企業,使用機器學習技術自動化會計。后來去了Insight,在Insight開發了一個模型,允許用戶從手繪的示意圖創建可以工作的HTML網站。現任Mythic深度學習科學家。

所有規模的公司而言,創建直觀、沉浸式的用戶體驗都是一個關鍵的目標。創建用戶體驗是一個以原型、設計、測試為周期的快速過程。Facebook這樣的巨頭有充足的資源,可以在設計過程中投入整個團隊,設計過程可能長達數周,涉及多個相關者;小企業沒有這樣的資源,因此它們的用戶界面做出來可能會不太好。

我在Insight的目標是使用現代深度學習算法顯著地流水線化設計工作流程,賦能任何企業快速創建和測試網頁。

今天的設計工作流程

經過多個相關者的設計工作流程

一個典型的設計工作流程可能是這樣的:

產業經理進行用戶研究,得出一些規格要求

設計師接收需求,探索低保真原型,并逐漸創建高保真模型

工程師將設計實現為代碼并最終交付產品至用戶

研發周期的長度可能很快成為瓶頸,Airbnb這樣的公司開始使用機器學習使這一過程更高效。

盡管看起來這是一個很有前途的機器輔助設計的樣例,我們并不清楚這一模型多大程度上是完全基于端到端訓練的,多大程度上依賴手工提取的特征。我們無法知道確切的答案,因為這是一個閉源的專有實現。我希望開發一個繪圖到代碼技術的開源版本,面向更廣泛的開發者和設計師。

理想情況下,我的模型將可以接受一個簡單的手繪網站設計原型,并立刻基于圖像生成可以工作的HTML網站:

SketchCode模型接受手繪示意圖,生成HTML代碼

事實上,上圖是我的模型在測試圖像集上生成的真實網站!相關代碼發布在我的GitHub上:ashnkumar/sketch-code

從圖像標注汲取靈感

我打算解決的問題屬于程序生成任務,自動生成可以工作的源代碼。不過,程序生成大多涉及從自然語言規格聲明或執行追蹤(execution trace)生成代碼,而我的案例將基于圖像(手繪示意圖)生成代碼。

在機器學習中,圖像標注是一個研究很充分的領域,圖像標注尋找能夠將圖像和文本相聯系的學習模型,特別是基于源圖像內容生成描述。

文本:一個扔飛盤的婦女

受最近的pix2code論文和Emil Wallner的相關項目的啟發,我決定重塑我的任務為圖像標注任務,以手繪網站示意圖為輸入圖像,相應的HTML代碼為輸出文本。

獲取合適的數據集

從圖像標注的角度來說,理想的數據集將是數以千計的成對的手繪草圖和相應的HTML代碼。毫不意外,我沒法找到這樣的數據集,我需要為這一任務創建自己的數據集。

我從pix2code論文的開源數據庫開始,其中包含1750張合成的網站截屏以及相關的源代碼。

pix2code數據集

這是一個很好的數據庫,可以作為我自己的數據集的基礎:

數據集中生成的網站包含一些簡單的Bootstrap元素的組合,例如按鈕、文本框和div。盡管這意味著我的模型的“詞匯表”將限于少數元素——可供選擇的生成網站的元素——這一方法可以簡單地推廣至更大的元素詞匯表。

每個樣本的源代碼包含一個領域特定語言(DSL)的token,該DSL是論文作者專門創建的。每個token對應一段HTML和CSS,有一個編譯器將DSL編譯成可以工作的HTML代碼。

讓圖像看起來像是手繪的

轉換彩色網站圖像至手繪版本

為了修改數據集以適應我自己的任務,我需要讓這些網站圖像看起來像是手繪的。我嘗試使用python中的OpenCV和PIL庫修改每張圖像,例如轉換為灰度圖像,等高線檢測。

最終,我決定直接修改原網站的CSS樣式表,進行以下操作:

修改網頁元素的圓角邊框以曲線化按鈕和div的邊角。

調整邊框的厚度,以模擬手繪草圖,并添加下降陰影。

修改字體為手繪風格字體。

最后,我通過添加傾斜、移動、旋轉以增強這些圖像,以模擬實際手繪草圖的變化性。

使用圖像標注模型架構

現在我已經有數據了,終于可以把數據傳給模型了!

我使用了一個圖像標注的模型架構,主要包含三部分:

使用卷積神經網絡(CNN)從源圖像提取圖像特征的計算機視覺模型

基于門控循環單元(GRU)的編碼源代碼token序列的語言模型

接受前兩步的輸出作為輸入,預測序列中的下一個token的解碼器模型(也是GRU)

訓練使用token序列作為輸入的模型

為了訓練這一模型,我將源代碼拆分成token序列。模型的單個輸入是一個序列和源代碼圖像,標簽為文檔中的下一個token。模型使用交叉熵作為損失函數,比較模型的下一個token預測和實際的下一個token。

在推理階段,當模型用來從頭生成代碼的時候,過程略有不同。圖像仍然由CNN處理,但文本過程僅僅使用一個開始序列作為種子。在每一步中,模型將預測的下一token序列附加到當前輸入序列,并傳給模型作為新輸入序列。不斷重復這一過程,直至模型預測一個token,或過程達到預先定義的文檔token數限制。

一旦模型生成了預測token的集合,編譯器轉換DSL token至可由任何瀏覽器渲染的HTML。

使用BLEU分數評估模型

我決定使用BLEU分數評估模型。BLEU分數是機器翻譯任務中一個常用的指標,這一指標衡量機器生成文本在多大程度上接近由人類基于相同輸入生成的文本。

基本上,BLEU比較生成文本和參考文本的n元序列,以創建準確率變體。用BLEU評估這一項目很合適,因為它基于實際生成的HTML元素,以及元素之間的關系。

最棒的是,我可以通過查看生成網站實際看到BLEU分數!

可視化BLEU分數

給定源圖像,完美的BLEU分數(1.0)意味著正確的元素位于正確的位置,而較低的分數預測錯誤的元素,或者元素位于錯誤的位置。最終模型能夠在評估數據集上取得0.76的BLEU分數。

額外獎勵——定制風格

我意識到模型提供了一個額外獎勵,由于模型僅僅生成網頁的骨架,我可以在編譯過程中加入定制的CSS層,然后立刻獲得所得網站的不同風格。

同一草圖對應不同風格

樣式解耦模型生成過程帶來了很大的優勢:

想要在自家公司使用SketchCode模型的前端工程師可以如原樣使用模型,僅僅修改一個CSS文件,使網站適配公司的風格指南

內置可伸縮性——基于單一源圖像,模型的輸出可以立刻編譯至5、10、50種不同的預定義分割,因此用戶可以可視化多個版本的網站,并在瀏覽器中瀏覽查看。

總結和未來方向

利用圖像標注方面的研究,SketchCode能夠接受手繪網站示意圖,并在數秒之內將它們轉換為可以工作的HTML網站。

這一模型具有一些限制,這也意味著未來可以做的改進:

由于訓練模型的詞匯表僅包括16個元素,它無法預測在數據中未見的token。下一步可能使用更多元素生成額外的網站樣本,例如圖像、下拉菜單、表單——Bootstrap組件是一個很好的開始。

生產環境中的實際網站有很多變化。創建更能反映這些變化的訓練數據集的一個很好的方法是抓取實際網站的HTML/CSS代碼和網站內容截屏。

手繪同樣有很多通過修改CSS無法完全捕捉的變化。在手繪草圖數據中生成更多變化的一個很好的方法是使用對抗生成網絡創建逼真的手繪網站圖像。

如前所述,你可以在GitHub上找到此項目的代碼:ashnkumar/sketch-code

原文地址:https://blog.insightdatascience.com/automated-front-end-development-using-deep-learning-3169dd086e82

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 深度學習
    +關注

    關注

    73

    文章

    5599

    瀏覽量

    124457
  • 前端開發
    +關注

    關注

    0

    文章

    28

    瀏覽量

    4812

原文標題:從草圖到網站:基于深度學習自動化前端開發

文章出處:【微信號:jqr_AI,微信公眾號:論智】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    SGM90516:高集成模擬前端芯片的深度解析

    SGM90516:高集成模擬前端芯片的深度解析 在電子設計領域,高集成度、高性能的模擬前端芯片一直是工程師們追求的目標。SGM90516作為一款由SGMICRO推出的16通道、12位模
    的頭像 發表于 03-12 10:30 ?123次閱讀

    智能制藥新引擎:解讀耐達訊自動化Profinet轉DeviceNet網關無縫對接之道

    ”,阻礙了數據集成。本文將探討耐達訊自動化Profinet轉DeviceNet網關如何作為關鍵技術,打破數據壁壘,提升制藥行業的生產效率與質量控制。 1. 協議深度解析:Profinet
    的頭像 發表于 02-06 15:10 ?214次閱讀
    智能制藥新引擎:解讀耐達訊<b class='flag-5'>自動化</b>Profinet轉DeviceNet網關無縫對接之道

    960單面點焊機的智能控制深度解析

    在新能源汽車與儲能產業高速發展的背景下,圓柱電池模組焊接工藝的精度與效率成為制約產能的關鍵瓶頸。深圳比斯特自動化設備有限公司推出的BT-960/960XZ單面自動點焊機,憑借其自適應壓力控制系統與的深度融合,實現了焊接質量與生產
    的頭像 發表于 12-17 16:23 ?1003次閱讀

    深度拆解比斯特1418單節自動點焊機自動化焊接流程

    比斯特1418單節自動點焊機的流水線式自動化焊接流程,是一個深度融合了機械工程、機器人學、傳感技術、軟件控制和材料科學的復雜系統。它將焊接從依賴工匠經驗的“手藝”,升華為可預測、可復制、可優化
    的頭像 發表于 11-27 15:24 ?418次閱讀

    羅克韋爾自動化邀您共赴2025年自動化博覽會

    11 月 17 - 20 日,作為工業自動化、信息和數字轉型領域的全球領先企業之一,羅克韋爾自動化將在芝加哥舉辦的 2025 年自動化
    的頭像 發表于 11-17 17:54 ?1988次閱讀

    高壓電力綜合自動化系統:技術解析與應用實踐

    角度解析高壓電力綜合自動化系統的應用現狀、功能特點與實現方法,并探討其在實際工程中的實踐意義。 一、高壓電力綜合自動化系統的應用背景 高壓電力系統涵蓋發電、輸電、變電等多個環節,其運行狀態復雜且對實時性要求
    的頭像 發表于 11-17 16:12 ?845次閱讀
    高壓電力綜合<b class='flag-5'>自動化</b>系統:技術<b class='flag-5'>解析</b>與應用實踐

    智慧科研新紀元:善思創興引領AI與自動化變革

    效率。 ?智能測試儀器與自動化平臺:?? 包括薄膜力學斷層掃描測試儀等精密儀器,為材料性能評估和實驗自動化提供強大支持。 ?聚焦核心:深耕能源與材料科學? 善思創興的解決方案深度聚焦兩大前沿領域
    發表于 09-05 16:55

    干貨分享 | TSMaster MBD模塊全解析:從模型搭建到自動化測試的完整實踐

    在汽車電子MBD開發中,TSMasterMBD模塊深度集成于TSMaster先進的總線分析、仿真與測試平臺,旨在為工程師提供一套從模型自動編譯、代碼集成到自動化測試的端到端無縫解決方案
    的頭像 發表于 08-22 20:04 ?2554次閱讀
    干貨分享 | TSMaster MBD模塊全<b class='flag-5'>解析</b>:從模型搭建到<b class='flag-5'>自動化</b>測試的完整實踐

    貿澤推出全新自動化資源中心

    新技術。借助這些資源,該領域的專業工程師將能夠了解控制系統、機器人和先進自動化軟件的新進展。 ? 工業自動化的核心在于提高效率和生產力、增強系統可靠性,同時降低營運成本并強化安全協議。通過該資源中心,專業人員可以獲取深度文章,包
    的頭像 發表于 08-01 16:26 ?822次閱讀
    貿澤推出全新<b class='flag-5'>自動化</b>資源中心

    玉林在線自動測寬儀 包帶自動化產線升級

    度檢測,如布、皮、革等。 在線自動測寬儀使包帶自動化產線升級,通過非接觸式光學測量、實時數據反饋與智能控制系統深度融合,顯著提升了生產精度與效率。 測寬儀的核心技術原理與功能優勢 光電測量 采用物方遠心
    發表于 07-23 15:23

    自動化測試平臺ATECLOUD推出AI算法功能

    作為納米軟件自主研發的自動化測試平臺,ATECLOUD 始終致力于為用戶提供高效優質的測試解決方案。面對5G、AI等前沿技術的迭代發展,平臺深度融合新技術持續升級測試能力,最新推出的AI算法功能更在自動化測試領域實現突破性創新。
    的頭像 發表于 07-22 16:10 ?850次閱讀
    <b class='flag-5'>自動化</b>測試平臺ATECLOUD推出AI算法功能

    自動化計算機的功能與用途

    工業自動化是指利用自動化計算機來控制工業環境中的流程、機器人和機械,以制造產品或其部件。工業自動化的目的是提高生產率、增加靈活性,并提升制造過程的質量。工業自動化在汽車制造中體現得最為
    的頭像 發表于 07-15 16:32 ?771次閱讀
    <b class='flag-5'>自動化</b>計算機的功能與用途

    自動化生產線如何依賴驅動芯片?關鍵技術解析

    解析傳送帶、泵類設備對電機控制的高精度需求,揭示華芯邦芯片在工業自動化中的穩定表現。
    的頭像 發表于 05-29 17:56 ?677次閱讀

    行業首創:基于深度學習視覺平臺的AI驅動輪胎檢測自動化

    全球領先的輪胎制造商 NEXEN TIRE 在其輪胎生產檢測過程中使用了基于友思特伙伴Neurocle開發的AI深度學習視覺平臺,實現缺陷檢測率高達99.96%,是該行業首個使用AI平臺技術推動缺陷檢測
    的頭像 發表于 03-19 16:51 ?1069次閱讀
    行業首創:基于<b class='flag-5'>深度</b><b class='flag-5'>學習</b>視覺平臺的AI驅動輪胎檢測<b class='flag-5'>自動化</b>

    智能讀碼器:工業自動化的眼睛與大腦

    隨著技術的不斷進步,讀碼器的功能也在持續拓展。從單一的數據采集到智能的數據分析,從獨立設備到與自動化生產線的深度融合,讀碼器正在逐步成為工業自動化的核心組件。
    的頭像 發表于 03-18 09:12 ?911次閱讀
    智能讀碼器:工業<b class='flag-5'>自動化</b>的眼睛與大腦