zoukankan      html  css  js  c++  java
  • ranker_worker.go

    package engine

    import (
        "github.com/huichen/wukong/types"
    )

    type rankerAddDocRequest struct {
        docId  uint64
        fields interface{}
    }

    type rankerRankRequest struct {
        docs                []types.IndexedDocument
        options             types.RankOptions
        rankerReturnChannel chan rankerReturnRequest
        countDocsOnly       bool
    }

    type rankerReturnRequest struct {
        docs    types.ScoredDocuments
        numDocs int
    }

    type rankerRemoveDocRequest struct {
        docId uint64
    }

    func (engine *Engine) rankerAddDocWorker(shard int) {
        for {
            request := <-engine.rankerAddDocChannels[shard]
            engine.rankers[shard].AddDoc(request.docId, request.fields)
        }
    }

    func (engine *Engine) rankerRankWorker(shard int) {
        for {
            request := <-engine.rankerRankChannels[shard]
            if request.options.MaxOutputs != 0 {
                request.options.MaxOutputs += request.options.OutputOffset
            }
            request.options.OutputOffset = 0
            outputDocs, numDocs := engine.rankers[shard].Rank(request.docs, request.options, request.countDocsOnly)
            request.rankerReturnChannel <- rankerReturnRequest{docs: outputDocs, numDocs: numDocs}
        }
    }

    func (engine *Engine) rankerRemoveDocWorker(shard int) {
        for {
            request := <-engine.rankerRemoveDocChannels[shard]
            engine.rankers[shard].RemoveDoc(request.docId)
        }
    }

  • 相关阅读:
    Spring使用@Value注解各种类型的值
    Jdom生成xml文件时的特殊字符问题
    将博客搬至CSDN
    ubuntu/mint添加字体
    linux保持ssh连接
    servlet 重定向与转发区别
    u盘写保护
    修改默认终端
    sudo apt-get update 无法获得锁
    logback多线程日志MDC
  • 原文地址:https://www.cnblogs.com/zhangboyu/p/7461676.html
Copyright © 2011-2022 走看看