說一個(gè)簡單的辦法:在公司內(nèi)部注冊一個(gè)域名,搭一個(gè) http 服務(wù),數(shù)據(jù)存在是 mysql 數(shù)據(jù)庫里。每個(gè)項(xiàng)目實(shí)例定期將統(tǒng)計(jì)信息匯報(bào)到這個(gè) http 服務(wù)。再寫一個(gè)查詢頁面,從 mysql 里查出數(shù)據(jù)并展示。
損失函數(shù)的選取,取決于你的模型
舉個(gè)例子,例如最常用的binary_crossentropy
import theano.tensor as T
cost = T.sum(-(real*T.log(outputs) + (1-real)*T.log(1-outputs)))
其中real是預(yù)設(shè)輸出對(duì)應(yīng)你的(1,0,0,1,0),outputs是實(shí)際輸出對(duì)應(yīng)你的(1,0,0,0,0)的轉(zhuǎn)置
redis通過一致性hash算法保證寫入時(shí)的服務(wù)器和讀取時(shí)的服務(wù)器在一臺(tái)來解決分布式環(huán)境問題。你的問題太過模糊,現(xiàn)在已經(jīng)遇到集群性能瓶頸了?
啥文件占滿了系統(tǒng)盤?aof嗎?改用rdb吧,rdb占用磁盤大小不可能超過內(nèi)存大小的。
另外,查下Redis配置文件的寫法,配置中是可以設(shè)置存儲(chǔ)文件路徑的。
redis是多線程的,你會(huì)問如何確認(rèn),其實(shí)很簡單,用gdb確認(rèn)即可,我服務(wù)器上的剛好有部署redis,它的進(jìn)程pid為26716。
[root@rookie_centos myXxl]# gdb -p 26716
[Thread debugging using libthread_db enabled]
Loaded symbols for /lib64/libpthread.so.0
Reading symbols from /lib64/libc.so.6...(no debugging symbols found)...done.
Loaded symbols for /lib64/libc.so.6
Reading symbols from /lib64/ld-linux-x86-64.so.2...(no debugging symbols found)...done.
Loaded symbols for /lib64/ld-linux-x86-64.so.2
0x00007f6e8faa81c3 in epoll_wait () from /lib64/libc.so.6
Missing separate debuginfos, use: debuginfo-install glibc-2.12-1.209.el6_9.2.x86_64
(gdb) bt
#0 0x00007f6e8faa81c3 in epoll_wait () from /lib64/libc.so.6
#1 0x000000000042491e in aeApiPoll (eventLoop=0x7f6e894340a0, flags=11) at ae_epoll.c:112
#2 aeProcessEvents (eventLoop=0x7f6e894340a0, flags=11) at ae.c:404
#3 0x0000000000424d3b in aeMain (eventLoop=0x7f6e894340a0) at ae.c:464
#4 0x000000000042d902 in main (argc=<value optimized out>, argv=0x7ffe660d3dd8) at server.c:3865
(gdb) info threads
4 Thread 0x7f6e893ff700 (LWP 26718) 0x00007f6e8fd5e68c in pthread_cond_wait@@GLIBC_2.3.2 () from /lib64/libpthread.so.0
3 Thread 0x7f6e889fe700 (LWP 26719) 0x00007f6e8fd5e68c in pthread_cond_wait@@GLIBC_2.3.2 () from /lib64/libpthread.so.0
2 Thread 0x7f6e87ffd700 (LWP 26720) 0x00007f6e8fd5e68c in pthread_cond_wait@@GLIBC_2.3.2 () from /lib64/libpthread.so.0
* 1 Thread 0x7f6e9060c740 (LWP 26716) 0x00007f6e8faa81c3 in epoll_wait () from /lib64/libc.so.6
(gdb)
正如上面一樓所說redis采用的是reactor的并發(fā)模型,也就是主線程使用io復(fù)用對(duì)多個(gè)客戶端進(jìn)行監(jiān)聽,有請求過來時(shí),喚醒工作線程來做讀io操作讀取客戶的請求數(shù)據(jù),工作線程處理完請求向主線程注冊寫請求,客戶端io可寫時(shí)主線程喚醒工作線程,工作線程再進(jìn)行寫io操作把應(yīng)答發(fā)送給客戶端。主線程通過條件變量來喚醒工作線程,從上面gdb的輸出可以看出工作線程都是調(diào)用pthread_cond_wait后被掛起,在等待主線程的喚醒,主線程則調(diào)用epoll_wait這個(gè)高效的io復(fù)用函數(shù)在等待客戶端的請求。
鏈表替換 node->newnode->node.pnext.pnext 把node.pnext 替換為newnode
原來是 ...->node->node.pnext->node.pnext.pnext->... 以下前后省略
第一句話 newnode.pnext = node.pnext.pnext
變成 ...->node->node.pnext->node.pnext.pnext->...和 newnode.pnext->node.pnext.pnext->...
第二句話 node.pnext = newnode
變成 ...->node->newnode->node.pnext.pnext->... 和 node.pnext->node.pnext.pnext->...
所以self.head是前面的鏈表,后面的鏈表被斷開了,完成了替換的目的
想明白了,我們在建預(yù)測模型的時(shí)候,其實(shí)應(yīng)該全盤考慮各種feature(特征)以及feature crosses(特征組合/特征叉積),并給予系數(shù)wi。至于wi是否會(huì)被學(xué)習(xí)為0,要看后面的數(shù)據(jù)處理,不應(yīng)當(dāng)再建模的時(shí)候想當(dāng)然的就不考慮進(jìn)來(即想當(dāng)然wi=0)。這也是為什么,機(jī)器學(xué)習(xí)引入L1正則、L2正則來使一些系數(shù)降為0,來消除模型的復(fù)雜度,以避免overfitting。
在AOF持久化的過程中,其實(shí)上是分成兩個(gè)部分:
WRITE:根據(jù)條件,將 aof_buf 中的緩存寫入到 AOF 文件。
SAVE:根據(jù)條件,調(diào)用 fsync 或 fdatasync 函數(shù),將 AOF 文件保存到磁盤中。
具體可以參見:http://redisbook.readthedocs....
但具體為何要分成兩個(gè)部分,原因相當(dāng)于“把緩存數(shù)據(jù)寫入aof不就已經(jīng)實(shí)現(xiàn)了同步了嗎”,具體如下:
對(duì)于write函數(shù)而言,其只會(huì)更新內(nèi)存頁緩存,而臟頁的更新取決于os的統(tǒng)一調(diào)度;由于write函數(shù)并不會(huì)一直阻塞直到IO完成才返回,因此期間若時(shí)發(fā)生故障就會(huì)造成數(shù)據(jù)丟失問題(盡管時(shí)間窗很小);對(duì)事務(wù)及數(shù)據(jù)一致性要求高的服務(wù)來說(比如備份服務(wù)),需要通過同步IO原語來提供os級(jí)別的保證,比如AOF中使用的fsync,其目的就是保證文件所有已修改的內(nèi)容內(nèi)容已經(jīng)爭取同步到磁盤(因?yàn)槠鋾?huì)阻塞直到IO完成);簡單來說write不是同步的,fsync是同步且有明確結(jié)果的
順便多說一句,對(duì)于已被打開的文件執(zhí)行寫操作來說,應(yīng)先調(diào)用fflush函數(shù)將修改同步到內(nèi)核緩沖區(qū),然后再調(diào)用fsync函數(shù)執(zhí)行同步調(diào)用,這樣的同步實(shí)現(xiàn)最安全,這也是AOF的源碼實(shí)現(xiàn)方式
這就是個(gè)背包問題,用動(dòng)態(tài)規(guī)劃來解決,嵌套兩個(gè)循環(huán),一個(gè)狀態(tài)轉(zhuǎn)移方程就能出結(jié)果,具體你可以看看這篇文章01背包問題,貼一下他的代碼:
#include<iostream>
#include<algorithm>
using namespace std;
int main()
{
const int N = 6; //物品個(gè)數(shù)
const int V = 10; //背包體積
int C[N + 1] = { -1,5,6,5,1,19,7 }; //第i個(gè)物品的體積(下標(biāo)從1開始)
int W[N + 1] = { -1,2,3,1,4,6,5 }; //第i個(gè)物品的價(jià)值
int F[N + 1][V + 1] = { 0 }; //狀態(tài)
for (int i = 1; i <= N; i++) //對(duì)于第i個(gè)物品
for (int v = 0; v <= V; v++)
{
F[i][v] = F[i - 1][v]; //第i個(gè)不放
if (v - C[i] >= 0 && F[i][v] < F[i - 1][v - C[i]] + W[i]) //如果比它大,再放第i個(gè)
F[i][v] = F[i - 1][v - C[i]] + W[i];
}
cout << "最大價(jià)值是:" << F[N][V] << endl; //9
return 0;
}
希望能幫助到你。
你這個(gè)問題我還是第一次遇到,你是如何設(shè)置成 nil 的?
可以嘗試一下: srem follow43007 ""
如果還不行,就全部讀出來,重寫這個(gè)key吧。
Hadoop,MR.
你這已經(jīng)是線性時(shí)間復(fù)雜度了,再低的話除非是對(duì)數(shù)時(shí)間
Redis把整個(gè)數(shù)據(jù)庫統(tǒng)統(tǒng)加載在內(nèi)存當(dāng)中進(jìn)行操作,每秒可以處理超過 10萬次讀寫操作.
redis的自身讀寫速度遠(yuǎn)大于程序并發(fā)請求.
快的原因是:多進(jìn)程比單進(jìn)程請求量更大
根據(jù)你的需求,疑問一個(gè)問題,
無線大的數(shù)組為什么不直接用數(shù)據(jù)庫解決
redis版本>=2.4可以填多個(gè)參數(shù),你應(yīng)該是版本比2.4小所以才不行
https://redis.io/commands/lpush/
可以考慮在相應(yīng)的組件里import這個(gè)js,不過Typescript默認(rèn)是不允許導(dǎo)入js的,要在tsconfig里配置allowjs
一行一行解釋源碼,估計(jì)也不太好理解;我們從另外一個(gè)角度來看這個(gè)問題。
首先看 bonusCombination 函數(shù)的返回語句是:return (new Function(str)).apply(null, [arr, fun])。這條語句的分解如下::
new Function(str) :含義是利用 str 字符串動(dòng)態(tài)構(gòu)造出函數(shù),我們暫且稱這個(gè)構(gòu)造出來的函數(shù)名為 strFn (即 var strFn = new Function(str))strFn.apply(null, [arr, fun]),轉(zhuǎn)換成我們平時(shí)可以理解的形式就是 strFn(arr, fun)
從這里我們可以看出,這個(gè) bonusCombination 的目的是動(dòng)態(tài)構(gòu)建一個(gè)函數(shù) strFn,該函數(shù)接受兩個(gè)入?yún)?arr 和 fun —— 而這兩個(gè)入?yún)⒕褪俏覀儌鹘o bonusCombination 的入?yún)ⅲ?/p>
對(duì)應(yīng)你給的例子,這里的 arr 就是 [1,2,3,4],而 fun 是 null
我們知道 bonusCombination 還有一個(gè)入?yún)?,就?num,它的作用就是 鍛造 上述動(dòng)態(tài)函數(shù) strFn 的具體內(nèi)容,利用這個(gè) num 入?yún)碛绊懩且淮蠖巫址僮鳎@樣也就影響了動(dòng)態(tài)函數(shù)的具體內(nèi)容:

