色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何使用TensorFlow Hub的ESRGAN模型來在安卓app中生成超分圖片

Tensorflowers ? 來源:TensorFlow ? 作者:魏巍 ? 2020-11-26 09:40 ? 次閱讀

從一張低分辨率的圖片生成一張對應(yīng)的高分辨率圖片的任務(wù)通常被稱為單圖超分(Single Image Super Resolution - SISR)。盡管可以使用傳統(tǒng)的插值方法(如雙線性插值和雙三次插值)來完成這個任務(wù),但是產(chǎn)生的圖片質(zhì)量卻經(jīng)常差強人意。深度學(xué)習(xí),尤其是對抗生成網(wǎng)絡(luò) GAN,已經(jīng)被成功應(yīng)用在超分任務(wù)上,比如 SRGAN 和 ESRGAN 都可以生成比較真實的超分圖片。那么在本文里,我們將介紹一下如何使用TensorFlow Hub上的一個預(yù)訓(xùn)練的 ESRGAN 模型來在一個安卓 app 中生成超分圖片。最終的 app 效果如下圖,我們也已經(jīng)將完整代碼開源給大家參考。

SRGAN
https://arxiv.org/abs/1609.04802

ESRGAN
https://arxiv.org/abs/1809.00219

完整代碼
https://github.com/tensorflow/examples/tree/master/lite/examples/super_resolution

首先,我們可以很方便的從 TFHub 上加載 ESRGAN 模型,然后很容易的將其轉(zhuǎn)化為一個 TFLite 模型。注意在這里我們使用了動態(tài)范圍量化(dynamic range quantization),并將輸入圖片的尺寸固定在50x50像素(我們已經(jīng)將轉(zhuǎn)化后的模型上傳到 TFHub 上了):

model = hub.load("https://tfhub.dev/captain-pool/esrgan-tf2/1") concrete_func = model.signatures[tf.saved_model.DEFAULT_SERVING_SIGNATURE_DEF_KEY] concrete_func.inputs[0].set_shape([1, 50, 50, 3]) converter = tf.lite.TFLiteConverter.from_concrete_functions([concrete_func]) converter.optimizations = [tf.lite.Optimize.DEFAULT] tflite_model = converter.convert() # Save the TF Lite model. with tf.io.gfile.GFile('ESRGAN.tflite', 'wb') as f: f.write(tflite_model) esrgan_model_path = './ESRGAN.tflite'

TFHub
https://hub.tensorflow.google.cn/

TFHub(轉(zhuǎn)化后模型)
https://hub.tensorflow.google.cn/captain-pool/lite-model/esrgan-tf2/1

現(xiàn)在 TFLite 已經(jīng)支持動態(tài)大小的輸入,所以你也可以在模型轉(zhuǎn)化的時候不指定輸入圖片的大小,而在運行的時候動態(tài)指定。如果你想使用動態(tài)輸入大小,請參考這個例子。

例子
https://github.com/tensorflow/tensorflow/blob/c58c88b23122576fc99ecde988aab6041593809b/tensorflow/lite/python/lite_test.py#L529-L560

模型轉(zhuǎn)化完之后,我們可以很快驗證 ESRGAN 生成的超分圖片質(zhì)量確實比雙三次插值要好很多。如果你想更多的了解 ESRGAN 模型,我們還有另外一個教程可供參考:

lr = cv2.imread(test_img_path) lr = cv2.cvtColor(lr, cv2.COLOR_BGR2RGB) lr = tf.expand_dims(lr, axis=0) lr = tf.cast(lr, tf.float32) # Load TFLite model and allocate tensors. interpreter = tf.lite.Interpreter(model_path=esrgan_model_path) interpreter.allocate_tensors() # Get input and output tensors. input_details = interpreter.get_input_details() output_details = interpreter.get_output_details() # Run the model interpreter.set_tensor(input_details[0]['index'], lr) interpreter.invoke() # Extract the output and postprocess it output_data = interpreter.get_tensor(output_details[0]['index']) sr = tf.squeeze(output_data, axis=0) sr = tf.clip_by_value(sr, 0, 255) sr = tf.round(sr) sr = tf.cast(sr, tf.uint8)

教程
https://tensorflow.google.cn/hub/tutorials/image_enhancing

