1. 程式人生 > >【百度飛漿AI Studio】2、感性快速體驗深度學習的線性歸回預測房價

【百度飛漿AI Studio】2、感性快速體驗深度學習的線性歸回預測房價

百度學習原文地址: https://www.paddlepaddle.org.cn/documentation/docs/zh/1.5/beginners_guide/basics/fit_a_line/README.cn.html

import paddle
import paddle.fluid as fluid
import numpy
import math
import sys
from __future__ import print_function
BATCH_SIZE = 20

train_reader = paddle.batch(
    paddle.reader.shuffle(
        paddle.dataset.uci_housing.train(), buf_size=500),
        batch_size=BATCH_SIZE)

test_reader = paddle.batch(
    paddle.reader.shuffle(
        paddle.dataset.uci_housing.test(), buf_size=500),
        batch_size=BATCH_SIZE)
x = fluid.layers.data(name='x', shape=[13], dtype='float32') # 定義輸入的形狀和資料型別
y = fluid.layers.data(name='y', shape=[1], dtype='float32') # 定義輸出的形狀和資料型別
y_predict = fluid.layers.fc(input=x, size=1, act=None) # 連線輸入和輸出的全連線層

main_program = fluid.default_main_program() # 獲取預設/全域性主函式
startup_program = fluid.default_startup_program() # 獲取預設/全域性啟動程式

cost = fluid.layers.square_error_cost(input=y_predict, label=y) # 利用標籤資料和輸出的預測資料估計方差
avg_loss = fluid.layers.mean(cost) # 對方差求均值,得到平均損失

sgd_optimizer = fluid.optimizer.SGD(learning_rate=0.001)
sgd_optimizer.minimize(avg_loss)

#克隆main_program得到test_program
#有些operator在訓練和測試之間的操作是不同的,例如batch_norm,使用引數for_test來區分該程式是用來訓練還是用來測試
#該api不會刪除任何操作符,請在backward和optimization之前使用
test_program = main_program.clone(for_test=True)

use_cuda = False
place = fluid.CUDAPlace(0) if use_cuda else fluid.CPUPlace() # 指明executor的執行場所

###executor可以接受傳入的program,並根據feed map(輸入對映表)和fetch list(結果獲取表)向program中新增資料輸入運算元和結果獲取運算元。使用close()關閉該executor,呼叫run(...)執行program。
exe = fluid.Executor(place)


num_epochs = 100

def train_test(executor, program, reader, feeder, fetch_list):
    accumulated = 1 * [0]
    count = 0
    for data_test in reader():
        outs = executor.run(program=program,
                            feed=feeder.feed(data_test),
                            fetch_list=fetch_list)
        accumulated = [x_c[0] + x_c[1][0] for x_c in zip(accumulated, outs)] # 累加測試過程中的損失值
        count += 1 # 累加測試集中的樣本數量
    return [x_d / count for x_d in accumulated] # 計算平均損失
%matplotlib inline
params_dirname = "fit_a_line.inference.model"
feeder = fluid.DataFeeder(place=place, feed_list=[x, y])
exe.run(startup_program)
train_prompt = "train cost"
test_prompt = "test cost"
from paddle.utils.plot import Ploter
plot_prompt = Ploter(train_prompt, test_prompt)
step = 0

exe_test = fluid.Executor(place)   


for pass_id in range(num_epochs):
    for data_train in train_reader():
        avg_loss_value, = exe.run(main_program,
                                  feed=feeder.feed(data_train),
                                  fetch_list=[avg_loss])
        if step % 10 == 0: # 每10個批次記錄並輸出一下訓練損失
            plot_prompt.append(train_prompt, step, avg_loss_value[0])
            plot_prompt.plot()
            print("%s, Step %d, Cost %f" %
                      (train_prompt, step, avg_loss_value[0]))
        if step % 100 == 0:  # 每100批次記錄並輸出一下測試損失
            test_metics = train_test(executor=exe_test,
                                     program=test_program,
                                     reader=test_reader,
                                     fetch_list=[avg_loss.name],
                                     feeder=feeder)
            plot_prompt.append(test_prompt, step, test_metics[0])
            plot_prompt.plot()
            print("%s, Step %d, Cost %f" %
                      (test_prompt, step, test_metics[0]))
            if test_metics[0] < 10.0: # 如果準確率達到要求,則停止訓練
                break

        step += 1

        if math.isnan(float(avg_loss_value[0])):
            sys.exit("got NaN loss, training failed.")

        #儲存訓練引數到之前給定的路徑中
        if params_dirname is not None:
            fluid.io.save_inference_model(params_dirname, ['x'], [y_predict], exe)