對(duì)于閱讀這樣的函數(shù),要理解它的含義,最好的辦法就是枚舉。
比如我們讓 num 為 2:那么動(dòng)態(tài)構(gòu)建的函數(shù) strFn 結(jié)構(gòu)體如下:
var strFn2 = function(arr, fun){
var arr=arguments[0];
var fun=arguments[1];
var ret=[];
for (var a = 0; a < arr.length; a++) {
for(var b = a + 1; b < arr.length; b++){
var temp = [];
temp.push(arr[a]);
temp.push(arr[b]);
if(fun){
ret.push(fun(temp));
} else {
ret.push(temp);
}
}
};
return ret;
}
可見函數(shù)體內(nèi)包含 2 次循環(huán)(因?yàn)?num 值為 2),返回的 ret 就是結(jié)果值;
也就說調(diào)用 bonusCombination([1,2,3,4],2) 就相當(dāng)于調(diào)用 strFn2([1,2,3,4]),返回值就是你題中的 [[1,2],[1,3],[1,4],[2,3],[2,4],[3,4]] 。
同樣如果我們讓 num 為 3:那么動(dòng)態(tài)構(gòu)建的函數(shù) strFn 結(jié)構(gòu)體如下:
var strFn3 = function(arr, fun){
var arr=arguments[0];
var fun=arguments[1];
var ret=[];
for (var a = 0; a < arr.length; a++) {
for(var b = a + 1; b < arr.length; b++){
for(var c = b + 1; c < arr.length; c++) {
var temp = [];
temp.push(arr[a]);
temp.push(arr[b]);
temp.push(arr[c]);
if(fun){
ret.push(fun(temp));
} else {
ret.push(temp);
}
}
}
};
return ret;
}
函數(shù)體內(nèi)包含 3 次循環(huán)(因?yàn)?num 值為 3);此時(shí)調(diào)用 bonusCombination([1,2,3,4],3) 就相當(dāng)于調(diào)用 strFn3([1,2,3,4]),返回值是 [[1,2,3],[1,2,4],[1,3,4],[2,3,4]];
你也可以自己試一下讓 num 為 4 或者 1,寫出的函數(shù)體內(nèi)容是怎么樣的,你就能徹底明白這個(gè) bonusCombination 函數(shù)的作用了。
問題1:看不懂為什么用字符串做變量,這個(gè)方法還有其他的功能嗎?
回答:字符串做變量就是為了動(dòng)態(tài)構(gòu)造函數(shù)體內(nèi)容,依據(jù) num 的不同值動(dòng)態(tài)生成不同的 strFn 函數(shù) —— 從這個(gè)角度上來講 bonusCombination 就是一個(gè) 工廠函數(shù);
該方法還有另外的功能,體現(xiàn)在入?yún)?fun 上,可以對(duì)每個(gè)結(jié)果元素調(diào)用 fun(temp),相當(dāng)于使用數(shù)組的 map 功能。
問題2:一開始為什么定義一個(gè) variable;
回答:主要是為動(dòng)態(tài)函數(shù)體提供足夠多的中間變量,沒啥具體含義,只要是符合 js 變量名稱就可以。這里使用 a、b... 這些變量名,估計(jì)是為了簡單起見,你可以用任何符合 js 變量名稱規(guī)范的字符串就行。
問題3:請一步一步來解釋
回答:讀懂上面兩小節(jié)的分析或者參考前一個(gè)回答,每一行解釋這里就不附上了。
這種利用 Function 動(dòng)態(tài)函數(shù)構(gòu)造出來的功能函數(shù),性能堪憂;
你也知道,如果 arr 入?yún)?shù)組越長,num 越大,那么嵌套的循環(huán)體也就越多,性能就越差。
這樣的代碼雖然能運(yùn)行,但質(zhì)量比較糟糕,還有很大的性能隱患,不能放在線上正式的產(chǎn)品中使用。這段代碼比較適合用來學(xué)習(xí) Function 的功能,以及 組合數(shù)學(xué) 的相關(guān)知識(shí)。
這種方式的編程屬于 元編程 范疇,可以參考我最近寫的文章 《【資源集合】 ES6 元編程(Proxy & Reflect & Symbol)》了解更多。后續(xù)有機(jī)會(huì),我看能否使用 Proxy & Reflect 來重寫這個(gè) bonusCombination 函數(shù)。
你可以給你遍歷這個(gè)列表的數(shù)組中每個(gè)對(duì)象添加一個(gè)屬性來綁定class。或者就像上面那樣,定義一個(gè)等長度的布爾值集合..
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國家深化產(chǎn)教融合/校企合作的政策,積極推進(jìn)“中國制造2025”,實(shí)現(xiàn)中華民族偉大復(fù)興的升級(jí)產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。