LR: 輸入的低分辨率圖片,該圖從 DIV2K 數(shù)據(jù)集中的一張蝴蝶圖片中切割出來. ESRGAN (x4): ESRGAN 模型生成的超分圖片,單邊分辨率提升4倍. Bicubic: 雙三次插值生成圖片. 在這里大家可以很容易看出來,雙三次插值生成的圖片要比 ESRGAN 模型生成的超分圖片模糊很多

你可能已經(jīng)知道,TensorFlow Lite 是 TensorFlow 用于在端側(cè)運行的官方框架,目前全球已有超過40億臺設(shè)備在運行 TFLite,它可以運行在安卓,iOS,基于 LinuxIoT 設(shè)備以及微處理器上。你可以使用 Java, C/C++ 或其他編程語言來運行 TFLite。在這篇文章中,我們將使用 TFLite C API,因為有許多的開發(fā)者表示希望我們能提供這樣一個范例。

DIV2K
https://data.vision.ee.ethz.ch/cvl/DIV2K/

Java, C/C++
https://tensorflow.google.cn/lite/guide/android

TFLite C API
https://github.com/tensorflow/tensorflow/blob/master/tensorflow/lite/c/c_api.h

我們在預(yù)先編譯好的 AAR 文件中包含了 TFLite C API需要的頭文件和庫 (包括核心庫和 GPU 庫)。為了正確的設(shè)置好 Android 項目,我們首先需要下載兩個 JAR 文件并將相應(yīng)的頭文件和庫抽取出來。我們可以在一個 download.gradle 文件中定義這些任務(wù),然后將這些任務(wù)導(dǎo)入 build.gradle。下面我們先定義下載 TFLite JAR 文件的兩個任務(wù):

task downloadTFLiteAARFile() { download { src "https://bintray.com/google/tensorflow/download_file?file_path=org%2Ftensorflow%2Ftensorflow-lite%2F2.3.0%2Ftensorflow-lite-2.3.0.aar" dest "${project.rootDir}/libraries/tensorflow-lite-2.3.0.aar" overwrite false retries 5 } } task downloadTFLiteGPUDelegateAARFile() { download { src "https://bintray.com/google/tensorflow/download_file?file_path=org%2Ftensorflow%2Ftensorflow-lite-gpu%2F2.3.0%2Ftensorflow-lite-gpu-2.3.0.aar" dest "${project.rootDir}/libraries/tensorflow-lite-gpu-2.3.0.aar" overwrite false retries 5 } }

AAR 文件
https://tensorflow.google.cn/lite/guide/android#use_tflite_c_api

然后我們定義另一個任務(wù)來講頭文件和庫解壓然后放到正確的位置:

