當前位置: 首頁>>代碼示例>>Java>>正文


Java MMapDirectory類代碼示例

本文整理匯總了Java中org.apache.lucene.store.MMapDirectory的典型用法代碼示例。如果您正苦於以下問題:Java MMapDirectory類的具體用法?Java MMapDirectory怎麽用?Java MMapDirectory使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


MMapDirectory類屬於org.apache.lucene.store包,在下文中一共展示了MMapDirectory類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: setPreload

import org.apache.lucene.store.MMapDirectory; //導入依賴的package包/類
private static Directory setPreload(Directory directory, Path location, LockFactory lockFactory,
        Set<String> preLoadExtensions) throws IOException {
    if (preLoadExtensions.isEmpty() == false
            && directory instanceof MMapDirectory
            && ((MMapDirectory) directory).getPreload() == false) {
        if (preLoadExtensions.contains("*")) {
            ((MMapDirectory) directory).setPreload(true);
            return directory;
        }
        MMapDirectory primary = new MMapDirectory(location, lockFactory);
        primary.setPreload(true);
        return new FileSwitchDirectory(preLoadExtensions, primary, directory, true) {
            @Override
            public String[] listAll() throws IOException {
                // avoid listing twice
                return primary.listAll();
            }
        };
    }
    return directory;
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:22,代碼來源:FsDirectoryService.java

示例2: main

import org.apache.lucene.store.MMapDirectory; //導入依賴的package包/類
/**
	 * @param args
	 * @throws IOException
	 */
	public static void main(String[] args) throws IOException {
		if (args.length != 2) {
			System.err
					.println("Incorrect number of arguments; expected <index_dir> <query_number>");
		}
		String indexDir = args[0];
		int i = Integer.parseInt(args[1]);
		Queries queries = new Queries();
		Directory directory = MMapDirectory.open(new File(indexDir));
		DirectoryReader reader = DirectoryReader.open(directory);
		TermFreqAnalyzer termFreqAnalyzer = new TermFreqAnalyzer(reader,
				queries.getQuery(i));
		termFreqAnalyzer.printAvgTf();
		termFreqAnalyzer.printAvgTfInDocsWithAllTerms();
		reader.close();
//		directory.close();
	}
 
開發者ID:arne-cl,項目名稱:fangorn,代碼行數:22,代碼來源:TermFreqAnalyzer.java

示例3: LuceneSearchProvider

import org.apache.lucene.store.MMapDirectory; //導入依賴的package包/類
/**
 * Constructor.
 *
 * @param luceneIndexPath  Path to the lucene index files
 * @param maxResults  Maximum number of allowed results in a page
 * @param searchTimeout  Maximum time in milliseconds that a lucene search can run
 */
public LuceneSearchProvider(String luceneIndexPath, int maxResults, int searchTimeout) {
    this.luceneIndexPath = luceneIndexPath;
    Utils.createParentDirectories(this.luceneIndexPath);

    this.maxResults = maxResults;
    this.searchTimeout = searchTimeout;

    try {
        luceneDirectory = new MMapDirectory(Paths.get(this.luceneIndexPath));
        luceneIndexIsHealthy = true;
    } catch (IOException e) {
        luceneIndexIsHealthy = false;
        String message = ErrorMessageFormat.UNABLE_TO_CREATE_DIR.format(this.luceneIndexPath);
        LOG.error(message, e);
    }
}
 
開發者ID:yahoo,項目名稱:fili,代碼行數:24,代碼來源:LuceneSearchProvider.java

示例4: Indexer

import org.apache.lucene.store.MMapDirectory; //導入依賴的package包/類
/**
 * Construct a new indexer object.
 * 
 * @param prop
 *            A {@link Properties} object.
 * @throws IOException
 */
public Indexer (Properties prop) throws IOException {
    if (path == null) {
        path = prop.getProperty("krill.indexDir");
    }

    log.info("Output directory: " + path);

    // Default to 1000 documents till the next commit
    String commitCount = prop.getProperty("krill.index.commit.count",
            "1000");

    // Create a new index object based on the directory
    this.index = new KrillIndex(new MMapDirectory(Paths.get(path)));
    this.count = 0;
    this.commitCount = Integer.parseInt(commitCount);

    jsonFilePattern = Pattern.compile(".*\\.json\\.gz$");
}
 
開發者ID:KorAP,項目名稱:Krill,代碼行數:26,代碼來源:Indexer.java

示例5: advancedTest

import org.apache.lucene.store.MMapDirectory; //導入依賴的package包/類
@Test
public void advancedTest() throws IOException {
	File indexFile = new File("data", "test3");
	FSDirectory directory = MMapDirectory.open(indexFile.toPath());

	LuceneObjectKVS<Integer, Sample> kvs = new LuceneObjectKVS<>(directory, indexFile, true);

	Sample sample = new Sample();
	sample.name = "hoge";
	sample.age = 10;

	kvs.put(1, sample);
	kvs.put(2, sample);

	// get object
	Sample actual = kvs.get(1);
	assertEquals(sample.name, actual.name);

	// iterator
	Iterator<Entry<Integer, Sample>> ite = kvs.iterator();
	while(ite.hasNext()) {
		ite.next();
	}

	kvs.close();
}
 
開發者ID:ksgwr,項目名稱:LuceneDB,代碼行數:27,代碼來源:LuceneObjectKVSTest.java

示例6: initialize

import org.apache.lucene.store.MMapDirectory; //導入依賴的package包/類
private void initialize(File indexPath, int kmerSize, int kmerSkips, boolean minStrandKmer, double minShouldMatch, QueryGenerationAlgorithm queryGenerationAlgorithm, Similarity similarity) throws Exception {
    if(!indexPath.exists() || !indexPath.isDirectory()) {
        throw new IllegalArgumentException("indexPath is not a directory or does not exist");
    }
    
    this.indexPath = indexPath;
    this.kmerSize = kmerSize;
    this.kmerSkips = kmerSkips;
    this.minStrandKmer = minStrandKmer;
    this.queryAnalyzer = new KmerQueryAnalyzer(this.kmerSize, this.kmerSkips, this.minStrandKmer);
    Directory dir = new MMapDirectory(this.indexPath.toPath()); 
    this.indexReader = DirectoryReader.open(dir);
    this.indexSearcher = new IndexSearcher(this.indexReader);
    if(similarity != null) {
        this.indexSearcher.setSimilarity(similarity);
    }
    this.minShouldMatch = minShouldMatch;
    this.queryGenerationAlgorithm = queryGenerationAlgorithm;
    
    BooleanQuery.setMaxClauseCount(10000);
}
 
開發者ID:iychoi,項目名稱:biospectra,代碼行數:22,代碼來源:Classifier.java

示例7: Environment

import org.apache.lucene.store.MMapDirectory; //導入依賴的package包/類
/**
 * Create a (possibly) shared NLP environment. The given data directory
 * must be created (usually from a downloaded zipfile, check the README).
 * Expect many open files and many reads. Network filesystems are known to
 * perform poorly as data directories. Strive to use a local directory if
 * possible, or at least the Lucene indices otherwise.
 * 
 * config.properties can be either in the data directory or the working
 * directory. This is to allow sharing (read-only) indices while still
 * allowing separate development configurations.  
 */
public Environment() {
	
	// Now do some per-thread setup
	db = new Database(this);
	rdf = TDBFactory.assembleDataset(
			pathMustExist("rdf/jena-lucene.ttl"));
	
	// Lucene indexes have huge overhead so avoid re-instantiating by putting them in the Environment
	IndexReader reader;
	try {
		reader = DirectoryReader.open(new MMapDirectory(Paths.get(getConfOrDie("lucene_index"))));
	} catch (IOException e) {
		e.printStackTrace();
		throw new RuntimeException("The candidate-answer Lucene index failed to open.");
	}
	lucene = new IndexSearcher(reader);
	//lucene.setSimilarity(new BM25Similarity());
}
 
開發者ID:SeanTater,項目名稱:uncc2014watsonsim,代碼行數:30,代碼來源:Environment.java

示例8: testSearchBenchmark

import org.apache.lucene.store.MMapDirectory; //導入依賴的package包/類
public void testSearchBenchmark() throws IOException {

        System.out.printf("%s\t%s\t%s\t%s\t%s\t%s\n", "Test", "[email protected]", "[email protected]", "[email protected]", "[email protected]", "[email protected]");
        IndexReader reader = DirectoryReader.open(MMapDirectory.open(new File(indexPath)));
        getRecall("ColorLayout (linear)", new GenericFastImageSearcher(50, ColorLayout.class, DocumentBuilder.FIELD_NAME_COLORLAYOUT, true, reader), reader);
        getRecall("PHOG (linear)", new GenericFastImageSearcher(50, PHOG.class, DocumentBuilder.FIELD_NAME_PHOG, true, reader), reader);
        getRecall("JCD (linear)", new GenericFastImageSearcher(50, JCD.class, DocumentBuilder.FIELD_NAME_JCD, true, reader), reader);
        getRecall("EdgeHistogram (linear)", new GenericFastImageSearcher(50, EdgeHistogram.class, DocumentBuilder.FIELD_NAME_EDGEHISTOGRAM, true, reader), reader);
//        getRecall("CEDD (linear)", new GenericFastImageSearcher(50, CEDD.class, DocumentBuilder.FIELD_NAME_CEDD, true, reader), reader);
//        getRecall("JointHistogram (linear)", new GenericFastImageSearcher(50, JointHistogram.class, DocumentBuilder.FIELD_NAME_JOINT_HISTOGRAM, true, reader), reader);
//        getRecall("LocalBinaryPatterns (linear)", new GenericFastImageSearcher(50, LocalBinaryPatterns.class, DocumentBuilder.FIELD_NAME_LOCAL_BINARY_PATTERNS, true, reader), reader);
//        getRecall("Luminance Layout (linear)", new GenericFastImageSearcher(50, LuminanceLayout.class, DocumentBuilder.FIELD_NAME_LUMINANCE_LAYOUT, true, reader), reader);
//        getRecall("BinaryPatternsPyramid (linear)", new GenericFastImageSearcher(50, BinaryPatternsPyramid.class, DocumentBuilder.FIELD_NAME_BINARY_PATTERNS_PYRAMID, true, reader), reader);
//
        getRecall("ColorLayout (hashed)", new BitSamplingImageSearcher(50, DocumentBuilder.FIELD_NAME_COLORLAYOUT, DocumentBuilder.FIELD_NAME_COLORLAYOUT + "_hash", new ColorLayout(), 1000), reader);
        getRecall("PHOG (hashed)", new BitSamplingImageSearcher(50, DocumentBuilder.FIELD_NAME_PHOG, DocumentBuilder.FIELD_NAME_PHOG + "_hash", new PHOG(), 1000), reader);
        getRecall("JCD (hashed)", new BitSamplingImageSearcher(50, DocumentBuilder.FIELD_NAME_JCD, DocumentBuilder.FIELD_NAME_JCD + "_hash", new JCD(), 1000), reader);
        getRecall("EdgeHistogram (hashed)", new BitSamplingImageSearcher(50, DocumentBuilder.FIELD_NAME_EDGEHISTOGRAM, DocumentBuilder.FIELD_NAME_EDGEHISTOGRAM + "_hash", new EdgeHistogram(), 1000), reader);
//        getRecall("CEDD (hashed)", new BitSamplingImageSearcher(50, DocumentBuilder.FIELD_NAME_CEDD, DocumentBuilder.FIELD_NAME_CEDD + "_hash", new JCD(), 1000), reader);
//        getRecall("JointHistogram (hashed)", new BitSamplingImageSearcher(50, DocumentBuilder.FIELD_NAME_JOINT_HISTOGRAM, DocumentBuilder.FIELD_NAME_JOINT_HISTOGRAM + "_hash", new JointHistogram(), 1000), reader);
//        getRecall("LocalBinaryPatterns (hashed)", new BitSamplingImageSearcher(50, DocumentBuilder.FIELD_NAME_LOCAL_BINARY_PATTERNS, DocumentBuilder.FIELD_NAME_LOCAL_BINARY_PATTERNS + "_hash", new LocalBinaryPatterns(), 1000), reader);
//        getRecall("Luminance Layout (hashed)", new BitSamplingImageSearcher(50, DocumentBuilder.FIELD_NAME_LUMINANCE_LAYOUT, DocumentBuilder.FIELD_NAME_LUMINANCE_LAYOUT + "_hash", new LuminanceLayout(), 1000), reader);
//        getRecall("BinaryPatternsPyramid (hashed)", new BitSamplingImageSearcher(50, DocumentBuilder.FIELD_NAME_BINARY_PATTERNS_PYRAMID, DocumentBuilder.FIELD_NAME_BINARY_PATTERNS_PYRAMID + "_hash", new LocalBinaryPatterns(), 1000), reader);
//        getRecall("VLAD (linear)", new GenericFastImageSearcher(1000, GenericByteLireFeature.class, DocumentBuilder.FIELD_NAME_SURF_VLAD, true, reader), reader);
    }
 
開發者ID:fish2000,項目名稱:lire,代碼行數:26,代碼來源:TestGroundTruth.java

示例9: init

import org.apache.lucene.store.MMapDirectory; //導入依賴的package包/類
@Override
public void init(Properties config) {
    try {
        decoder = new JSONString();
        String indexPath = config.getProperty("subscription.lucene.directory");
        LuceneQueryCache queryCache = new LuceneQueryCache("text");
        Presearcher presearcher = new TermFilteredPresearcher();
        if (indexPath == null || indexPath.isEmpty()) {
            monitor = new Monitor(queryCache, presearcher, new RAMDirectory());
        } else {
            monitor = new Monitor(queryCache, presearcher, new MMapDirectory(new File(indexPath)));
        }
    } catch(IOException e) {
        throw new RuntimeException(e.getCause());
    }
}
 
開發者ID:Team-Whitespace,項目名稱:BASK,代碼行數:17,代碼來源:SubscriptionTask.java

示例10: getTaxoWriter

import org.apache.lucene.store.MMapDirectory; //導入依賴的package包/類
public DirectoryTaxonomyWriter getTaxoWriter(int segmentNumber) throws IOException {

		Directory d;

		if (indexConfig.getIndexSettings().getStoreIndexOnDisk()) {
			d = MMapDirectory.open(getPathForFacetsIndex(segmentNumber));
		}
		else {
			String indexSegmentDbName = getIndexSegmentDbName(segmentNumber);
			String indexSegmentCollectionName = getIndexSegmentCollectionName(segmentNumber) + "_facets";
			MongoDirectory mongoDirectory = new MongoDirectory(mongo, indexSegmentDbName, indexSegmentCollectionName, clusterConfig.isSharded(),
					clusterConfig.getIndexBlockSize());
			d = new DistributedDirectory(mongoDirectory);
		}

		NRTCachingDirectory nrtCachingDirectory = new NRTCachingDirectory(d, 2, 10);

		return new DirectoryTaxonomyWriter(nrtCachingDirectory);
	}
 
開發者ID:lumongo,項目名稱:lumongo,代碼行數:20,代碼來源:LumongoIndex.java

示例11: getDVConfigs

import org.apache.lucene.store.MMapDirectory; //導入依賴的package包/類
/**
 * Extracts field information from the Lucene index at the given location.
 * </p><p>
 * Important: The {@link DVConfig#numericType} is always set to LONG as the auto-detection code
 * has not been implemented.
 * @param indexLocation where the index is stored.
 * @return a complete list of DocValues-relevant information on the fields contained in the index.
 * @throws IOException if the information could not be extracted.
 */
public static List<DVConfig> getDVConfigs(File indexLocation) throws IOException {
    try (IndexReader reader = DirectoryReader.open(MMapDirectory.open(indexLocation))) {
        Map<String, DVConfig> dvConfigs = new HashMap<>();
        for (AtomicReaderContext context : reader.leaves()) {
            for (FieldInfo fieldInfo : context.reader().getFieldInfos()) {
                if (dvConfigs.containsKey(fieldInfo.name)) {
                    continue;
                }
                String first = getFirst(context.reader(), fieldInfo.name);
                dvConfigs.put(fieldInfo.name, new DVConfig(
                        fieldInfo,
                        fieldInfo.hasDocValues() && fieldInfo.getDocValuesType() == FieldInfo.DocValuesType.NUMERIC
                        ? FieldType.NumericType.LONG : null,
                        first));
            }
        }
        List<DVConfig> configs = new ArrayList<>(dvConfigs.values());
        Collections.sort(configs);
        return configs;
    }
}
 
開發者ID:netarchivesuite,項目名稱:dvenabler,代碼行數:31,代碼來源:IndexUtils.java

示例12: TripleIndex

import org.apache.lucene.store.MMapDirectory; //導入依賴的package包/類
public TripleIndex() throws IOException {
	Properties prop = new Properties();
	InputStream input = TripleIndex.class.getResourceAsStream("/config/agdistis.properties");
	prop.load(input);

	String envIndex = System.getenv("AGDISTIS_INDEX");
	String index = envIndex != null ? envIndex : prop.getProperty("index");
	log.info("The index will be here: " + index);

	directory = new MMapDirectory(new File(index));
	ireader = DirectoryReader.open(directory);
	isearcher = new IndexSearcher(ireader);
	this.urlValidator = new UrlValidator();

	cache = CacheBuilder.newBuilder().maximumSize(50000).build();
}
 
開發者ID:dice-group,項目名稱:AGDISTIS,代碼行數:17,代碼來源:TripleIndex.java

示例13: TripleIndexContext

import org.apache.lucene.store.MMapDirectory; //導入依賴的package包/類
public TripleIndexContext() throws IOException {
	Properties prop = new Properties();
	InputStream input = TripleIndexContext.class.getResourceAsStream("/config/agdistis.properties");
	prop.load(input);

	String envIndex = System.getenv("AGDISTIS_INDEX_2");
	String index = envIndex != null ? envIndex : prop.getProperty("index2");
	log.info("The index will be here: " + index);

	directory = new MMapDirectory(new File(index));
	ireader = DirectoryReader.open(directory);
	isearcher = new IndexSearcher(ireader);
	new UrlValidator();

	cache = CacheBuilder.newBuilder().maximumSize(50000).build();
}
 
開發者ID:dice-group,項目名稱:AGDISTIS,代碼行數:17,代碼來源:TripleIndexContext.java

示例14: initSettings

import org.apache.lucene.store.MMapDirectory; //導入依賴的package包/類
public void initSettings(Path stateDir, LuceneSettings settings) throws Exception {
    if (this.settings != null)
        throw new Exception("Init settings is only allowed once");
    this.settings = settings;

    MMapDirectory indexDirectory = new MMapDirectory(stateDir.resolve("index"));
    indexDirectory.setUseUnmap(false);

    MMapDirectory taxoDirectory = new MMapDirectory(stateDir.resolve("taxo"));
    taxoDirectory.setUseUnmap(false);

    IndexWriterConfig config = new IndexWriterConfig(settings.analyzer);
    config.setSimilarity(settings.similarity);
    config.setMergePolicy(settings.getMergePolicy());

    this.indexWriter = new IndexWriter(indexDirectory, config);
    this.indexWriter.commit();
    this.taxoWriter = new DirectoryTaxonomyWriter(taxoDirectory, IndexWriterConfig.OpenMode.CREATE_OR_APPEND, new LruTaxonomyWriterCache(settings.lruTaxonomyWriterCacheSize));
    this.taxoWriter.commit();

    this.scoreCollectorCache = Collections.synchronizedMap(new LRUMap<KeyNameQuery, ScoreSuperCollector>(50));
    this.keyCollectorCache = Collections.synchronizedMap(new LRUMap<KeyNameQuery, FixedBitSet>(50));

    this.manager = new SearcherTaxonomyManager(indexDirectory, taxoDirectory, new MerescoSearchFactory(indexDirectory, taxoDirectory, settings));
    this.manager.addListener(refreshListener);
}
 
開發者ID:seecr,項目名稱:meresco-lucene,代碼行數:27,代碼來源:Lucene.java

示例15: createDirectory

import org.apache.lucene.store.MMapDirectory; //導入依賴的package包/類
/**
 * Creates a new {@link MMapDirectory} for the {@link #location} and sets it to {@link #directory}.
 * If an {@link IOException} during creation will be thrown it will be logged and the old
 * {@link Directory} will be kept.
 */
private void createDirectory() {
	try {
		directory = new MMapDirectory(location);
	} catch (final IOException e) {
		LOGGER.error("Exception was thrown during instantiaton of MMapDirectory for location {}.",
				location.getAbsolutePath(), e);
	}
}
 
開發者ID:XMBomb,項目名稱:InComb,代碼行數:14,代碼來源:Index.java


注:本文中的org.apache.lucene.store.MMapDirectory類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。