infer_exe = fluid.Executor(place)
inference_scope = fluid.core.Scope()


def save_result(points1, points2):
    import matplotlib
    matplotlib.use('Agg')
    import matplotlib.pyplot as plt
    x1 = [idx for idx in range(len(points1))]
    y1 = points1
    y2 = points2
    l1 = plt.plot(x1, y1, 'r--', label='predictions')
    l2 = plt.plot(x1, y2, 'g--', label='GT')
    plt.plot(x1, y1, 'ro-', x1, y2, 'g+-')
    plt.title('predictions VS GT')
    plt.legend()
    plt.savefig('./image/prediction_gt.png')
    
with fluid.scope_guard(inference_scope):
    [inference_program, feed_target_names,
     fetch_targets] = fluid.io.load_inference_model(params_dirname, infer_exe) # 載入預訓練模型
    batch_size = 10

    infer_reader = paddle.batch(
        paddle.dataset.uci_housing.test(), batch_size=batch_size) # 準備測試集

    infer_data = next(infer_reader())
    infer_feat = numpy.array(
        [data[0] for data in infer_data]).astype("float32") # 提取測試集中的資料
    infer_label = numpy.array(
        [data[1] for data in infer_data]).astype("float32") # 提取測試集中的標籤

    assert feed_target_names[0] == 'x'
    results = infer_exe.run(inference_program,
                            feed={feed_target_names[0]: numpy.array(infer_feat)},
                            fetch_list=fetch_targets) # 進行預測
    #列印預測結果和標籤並可視化結果
    print("infer results: (House Price)")
    for idx, val in enumerate(results[0]):
        print("%d: %.2f" % (idx, val)) # 列印預測結果

    print("\nground truth:")
    for idx, val in enumerate(infer_label):
        print("%d: %.2f" % (idx, val)) # 列印標籤值

    save_result(results[0], infer_label) # 儲存圖片
    
    
    

把程式碼複製進去

點選執行檢視效果:

相關推薦

漿AI Studio2感性快速體驗深度學習線性預測房價

百度學習原文地址: https://www.paddlepaddle.org.cn/documentation/docs/zh/1

漿AI Studio1漿AI Studio的初次使用

百度在AI人工智慧方面的發力巨大,開源了優秀的PaddlePaddle平臺,為開發者提供支援。 環境方面和硬體配備方面如果對於新

蜂口 | AI人工智慧人臉風格化——龍鵬 深度學習與人臉影象應用連載(九)

本次我們接著上一節內容繼續分享,今天的分享內容是人臉風格化這個主題。同樣我們將從以下幾個方面給大家進行分享: 首先,我們會對風格化做一個簡單的介紹。風格化到底是一個什麼樣的課題?在我們這裡實際上包含了兩層內容,即通用的風格化問題和與人臉有關的風格化問題。 其次,我們將會對風格化中的核

圖表頁面引入多個圖表,讓其只適應

++ i++ top color win setoption 實例 get logs 【百度圖表】頁面引入多個圖表,讓其只適應 網上發現有個這樣的方法讓圖表自適應,window.onresize = myChart.resize; 但是發現好像只有最後一個有效,於是就有了

搜索框

add size nts on() post 百度搜索 aid style left html樣式 <div class="img"></div> <div class="yi"> <input type="text" id

ARAndroiddemo工程使用手記

AR【百度AR】【Android】demo工程使用手記 demo工程獲取和註意事項 百度AR平臺地址:https://ar.baidu.com/testapply 技術文檔地址:https://ai.baidu.com/docs#/DuMixAR-Android-SDK/top AR內容管理地址:https

雲破解Aria2GUI使用教程

兩個工具: Aria2GUI 下載地址 Aria2GUI Chrome外掛 下載地址 Chrome外掛設定:下載後文件解壓一下,開啟chrome瀏覽器-》更多工具-》擴充套件程式,直接將資料夾拖入即可;下面為成功例項 先開啟Aria2GUI, 找到自己網盤對應資源介面,重新整理

大型網站的HTTPS實踐(一)——HTTPS協議和原理