task fetchTFLiteLibs() { copy { from zipTree("${project.rootDir}/libraries/tensorflow-lite-2.3.0.aar") into "${project.rootDir}/libraries/tensorflowlite/" include "headers/tensorflow/lite/c/*h" include "headers/tensorflow/lite/*h" include "jni/**/libtensorflowlite_jni.so" } copy { from zipTree("${project.rootDir}/libraries/tensorflow-lite-gpu-2.3.0.aar") into "${project.rootDir}/libraries/tensorflowlite-gpu/" include "headers/tensorflow/lite/delegates/gpu/*h" include "jni/**/libtensorflowlite_gpu_jni.so" }

因為我們是用安卓 NDK 來編譯這個 app,我們需要讓 Android Studio 知道如何處理對應(yīng)的原生文件。我們在 CMakeList.txt 文件中這樣寫:

set(TFLITE_LIBPATH "${CMAKE_CURRENT_SOURCE_DIR}/../../../../libraries/tensorflowlite/jni") set(TFLITE_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/../../../../libraries/tensorflowlite/headers") set(TFLITE_GPU_LIBPATH "${CMAKE_CURRENT_SOURCE_DIR}/../../../../libraries/tensorflowlite-gpu/jni") set(TFLITE_GPU_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/../../../../libraries/tensorflowlite-gpu/headers") set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=gnu++14") set(CMAKE_CXX_STANDARD 14) add_library(SuperResolution SHARED SuperResolution_jni.cpp SuperResolution.cpp) add_library(lib_tensorflowlite SHARED IMPORTED) set_target_properties(lib_tensorflowlite PROPERTIES IMPORTED_LOCATION ${TFLITE_LIBPATH}/${ANDROID_ABI}/libtensorflowlite_jni.so) add_library(lib_tensorflowlite_gpu SHARED IMPORTED) set_target_properties(lib_tensorflowlite_gpu PROPERTIES IMPORTED_LOCATION ${TFLITE_GPU_LIBPATH}/${ANDROID_ABI}/libtensorflowlite_gpu_jni.so) find_library(log-lib log) include_directories(${TFLITE_INCLUDE}) target_include_directories(SuperResolution PRIVATE ${TFLITE_INCLUDE}) include_directories(${TFLITE_GPU_INCLUDE}) target_include_directories(SuperResolution PRIVATE ${TFLITE_GPU_INCLUDE}) target_link_libraries(SuperResolution android lib_tensorflowlite lib_tensorflowlite_gpu ${log-lib})

我們在 app 里包含了3個示例圖片,這樣用戶可能會運行同一個模型多次,這意味著為了提高運行效率,我們需要將 TFLite 解釋執(zhí)行器進行緩存。這一點我們可以在解釋執(zhí)行器成功建立后通過將其指針從 C++ 傳回到 Java 來實現(xiàn):

extern "C" JNIEXPORT jlong JNICALL Java_org_tensorflow_lite_examples_superresolution_MainActivity_initWithByteBufferFromJNI(JNIEnv *env, jobject thiz, jobject model_buffer, jboolean use_gpu) { const void *model_data = static_cast(env->GetDirectBufferAddress(model_buffer)); jlong model_size_bytes = env->GetDirectBufferCapacity(model_buffer); SuperResolution *super_resolution = new SuperResolution(model_data, static_cast(model_size_bytes), use_gpu); if (super_resolution->IsInterpreterCreated()) { LOGI("Interpreter is created successfully"); return reinterpret_cast(super_resolution); } else { delete super_resolution; return 0; } }

解釋執(zhí)行器建立之后,運行模型實際上就非常簡單了,我們只需要按照 TFLite C API 來就好。不過我們需要注意的是如何從每個像素中抽取 RGB 值:

// Extract RGB values from each pixel float input_buffer[kNumberOfInputPixels * kImageChannels]; for (int i = 0, j = 0; i < kNumberOfInputPixels; i++) { // Alpha is ignored input_buffer[j++] = static_cast((lr_img_rgb[i] >> 16) & 0xff); input_buffer[j++] = static_cast((lr_img_rgb[i] >> 8) & 0xff); input_buffer[j++] = static_cast((lr_img_rgb[i]) & 0xff); }

TFLite C API
https://github.com/tensorflow/tensorflow/blob/master/tensorflow/lite/c/c_api.h

運行完模型后我們需要再將 RGB 值再打包進每個像素:

// Postprocess the output from TFLite int clipped_output[kImageChannels]; auto rgb_colors = std::make_unique(kNumberOfOutputPixels); for (int i = 0; i < kNumberOfOutputPixels; i++) { for (int j = 0; j < kImageChannels; j++) { clipped_output[j] = std::max(0, std::min(255, output_buffer[i * kImageChannels + j])); } // When we have RGB values, we pack them into a single pixel. // Alpha is set to 255. rgb_colors[i] = (255u & 0xff) << 24 | (clipped_output[0] & 0xff) << 16 | (clipped_output[1] & 0xff) << 8 | (clipped_output[2] & 0xff); }

那么到這里我們就完成了這個 app 的關(guān)鍵步驟,我們可以用這個 app 來生成超分圖片。您可以在對應(yīng)的代碼庫中看到更多信息。我們希望這個范例能作為一個好的參考來幫助剛剛起步的開發(fā)者更快的掌握如何使用 TFLite C/C++ API 來搭建自己的機器學(xué)習(xí) app。

對應(yīng)的代碼庫中
https://github.com/tensorflow/examples/tree/master/lite/examples/super_resolution

致謝

作者十分感謝 @captain__pool 將他實現(xiàn)的 ESRGAN 模型上傳到 TFHub, 以及 TFLite 團隊的 Tian Lin 和 Jared Duke 提供十分有幫助的反饋。

— 參考 —

[1] Christian Ledig, Lucas Theis, Ferenc Huszar, Jose Caballero, Andrew Cunningham, Alejandro Acosta, Andrew Aitken, Alykhan Tejani, Johannes Totz, Zehan Wang, Wenzhe Shi. 2016. Photo-Realistic Single Image Super-Resolution Using a Generative Adversarial Network.

[2] Xintao Wang, Ke Yu, Shixiang Wu, Jinjin Gu, Yihao Liu, Chao Dong, Chen Change Loy, Yu Qiao, Xiaoou Tang. 2018. ESRGAN: Enhanced Super-Resolution Generative Adversarial Networks.

[3] Tensorflow 2.x based implementation of EDSR, WDSR and SRGAN for single image super-resolution

https://github.com/krasserm/super-resolution

[4] @captain__pool 的 ESGRAN 代碼實現(xiàn)

https://github.com/captain-pool/GSOC

[5] Eirikur Agustsson, Radu Timofte. 2017. NTIRE 2017 Challenge on Single Image Super-Resolution: Dataset and Study.

責(zé)任編輯:xj

原文標(biāo)題:學(xué)習(xí)教程 | 使用 TensorFlow Lite 在 Android App 中生成超分圖片

文章出處:【微信公眾號:TensorFlow】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Android
    +關(guān)注

    關(guān)注

    12

    文章

    3938

    瀏覽量

    127545
  • APP
    APP
    +關(guān)注

    關(guān)注

    33

    文章

    1574

    瀏覽量

    72569
  • tensorflow
    +關(guān)注

    關(guān)注

    13

    文章

    329

    瀏覽量

    60540

原文標(biāo)題:學(xué)習(xí)教程 | 使用 TensorFlow Lite 在 Android App 中生成超分圖片

文章出處:【微信號:tensorflowers,微信公眾號:Tensorflowers】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    APP開發(fā)中,如何使用加密芯片?

    加密芯片是一種專門設(shè)計用于保護信息安全的硬件設(shè)備,它通過內(nèi)置的加密算法對數(shù)據(jù)進行加密和解密,以防止敏感數(shù)據(jù)被竊取或篡改。如下圖HD-RK3568-IOT工控板,搭載ATSHA204A加密芯片,常用于有安全防護要求的工商業(yè)場景,下文將為大家介紹
    的頭像 發(fā)表于 10-31 17:43 ?429次閱讀
    <b class='flag-5'>安</b><b class='flag-5'>卓</b><b class='flag-5'>APP</b>開發(fā)中,如何使用加密芯片?

    AIC3262 CODEC能否下運用?

    我們有多路音頻混音應(yīng)用需求(雙路MIC. LINE IN, I2S 音源輸入,耳機輸出監(jiān)聽及混音后錄音),針對混音還有通過DSP 作混響, 10段EQ應(yīng)用, 該裝置需要在環(huán)境下運行。不知TI AIC3262 CODEC能否
    發(fā)表于 10-29 08:19

    TAS5731想在app中的平衡器界面中直觀的根據(jù)對應(yīng)頻率的值調(diào)整寄存器值有什么方法嗎?

    想在app中的平衡器界面中直觀的根據(jù)對應(yīng)頻率的值調(diào)整寄存器值有什么方法嗎? 之前是通過TAS57X1 GDE工具調(diào)好后生成的參數(shù)設(shè)置值寫進去,每次只能調(diào)好一組參數(shù)設(shè)置進去
    發(fā)表于 10-22 07:30

    快速部署Tensorflow和TFLITE模型Jacinto7 Soc

    電子發(fā)燒友網(wǎng)站提供《快速部署Tensorflow和TFLITE模型Jacinto7 Soc.pdf》資料免費下載
    發(fā)表于 09-27 11:41 ?0次下載
    快速部署<b class='flag-5'>Tensorflow</b>和TFLITE<b class='flag-5'>模型</b><b class='flag-5'>在</b>Jacinto7 Soc

    基于ArkTS語言的OpenHarmony APP應(yīng)用開發(fā):圖片處理

    1、程序介紹本案例使用TextArea實現(xiàn)多文本輸入,使用mediaLibrary實現(xiàn)在相冊中獲取圖片,使用image生成pixelMap,使用pixelMap的scale(),crop
    的頭像 發(fā)表于 09-20 08:07 ?629次閱讀
    基于ArkTS語言的OpenHarmony <b class='flag-5'>APP</b>應(yīng)用開發(fā):<b class='flag-5'>圖片</b>處理

    工控機inbox系列有不支持32位app的嗎?

    工控機 inbox系列有不支持32位app的嗎
    發(fā)表于 07-24 06:59

    如何在Tensorflow中實現(xiàn)反卷積

    TensorFlow中實現(xiàn)反卷積(也稱為轉(zhuǎn)置卷積或分?jǐn)?shù)步長卷積)是一個涉及多個概念和步驟的過程。反卷積在深度學(xué)習(xí)領(lǐng)域,特別是圖像分割、圖像分辨率、以及
    的頭像 發(fā)表于 07-14 10:46 ?658次閱讀

    使用TensorFlow進行神經(jīng)網(wǎng)絡(luò)模型更新

    使用TensorFlow進行神經(jīng)網(wǎng)絡(luò)模型的更新是一個涉及多個步驟的過程,包括模型定義、訓(xùn)練、評估以及根據(jù)新數(shù)據(jù)或需求進行模型微調(diào)(Fine-tuning)或重新訓(xùn)練。下面我將詳細(xì)闡述這
    的頭像 發(fā)表于 07-12 11:51 ?441次閱讀

    請問ESP32如何運行TensorFlow模型

    請問ESP32如何運行TensorFlow模型
    發(fā)表于 07-09 07:30

    tensorflow簡單的模型訓(xùn)練

    本文中,我們將詳細(xì)介紹如何使用TensorFlow進行簡單的模型訓(xùn)練。TensorFlow是一個開源的機器學(xué)習(xí)庫,廣泛用于各種機器學(xué)習(xí)任務(wù),包括圖像識別、自然語言處理等。我們將從安裝
    的頭像 發(fā)表于 07-05 09:38 ?711次閱讀

    keras模型轉(zhuǎn)tensorflow session

    在這篇文章中,我們將討論如何將Keras模型轉(zhuǎn)換為TensorFlow session。 Keras和TensorFlow簡介 Keras是一個高級神經(jīng)網(wǎng)絡(luò)API,它提供了一種簡單、快速的方式
    的頭像 發(fā)表于 07-05 09:36 ?560次閱讀

    如何使用Tensorflow保存或加載模型

    TensorFlow是一個廣泛使用的開源機器學(xué)習(xí)庫,它提供了豐富的API構(gòu)建和訓(xùn)練各種深度學(xué)習(xí)模型模型訓(xùn)練完成后,保存
    的頭像 發(fā)表于 07-04 13:07 ?1606次閱讀

    KOALA人工智能圖像生成模型問世

    近日,韓國科學(xué)團隊宣布研發(fā)出名為 KOALA 的新型人工智能圖像生成模型,該模型速度和質(zhì)量上均實現(xiàn)了顯著突破。KOALA 能夠短短 2
    的頭像 發(fā)表于 03-05 10:46 ?802次閱讀

    谷歌模型怎么用PS打開文件和圖片

    谷歌模型本身并不是用Adobe Photoshop(簡稱PS)打開的文件和圖片格式。谷歌模型通常是用于機器學(xué)習(xí)和深度學(xué)習(xí)的模型文件,如TensorF
    的頭像 發(fā)表于 02-29 18:25 ?1485次閱讀

    GHDS中生成Sprite順序,程序無法正常運行是怎么回事?

    你好:我有一個關(guān)于GHDS中生成Sprite順序的問題,當(dāng)我GHDS中建立多個Sprite,其中包括單個符號片、通過刷新圖片的幾組數(shù)據(jù),和背景
    發(fā)表于 02-22 07:23
    主站蜘蛛池模板: 无限资源在线观看8| 各种场合肉H校园1V1| 久久这里只有精品视频e| 亚洲在线国产日韩欧美| 美女洗澡脱得一二干净| 成年视频国产免费观看| 亚洲 日韩 自拍 视频一区| 六六影院午夜伦理| 国产成人精品免费视频下载| 夜夜国产亚洲视频香蕉| 人妻久久久精品99系列AV| 韩国女主播内部vip自带氏巾 | 一品道门在线视频| 久欠热视频精品首页| 亚洲va久久久久| 两个客户一起吃我的奶| 国产二区自拍| 3d无遮挡h肉动漫在线播放| 色噜噜噜视频| 久久这里只精品热在线99| 国产精品高潮AV久久无码| 3D内射动漫同人资源在线观看| 天美传媒在线完整免费观看网站| 麻豆狠色伊人亚洲综合网站| 国产三级级在线电影| YELLOW在线观看高清视频免费| 亚洲午夜精品A片久久WWW软件 | 女人18毛片| 狼与美女谐音歌词| 久久精品亚洲AV高清网站性色| 国产在线综合色视频| 国产精品日韩欧美一区二区三区 | 久久99综合国产精品亚洲首页| 国产午夜精品一区二区| 国产精品亚洲AV色欲在线观看 | 免费果冻传媒2021在线看| 久久精品国产eeuss| 久草在在线免视频在线观看| 激情床戏揉胸吃胸视频| 激情内射亚洲一区二区三区爱妻| 国内精品不卡一区二区三区|