All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.lucene.facet.util.PartitionsUtils Maven / Gradle / Ivy

There is a newer version: 9.11.1
Show newest version
package org.apache.lucene.facet.util;

import org.apache.lucene.facet.index.params.CategoryListParams;
import org.apache.lucene.facet.index.params.FacetIndexingParams;
import org.apache.lucene.facet.search.params.FacetSearchParams;
import org.apache.lucene.facet.taxonomy.TaxonomyReader;

/**
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

/**
 * Utilities for partitions - sizes and such
 * 
 * @lucene.experimental
 */
public final class PartitionsUtils {

  /**
   * Get the offset for a given partition.  That is, what is the minimum number an
   * ordinal could be for a particular partition. 
   */
  public final static int partitionOffset (  FacetIndexingParams iParams, 
                        int partitionNumber, 
                        final TaxonomyReader taxonomyReader) {
    return partitionNumber * partitionSize(iParams, taxonomyReader);
  }

  /**
   * @see #partitionOffset(FacetIndexingParams, int, TaxonomyReader)
   */
  public final static int partitionOffset (  FacetSearchParams sParams, 
                        int partitionNumber, 
                        final TaxonomyReader taxonomyReader) {
    return partitionOffset(sParams.getFacetIndexingParams(), partitionNumber, taxonomyReader);
  }

  /**
   * Get the partition size in this parameter, or return the size of the taxonomy, which
   * is smaller.  (Guarantees usage of as little memory as possible at search time).
   */
  public final static int partitionSize(FacetIndexingParams indexingParams, final TaxonomyReader taxonomyReader) {
    return Math.min(indexingParams.getPartitionSize(), taxonomyReader.getSize());
  }

  /**
   * @see #partitionSize(FacetIndexingParams, TaxonomyReader)
   */
  public final static int partitionSize(FacetSearchParams sParams, final TaxonomyReader taxonomyReader) {
    return partitionSize(sParams.getFacetIndexingParams(), taxonomyReader);
  }

  /**
   * Partition number of an ordinal.
   * 

* This allows to locate the partition containing a certain (facet) ordinal. * @see FacetIndexingParams#getPartitionSize() */ public final static int partitionNumber(FacetIndexingParams iParams, int ordinal) { return ordinal / iParams.getPartitionSize(); } /** * @see #partitionNumber(FacetIndexingParams, int) */ public final static int partitionNumber(FacetSearchParams sParams, int ordinal) { return partitionNumber(sParams.getFacetIndexingParams(), ordinal); } /** * Partition name by category ordinal */ public final static String partitionNameByOrdinal( FacetIndexingParams iParams, CategoryListParams clParams, int ordinal) { int partition = partitionNumber(iParams, ordinal); return partitionName(clParams, partition); } /** * Partition name by its number */ public final static String partitionName(CategoryListParams clParams, int partition) { String term = clParams.getTerm().text(); if (partition == 0) { return term; // for backwards compatibility we do not add a partition number in this case } return term + partition; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy