Skip to content

Commit

Permalink
Release 0.6.1
Browse files Browse the repository at this point in the history
Signed-off-by: Simeon H.K. Fitch <[email protected]>
  • Loading branch information
metasim committed Mar 31, 2018
1 parent b85a86c commit af66dc3
Show file tree
Hide file tree
Showing 32 changed files with 525 additions and 893 deletions.
2 changes: 1 addition & 1 deletion LICENSE
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
This software is licensed under the Apache 2 license, quoted below.

Copyright 2017 Astraea. Inc.
Copyright 2017-2018 Astraea. Inc.

Licensed 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
Expand Down
5 changes: 3 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,12 +11,13 @@ Please see the [Getting Started](http://rasterframes.io/getting-started.html) se

## Documentation

* [Giter8 Template](https://github.com/s22s/raster-frames.g8) (i.e. `sbt new s22s/raster-frames.g8`)
* [Users' Manual](http://rasterframes.io/)
* [API Documentation](http://rasterframes.io/latest/api/index.html)
* [List of available UDFs](http://rasterframes.io/latest/api/index.html#astraea.spark.rasterframes.ColumnFunctions)
* [List of available UDFs](http://rasterframes.io/latest/api/index.html#astraea.spark.rasterframes.RasterFunctions)

## Copyright and License

RasterFrames is released under the Apache 2.0 License, copyright Astraea, Inc. 2017.
RasterFrames is released under the Apache 2.0 License, copyright Astraea, Inc. 2017-2018.


24 changes: 1 addition & 23 deletions build.sbt
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
addCommandAlias("makeSite", "docs/makeSite")
addCommandAlias("console", "datasource/console")

lazy val root = project
.in(file("."))
Expand All @@ -18,27 +19,4 @@ lazy val docs = project
lazy val bench = project
.dependsOn(core)

initialCommands in console := """
|import astraea.spark.rasterframes._
|import geotrellis.raster._
|import geotrellis.spark.io.kryo.KryoRegistrator
|import org.apache.spark.serializer.KryoSerializer
|import org.apache.spark.sql._
|import org.apache.spark.sql.functions._
|implicit val spark = SparkSession.builder()
| .master("local[*]")
| .appName(getClass.getName)
| .config("spark.serializer", classOf[KryoSerializer].getName)
| .config("spark.kryoserializer.buffer.max", "500m")
| .config("spark.kryo.registrationRequired", "false")
| .config("spark.kryo.registrator", classOf[KryoRegistrator].getName)
| .getOrCreate()
| .withRasterFrames
|spark.sparkContext.setLogLevel("ERROR")
|import spark.implicits._
|
""".stripMargin

cleanupCommands in console := """
|spark.stop()
""".stripMargin
Original file line number Diff line number Diff line change
Expand Up @@ -16,44 +16,44 @@

package astraea.spark.rasterframes.extensions

import astraea.spark.rasterframes.StandardColumns._
import astraea.spark.rasterframes.util._
import astraea.spark.rasterframes.{MetadataKeys, RasterFrame}
import geotrellis.raster.Tile
import geotrellis.spark.io._
import geotrellis.spark.{SpaceTimeKey, SpatialComponent, SpatialKey, TemporalKey, TileLayerMetadata}
import geotrellis.util.MethodExtensions
import org.apache.spark.sql.catalyst.expressions.Attribute
import org.apache.spark.sql.gt._
import org.apache.spark.sql.types.MetadataBuilder
import org.apache.spark.sql.{Column, DataFrame}
import org.apache.spark.sql.functions._
import org.apache.spark.sql.gt.types.TileUDT
import org.apache.spark.sql.types.{MetadataBuilder, StructField}
import org.apache.spark.sql.{Column, DataFrame, TypedColumn}
import spray.json.JsonFormat
import astraea.spark.rasterframes.util._
import astraea.spark.rasterframes.{MetadataKeys, RasterFrame}
import scala.util.Try

import scala.util.Try

/**
* Extension methods over [[DataFrame]].
*
* @since 7/18/17
*/
trait DataFrameMethods extends MethodExtensions[DataFrame] with MetadataKeys {
import Implicits.WithMetadataBuilderMethods
import Implicits.WithMetadataMethods
import Implicits.WithRasterFrameMethods
import Implicits.WithDataFrameMethods
trait DataFrameMethods[DF <: DataFrame] extends MethodExtensions[DF] with MetadataKeys {
import Implicits.{WithDataFrameMethods, WithMetadataBuilderMethods, WithMetadataMethods, WithRasterFrameMethods}

private def selector(column: Column) = (attr: Attribute)
attr.name == column.columnName || attr.semanticEquals(column.expr)

/** Map over the Attribute representation of Columns, modifying the one matching `column` with `op`. */
private[astraea] def mapColumnAttribute(column: Column, op: Attribute Attribute): DataFrame = {
private[astraea] def mapColumnAttribute(column: Column, op: Attribute Attribute): DF = {
val analyzed = self.queryExecution.analyzed.output
val selects = selector(column)
val attrs = analyzed.map { attr
if(selects(attr)) op(attr) else attr
}
self.select(attrs.map(a new Column(a)): _*)
self.select(attrs.map(a new Column(a)): _*).asInstanceOf[DF]
}

private[astraea] def addColumnMetadata(column: Column, op: MetadataBuilder MetadataBuilder): DataFrame = {
private[astraea] def addColumnMetadata(column: Column, op: MetadataBuilder MetadataBuilder): DF = {
mapColumnAttribute(column, attr {
val md = new MetadataBuilder().withMetadata(attr.metadata)
attr.withMetadata(op(md).build)
Expand All @@ -67,25 +67,61 @@ trait DataFrameMethods extends MethodExtensions[DataFrame] with MetadataKeys {

private[astraea]
def setSpatialColumnRole[K: SpatialComponent: JsonFormat](
column: Column, md: TileLayerMetadata[K]) =
column: Column, md: TileLayerMetadata[K]): DF =
addColumnMetadata(column,
_.attachContext(md.asColumnMetadata).tagSpatialKey
)

private[astraea]
def setTemporalColumnRole(column: Column) =
def setTemporalColumnRole(column: Column): DF =
addColumnMetadata(column, _.tagTemporalKey)

/** Get the role tag the column plays in the RasterFrame, if any. */
private[astraea]
def getColumnRole(column: Column): Option[String] =
fetchMetadataValue(column, _.metadata.getString(SPATIAL_ROLE_KEY))

/** Get the names of the columns that are of type `Tile` */
def tileColumns: Seq[TypedColumn[Any, Tile]] =
self.schema.fields
.filter(_.dataType.typeName.equalsIgnoreCase(TileUDT.typeName))
.map(f col(f.name).as[Tile])

/** Get the spatial column. */
def spatialKeyColumn: Option[TypedColumn[Any, SpatialKey]] = {
val key = findSpatialKeyField
key
.map(_.name)
.map(col(_).as[SpatialKey])
}

/** Get the temporal column, if any. */
def temporalKeyColumn: Option[TypedColumn[Any, TemporalKey]] = {
val key = findTemporalKeyField
key.map(_.name).map(col(_).as[TemporalKey])
}

/** Find the field tagged with the requested `role` */
private[rasterframes] def findRoleField(role: String): Option[StructField] =
self.schema.fields.find(
f
f.metadata.contains(SPATIAL_ROLE_KEY) &&
f.metadata.getString(SPATIAL_ROLE_KEY) == role
)

/** The spatial key is the first one found with context metadata attached to it. */
private[rasterframes] def findSpatialKeyField: Option[StructField] =
findRoleField(SPATIAL_KEY_COLUMN.columnName)

/** The temporal key is the first one found with the temporal tag. */
private[rasterframes] def findTemporalKeyField: Option[StructField] =
findRoleField(TEMPORAL_KEY_COLUMN.columnName)

/** Renames all columns such that they start with the given prefix string.
* Useful for preparing dataframes for joins where duplicate names may arise.
*/
def withPrefixedColumnNames(prefix: String): DataFrame =
self.columns.foldLeft(self)((df, c) df.withColumnRenamed(c, s"$prefix$c"))
def withPrefixedColumnNames(prefix: String): DF =
self.columns.foldLeft(self)((df, c) df.withColumnRenamed(c, s"$prefix$c").asInstanceOf[DF])

/** Converts this DataFrame to a RasterFrame after ensuring it has:
*
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ trait Implicits {
implicit class WithProjectedRasterMethods(val self: ProjectedRaster[Tile])
extends ProjectedRasterMethods

implicit class WithDataFrameMethods(val self: DataFrame) extends DataFrameMethods
implicit class WithDataFrameMethods[D <: DataFrame](val self: D) extends DataFrameMethods[D]

implicit class WithRasterFrameMethods(val self: RasterFrame) extends RasterFrameMethods

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -103,7 +103,6 @@ trait RFSpatialColumnMethods extends MethodExtensions[RasterFrame] with Standard
case rf rf.certify
}
}

}

object RFSpatialColumnMethods {
Expand Down
Loading

0 comments on commit af66dc3

Please sign in to comment.