Generating Real-Time Sensor Maps From Videos And In-Ground Sensor Data
An apparatus for generating precision maps of an area is disclosed. The apparatus receives sensor data, where the sensor data includes sensor readings each indicating a level of a parameter in one of a plurality of first portions of an area, and video data representing an aerial view of the area. The sensor data may be received from sensors that are each deployed in one of the first portions of the area. The video data may be received from an aerial vehicle. An orthomosaic may be generated from the video data, and the orthomosaic and the sensor data used to generate a predication model. The prediction model may then be used to extrapolate the sensor data to determine a level of the parameter in each of a plurality of second portions of the area. A precision map of the area may be generated using the extrapolated sensor readings.
This application is a continuation application and, pursuant to 35 U.S.C. § 120, is entitled to and claims the benefit of earlier filed application U.S. application Ser. No. 15/256,566 filed Sep. 3, 2016, the content of which is incorporated herein by reference in its entirety for all purposes.
BACKGROUNDCurrent applications of technology for area mapping and area analysis use detailed sensor maps of an area to generate and display data. The data may be generated in the form of a precision map that shows, for example, parameters measured by sensors at specific locations. Applications may include, for example, applications used in agriculture, forestry, mining, climate monitoring, or security. The measured parameters may include parameters such as soil moisture, ground temperature, soil acidity level, ground movement, or other parameters. The current applications rely on a deployment of sensors within an area to provide the detailed sensor map. The deployment of sensors must normally be extremely dense in order to provide accurate data about the area. Other current area mapping and analysis applications may rely on the use of videos taken from aerial vehicles (AVs) such as drones (i.e., unmanned aerial vehicles (UAVs). However, a video taken from an AV cannot provide actual ground data. For example, in agricultural applications videos taken from AVs do not have detailed information about actual soil health, such as moisture content, temperature, or acidity level. In these applications that use an AV, a dense deployment of sensors would also be needed to provide actual accurate ground data about the area. Additionally, a typical high definition AV video made during a 15 minute flight can commonly exceed a gigabyte (GB) in size and may be difficult to manage and/or transfer.
SUMMARYThis summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This summary is not intended to exclusively identify key features or essential features of the claimed subject matter, nor is it intended as an aid in determining the scope of the claimed subject matter.
Embodiments of the disclosure include apparatus and methods for efficiently and accurately generating precision maps of an area. The methods and apparatus allow creation of a precision map from video data, for example a video of an aerial overfly of the area, and from sensor data. The sensor data may be generated by sensors that are sparsely deployed throughout the area. The embodiments include apparatus and methods for generating an efficient and accurate orthomosaic of an area from the video data. The embodiments further included apparatus and methods for combining the orthomosaic with the sensor data measured at the sparsely deployed sensors to generate the precision maps.
In an implementation, an apparatus may be configured to receive sensor data where the sensor data includes sensor readings, each indicating a level of a parameter in one of a plurality of first portions of an area. The apparatus may also be configured to receive video data representing an aerial view of the area. The sensor data may be received, for example, from sensors that are each deployed in one of the first portions of the area. The video data may be received, for example, from an aerial vehicle (AV) such as a drone (i.e., unmanned aerial vehicle (UAV)) that performs flyovers of the area. The apparatus may generate an orthomosaic from the video data and then generate a predication model using the orthomosaic and the sensor data. The prediction model may then be used to extrapolate the sensor data to determine a level of the parameter in each of second portions of the area. The second portions of the area may be portions of the area that do not contain sensors. The apparatus then may generate a map of the area. The map may include data that is displayable to provide an aerial view of the area and data that indicates the level of the parameter in each of the first and second portions of the area. In various example implementations, the level of the parameter may include a heat, moisture, or acidity measurement. The data on the levels of the parameter each of the first and second portions of the area may be displayable to provide a heat, moisture, or acidity map of the area. In an implementation in which the apparatus receives new sensor data more frequently than the apparatus receives new video data, the apparatus may update the map based on the new sensor data and a previously generated orthomosaic and/or prediction model. When new video data is received, the apparatus may update the previously generated orthomosaic and prediction model.
In another implementation an apparatus may be configured receive video data representing an aerial overview of an area. The video data may be received, for example, from a AV that performs flyovers of the area. The apparatus may then determine images from the video data, align the images, and stitch the aligned images together. The apparatus may generate an orthomosaic from the stitched images, where the orthomosaic includes data that is displayable to provide a geographically referenced image of the area. The apparatus may align the images to generate the orthomosaic by sampling frames from the video data, generating 3D position data and 3D orientation data corresponding to each of the frames, and generating 3D point data corresponding to a scene of the area. The apparatus may stitch the images to generate the orthomosaic by warping each of the frames to a ground plane to create warped images, determine optimal seams in areas where the warped images overlap, and adjust colors of each of the frames using the optimal seams.
In a further implementation an apparatus may be configured to receive sensor data, where the sensor data includes sensor readings each indicating a level of a parameter in a portion of first portions of an area. The apparatus may generate a prediction model using the sensor data and an orthomosaic of the area to generate a prediction model. The prediction model may then be used to extrapolate the sensor data to determine a level of the parameter in each portion of second portions of the area. The apparatus may then use the extrapolated sensor data to generate a map of the area, where the map includes data that is displayable to indicate the level of the parameter in each of the first and second portions of the area. The prediction model may be generated by determining visual similarities of the first and second portions and determining spatial similarities of the first and second portions. The prediction model for a level of the parameter in each of the second portions may then be generated from the visual and spatial similarities of the first and second portions of the area.
The system and method will now be described by use of example embodiments. The example embodiments are presented in this disclosure for illustrative purposes, and not intended to be restrictive or limiting on the scope of the disclosure or the claims presented herein.
Current area mapping and analysis applications require use of a detailed sensor map of an area for generating and displaying data. The data is commonly generated in the form of a precision map that shows, for example, parameters measured by sensors at specific locations. These applications may include, for example, applications used in agriculture, forestry, mining, climate monitoring, or security. The measured parameters may include parameters such as soil moisture, ground temperature, soil acidity level, ground movement, or any other appropriate parameter. Current applications rely on a deployment of sensors within an area to provide a detailed sensor map. The deployment of sensors must normally be extremely dense in order to provide accurate data about the area. This dense deployment of sensors requires a large number of sensors which is expensive. For example, accurate sensors for agricultural applications are expensive. The deployment of even one sensor per acre quickly becomes cost-prohibitive for most farmers.
Other current area mapping and analysis applications may rely on the use of videos taken from aerial vehicles (AVs) such as drones (i.e., unmanned aerial vehicles (UAVs)) or helicopters performing a flyover of an area to provide video data for a detailed map. However, a video taken from an AV cannot provide actual ground data. For example, in agricultural applications videos taken from AVs do not have detailed information about actual soil health, such as moisture content, temperature, or acidity level. In these applications that use an AV, a dense deployment of sensors would be needed to provide actual accurate ground data about the area.
The embodiments of the disclosure provide technical advantages by allowing use of a sparse deployment of sensors that requires fewer sensors and incurs less expense then currently used methods of creating sensor maps. Implementations of the embodiments include systems, apparatus and methods that compress video data captured from an AV into an aerial orthomosaic overview of an area. The orthomosaic may then be processed in combination with sensor values, measured by sensors sparsely deployed in the area, to generate precision maps for the entire area, including areas in which no sensors are deployed. For example, sensors that directly measure soil temperature at locations in the area can inform a machine learning pipeline to make predictions or extrapolations about other locations in the area by considering spatial proximity of the other locations to the deployed sensors. Visual similarity of the areas of the other locations as compared to areas within which the sensors are deployed can also inform the machine learning pipeline to make predictions about the other locations.
The embodiments also provide an advantage through the conversion and compression of the video data into the orthomosaic which results in a robust orthomosaic with few visual artifacts. The robust orthomosaic then allows resource efficient extrapolation of sensor data and generation of precision maps. In implementations of the embodiments, selected elements of aerial 3D mapping techniques are combined with selected elements of image stitching techniques. The new techniques that use the combination of the selected elements are also more robust than currently used techniques that use either aerial 3D mapping or aerial image stitching alone. In addition, the implementations are faster than currently used aerial 3D mapping techniques. This is because the implementations avoid several computationally expensive processing steps used in the current 3D mapping techniques. For example, the embodiments of the disclosure do not require construct of a dense digital surface model (DSM) of the terrain from an aerial video. This avoids the need for the high resolution depth maps used to create accurate DSMs in current 3D mapping techniques. The creation of DSMs is both computationally and memory intensive, and may not be suitable for resource constrained systems.
The compression of video data into an orthomosaic according to the embodiments also provides advantages in that the orthomosaic may include much less data than the original video data. For example, the orthomosaic may be an order of magnitude smaller than the video at full resolution. This provides advantage when the video data is being processed in a device in a weakly connected internet setting, i.e., when a connection to the internet is only available to the device over an intermittent or over a slow/low bandwidth connection. For example, sending large data files such as videos over an Internet connection takes time, and may also cost more than sending conventionally sized data files. These problems may be especially acute for internet of things (IoT) applications that use high volume data collecting devices such as AVs that collect video data. A typical high definition AV video made during a 15 minute flight can commonly exceed a gigabyte (GB) in size. Sending an entire video of this size over a weak internet connection for processing in a cloud network may take a long time. In the weakly connected setting, a user may find the time it takes to send such a large video file unacceptable because of the slow connection speed, or because the connection is only available intermittently. Services that utilize the video may then be degraded as far as service latency and quality of service. Other service relying on the same weak internet connection may also be degraded when the large video file is sent. In the embodiments, only the orthomosaic and sensor data need be sent to a cloud network rather than the whole video. The cloud network may then reconstruct the precision maps using based on the orthomosaic and sensor data.
The embodiments may be utilized to construct a dynamic, precision map that captures and presents the temporal variations of various environmental parameters on an area. The precision map may be constructed by generating an orthomosaic from a flyover video taken from an AV and then processing the orthomosaic in combination with sensor data to generate the precision map. The flyover videos may be generated at first time intervals. The sensor data may be received at second time intervals shorter than the first time intervals so the sensor data is received at a higher frequency than the video data. Each time new video data is received the orthomosaic used for generating the precision map may be updated. Each time the sensor data is received the precision map may be updated based on the current orthomosaic. This provides an advantage when the sensor data changes more quickly than the video data. Video data may be days or weeks old but the precision map may be kept up to date with current sensor data.
An example scenario in which the embodiments provide an advantage may include an agricultural setting in a remote area. To avoid shipping gigabytes of drone video and sensor data to the cloud over a weak internet connection in the agricultural setting, video processing may be performed locally on a low-cost PC, or a similar apparatus/machine functioning as a gateway. The gateway may be located at a farmer's home or office and collect information from ground sensors sparsely deployed in an area of the farm. The farmer may also use an AV to perform overflies of the area to create videos which are sent to the gateway. The gateway may compress the video and sensor data into summarized precision maps of the farm. To do so, the gateway first converts the drone video into a detailed orthomosaic of the farm and extrapolates the sensor readings to generate a precision map of the farm using embodiments of the disclosure. In one implementation, the gateway may send the orthomosaic and sensor data to the cloud. This reduces the size of data shipped to the cloud by an order of magnitude. In another implementation the gateway may only sends the precision maps to the cloud. This further reduces the size of data shipped to the cloud by another order of magnitude. In this way, the gateway may enable long term as well as cross-farm analytics in cloud services, while still continuing to provide near real-time analytics locally to the farmer through a web-based interface in the gateway
Area 101 is shown as including various differentiated areas. Area 104 may represents an area darker in color and wetter than surrounding areas. Area 112 may represents an area of particular plants/vegetation. Area 108 may represents another area of other plants/vegetation. Area 114 may represent a dirt area without plants or vegetation.
In an implementation of system 100, gateway 102 may comprise a gateway that is located in a weakly connected setting, i.e., in a setting in which connections over the local internet/cloud interface for link 110 is only available intermittently, and/or is only available with poor quality or low speed/low bandwidth connections. Gateway 102 may provide local services though user interfaces and/or connected devices for users located in the service area of gateway 102. The services may include local services that do not require communication with cloud network 116. The services may also include local services that require communication with cloud network 116. Use of data from gateway 102 may also enable provision of cloud services to users located remotely from gateway 102. Data that is communicated to the cloud network 116 from gateway 102 may also be combined with other data, such as weather data or data from gateways operating in other agricultural areas, in the cloud network 116 in order to provide enhanced cloud based services on a more global scale.
System 100 has application in any situation where an area may be monitored/analyzed using video data and/or sensor data. For example, system 100 may have application for use in providing services to other operations such as mining, mapping, geographical research, oceanography, environmental research, forestry, security, or surveillance over any type of area.
Gateway 102 may also be connected to a UAV flight planner 146 implemented in a computing device. For example, UAV flight planner 146 may be implemented as an application in a smartphone, tablet computer, laptop computer or desktop computer connected to gateway 102 by a Wi-Fi or other type of connection. UAV flight planner 146 may communicate with, and control, UAV 107b over a radio control link configured in the device in which the UAV flight planner 146 is implemented. UAV flight planner 146 may also communicate with, and control, UAV 107b through gateway 102, for example over FTP link 106b. In an alternative implementation, UAV flight planner 146 may be implemented as part of gateway 102. Webserver 130 of gateway 102 may also be connected to one or more devices 144 through, for example, a Wi-Fi link 148 to allow gateway 102 to provide local network services to a user of devices 144 without requiring a cloud connection (i.e., while offline). Gateway 102 also may be connected to the cloud network 116 though HTTP/AMQP link 110. The Cloud network 116 may provide cloud services based on the data received from gateway 102 and/or received from other gateways. Devices 144 may also provide users access to a remote webserver 138 to allow users to access services provided by the cloud network 116 when internet/cloud connections are available. The link 150 from devices 144 to webserver 138 may be implemented over the same weakly connected local Wi-Fi internet/cloud interface as is HTTP/AMQP link 110. Cloud network 116 may also include a connection to a global storage 140 that stores data for use by cloud services.
In an example implementation, gateway 102 may be implemented in an agricultural setting including an area such as area 101 of
The local network may be configured for efficient provision of services despite a lack of inexpensive internet/cloud connectivity in the fields, and despite a slow and unreliable network connection to cloud network 116 from elsewhere in the local network, for example, from the farmer's house or office. Services may be provided using a task allocation and data transfer scheme between gateway 102 and cloud network 116 that allows for efficient provision of both local services 125, and cloud services 120 and 122 in the weakly connected setting.
Various sets of data generated during the process of creating precision maps, such as the orthomosaic and sensor data, may also be backed up in storage 132 for sending to the cloud network 116 to enable cross-farm (i.e., between different farms) and long-term analytics performed in the cloud network 116. The various sets of data may be queued for sending to the one or more cloud network base on assigned priorities that allow for efficient provision of both local and cloud services given the weakly connected setting. The task allocations and the various sets of data may be configured to avoid sending large data sets on the weakly connected setting.
At 204, sensor interface 124 of gateway 102 receives video data from UAV 107b. The video data is provided to orthomosaic function 126b of processor 126 to generate an orthomosaic. The video data, which may comprise several gigabytes of data, is converted by orthomosaic function 126b into an orthomosaic that comprises a compact representation of an aerial view RGB color image of the area 101. In one example implementation, the orthomosaic may be constructed from the UAV video using a hybrid technique which combines components from both 3D mapping and mosaicking to construct the orthomosaic. For example, techniques from aerial 3D mapping may be used to estimate the relative position of different video frames without computing expensive high resolution digital surface maps. This allows the inaccuracies due to non-planar nature of area 101 to be removed. Once the relative positions have been computed, the images may be stitched together using mosaicking techniques to generate the orthomosaic.
At 208, precision map function 126a of processor 126 generates a precision map. The orthomosaic is provided to the precision map function 126a. Precision map function 126a uses the sensor data, received at 202, along with visual features in the orthomosaic, to determine a prediction model/function for extrapolating the sensor readings to create a precision map or update an existing precision map. For example, sensor data received from sensors 107a(1)-107a(n) that measures soil temperature at the locations of sensors 107a(1)-107(n) allow precision map function 126a to make predictions about every location in the farm. This may be done by considering spatial proximity as well visual similarity of the locations to the sensors 107a(1)-107(n). Visual similarity may be determined by analyzing spatial and visual smoothness. Areas that have similar spatial and visual smoothness may be considered to have similar sensor readings.
Precision map function 126a uses the prediction model and the latest sensor data to generate one or more precision maps of area 101. Precision map function 126a may use the prediction model to extrapolate the received sensor data to determine a predicted level of the measured parameter in each of the plurality of portions of the area that do not contain one of sensors 107a(1)-107a(n) and generate a precision map. The precision map may comprise a moisture map, pH map, temperature map, or a map of other parameters. The precision map may include data that is displayable to indicate the level of the parameter in each of the portions of area 101 that include sensors 107a(1)-107a(n) and, also, may indicate a level of the parameter in each of portions of the area 101 that contain no sensors.
At 210 services 128 of gateway 102 may utilize the precision map. For example, the map may be displayed to a user of gateway 102 to allow the user to observe moisture levels, pH level, temperature levels, or other parameters in the area 101. Service 128 may also include applications that may provide, at 212, management instructions or plans, such as irrigation or fertilizing programs, based on the precision map.
At 218, gateway 102 begins to receive the sensor data from sensors 107a(1)-07a(n) at sensor interface 124 over MQTT interface 106a at the intervals at which the sensor data is sent. Gateway 102 may continue to receive the sensor data at each interval throughout the process of
At 220, gateway 102 determines if it is time to send UAV 107b on a flight to collect video data over the area 101 in which sensors 107a(1)-107a(n) are located. The flights of UAV 107b may be timed to occur at intervals that are longer than the intervals at which sensor data is received at 218. If it is determined that it is not time for a UAV flight, the process moves to 228. If, however, it is determined at 220 that it is time for a UAV flight, gateway 102 sends a notification to UAV flight planner 146 and UAV 107a is flown over the area in which sensors 107a(1)-107a(n) are located to record a video of an aerial view of the area 101. In an implementation, the UAV flights may be initiated by gateway 102, or another device communicating with gateway 102 in the local network, on a predetermined basis, for example once or twice every 24 hours or several times a week. In another implementation, the UAV flights may be initiated by receipt of user input at a device in which UAV flight planner 146 is installed, such as, for example, computer device 144 when a user desires to collect video data. The flight of UAV 107a may be directed by a user of UAV flight planner 146 or may be an automatically controlled flight. At 224, UAV 107b sends video data of the flyover to gateway 102. Gateway 102 receives the video data over FTP interface 106b at FTP server. The video data is then input from sensor interface 124 to orthomosaic converter 126b of processor 126.
At 226, the video data, which may comprise several gigabytes of data, is converted by orthomosaic function 126b into an orthomosaic that comprises a compact representation of an aerial view RGB color image of the area in which the sensors 107a are located. In one example implementation, the orthomosaic may be generated from the UAV video using the hybrid technique as described for operation 206 of
At 228, gateway 102 generates a precision map from the mosaic and/or current sensor data. If operation 228 is entered from operation 226, the mosaic generated at operation 226 is used along with the current sensor data. In this case, the orthomosaic and current sensor data are input to the precision map function 126a in processor 126 of gateway 102. Precision map function 126a uses the current sensor data along with visual features in the current orthomosaic, to determine a prediction model/function for extrapolating the sensor readings to generate a precision map or generate an updated precision map. In one example implementation, the precision map may be generated as described for operation 208 of
At 228, Processor 126 may also queue any updated data/information associated with the function for extrapolating the sensor readings in storage 132 for sending to cloud network 116. In an implementation, the data/information associated with the function for extrapolating the sensor readings sensor may be assigned a time sensitive priority for sending to the cloud network 116. In a weakly connected setting, this causes the data/information for extrapolating the sensor readings to be sent to cloud network 116 with a preferred priority when the connection is intermittent or of low quality/low speed bandwidth. Cloud network 116 may then use the data/information associated with the function for extrapolating the sensor readings for time critical analysis by updating mosaics and sensor data currently being used in cloud network 116 for providing services. For example, if sensors 107a(1)-107a(n) monitor conditions that change quickly, such as moisture or temperature, updated data/information associated with the function for extrapolating the sensor readings will allow cloud network 116 to use current data/information associated with the function for extrapolating the sensor readings for analysis and provide up to date analysis. The data/information associated with the function for extrapolating the sensor readings may be assigned the preferred priority based on that data requiring less bandwidth and be easier to transmit without error or interfering with other data transmission in the weakly connected setting.
In the process of
At 230, processor 126 provides the precision map to services 128. The precision maps may then be accessed and utilized by service function 128 to provide services at gateway 102. Service function 128 may include services, such as service-1 128a through service-n 128n, each of which may be a service that utilizes a precision map. For example, a precision map may be used to provide services by generating information to a user about what tasks need to be performed, and where the tasks need to be performed on the farm. In an example implementation, an irrigation service may utilize a moisture map to provide information about the amount of water to use for irrigation on different parts of a farm. In another example, a precision pH service may utilize a pH map to provide information or recommendations about how much lime to apply on different parts of a farm to reduce the acidity of the soil in those regions. Processor 126 may also store the one or more precision maps in storage 132.
Use of cloud Sync component 134 ensures that the relevant data is backed up in the cloud for data access outside the agricultural network (e.g. when the farmer is travelling), for long term studies, and for cross-farm analytics. Because the video data received from the UAV is large in size, and the internet/cloud connection is weak, the UAV video data is not sent to the cloud. The video data may be kept in local storage 132 for a predefined duration, after which the video data may be deleted. In other implementations, additional levels of priority may be used for queuing data for sending from gateway 102 to cloud network 116. For example, a level of intermediate time sensitive, which has may have a priority between time sensitive and non-time sensitive, may be assigned.
Next, at 318, orthomosaic function 126b warps the key frames to the ground plane using the corresponding camera pose estimates. All the warped images then will be geometrically aligned on the ground plane. Next, at 320, orthomosaic function 126b determines optimal seams (i.e. simple polygonal curves) in areas where multiple warped images overlap. An optimal seam may be determined as one that passes through image regions with low contrast such that underlying image misalignment is harder to notice in the final result. The optimal seams may be determined by discrete optimization on a 2D pixel grid whose size is decided by the target resolution of the orthomosaic. Next, at 322, using the determined optimal seams, orthomosaic function 126b adjusts the colors of the individual key frames using image editing. At 324 the orthomosaic function 126b then generates the orthomosaic.
At 406, precision maps function 126a utilizes the orthomosaic to model visual similarity for portions of area 101. This includes determining visual similarity between portions of area 101 that include sensors 107a(1)-sensors 107a(n), and portions of area 101 that do not contain sensors. The visual similarity may be utilized because portions/areas that look similar normally have similar sensor values. For example, a recently irrigated area/portion would look darker and have soil with high moisture content.
Next, at 408, precision maps function 126a models spatial similarity for the portions of area 101. This includes determining spatial similarity or nearness for portions of area 101 that include sensors 107a(1)-sensors 107a(n), and portions of area 101 that do not contain sensors. The spatial similarity may be utilized because the sensors measure parameter levels of physical properties of the soil and the environment. These parameter levels should be similar for areas/portions of area 101 that are nearby or close to each other.
Next, at 410, precision maps function 126a creates a prediction model. The prediction model is created based on probability functions based on the visual similarity and spatial similarity and created using training data. The prediction model may then be used to predict parameter levels in any portion of area 101, including those portions that do not contain any of sensors 107a(1)-107a(n).
At 416, precision map generator 126a incorporates the visual smoothness described above by defining the corresponding potential function for visual smoothness as:
et((−wtTxii−yiit2)/2σt2)
Next, at 418, precision map generator 126a creates a value, D, to denote the N×N matrix such that:
Diij=et((−pii−pijt2)/2σt2)
where pi is the two-dimensional position coordinates for location i.
Next, at 418, in order to incorporate the spatial smoothness constraint, precision map generator 126a creates another term for the joint probability function:
At 420, precision map generator 126a then determines the joint probability defining the prediction model of system as:
where P(W) is a uniform prior on W added as a regularization term to this probability function.
Next, at 422, the model may be trained. Training and inference for this model may follow standard Gaussian processes. In the training phase, the value of w is learned from training data and may then be used to predict the sensor output yi on any data point. The value of the hyper-parameters σ and χ are chosen such that they maximize the likelihood of the observed data, P({Xiti(i=1)tN},{yiti(i=1)tN}. At 424 the prediction model may then be provided for data prediction. Once the sensor values at all the data points are known or inferred, a precision map may be generated from the data points.
Memory/storage 510 may be implemented as any type of computer readable storage media, including non-volatile and volatile memory. Memory/storage 510 is shown as including operating system (OS) 512, UAV control programs 514, gateway control programs 516, service programs 518, web server programs 520, orthomosaic generation programs 522, prediction model programs 524, and precision map programs 526. Processing unit 506 may comprise one or more processors, or other control circuitry, or any combination of processors and control circuitry that provide overall control of gateway 500 according to the disclosed embodiments.
Gateway control programs 516 may cause processing unit 506 to control gateway 500 to provide overall manage and coordination for functions described for gateway 102 in
Service programs 518 may cause processing unit 506 to control gateway 500 to provide the service functions 128 described in relation to
The example embodiments disclosed herein may be described in the general context of processor-executable code or instructions stored on memory that may comprise one or more computer readable storage media (e.g., tangible non-transitory computer-readable storage media such as memory 510). As should be readily understood, the terms “computer-readable storage media” or “non-transitory computer-readable media” include the media for storing of data, code and program instructions, such as memory 510, and do not include portions of the media for storing transitory propagated or modulated data communication signals.
While implementations have been disclosed and described as having functions implemented on particular wireless devices operating in a network, one or more of the described functions for the devices may be implemented on a different one of the devices than shown in the figures, or on different types of equipment operating in different systems.
Embodiments have been disclosed that include an apparatus comprising, one or more processors and memory in communication with the one or more processors. The memory comprises code that, when executed, causes the one or more processors to control the apparatus to receive video data representing an aerial view of an area, receive sensor data, the sensor data generated from a plurality of sensor readings, each indicating a level of a parameter in one of a plurality of first portions of the area, generate an orthomosaic from the video data, generate a prediction model using the orthomosaic and the sensor data, extrapolate the sensor data to determine a level of the parameter in each of a plurality of second portions of the area using the prediction model, and generate a map of the area, the map including data displayable to indicate the level of the parameter in each of the first and second portions of the area. The parameter may include a heat measurement and the map may include a heat map of the area. The parameter may include a moisture measurement and the may map include a moisture map of the area. The parameter may include an acidity measurement and the map may include an acidity map of the area. The sensor data may comprises first sensor data, the plurality of sensor reading may comprise a plurality of first sensor readings, the level of a parameter may comprise a first level of a parameter, and the code may further causes the one or more processors to control the apparatus to receive second sensor data, the second sensor data generated from a plurality of second sensor readings, each indicating a second level of a parameter in one of the plurality of first portions of the area, extrapolate the second sensor data to determine a second level of the parameter in each of the plurality of second portions of the area using the prediction model, and update the map of the area, the map displayable to indicate the second level of the parameter in each of the first and second portions of the area.
The code may further cause the one or more processors to generate the orthomosaic by controlling the one or more processors to align each of a plurality of images in the video data, and stitch the plurality of aligned images together to generate the orthomosaic. The code may further cause the one or more processors to align each of the plurality of images by controlling the apparatus to sample a plurality frames from the video data, and generate 3D position data and 3D orientation data corresponding to each of the plurality of frames, and 3D point data corresponding to a scene of the area. The code may further causes the one or more processors to stitch the plurality of images together by controlling the apparatus to fit a ground plane to the 3D point data, warp each of the plurality of frames to the ground plane to create a plurality of warped images, determine optimal seams in areas where of the plurality of warped images overlap, and adjust colors of each of the plurality of frames using the optimal seams. The code may further cause the one or more processors to generate the prediction model by controlling the apparatus to determine visual similarities of areas in the first and second portions, determine spatial similarities of areas in the first and second portions, and generate a prediction model for a level of the parameter in each of a plurality of second portions from the visual and spatial similarities of the areas in the first and second portions. The code may further cause the one or more processors to determine visual similarity by controlling the apparatus to determine a mean and variance of color of each of the areas in the first and second portions, and determine visual similarities of the areas in the first and second portions from the mean and variance of color in each of the areas.
The disclosed embodiments also include an apparatus comprising one or more processors and memory in communication with the one or more processors. The memory comprises code that, when executed, causes the one or more processors to control the apparatus to receive video data representing an aerial overview of an area, determine a plurality of images from the video data, align each of a plurality of images, stitch the plurality of aligned images together, and generate an orthomosaic from the stitched plurality of images, the orthomosaic displayable to provide a geo-referenced image of the area. The code further causes the one or more processors to align each of the plurality of images by controlling the apparatus to sample a plurality frames from the video data, and generate 3D position data and 3D orientation data corresponding to each of the plurality of frames, and 3D point data corresponding to a scene of the area. The code further causes the one or more processors to stitch the plurality of images together by controlling the apparatus to fit a ground plane to the 3D point data, warp each of the plurality of frames to the ground plane to create a plurality of warped images, determine optimal seams in areas where of the plurality of warped images overlap, and adjust colors of each of the plurality of frames using the optimal seams. The apparatus may be implemented in a gateway connected to a cloud network, and the code may further cause the one or more processors to control the apparatus to store the video data at the gateway and send the orthomosaic to the cloud network.
The disclosed embodiments further include an apparatus comprising one or more processors and memory in communication with the one or more processors. The memory comprises code that, when executed, causes the one or more processors to control the apparatus to receive sensor data, the sensor data generated from a at least one sensor reading, each indicating a level of a parameter in one of at least one first portion of an area, generate a prediction model using the sensor data together and an orthomosaic of the area, extrapolate the sensor data to determine a level of the parameter in each of at least one second portion of the area using the prediction model, and generate a map of the area, the map displayable to indicate the level of the parameter in each of the at least one first and at least one second portion of the area. The code may further causes the one or more processors to process the sensor data together with the orthomosaic by controlling the apparatus to determine visual similarities of areas in the at least one first and at least one second portion, determine spatial similarities of areas in the at least one first and at least one second portion, and generate a prediction model for a level of the parameter in each of the at least one second portion from the visual and spatial similarities of the areas in the at least one first and at least one second portion. The apparatus may further comprise a plurality of sensors each configured in the at least one first portions of the area, wherein the code causes the one or more processors to receive the sensor data from the plurality of sensors. The parameter may include an acidity measurement and the map may include an acidity map of the area. The parameter may include a heat measurement and the map may include a heat map of the area. The apparatus may include a moisture measurement and the map may include a moisture map of the area.
While the functionality disclosed herein has been described by illustrative example using descriptions of the various components and devices of embodiments by referring to functional blocks and processors or processing units, controllers, and memory including instructions and code, the functions and processes of the embodiments may be implemented and performed using any appropriate functional blocks, type of processor, circuitry or combinations of processors and/or circuitry and code. This may include, at least in part, one or more hardware logic components. For example, and without limitation, illustrative types of hardware logic components that can be used include field programmable gate arrays (FPGAs), application specific integrated circuits (ASICs), application specific standard products (ASSPs), system-on-a-chip systems (SOCs), complex programmable logic devices (CPLD s), etc. Use of the term processor or processing unit in this disclosure is meant to include all such implementations.
Also, although the subject matter has been described in language specific to structural features and/or methodological operations or acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features, operations, or acts described above. Rather, the specific features, operations, and acts described above are disclosed as example embodiments, implementations, and forms of implementing the claims and these example configurations and arrangements may be changed significantly without departing from the scope of the present disclosure. Moreover, although the example embodiments have been illustrated with reference to particular elements and operations that facilitate the processes, these elements, and operations may or combined with or, be replaced by, any suitable devices, components, architecture or process that achieves the intended functionality of the embodiment. Numerous other changes, substitutions, variations, alterations, and modifications may be ascertained to one skilled in the art and it is intended that the present disclosure encompass all such changes, substitutions, variations, alterations, and modifications as falling within the scope of the appended claims.
Claims
1. (canceled)
2. A method comprising:
- receiving a plurality of images representing an aerial view of an area;
- receiving sensor data generated from a plurality of sensor readings that represent measured levels of a parameter in a plurality of first portions of the area;
- generating an orthomosaic from the plurality of images;
- generating a prediction model using the orthomosaic and the sensor data;
- extrapolating the sensor data using the prediction model to produce extrapolated data that represent predicted levels of the parameter among a plurality of second portions of the area; and
- using the sensor data and the extrapolated data to indicate levels of the parameter in the first and second portions of the area.
3. The method of claim 2, wherein the parameter includes a heat measurement.
4. The method of claim 2, wherein the parameter includes a moisture measurement.
5. The method of claim 2, wherein the parameter includes an acidity measurement.
6. The method of claim 2, further comprising:
- receiving additional sensor data; and
- extrapolating the additional sensor data using the prediction model to produce updated extrapolated data that represent predicted levels of the parameter among a plurality of second portions of the area based on the additional sensor data; and
- using the additional sensor data and the updated extrapolated data to indicate new levels of the parameter in the first and second portions of the area.
7. The method of claim 2, wherein generating the orthomosaic from the plurality of images, includes:
- aligning the plurality of images; and
- stitching the plurality of aligned images together to generate the orthomosaic.
8. The method of claim 7, wherein aligning each of the plurality of images includes:
- sampling a plurality frames from among the plurality of images; and,
- generating 3D position data and 3D orientation data corresponding to each of the plurality of frames, and 3D point data corresponding to a scene of the area.
9. The method of claim 8, wherein stitching the plurality of aligned images together includes:
- fitting a ground plane to the 3D point data;
- warping each of the plurality of frames to the ground plane to create a plurality of warped images;
- determining optimal seams in locations where of the plurality of warped images overlap; and
- adjusting colors of each of the plurality of frames using the optimal seams.
10. The method of claim 2, wherein generating a prediction model includes:
- determining visual similarities of the first and second portions;
- determining spatial similarities of the first and second portions; and
- generating a prediction model for a level of the parameter in each of a plurality of second portions from the visual and spatial similarities of the first and second portions.
11. The method of claim 10, wherein determining visual similarities of the first and second portions includes:
- determining a mean and variance of color of each of the first and second portions; and
- determining visual similarities of the first and second portions from the mean and variance of color in each of the first and second portions.
12. A non-transitory computer-readable storage medium having stored thereon computer executable instructions, which when executed by a computer device, cause the computer device to:
- receive a plurality of images representing an aerial view of an area;
- receive sensor data generated from a plurality of sensor readings that represent measured levels of a parameter in a plurality of first portions of the area;
- generate an orthomosaic from the plurality of images;
- generate a prediction model using the orthomosaic and the sensor data;
- extrapolate the sensor data using the prediction model to produce extrapolated data that represent predicted levels of the parameter among a plurality of second portions of the area; and
- use the sensor data and the extrapolated data to indicate levels of the parameter in the first and second portions of the area.
13. The non-transitory computer-readable storage medium of claim 12, wherein parameter includes a heat measurement, a moisture measurement, or an acidity measurement.
14. The non-transitory computer-readable storage medium of claim 12, wherein the computer executable instructions, which when executed by the computer device, further cause the computer device to:
- receive additional sensor data; and
- extrapolate the additional sensor data using the prediction model to produce updated extrapolated data that represent predicted levels of the parameter among a plurality of second portions of the area based on the additional sensor data; and
- use the additional sensor data and the updated extrapolated data to indicate new levels of the parameter in the first and second portions of the area.
15. The non-transitory computer-readable storage medium of claim 12, wherein the computer executable instructions, which when executed by the computer device, further cause the computer device to generate the orthomosaic by:
- aligning the plurality of images; and
- stitching the plurality of aligned images together to generate the orthomosaic.
16. The non-transitory computer-readable storage medium of claim 12, wherein the computer executable instructions, which when executed by the computer device, further cause the computer device to generate the prediction model by:
- determining visual similarities of the first and second portions;
- determining spatial similarities of the first and second portions; and
- generating a prediction model for a level of the parameter in each of a plurality of second portions from the visual and spatial similarities of the first and second portions.
17. An apparatus comprising:
- one or more computer processors; and
- a computer-readable storage medium comprising instructions for controlling the one or more computer processors to be operable to:
- receive a plurality of images representing an aerial view of an area;
- receive sensor data generated from a plurality of sensor readings that represent measured levels of a parameter in a plurality of first portions of the area;
- generate an orthomosaic from the plurality of images;
- generate a prediction model using the orthomosaic and the sensor data;
- extrapolate the sensor data using the prediction model to produce extrapolated data that represent predicted levels of the parameter among a plurality of second portions of the area; and
- use the sensor data and the extrapolated data to indicate levels of the parameter in the first and second portions of the area.
18. The apparatus of claim 17, wherein parameter includes a heat measurement, a moisture measurement, or an acidity measurement.
19. The apparatus of claim 17, wherein the computer-readable storage medium further comprises instructions for controlling the one or more computer processors to be operable to:
- receive additional sensor data; and
- extrapolate the additional sensor data using the prediction model to produce updated extrapolated data that represent predicted levels of the parameter among a plurality of second portions of the area based on the additional sensor data; and
- use the additional sensor data and the updated extrapolated data to indicate new levels of the parameter in the first and second portions of the area.
20. The apparatus of claim 17, wherein the computer-readable storage medium further comprises instructions for controlling the one or more computer processors to be operable to generate the orthomosaic by:
- aligning the plurality of images; and
- stitching the plurality of aligned images together to generate the orthomosaic.
21. The apparatus of claim 17, wherein the computer-readable storage medium further comprises instructions for controlling the one or more computer processors to be operable to generate the prediction model by:
- determining visual similarities of the first and second portions;
- determining spatial similarities of the first and second portions; and
- generating a prediction model for a level of the parameter in each of a plurality of second portions from the visual and spatial similarities of the first and second portions.
Type: Application
Filed: Sep 12, 2018
Publication Date: Apr 4, 2019
Inventors: Ranveer CHANDRA (Kirkland, WA), Ashish KAPOOR (Kirkland, WA), Sudipta SINHA (Redmond, WA), Deepak VASISHT (Cambridge, MA)
Application Number: 16/129,462