大型網站的HTTPS實踐(一)——HTTPS協議和原理 原創 網路通訊/物聯網 作者:AIOps智慧運維 時間:2018-11-09 15:07:39  349  0   前言

大型網站的HTTPS實踐(二)——HTTPS加密演算法介紹

大型網站的HTTPS實踐(二)——HTTPS加密演算法介紹 原創 網路通訊/物聯網 作者:AIOps智慧運維 時間:2018-11-09 15:09:43  358  0   前言

大型網站的HTTPS實踐(三)——HTTPS對效能的影響

HTTPS在保護使用者隱私,防止流量劫持方面發揮著非常關鍵的作用,但與此同時,HTTPS也會降低使用者訪問速度,增加網站伺服器的計算資源消耗。本文主要介紹HTTPS對效能的影響。 HTTPS對訪問速度的影響 在介紹速度優化策略之前,先來看下HTTPS對速度有什麼影響。影響主要來自兩方面:協議互動所增加的網

地圖地圖指定省市進行描邊處理,省市外進行半透明遮蓋。

//指定省市進行描邊處理,省市外進行半透明遮蓋。 function getBoundary2(map,city){ var bdary = new BMap.Boundary(); bdary.get(city, function(rs){//獲取行政區域

地圖地圖上框出邊界線

程式碼: 一、建立地圖 建立地圖物件;設立中心點以及地圖級別。 var map = new BMap.Map("container"); map.centerAndZoom(new BMap.Point(116.403765, 39.914850), 12); 二、新增地圖事件

Ruby環境搭建,附網盤分享連結,不用擔心下載慢哦!

首先要下載,下載地址:https://rubyinstaller.org/downloads/ 如果慢的話,可以直接通過我的百度網盤分享下載哦。連結: https://pan.baidu.com/s/1P6rkF5CwK5yyrxUrh-jj8w 提取碼: c38h 點選對應版

LOGO許可權三天時間從獲取LOGO許可權到稽核通過

  一、百度LOGO許可權是什麼?   在百度站長平臺的介紹中有關於網站logo許可權的說明:官網LOGO旨在幫助站點提升百度搜索的優質展示。因此,獲得logo許可權也可以說是百度對於我們網站質量的認可。   二、如何獲取LOGO許可權?   在百度站長平臺有關於L

地圖製作多途經點的線路導航,模擬運動 (vue,typescript)

  網上有從起點到終點的模擬線路和運動,途經點的比較少。 結合網上demo,再進行了一下修改。 VUE (Typescript),先在index.html裡引用 <!DOCTYPE html> <html lang="en"> <head>

地圖API如何使用suggestion--下拉列表方式的搜尋建議

                摘要:  百度地圖上有一個很強大的搜尋建議功能,以下拉列表的方式展示出來。比如,輸入“百度”,下拉列表中就會出現“北京市海淀區百度線上網路技術(北京)有限公司”。這個如何實現呢?讓我們一步一步來學習。---------------------------------------

在MVC中應用富文字編輯器

1.下載.NET版本的百度富文字編輯器,前往 下載.NET版本百度富文字框  2.解壓下載的.zip壓縮包,將utf8-.net資料夾名稱改為:ueditor,複製到MVC根目錄下面。結構如下: App_Code 上的檔案是應用程式的原始碼 Config.cs 負

運營部面試記錄

1. 投遞概況 投遞部門:百度運維部(睿思內推)8月初投遞 投遞崗位:智慧平臺研發工程師 崗位描述: 負責百度運維智慧平臺(智慧運維機器人)的研究,設計與實現 負責百度超大規模系統,產品運維資料分析和機器學習模型/策略/演算法的設計和實現 參與產品系統

群面2017年春招-實習產品經理-群面覆盤

本來以為掛掉的群面,突然收到了二面的通知。緊張、興奮、一頭霧水。。。 不知道bd每年的春招hc和每輪面試的淘汰率,在準備群面前確實是相對輕鬆的,正常準備,而且如此大公司的群面淘汰率是很高的,我對自己的

如何在linux上部署網站環境-雲伺服器bcc+花生殼管理

1.環境介紹伺服器:用的是百度雲伺服器BCC域名管理軟體:花生殼2.具體介紹2-1.百度雲伺服器BCC當時決定找一個雲伺服器來搭建自己的網站,因為前面做了一個小網站一直是用公司的電腦做一個伺服器。但是由於公司的電腦是windows系統,長時間開機會造成非常嚴重的卡頓,導致無法