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


Java DistanceUnit類代碼示例

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


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

示例1: distance

import org.elasticsearch.common.unit.DistanceUnit; //導入依賴的package包/類
@Override
protected NumericDoubleValues distance(LeafReaderContext context) {
    final MultiGeoPointValues geoPointValues = fieldData.load(context).getGeoPointValues();
    return mode.select(new MultiValueMode.UnsortedNumericDoubleValues() {
        @Override
        public int count() {
            return geoPointValues.count();
        }

        @Override
        public void setDocument(int docId) {
            geoPointValues.setDocument(docId);
        }

        @Override
        public double valueAt(int index) {
            GeoPoint other = geoPointValues.valueAt(index);
            return Math.max(0.0d,
                    distFunction.calculate(origin.lat(), origin.lon(), other.lat(), other.lon(), DistanceUnit.METERS) - offset);
        }
    }, 0.0);
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:23,代碼來源:DecayFunctionBuilder.java

示例2: testArcDistanceVsPlaneInEllipsis

import org.elasticsearch.common.unit.DistanceUnit; //導入依賴的package包/類
/**
 * The old plane calculation in 1.x/2.x incorrectly computed the plane distance in decimal degrees. This test is
 * well intended but bogus. todo: fix w/ new plane distance calculation
 * note: plane distance error varies by latitude so the test will need to correctly estimate expected error
 */
@AwaitsFix(bugUrl = "old plane calculation incorrectly computed everything in degrees. fix this bogus test")
public void testArcDistanceVsPlaneInEllipsis() {
    GeoPoint centre = new GeoPoint(48.8534100, 2.3488000);
    GeoPoint northernPoint = new GeoPoint(48.8801108681, 2.35152032666);
    GeoPoint westernPoint = new GeoPoint(48.85265, 2.308896);

    // With GeoDistance.ARC both the northern and western points are within the 4km range
    assertThat(GeoDistance.ARC.calculate(centre.lat(), centre.lon(), northernPoint.lat(),
            northernPoint.lon(), DistanceUnit.KILOMETERS), lessThan(4D));
    assertThat(GeoDistance.ARC.calculate(centre.lat(), centre.lon(), westernPoint.lat(),
            westernPoint.lon(), DistanceUnit.KILOMETERS), lessThan(4D));

    // With GeoDistance.PLANE, only the northern point is within the 4km range,
    // the western point is outside of the range due to the simple math it employs,
    // meaning results will appear elliptical
    assertThat(GeoDistance.PLANE.calculate(centre.lat(), centre.lon(), northernPoint.lat(),
            northernPoint.lon(), DistanceUnit.KILOMETERS), lessThan(4D));
    assertThat(GeoDistance.PLANE.calculate(centre.lat(), centre.lon(), westernPoint.lat(),
            westernPoint.lon(), DistanceUnit.KILOMETERS), greaterThan(4D));
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:26,代碼來源:GeoDistanceTests.java

示例3: distance

import org.elasticsearch.common.unit.DistanceUnit; //導入依賴的package包/類
@Override
protected NumericDoubleValues distance(LeafReaderContext context) {
    final MultiGeoPointValues geoPointValues = fieldData.load(context).getGeoPointValues();
    return mode.select(new MultiValueMode.UnsortedNumericDoubleValues() {
        @Override
        public int count() {
            return geoPointValues.count();
        }

        @Override
        public void setDocument(int docId) {
            geoPointValues.setDocument(docId);
        }

        @Override
        public double valueAt(int index) {
            GeoPoint other = geoPointValues.valueAt(index);
            return Math.max(0.0d, distFunction.calculate(origin.lat(), origin.lon(), other.lat(), other.lon(), DistanceUnit.METERS) - offset);
        }
    }, 0.0);
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:22,代碼來源:DecayFunctionParser.java

示例4: resolveGridLevel

import org.elasticsearch.common.unit.DistanceUnit; //導入依賴的package包/類
private Integer resolveGridLevel(Optional<Double> distErrOp, Optional<Double> distErrPctOp) {
    SpatialArgs spatialArgs = new SpatialArgs(SpatialOperation.Intersects, this.inputShape);
    if (distErrOp.isPresent()) {
        spatialArgs.setDistErr(distErrOp.get() * DistanceUnit.DEFAULT.getDistancePerDegree());
    }    
    spatialArgs.setDistErrPct(distErrPctOp.orElse(DEFAULT_DIST_ERR_PCT));
    double distErr = spatialArgs.resolveDistErr(strategy.getSpatialContext(), DEFAULT_DIST_ERR_PCT);
    if (distErr <= 0) {
      throw new AggregationInitializationException(String.format(Locale.ROOT,
          "%s or %s should be > 0 or instead provide %s=%s for absolute maximum detail", 
              GeoHeatmapAggregationBuilder.DIST_ERR_PCT_FIELD, 
              GeoHeatmapAggregationBuilder.DIST_ERR_FIELD,
              GeoHeatmapAggregationBuilder.GRID_LEVEL_FIELD,
              strategy.getGrid().getMaxLevels()));
    }
    return strategy.getGrid().getLevelForDistance(distErr);
}
 
開發者ID:boundlessgeo,項目名稱:elasticsearch-heatmap,代碼行數:18,代碼來源:GeoHeatmapAggregatorFactory.java

示例5: findPropertiesByLocation

import org.elasticsearch.common.unit.DistanceUnit; //導入依賴的package包/類
@Override
public List<Property> findPropertiesByLocation(final GeoPoint geoPoint, Double distance, final SortOrder sortOrder) {
    GeoDistanceFilterBuilder filter = FilterBuilders.geoDistanceFilter("location").point(geoPoint.getLat(), geoPoint.getLon())
            .distance(distance, DistanceUnit.KILOMETERS);

    SearchQuery searchQuery = new NativeSearchQueryBuilder()
            .withFilter(filter)
            .withSort(
                    SortBuilders.geoDistanceSort("location").point(geoPoint.getLat(), geoPoint.getLon())
                            .order(sortOrder == null ? SortOrder.ASC : sortOrder)).build();

    searchQuery.addIndices("searchahouse");
    searchQuery.addTypes("property");

    List<Property> properties = this.elasticsearchOperations.queryForList(searchQuery, Property.class);

    return properties;
}
 
開發者ID:gustavoorsi,項目名稱:searchahouse.com,代碼行數:19,代碼來源:PropertyServiceImpl.java

示例6: GeoDistanceRangeAggregatorFactory

import org.elasticsearch.common.unit.DistanceUnit; //導入依賴的package包/類
public GeoDistanceRangeAggregatorFactory(String name, ValuesSourceConfig<ValuesSource.GeoPoint> config, GeoPoint origin,
        Range[] ranges, DistanceUnit unit, GeoDistance distanceType, boolean keyed, SearchContext context,
        AggregatorFactory<?> parent, AggregatorFactories.Builder subFactoriesBuilder, Map<String, Object> metaData) throws IOException {
    super(name, config, context, parent, subFactoriesBuilder, metaData);
    this.origin = origin;
    this.ranges = ranges;
    this.unit = unit;
    this.distanceType = distanceType;
    this.keyed = keyed;
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:11,代碼來源:GeoDistanceRangeAggregatorFactory.java

示例7: DistanceSource

import org.elasticsearch.common.unit.DistanceUnit; //導入依賴的package包/類
DistanceSource(ValuesSource.GeoPoint source, GeoDistance distanceType,
        org.elasticsearch.common.geo.GeoPoint origin, DistanceUnit units) {
    this.source = source;
    // even if the geo points are unique, there's no guarantee the
    // distances are
    this.distanceType = distanceType;
    this.units = units;
    this.origin = origin;
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:10,代碼來源:GeoDistanceRangeAggregatorFactory.java

示例8: GeoDistanceAggregationBuilder

import org.elasticsearch.common.unit.DistanceUnit; //導入依賴的package包/類
/**
 * Read from a stream.
 */
public GeoDistanceAggregationBuilder(StreamInput in) throws IOException {
    super(in, InternalGeoDistance.FACTORY.getValueSourceType(), InternalGeoDistance.FACTORY.getValueType());
    origin = new GeoPoint(in.readDouble(), in.readDouble());
    int size = in.readVInt();
    ranges = new ArrayList<>(size);
    for (int i = 0; i < size; i++) {
        ranges.add(new Range(in));
    }
    keyed = in.readBoolean();
    distanceType = GeoDistance.readFromStream(in);
    unit = DistanceUnit.readFromStream(in);
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:16,代碼來源:GeoDistanceAggregationBuilder.java

示例9: GeoDistanceSortBuilder

import org.elasticsearch.common.unit.DistanceUnit; //導入依賴的package包/類
/**
 * Read from a stream.
 */
@SuppressWarnings("unchecked")
public GeoDistanceSortBuilder(StreamInput in) throws IOException {
    fieldName = in.readString();
    points.addAll((List<GeoPoint>) in.readGenericValue());
    geoDistance = GeoDistance.readFromStream(in);
    unit = DistanceUnit.readFromStream(in);
    order = SortOrder.readFromStream(in);
    sortMode = in.readOptionalWriteable(SortMode::readFromStream);
    nestedFilter = in.readOptionalNamedWriteable(QueryBuilder.class);
    nestedPath = in.readOptionalString();
    validation = GeoValidationMethod.readFromStream(in);
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:16,代碼來源:GeoDistanceSortBuilder.java

示例10: parseGeoVariable

import org.elasticsearch.common.unit.DistanceUnit; //導入依賴的package包/類
private AbstractDistanceScoreFunction parseGeoVariable(XContentParser parser, QueryShardContext context,
        MappedFieldType fieldType, MultiValueMode mode) throws IOException {
    XContentParser.Token token;
    String parameterName = null;
    GeoPoint origin = new GeoPoint();
    String scaleString = null;
    String offsetString = "0km";
    double decay = 0.5;
    while ((token = parser.nextToken()) != XContentParser.Token.END_OBJECT) {
        if (token == XContentParser.Token.FIELD_NAME) {
            parameterName = parser.currentName();
        } else if (DecayFunctionBuilder.SCALE.equals(parameterName)) {
            scaleString = parser.text();
        } else if (DecayFunctionBuilder.ORIGIN.equals(parameterName)) {
            origin = GeoUtils.parseGeoPoint(parser);
        } else if (DecayFunctionBuilder.DECAY.equals(parameterName)) {
            decay = parser.doubleValue();
        } else if (DecayFunctionBuilder.OFFSET.equals(parameterName)) {
            offsetString = parser.text();
        } else {
            throw new ElasticsearchParseException("parameter [{}] not supported!", parameterName);
        }
    }
    if (origin == null || scaleString == null) {
        throw new ElasticsearchParseException("[{}] and [{}] must be set for geo fields.", DecayFunctionBuilder.ORIGIN,
                DecayFunctionBuilder.SCALE);
    }
    double scale = DistanceUnit.DEFAULT.parse(scaleString, DistanceUnit.DEFAULT);
    double offset = DistanceUnit.DEFAULT.parse(offsetString, DistanceUnit.DEFAULT);
    IndexGeoPointFieldData indexFieldData = context.getForField(fieldType);
    return new GeoFieldDataScoreFunction(origin, scale, decay, offset, getDecayFunction(), indexFieldData, mode);

}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:34,代碼來源:DecayFunctionBuilder.java

示例11: parse

import org.elasticsearch.common.unit.DistanceUnit; //導入依賴的package包/類
@Override
public Mapper.Builder parse(String name, Map<String, Object> node, ParserContext parserContext) throws MapperParsingException {
    Builder builder = new Builder(name);
    for (Iterator<Map.Entry<String, Object>> iterator = node.entrySet().iterator(); iterator.hasNext();) {
        Map.Entry<String, Object> entry = iterator.next();
        String fieldName = entry.getKey();
        Object fieldNode = entry.getValue();
        if (Names.TREE.equals(fieldName)) {
            builder.fieldType().setTree(fieldNode.toString());
            iterator.remove();
        } else if (Names.TREE_LEVELS.equals(fieldName)) {
            builder.fieldType().setTreeLevels(Integer.parseInt(fieldNode.toString()));
            iterator.remove();
        } else if (Names.TREE_PRESISION.equals(fieldName)) {
            builder.fieldType().setPrecisionInMeters(DistanceUnit.parse(fieldNode.toString(), DistanceUnit.DEFAULT, DistanceUnit.DEFAULT));
            iterator.remove();
        } else if (Names.DISTANCE_ERROR_PCT.equals(fieldName)) {
            builder.fieldType().setDistanceErrorPct(Double.parseDouble(fieldNode.toString()));
            iterator.remove();
        } else if (Names.ORIENTATION.equals(fieldName)) {
            builder.fieldType().setOrientation(ShapeBuilder.Orientation.fromString(fieldNode.toString()));
            iterator.remove();
        } else if (Names.STRATEGY.equals(fieldName)) {
            builder.fieldType().setStrategyName(fieldNode.toString());
            iterator.remove();
        } else if (Names.COERCE.equals(fieldName)) {
            builder.coerce(TypeParsers.nodeBooleanValue(fieldName, Names.COERCE, fieldNode, parserContext));
            iterator.remove();
        } else if (Names.STRATEGY_POINTS_ONLY.equals(fieldName)
            && builder.fieldType().strategyName.equals(SpatialStrategy.TERM.getStrategyName()) == false) {
            boolean pointsOnly = TypeParsers.nodeBooleanValue(fieldName, Names.STRATEGY_POINTS_ONLY, fieldNode, parserContext);
            builder.fieldType().setPointsOnly(pointsOnly);
            iterator.remove();
        }
    }
    return builder;
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:38,代碼來源:GeoShapeFieldMapper.java

示例12: doXContentBody

import org.elasticsearch.common.unit.DistanceUnit; //導入依賴的package包/類
@Override
protected void doXContentBody(XContentBuilder builder, boolean includeDefaults, Params params) throws IOException {
    builder.field("type", contentType());

    if (includeDefaults || fieldType().tree().equals(Defaults.TREE) == false) {
        builder.field(Names.TREE, fieldType().tree());
    }
    if (includeDefaults || fieldType().treeLevels() != 0) {
        builder.field(Names.TREE_LEVELS, fieldType().treeLevels());
    }
    if (includeDefaults || fieldType().precisionInMeters() != -1) {
        builder.field(Names.TREE_PRESISION, DistanceUnit.METERS.toString(fieldType().precisionInMeters()));
    }
    if (includeDefaults || fieldType().strategyName() != Defaults.STRATEGY) {
        builder.field(Names.STRATEGY, fieldType().strategyName());
    }
    if (includeDefaults || fieldType().distanceErrorPct() != fieldType().defaultDistanceErrorPct) {
        builder.field(Names.DISTANCE_ERROR_PCT, fieldType().distanceErrorPct());
    }
    if (includeDefaults || fieldType().orientation() != Defaults.ORIENTATION) {
        builder.field(Names.ORIENTATION, fieldType().orientation());
    }
    if (includeDefaults || fieldType().pointsOnly() != GeoShapeFieldMapper.Defaults.POINTS_ONLY) {
        builder.field(Names.STRATEGY_POINTS_ONLY, fieldType().pointsOnly());
    }
    if (includeDefaults || coerce.explicit()) {
        builder.field("coerce", coerce.value());
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:30,代碼來源:GeoShapeFieldMapper.java

示例13: createTestAggregatorBuilder

import org.elasticsearch.common.unit.DistanceUnit; //導入依賴的package包/類
@Override
protected GeoDistanceAggregationBuilder createTestAggregatorBuilder() {
    int numRanges = randomIntBetween(1, 10);
    GeoPoint origin = RandomShapeGenerator.randomPoint(random());
    GeoDistanceAggregationBuilder factory = new GeoDistanceAggregationBuilder("foo", origin);
    for (int i = 0; i < numRanges; i++) {
        String key = null;
        if (randomBoolean()) {
            key = randomAsciiOfLengthBetween(1, 20);
        }
        double from = randomBoolean() ? 0 : randomIntBetween(0, Integer.MAX_VALUE - 1000);
        double to = randomBoolean() ? Double.POSITIVE_INFINITY
                : (Double.compare(from, 0) == 0 ? randomIntBetween(0, Integer.MAX_VALUE)
                        : randomIntBetween((int) from, Integer.MAX_VALUE));
        factory.addRange(new Range(key, from, to));
    }
    factory.field(randomAsciiOfLengthBetween(1, 20));
    if (randomBoolean()) {
        factory.keyed(randomBoolean());
    }
    if (randomBoolean()) {
        factory.missing("0, 0");
    }
    if (randomBoolean()) {
        factory.unit(randomFrom(DistanceUnit.values()));
    }
    if (randomBoolean()) {
        factory.distanceType(randomFrom(GeoDistance.values()));
    }
    return factory;
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:32,代碼來源:GeoDistanceRangeTests.java

示例14: testCommonCaseIsOptimized

import org.elasticsearch.common.unit.DistanceUnit; //導入依賴的package包/類
public void testCommonCaseIsOptimized() throws IOException {
    // make sure the below tests test something...
    assertFalse(SortField.class.equals(LatLonDocValuesField.newDistanceSort("random_field_name", 3.5, 2.1).getClass()));

    QueryShardContext context = createMockShardContext();
    // The common case should use LatLonDocValuesField.newDistanceSort
    GeoDistanceSortBuilder builder = new GeoDistanceSortBuilder("", new GeoPoint(3.5, 2.1));
    SortFieldAndFormat sort = builder.build(context);
    assertEquals(LatLonDocValuesField.newDistanceSort("random_field_name", 3.5, 2.1).getClass(), sort.field.getClass());

    // however this might be disabled by fancy options
    builder = new GeoDistanceSortBuilder("random_field_name", new GeoPoint(3.5, 2.1), new GeoPoint(3.0, 4));
    sort = builder.build(context);
    assertEquals(SortField.class, sort.field.getClass()); // 2 points -> plain SortField with a custom comparator

    builder = new GeoDistanceSortBuilder("random_field_name", new GeoPoint(3.5, 2.1));
    builder.unit(DistanceUnit.KILOMETERS);
    sort = builder.build(context);
    assertEquals(SortField.class, sort.field.getClass()); // km rather than m -> plain SortField with a custom comparator

    builder = new GeoDistanceSortBuilder("random_field_name", new GeoPoint(3.5, 2.1));
    builder.order(SortOrder.DESC);
    sort = builder.build(context);
    assertEquals(SortField.class, sort.field.getClass()); // descending means the max value should be considered rather than min

    builder = new GeoDistanceSortBuilder("random_field_name", new GeoPoint(3.5, 2.1));
    builder.setNestedPath("some_nested_path");
    sort = builder.build(context);
    assertEquals(SortField.class, sort.field.getClass()); // can't use LatLon optimized sorting with nested fields

    builder = new GeoDistanceSortBuilder("random_field_name", new GeoPoint(3.5, 2.1));
    builder.order(SortOrder.DESC);
    sort = builder.build(context);
    assertEquals(SortField.class, sort.field.getClass()); // can't use LatLon optimized sorting with DESC sorting
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:36,代碼來源:GeoDistanceSortBuilderTests.java

示例15: createRandomDecayFunction

import org.elasticsearch.common.unit.DistanceUnit; //導入依賴的package包/類
/**
 * Create a random decay function setting all of its constructor parameters randomly. The caller is responsible for randomizing other
 * fields.
 */
private static DecayFunctionBuilder<?> createRandomDecayFunction() {
    String field = randomFrom(INT_FIELD_NAME, DOUBLE_FIELD_NAME, DATE_FIELD_NAME, GEO_POINT_FIELD_NAME);
    Object origin;
    Object scale;
    Object offset;
    switch (field) {
    case GEO_POINT_FIELD_NAME:
        origin = new GeoPoint(randomDouble(), randomDouble()).geohash();
        scale = randomFrom(DistanceUnit.values()).toString(randomDouble());
        offset = randomFrom(DistanceUnit.values()).toString(randomDouble());
        break;
    case DATE_FIELD_NAME:
        origin = new DateTime(System.currentTimeMillis() - randomIntBetween(0, 1000000), DateTimeZone.UTC).toString();
        scale = randomPositiveTimeValue();
        offset = randomPositiveTimeValue();
        break;
    default:
        origin = randomBoolean() ? randomInt() : randomFloat();
        scale = randomBoolean() ? between(1, Integer.MAX_VALUE) : randomFloat() + Float.MIN_NORMAL;
        offset = randomBoolean() ? between(1, Integer.MAX_VALUE) : randomFloat() + Float.MIN_NORMAL;
        break;
    }
    offset = randomBoolean() ? null : offset;
    double decay = randomDouble();
    switch (randomIntBetween(0, 2)) {
    case 0:
        return new GaussDecayFunctionBuilder(field, origin, scale, offset, decay);
    case 1:
        return new ExponentialDecayFunctionBuilder(field, origin, scale, offset, decay);
    case 2:
        return new LinearDecayFunctionBuilder(field, origin, scale, offset, decay);
    default:
        throw new UnsupportedOperationException();
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:40,代碼來源:FunctionScoreQueryBuilderTests.java


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