摘要:在上一篇文章圖工具的優(yōu)化實現(xiàn)文本居中中,我們已經(jīng)實現(xiàn)了對插入字體的左中右對齊顯示,那因為上期文章混進去了不少語法講解,所以后面的內(nèi)容就順延到這啦,哈哈哈。
在上一篇文章【圖工具的優(yōu)化——實現(xiàn)文本居中】中,我們已經(jīng)實現(xiàn)了對插入字體的左中右對齊顯示,那因為上期文章混進去了不少語法講解,所以后面的內(nèi)容就順延到這啦,哈哈哈。
我比較長怎么辦啊?我們的斗圖小工具,現(xiàn)在面臨這一個苦惱,這些文本他壞,一會長一會短的,一旦有個很長很長的,直接就捅到里面去了,根本顯示不全啊,這咋辦呢?
我稍微想了下,這個也簡單,我可以不斷的減小字號,直到我們的空白區(qū)域可以放得下:
while (CONST_IMG_WIDTH <= textLen + 2*off_set[0]) and fontSize >= 1: fontSize -= 1 imageFont = ImageFont.truetype("./resources/msyh.ttc", fontSize) textLen = draw.textsize(text, imageFont)[0] print("當前字號{},文本寬度{}".format(fontSize, textLen))
看看效果吧:
python emofigther.py 長的就會變細變細了就能塞下了嘛
效果其實還是挺好的,就是實現(xiàn)的方式有點太low了,而且不停的加載字體,看著就覺得開銷很大,那有沒有更優(yōu)雅的辦法呢?
來做點小數(shù)據(jù)分析吧下面我們來研究一下,字體的字號大小跟其經(jīng)過PIL繪制之后的大小有什么關(guān)系,接下來我們主要會用到Numpy、matplotlib跟scipy幾個庫。
先來準備點數(shù)據(jù)樣本,通過draw.textSize函數(shù),繪制單個字并獲取其大小:
# 準備分析數(shù)據(jù) font_num = [] text_size = [] for i in range(1, 31): imageFont = ImageFont.truetype("./resources/msyh.ttc", i) text_size.append(draw.textsize("字", font=imageFont)) font_num.append(i)
借助matplotlib的pyplot模塊,我們可以繪制各種圖像,先讓我們以字號為x軸,字體寬度為y軸,畫出樣本的散點圖
import matplotlib.pyplot as plt #.... # scatter畫出散點圖,以字號為x軸,字體寬度為y軸 # 在分析前,先繪制散點圖,對大致的函數(shù)形狀進行分析 plt.scatter(list(map(lambda x: x[0], text_size)), font_num, color="b", label=u"字體寬度")
運行之后,會彈出這樣一個窗口
好的,從這個圖片上分析,我們的字號與寬度是一個完美的正相關(guān),用函數(shù)來表示,就是
$$ y=kx+b $$
那問題來了,我們?nèi)绾稳〉胟和b兩個常數(shù)的值呢,那個說k=1,b=0的同學(xué)你坐下!我們要嚴謹,看出來了也不要說出來嘛,額,不對,就算是看出來了,但我們還是要以嚴謹?shù)姆绞饺プC明他的!為了求出k和b兩個常數(shù)的最優(yōu)解,我們需要用到scipy.optimize模塊的leastsq函數(shù),這個函數(shù)實現(xiàn)了“最小二乘法”算法,通過不斷的嘗試不同的常數(shù),求出與期望結(jié)果誤差最小的最優(yōu)解,那下面就簡單介紹一下怎么用leastsq對函數(shù)進行擬合:
首先,我們要定義一個函數(shù)形狀(一元一次、一元二次、多元多次)
def func_shape(p, x): """定義函數(shù)形狀,哈哈哈,就是 y = kx+b 直線! Args: p: 常數(shù) x: 自變量 Returns: 函數(shù)運算求得的因變量 """ k,b = p return k*x + b
然后定義一個誤差計算函數(shù)
def func_err(p, x, y): """定義誤差函數(shù) Args: p: 常數(shù) x: 自變量 y: 驗證因變量 Returns: 返回函數(shù)運算結(jié)果與驗證因變量之間的誤差值 """ return func_shape(p, x) - y
使用leastsq函數(shù)進行求解,獲取最優(yōu)常量k、b
from scipy.optimize import leastsq r = leastsq(func_err, p0, args=(_font_size_np[:,0], _font_num_np)) # 計算結(jié)果中的r[0]為一個元組,為求得的k和b k, b = r[0] # 最后我們得出結(jié)論,擬合結(jié)果為y = x print("k=",k,"b=",b, "r=", r)
把擬合曲線也畫在圖標上:
# 畫出擬合線,以字號為X軸,函數(shù)運算結(jié)果為Y軸 plt.plot(X,func_shape((k, b), X),color="orange",label=u"字體寬度擬合",linewidth=2)
可以看到擬合曲線完美的經(jīng)過了每一個數(shù)據(jù)點,這基本就可以認定我們的擬合曲線基本上就是 y=x了,
當然,我們的樣本量現(xiàn)在是非常少的,也非常的規(guī)整,其實更多情況下,數(shù)據(jù)可能是這樣分布的:
這樣是不是就能體現(xiàn)出擬合的意義了呢?
# 方法2:通過簡單的數(shù)據(jù)分析,我們研究出字體寬度 = 字體字號這一函數(shù) def char_len(text_size): return text_size # 減小字號,直到 字數(shù)*單位寬度 適應(yīng)空白區(qū)域?qū)挾? while char_len(fontSize) * len(text) > (CONST_IMG_WIDTH - 2*off_set[0]): fontSize -= 1學(xué)霸們,動起來!
如果有小伙伴們看到這個章節(jié),對本章節(jié)描述的數(shù)據(jù)分析過程非常感興趣,而且覺得自己的數(shù)學(xué)功底非常扎實(特別是離散數(shù)學(xué)、概率、統(tǒng)計這方面的)你們請離開本系列文章——因為你們已經(jīng)了解到了在科學(xué)計算領(lǐng)域,Python也是一把不錯的兵刃,而你們,被選中的魔法少女(大霧)們,可以去深入了解以下幾個庫,然后投入到轟轟烈烈的數(shù)據(jù)分析事業(yè)中去吧!
Numpy —— 為Python提供了多維數(shù)組的擴展,同時也提供了豐富的集合運算、矩陣運算、向量運算,可以說是Python科學(xué)計算的基石
matplotlib —— 可產(chǎn)生出版物質(zhì)量的圖表的2D繪圖庫,數(shù)據(jù)可視化是數(shù)據(jù)分析不可或缺的手段之一
pandas —— 數(shù)據(jù)分析庫,包括數(shù)據(jù)框架(dataframes)等結(jié)構(gòu)
Scipy —— 高級科學(xué)計算庫,提供了大量的科學(xué)計算工具及算法,例如本文用到的leastsq最小二乘法求解多項式算法(媽媽再也不用擔心我要重復(fù)造輪子了!)
這些庫的相關(guān)資料都非常的好找,而小弟又才疏學(xué)淺,就不再對它們在作過多展開了!
因為作者數(shù)學(xué)水平太差了,我們下期換個方向玩按照慣例,放上此次的源碼:
GitHub
其中的char_analysis.py即為本文所屬的函數(shù)擬合例子
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.hztianpu.com/yun/42121.html
摘要:大家還記得上一篇文章來學(xué)點吧從一個斗圖小工具開始中最后提到的幾個問題么,我們這次就來解決一下其中難度最大的一個文本居中看,我把代碼優(yōu)化了上次之后,我偷偷把代碼優(yōu)化了,現(xiàn)在的方法長這樣創(chuàng)建表情圖調(diào)試用生成表情包對的,我把那些老長老長 showImg(https://segmentfault.com/img/bVbeDVL?w=250&h=250); 大家還記得上一篇文章0.來學(xué)點Pyth...
摘要:因此,本文將會以一些正經(jīng)的嚴謹?shù)挠猩疃鹊拇蟾虐傻恼n題,慢慢的接觸人工智能的相關(guān)知識。 Before The Beginning ????近年,技術(shù)圈炒的最火的兩個話(ba)題(gua)不外乎就是人工智障智能以及炒幣區(qū)塊鏈了,這個系列文章我主要以一個小菜鳥的角度一步一步的對人工智能的相關(guān)知識做一點了解,也算是一個顫顫巍巍追著AI浪潮公交車的社會主義五好青年,咳咳,扯遠了...其實對于人工...
摘要:深度學(xué)習(xí)在過去的幾年里取得了許多驚人的成果,均與息息相關(guān)。機器學(xué)習(xí)進階筆記之一安裝與入門是基于進行研發(fā)的第二代人工智能學(xué)習(xí)系統(tǒng),被廣泛用于語音識別或圖像識別等多項機器深度學(xué)習(xí)領(lǐng)域。零基礎(chǔ)入門深度學(xué)習(xí)長短時記憶網(wǎng)絡(luò)。 多圖|入門必看:萬字長文帶你輕松了解LSTM全貌 作者 | Edwin Chen編譯 | AI100第一次接觸長短期記憶神經(jīng)網(wǎng)絡(luò)(LSTM)時,我驚呆了。原來,LSTM是神...
閱讀 2719·2021-09-13 10:26
閱讀 1990·2021-09-03 10:28
閱讀 2051·2019-08-30 15:44
閱讀 867·2019-08-29 14:07
閱讀 454·2019-08-29 13:12
閱讀 2205·2019-08-26 11:44
閱讀 2395·2019-08-26 11:36
閱讀 2062·2019-08-26 10:19