Any and all applications for which a foreign or domestic priority claim is identified in the Application Data Sheet as filed with the present application are hereby incorporated by reference under 37 CFR 1.57.
A portion of the disclosure of this patent document contains material which is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document and/or the patent disclosure as it appears in the United States Patent and Trademark Office patent file and/or records, but otherwise reserves all copyrights whatsoever.
The present disclosure generally relates to computer-based methods and systems of managing greenhouse and the sowing and harvesting of greenhouse produce.
Conventional approaches to sowing, harvesting, and delivering produce in a greenhouse environment fail to ensure that there are adequate, yet non-wasteful, amounts of produce planted or harvested in order to satisfy actual or anticipated produce demand. Such conventional approaches further fail to adequately address changing environmental conditions.
The following presents a simplified summary of one or more aspects in order to provide a basic understanding of such aspects. This summary is not an extensive overview of all contemplated aspects, and is intended to neither identify key or critical elements of all aspects nor delineate the scope of any or all aspects. Its sole purpose is to present some concepts of one or more aspects in a simplified form as a prelude to the more detailed description that is presented later.
An aspect of the present disclosure relates to a networked greenhouse control system, the networked greenhouse control system comprising: a network interface configured to communicated over a network with a plurality of greenhouse computer system; at least one processing device operable to: receive, from a remote enterprise resource planning system, orders for greenhouse crops; utilize a demand planning engine to predict demand for greenhouse crops based at least in part on the orders for greenhouse crops from the remote enterprise resource planning system; based at least in part on the predicted demand for greenhouse crops from the demand planning engine, generate crop production instructions regarding one or more greenhouse crops, wherein the instructions include at least crop sowing instructions and/or crop picking instructions configured to cause crops to be respectively sown or picked in one or more greenhouses; transmit the crop production instructions to a greenhouse computer system; generate, based at least in part on the orders for greenhouse crops from the remote enterprise resource planning system, pallet loading instructions comprising instructions to load specified quantities of crop packs on respective pallets for shipment to a destination; access, for a first pallet, corresponding pallet loading instructions, an identifier associated with a recipient of the first pallet, a delivery date associated with the first palette, and an order identifier; generate, based at least in part on the pallet loading instructions, the identifier associated with the recipient of the first pallet, the delivery date associated with the first palette, and the order identifier, a placard configured to be affixed to the first palette; access greenhouse inventory data; utilize the greenhouse inventory data to populate crop pick instructions and a dump user interface; and transmit the crop pick instructions to the greenhouse computer system to thereby effect a corresponding harvest of crops.
An aspect of the present disclosure relates to a computer-implemented method, the method comprising: receiving over a network at a first computer system comprising one or more computing devices, orders for greenhouse crops; predicting demand for greenhouse crops based at least in part on the orders for greenhouse crops received over the network; based at least in part on the predicted demand for greenhouse crops, generating crop production instructions regarding one or more greenhouse crops, wherein the instructions include at least crop sowing instructions and/or crop picking instructions configured to cause crops to be respectively sown or picked in one or more greenhouses; transmitting the crop production instructions to a greenhouse computer system; generating, based at least in part on the orders for greenhouse crops received over the network, pallet loading instructions comprising instructions to load specified quantities of crop packs on respective pallets for shipment to a destination; and transmitting the pallet loading instructions to the greenhouse system to cause crops to be loaded onto pallets in accordance with the pallet loading instructions.
Embodiments will now be described with reference to the drawings summarized below. These drawings and the associated description are provided to illustrate example aspects of the disclosure, and not to limit the scope of the invention.
An aspect of the present disclosure relates to systems and methods configured to manage greenhouse crop harvest, yields and transport timing and yields, and that utilize predictions and demand data to perform crop allocations to customers.
As will be described, crop data is recorded and tracked with high accuracy, thereby enabling accurate predictions and determinations as to how much of a given crop will be available at a given point in time. Further, based on the monitoring of environmental conditions, a determination may optionally be made as to whether previous crop yield predictions need to be modified. Yet further, using the foregoing predictions and known or predicted demand, a determination may be made, for a given point in time, whether the crop yield will be sufficient to satisfy the demand. Still further, when a determination is made that the predicted crop yield is insufficient to meet known or predicted demand, the system may identify alternative sources of crops to satisfy the shortfall, and may direct transport vehicles to transport crops from such alternative sources to designated destinations. Aspects of the disclosure relate to the efficient packing of crop trays for transport to destinations.
Aspects of a greenhouse environment will now be described. A greenhouse may include one or more freestanding structures or two or more tables, ponds or zones or structures. The greenhouse roof and/or walls (e.g., glass, which may optionally be tempered glass, double walled polycarbonate, double walled polyethylene greenhouse with an air space between the two poly layers) provide light penetration as well as isolation from the outside elements (e.g., rain, snow, hail, the sun, wind, too hot temperatures, and/or two cold temperatures). The greenhouse may include environmental controls and feeding systems to enable crops to be grown. For example, a greenhouse may include heaters and evaporative coolers (e.g., to maintain the interior temperature within a desired range), evaporative cooling walls (configured to provide air into the greenhouse that is cooler than outside air), misters, fans (e.g., vertical air flow fans, horizontal air flow fans, gable fans, etc.), feed systems, and environmental controllers.
The greenhouse may include grow lights (e.g., CFL Full Spectrum lights). In addition, the greenhouse may include a bench system that supports crops at a working height. Optionally, troughs, pitched from an irrigation water supply end to a sump, may be provided for pot-based production.
The greenhouse may utilize a tray system. The trays may be loaded with potted plants or flats may be shipped directly to customers. A given tray may be of any dimension. A tray transport system may be in the form of a roller conveyor system, a frame slide bed conveyor system, a turning and incline conveyor system, and/or a plastic roller gravity conveyors system.
The greenhouse may optionally include one or more sensor types (which may be wired or wireless (e.g., Wi-Fi, Bluetooth, Zigbee, etc.) sensors). For example, moisture detection sensors may be placed in the soil to measure moisture content. CO2 sensors may be utilized to measure CO2 levels and to detect if the CO2 levels go above or below certain thresholds. Water pH level sensors may be placed in irrigation water as it runs through pipes or other water transport to detect over-acidic or under-acidic water conditions (which may cause nutrient deficiencies). The sensor readings may also be used to track, timestamp, and record interior and/or exterior temperatures, humidity, sunlight intensity, and/or rain.
Equipment monitoring sensors may be placed on misting and irrigation systems to monitor the performance of pumps and pressure lines. Airflow sensors may be located on vented roofs, side vents and fans and may be used to detect whether fans have stopped running or are running outside of certain specified parameters. Greenhouse temperature sensors may be used to measure internal temperatures in the greenhouse, and to detect when the temperature is above a first defined threshold and/or below a second defined threshold.
Cameras may be used to capture images of the greenhouse crops, and the images may be used to determine the crop health, size, color, estimated weight, and/or readiness to harvest. The camera(s) may be mounted to an unmanned vehicle (e.g., an unmanned aerial vehicle (UAV), an unmanned ground-based vehicle, an unmanned vehicle running on raised tracks, or the like, which may be referred to herein as drones). The drones may be autonomous and configured to fly along a pre-specified flight path. The drones may in addition or instead be remotely navigated by a remote drone control ground station system. The drones may be manually navigated by an operator using a remote control device.
The greenhouse may optionally include automated watering equipment, automated pesticide spray equipment, automated crop picking equipment, climate control equipment, crop spacing equipment, packaging equipment, and/or pallet loading equipment. The automated equipment may be controlled in whole or in part via the instructions discussed herein.
An example system architecture that may be utilized to provide crop management services (including crop demand forecasting, crop inventory tracking, component inventory (e.g., seeds, soil, containers, sleeves, trays, boxes, etc.), readiness to harvest, differences between demand and crop availability, routing, and/or exception condition handling) will now be discussed with reference to
The greenhouse computer systems may be in the form of a desktop computer, laptop computer, tablet computer, mobile phone, smart television, cloud-based system, and/or other computing system. A greenhouse computer system may include user input and output devices, such as displays (touch or non-touch displays), speakers, microphones, trackpads, mice, pen input, printers, haptic feedback devices, cameras, and the like. A greenhouse computer system may include wireless and/or wired network interfaces via which the greenhouse computer system may communicate with the crop management system 104 over one or more networks and with one or more greenhouse sensors, such as those discussed elsewhere herein. A greenhouse computer system may optionally include a local data store that may store customer and distributor contact information, order histories, sow data, dump date, pick data, call sheets, production schedules, and/or other data discussed herein, which may also be stored on, and synchronized with, a cloud data store associated with the crop management system 104.
User interfaces described herein are optionally configured to present data in real time from sources described herein, and user edits may be displayed and propagated in real time to other user interfaces, data stores, and data consumers. The user interfaces may present controls and interfaces to further ease the management of crops and ensure the accuracy of crop management data.
Optionally, a version of the user interfaces described herein may be enhanced for use with a small screen (e.g., 4 to 10 inches diagonal), such as that of a mobile phone or small tablet computer. For example, the orientation of the controls may be relatively more vertical rather than horizontal to reflect the height/width ratio of typical mobile device displays. Further, the user interfaces may utilize contextual controls that are displayed in response to an inferred user desire, rather than displaying a large number of tiny controls at the same time (which would make them hard to select or manipulate using a finger).
The crop management system 104 may provide tools to graphically generate certain models, such as those configured to perform demand planning, provide real time snapshots of greenhouse availability, identify and depict sales trends, and/or the like.
The crop management system 104 may optionally generate, based on order data from an enterprise resource system 106 (or other system) and/or call sheet data (discussed elsewhere herein) placards (which may be printed out and used with respect to crop shipments). The crop management system 104 may optionally generate pallet loading data (e.g., specifying how many cases of one or more types of crops are to be loaded onto a given pallet) based on order data from an enterprise resource system (or other system) and/or call sheet data.
In addition, based on customer orders (which may include direct to store delivery (DSD) orders and non-DSD orders), greenhouse data, and/or historical demand data, customer provided dynamic forecasting reports, the crop management system 104 may generate demand planning predictions. The demand planning predictions may in turn be utilized to generate production schedules for greenhouses (e.g., daily, weekly, monthly, and/or seasonal production schedules).
Real time data may be received from one or more systems and/or devices 102 (e.g., sensor data, weather data, etc.). Such real time data may be utilized in generating crop production and availability predictions, and may be used by a demand planning engine comprising a demand planning algorithm. For example, the sensors may include moisture detection sensors placed in the crop soil to measure moisture content, CO2 sensors to measure CO2 levels, water pH level sensors placed in irrigation water to detect over-acidic or under-acidic water conditions, airflow sensors (e.g., located on greenhouse vented roofs, side vents and fans and which may be used to detect whether the fans have stopped running or are running outside of certain specified parameters). Data from the sensors and/or other real time data sources (e.g., weather data providing temperature and humidity data in areas where greenhouses are located and/or along a route via which crops are to be transported) may be used to estimate crop yields, the likelihood of damage to crops being transported to distribution centers or stores, and to determinate if crop availability will satisfy known and/or predicted demand for such crop. In addition, some or all of the foregoing data may be utilized by an environmental impact algorithm, as discussed elsewhere herein. Some or all of the information generated by the crop management system 104 may be provided to the enterprise resource planning system, greenhouse systems, customer systems, and/or distributor systems.
Optionally some or all of the services provided by the crop management system 104 may be accessed via one or more APIs by authorized third party systems. The crop management system 104 may optionally generate directives in the form of routing instructions.
For example DSD customers may be assigned to one or more day/route delivery combinations. As the DSD orders are received by the system, the system may generate a DSD Call Sheet (e.g., a daily DSD Call Sheet) which defines the packout crops to be transported on a specified route and the corresponding delivery schedule. A given route may be assigned to a driver and/or vehicle (e.g., which optionally may be an autonomous, self-driving vehicle configured to execute the route instructions). The driver or autonomous, self-driving vehicle will then drive the route and deliver the crops to customers on the route in accordance with the delivery schedule.
The crop management system 104 may include one or more processing units 120B (e.g., a general purpose processor and/or a high speed graphics processor with integrated transform, lighting, triangle setup/clipping, and/or rendering engines), one or more network interfaces 122B, a non-transitory computer-readable medium drive 124B, and an input/output device interface 126B, all of which may communicate with one another by way of one or more communication buses. The network interface 122B may provide connectivity to and communications with one or more networks or computing systems (e.g., greenhouse systems/devices, sensors, customer systems/devices, distributor systems/devices, enterprise resource planning systems/devices, real time data systems/devices, etc.). The processing unit 120B may thus communicate information and instructions to and/or from other computing devices, systems, or services via a network. The processing unit 120B may also communicate to and from memory 124B and further provide output information via the input/output device interface 126B. The input/output device interface 126B may also accept input from one or more input devices, such as a keyboard, mouse, digital pen, touch screen, microphone, camera, other sensors, etc.
The memory 128B may contain computer program instructions that the processing unit 1206 may execute in order to implement one or more aspects of the present disclosure. The memory 1206 generally includes RAM, ROM (and variants thereof, such as EEPROM) and/or other persistent or non-transitory computer-readable storage media. The memory 120B may store an operating system 132B that provides computer program instructions for use by the processing unit 120B in the general administration and operation of the crop planning module 134B, including its components. The memory 128B may store user accounts for greenhouse operators, customers, distributors, and/or other entities. A user account may include, for example, contact information (e.g., email address, phone number, physical address), billing data, and/or other data. Optionally, in addition or instead, the data may be stored remotely on a cloud-based or other networked data store. The account data may optionally be stored in a relational database, an SQL database, a NOSQL database, a hierarchical database, an object oriented database, a graph database, and/or other database type.
For a greenhouse operator, the account data may also include, by way of example, the number of greenhouses, the size of the greenhouses, the configuration of the greenhouse (e.g., internal layout, presence of heating equipment, cooling/airflow equipment, irrigation equipment, tray/case handling systems, loading area data for shipping, etc.), the types and/or quantities of crops currently being grown, historical data on the types and/or quantities of crops previously grown and harvested, preferred tray size, preferred shipping containers, shipping data, and/or other data (e.g., other data discussed herein).
For a customer, the account data may also include, by way of example, the current orders for crops (e.g., including crop types, quantities, purchase prices, date orders placed, crop delivery dates, delivery address, etc.), predicted crop orders (e.g., including crop types, quantities, purchase prices, date orders placed, crop delivery dates, delivery address, etc.), and historical crop orders (e.g., including crop types, quantities, purchase prices, date orders placed, crop delivery dates, delivery address, etc.). In addition, customer logos and/or trademarks (which may be printed on placards for use with pallets, as described elsewhere herein) may be stored in the account. A distributor may be part of the same entity as one or more customers. For example, a distributor may receive bulk shipments of crops, and then forward selected portions of the delivery to different supermarkets (where the distributor and the supermarkets may be part of the same overall company). The account data for a distributor may include some or all of the same type of data as for customers and/or different data (e.g., an identification of the supermarkets to whom the distributor ships crops, the distributor warehouse size, etc.).
The memory 128B may include an interface module 130B. The interface module 130B can be configured to facilitate generating one or more interfaces through which a compatible computing device, may send data to, or receive data from the crop planning module 134B.
The modules or components described above may also include additional modules or may be implemented by computing devices that may not be depicted in
The order data from the ERP system and/or the DSD system may be utilized by a demand planning algorithm 206 and to populate call reports 212 (e.g., daily herb call sheets). As described in greater detail herein, the demand planning algorithm 206 may employ year-over-year sales of a given crop/product (e.g., customer specific and/or aggregate sales for all or a set of customers), trending demand projections vs actual ratio (Rolling Demand Factor—RDF), and/or rolling sales averages (RSA), to dynamically calculate the projected demand for each crop/product. The demand planning algorithm 206 may comprise a learning artificial intelligence model.
An aspect of the present disclosure relates to artificial intelligence (AI) driven dynamic forecasting of crop demand. An AI engine, which may be incorporated into the demand planning algorithm 206, is disclosed that learns from past data to optimize greenhouse yields to meet demand (e.g., expected orders) while reducing waste. The AI engine may provide real time demand predictions based at least in part on past demand and current orders, and optionally on other factors, such as those described herein. The AI engine may generate a demand forecast using a rolling average or mean of past demand over a specified period of time. The AI engine may optionally be configured to detect and filter out anomalous past orders. The AI engine may optionally be configured to determine if a past order was reduced as a result of a lack of available crops, and may determine whether to utilize the original order, the reduced order, or an average of the original order and the reduced order in predicting future demand for a given crop.
The demand planning algorithm 206 may optionally comprise a neural network having an input layer, an output layer, and one or more hidden layers. The hidden layers may include neurons connected by weights, the weights corresponding to the strength of the connection between neurons. The neural network may optionally be configured as a fully connected deep convolutional network. Optionally, the neural network may include one or more pooling layers configured to reduce the dimensions of a hidden layer by combining the outputs of neuron clusters at the previous layer into a single neuron in the next layer. During a training process, when a neural layer is trained on an input, the difference between the predicted and true output (e.g., as determined using an error function) causes an update in the weights via a backpropagation process. Optionally, the artificial intelligence may be implemented using a different architecture (e.g., random forests, support vector machines, k-nearest neighbors algorithms, symbolic regression, and/or other architectures).
The demand planning algorithm 206 may include a trending algorithm in making demand predictions, optionally for an individual crop/SKU. For example, the demand planning algorithm 206 may compare a demand prediction made by the demand planning algorithm 206 to the actual demand and determine the delta. The demand planning algorithm 206 may adjust the period over which the rolling sales are averaged so as to determine what period would have resulted in the smallest delta between the predicted demand and the actual demand. The period over which the rolling sales is to be averaged to achieve the most accurate prediction may be different during different seasons and for different crops (where a given crop may be associated with a corresponding SKU).
By way of illustration, if a 2 month rolling average for a given crop during a given season results in a demand prediction that is 14% below the actual demand, and a 3 month rolling average results in a demand prediction that is 1% above the actual demand, the 3 month rolling average may be used to make more accurate predictions.
Thus, for example, the demand planning algorithm 206, as part of its learning, may determine that a year-over-year 2 month rolling sales average should be used for mint in the spring, while a year-over-year 3 week rolling sales average should be used for mint in the fall. Thus, by way of illustration, if the 2 month rolling average in the spring is 20% higher than the same 2 month period the previous year, the algorithm may increase the prediction for the next week by 20% over the same week the previous year. By way of further example, the demand planning algorithm 206, as part of its learning, may determine that a year-over-year 6 week rolling sales average should be used for thyme in the spring, while a year-over-year 4 week rolling sales average should be used for thyme in the fall.
Optionally, rather than or in addition to using rolling averages, a mean demand/order may be used. Optionally, in determining the mean a filtering process may be used where the lowest and/or highest demand/order are excluded from determining the mean.
Optionally, the artificial intelligence learning process may be triggered in response to one or more events. For example, the training process may be initiated in response to determining that a prediction for demand/order amount for a given time period is more than a threshold percentage off from the actual demand/order amount for the given time period. By way of further example, the artificial intelligence learning process may be triggered in accordance with a schedule (that may specify specific dates on which the learning process is to be performed, such as the beginning of a season, or may specify a recurring time period (e.g., the first day of each week or month) at which the learning process is to be performed). Optionally, a user may be able to initiate a training process by activating a corresponding training initiation control.
The demand planning algorithm 206 may also be configured to detect certain outlier historical orders which it may exclude from the rolling average. For example, if a given rolling average results in a prediction for a given week that is more than twice the demand for the same week the previous year, and a threshold specifies that the predicted demand should not be more than 140% for the corresponding week in the previous year, a determination may be made that the predicted demand has exceeded the threshold. Optionally, the predicted demand will then be capped at the threshold (e.g., 140% the demand from the corresponding week in the previous year). Optionally, a determination may be made as to which order(s) in the rolling average caused the spike in the predicted demand, and that order may be eliminated from the rolling average calculation or may be reduced by a specified factor.
Optionally, other historical demand (e.g., order) data may be excluded from the calculation and new data may be used to adjust a prediction. For example, if a customer has ceased being a customer, the customer's order may be excluded from the rolling average, and the previous year's demand for a given time period may be reduced by the customer's order during that period when generating a prediction for an upcoming time period.
Optionally, as similarly described elsewhere herein, the demand planning algorithm 206 may be configured to determine if a past order was reduced as a result of a lack of available crops to supply the original order, and may determine whether to utilize the original order, the reduced order, or an average of the original order and the reduced order in predicting future demand for a given crop.
The demand planning algorithm 206 may be configured to generate and populate a forecast user interface that includes its demand/order predictions.
Optionally, if it is determined that a SKU (stock keeping unit assigned to a product such as a crop) has changed for a crop, a mapping may be made of the previous SKU to the new SKU for purposes of prediction. Thus, for example, in performing a rolling average calculation for a given crop for which the SKU has changed, orders for both SKUs may be treated as the same SKU and the orders for both SKUs may be aggregated as a single SKU.
Optionally, if there is insufficient quantity of a given crop to fulfill a predicted demand/orders for a given time period (e.g., as a result of a crop failure, breakage of a greenhouse table that results in the spillage of crops, as a result of a crop freeze, etc.), an instruction may be generated by the system to plant additional quantities of the crop to make up for the difference between the predicted demand/orders and the quantity of the crop that would otherwise be available for the given time period.
Optionally, a supply smoothing algorithm may be utilized to fulfill an order for a given crop/SKU in the event there is insufficient crop scheduled to be harvested for the shipping date for the order. For example, supply smoothing algorithm may schedule a late harvesting of the crop that was originally scheduled to be harvested at an earlier time (e.g., the previous week) and/or may schedule an early harvesting of the crop that was originally scheduled to be harvested at later time (e.g., the next week) in a quantity sufficient to make up the difference between the quantity of crop in the order and the quantity of crop scheduled to be harvested for the shipping date for the order. Optionally, the supply smoothing algorithm may be configured to split the harvesting of the crop needed to make up the shortfall for the scheduled harvest between a previous time period (e.g., the previous week) and a next time period (e.g., the next week). The split may be even or may be more heavily weighted towards the earlier or later time period. For example, 25% of the shortfall may be supplemented by the previous time period and 75% of the shortfall may be supplemented by the next time period.
The call report may be populated using the crop/product orders (sales data) from the ERP system and from the DSD customers. For example, a given order may be parsed by a computer system to identify the corresponding purchase order (PO) and crop (e.g., herb) totals. In addition, pallet maps and pallet placards 216 may be generated and which may be optionally printed. The call report 212 may in turn be utilized, in concert with available greenhouse inventory data 220, to populate a pick report 214 (which may include pick week dates, sow date, crop/product, and/or case quantity). The available greenhouse inventory data 220 may be populated at least in part using a sow report 222.
As described elsewhere herein, the output of the demand planning algorithm 206 may be utilized to generate a production schedule 208 (e.g., a daily, weekly, and/or monthly production schedule, which may also be referred to as a sow schedule). The production schedule 208 may in turn be utilized to generate one or more other schedules 210 (which may optionally be utilized to control or program automated greenhouse systems). For example, the production schedule 208 may be dynamically generated using the demand planning algorithm 206, and may then be used in defining the daily sow schedule for a corresponding time period (e.g., for each week). Example schedules 210 may include sow schedules, spacing schedules/reports, and/or crop spray schedules. By way of illustration, a spacing report may be a dynamically generated report that assigns the task of plant spacing based upon the spacing periods (e.g., days) in a corresponding time to finish (e.g., weeks to finish until the plant, such as an herb, is ready to be picked or otherwise harvested).
As noted above, available greenhouse inventory data 220 (which may include crop names and quantities of available greenhouse crop inventory) may be used to populate the pick report 214. In addition, available greenhouse inventory data 220 may be used to populate dump reports 218. As discussed elsewhere herein, a dump report 218 may be populated with a week number, sow date, crop type, tray type/count, quantity, dump date, zone/bay, and reason for dumping. For example, crop dumping may take the form of deliberate crop destruction to render the crop useless for consumption or processing. Dumping may be performed using one or more techniques such as grinding, burning, processing with chemicals, and/or soaking in water. Dumping may also take the form of free distribution of crops (e.g., to foodbanks).
The disclosed system may optionally be configured to track component inventory utilizing a component inventory management software module 226 and to order additional components based on the difference between current and/or predicted inventory and predicted future sowing of crops. The components may include consumables needed to grow and ship crops to customers. For example, components may include seeds, soil, trays, boxes, sleeves, and/or the like. The component inventory management software module 226 may track when new component inventory is delivered (and store in a database the quantity of each component received into inventory and the date of the delivery of such component inventory). The component inventory utilization may likewise be tracked, including the quantity of a given component withdrawn from inventory and the date it was withdrawn. For example, as component inventory is withdrawn from storage, barcodes on the components may be read with a barcode scanner and such withdrawal may be stored in the database.
Optionally, instead, a user may manually enter the quantity of the components retrieved from stored inventory. Optionally, an inventory report may be generated indicating the current quantity of components stored in inventory, the dates and quantity of withdrawal of components from inventory, the dates and quantity of components ordered, and the dates and quantity of received ordered components. Graphs may be generated depicting the utilization rate of component inventory, providing insights into inventory ordering and consumption.
The system may optionally be configured to generate fill rate reports, that identify the customer, the ship date, the purchase order identifier, the delivery location, tracks crop orders (including the quantity of each crop ordered and the requested delivery date/time frame), shipments of ordered crops (including the quantity of each crop shipped and the shipment date), and receipt of crops by customers that ordered such crops (including the quantity of each crop received as reported by the customer and the receipt date). The system may be configured to compare the quantity of received crops with the quantity of shipped crops for a given order and identify whether there is a difference. For example, the quantity of received crops may be subtracted from the quantity of shipped crops for a given order, and if there is a non-zero difference, then a discrepancy may be identified and optionally a resolution process may be initiated, and If there is a zero difference or less than a threshold difference, no action need be taken.
For example, a quantity of the crops corresponding to the difference may be added to a next shipment to the customer by the system. By way of further example, a message (e.g., an email message, a text message, a message presented via greenhouse software application, and/or the like) regarding the discrepancy (e.g., identifying an order identifier, a customer, crop quantities ordered, the crop quantities shipped, the crop quantities, the shipment date, and/or the like) may be transmitted to one or more destinations (e.g., associated with an administrator who can resolve the discrepancy). Such a process enables order accuracy to be determined and may ensure timely and complete delivery of crop orders.
The disclosed system may host a greenhouse web portal that enables users to compare available inventory with AI-driven forecasts. The web portal may identify (e.g., via a user interface, textually, via graphics, via highlights, or otherwise) a predicted shortage of inventory to meet predicted demand for a given crop and/or a predicted surplus of inventory exceeding predicted demand for a given crop. This enables the precise alignment of resources (e.g., inventory) with the predicted needs of a greenhouse, reducing the risk of overstocking (which may result in environmentally detrimental waste) or stockouts which may result in an insufficient quantity of crops to meet the demand. By integrating available inventory data with dynamic forecasting, real-time decision making is enabled, ensuring that the greenhouse operates at high efficiency while minimizing waste and optimizing crop production.
Certain example user interfaces will now be described. User interface fields and table entries may be automatically populated from one or more data sources (e.g., databases or systems described herein) and/or may be populated via a user entry. The user interfaces may optionally be served by a web server hosted by the crop management system. Optionally instead, the user interfaces may be provided by a dedicated application hosted on a user device.
Referring now to
The input data regarding the crop(s) may be used to determine/calculate available inventory totals for a given crop. The available inventory totals may be stored in a crops availability database (e.g., associated with the crop management system), and used in generating crops availability reports. For example, the sow week+the “weeks to finish” (WTF) may be used to determine if a given crop will be available (e.g., ready to be harvested or transported to customer) for a given week. The report may show in table format, for each crop, how many pots and/or plants are available for the current week. Optionally, the table may be sorted in accordance with a selected column (e.g., ascending to descending or descending to ascending, in alphabetical order or reverse alphabetical order). For example, the table rows may be sorted by crop name or by pot quantities.
The crops availability reports (and other reports disclosed herein) may be transmitted as a file, or as a link to a file or record, to one or more recipients. Optionally, the report may be viewed via a dedicated application or via a Software as a Service webpage generated by a web server. The crop availability report may be used by the greenhouse staff or automated picking equipment to identify which SOW week crops should be picked each day for the Dailey crop (e.g., herb) call sheets.
A menu of user interfaces or sections may be provided on some or all of the user interfaces described herein that provide a link to the corresponding user interface. Thus, the user may quickly navigate to a described user interface from other user interfaces by selecting a corresponding menu entry.
Referring now to
Once entered via the dump report user interface, the crop may be correspondingly added (e.g., in response to a user activation of submit control) to the dump totals in a dumps database, and may be used in availability reports described herein. The dump report may show in table format, for each crop, the quantity being dumped, the quantity being dumped, the tray size being dumped, the sow week, the zone bay, and the dump reason for the selected week. Optionally, the table may be sorted in accordance with a selected column (e.g., ascending to descending or descending to ascending, in alphabetical order or reverse alphabetical order). For example, the table rows may be sorted by crop name or dump quantities. Edit controls may optionally be provided that enable entries to be edited and that enable an entire row of entries to be deleted.
Referring now to
Referring now to
The crop management system may calculate the demand for a given week for a given product, and may automatically trigger an availability alert communication when the calculated demand for the crop/week is greater than the actual availability. The availability alert communication may be transmitted via a messaging service (e.g., an SMS/MMS messaging service, an email, a dedicated application hosted on a user device, via a SaaS webpage, etc.) to one or more destinations (e.g., the grower, an administrator participating in the crop management, etc.) that notifies the recipients that there is a potential shortfall of a specified crop in a specified future week.
A demand planning algorithm may be utilized that employs year-over-year (YoY) sales of a given crop, trending demand projections vs actual ratio (Rolling Demand Factor—RDF), and rolling sales averages (RSA), to dynamically calculate the projected demand for each crop/product.
Projected Demand=YoY*(Factor1)*RDF+0.25*RSA
Where Factor1 relates to the projected change in YoY sales total across the board (e.g., Factor1 may be set to 1.1 which represents a 10% projected YoY increase in sales total across the board).
The projected demand may then be used to dynamically populate a production/demand planning schedule for a given time period (e.g., a weekly production schedule comprising data and/or instructions) for the greenhouse. Optionally, such equipment may be used to control automated greenhouse equipment (e.g., the automated greenhouse equipment, such as automated watering equipment, automated pesticide spray equipment, automated crop picking equipment, climate control equipment, crop spacing equipment, packaging equipment, and/or pallet loading equipment).
Referring now to
Referring now to
For example, if the availability quantity of a given crop for a given week is less than the orders for that week (resulting in a shortfall), a determination may be made based on projected availability for the crop for a future week (e.g., the next week) and orders for the future week whether the crop for the future week may be shipped in the current week to make up the shortfall in crops for the current week relative to the orders for the week.
By way of further example, if the availability quantity of a given crop for a given week is greater than the orders for that week (resulting in an oversupply), a determination may be made based on projected availability for the crop for a future week (e.g., the next week) and on orders for the future week whether the crop oversupply for the current week may be used to fulfill orders for the future week. This may be particularly advantageous when the projected availability for the crop for the future week is less than the actual or projected orders for the future week.
The rolling orders report user interface may utilize sales data imported from sales tracking software, which may be a component of an enterprise resource planning software suite, and from the pick report discussed elsewhere herein. The crop management system (and the rolling orders report user interface) may continuously track crop/product sales data against crop availability to assure smooth distribution of available crops. A menu may be provided via which a user can select a desired time period (e.g., a desired week) for which data is to be presented.
Table columns may include running total (the total ordered for the week), total (the total ordered for the day), and an order amount column for each crop/product. Rows may include projected, available, total, order percentage, projected percentage, and days (days of the week). The projected value corresponds to the projected quantity of a given crop that will be available for the selected week. The availability value corresponds to the actual quantity of a given crop that is available for the selected week. The order percentage is the order quantity as a percentage of the crop availability. The projected percentage is the projected crop quantity as a percentage of the actual crop availability. Thus, for each, for each day, the columns may provide the running total, total, and an order amount for each crop for that day. The rolling order user interface may be populated using data from a pick report that includes the identification of and the quantity of actually picked/harvested data for the corresponding time period.
A rolling order alert may be automatically triggered when the system detects that orders for a certain time period (e.g., weekly orders) are trending (on track) to exceed available inventory. The determination as to whether weekly orders are trending (on track) to exceed available inventory alert may be based on the historical percentage of weekly order by day, and the rolling alert may be triggered when the weekly orders to date exceed the expected orders to date. The rolling order communication may be transmitted via a messaging service (e.g., an SMS/MMS messaging service, an email, a dedicated application hosted on a user device, via a SaaS webpage, etc.) to one or more destinations (e.g., the grower, an administrator participating in the crop management, etc.) that notifies the recipients that there may be insufficient crops to fill the actual orders to enable alternative sources of crop to be identified.
For example, when such a rolling order alert is triggered, a determination may be made as to whether there are greenhouse crops scheduled to be harvested in a future week that may be harvested earlier to make up the shortfall. Such a determination may be made based on the state of the crops scheduled to be harvested in a future week. For example, a camera-equipped drone may be used to periodically (e.g., hourly, daily, weekly, etc.) fly through the greenhouse and capture images of the crops. The greenhouse may have been mapped, with an indication as to where the rows of plant trays or other growing medium are placed, and what plants are in what trays. As described elsewhere herein, an object recognition and analysis system may be utilized to analyze the images and determine the height, width, colors, and/or health of a given crop, and utilize such analysis to determine whether a crop scheduled to be harvested in a future week is ready to be harvested in the current week. For example, the greenhouse map may be used to associate the output of the object recognition and analysis system with respect to greenhouse crops (e.g., herbs).
Referring now to
Referring now to
Available week=SOW Week+Weeks to finish
The time to finish may also be used in performing crop/product demand planning. The year-over-year crop demand may be imported from the demand week calculation below:
Demand Week=SOW Week+weeks to finish
As noted above, rather than using weeks to finish, days to finish may be utilized to provide finer control of the greenhouse crops.
Referring to
Sort controls may be provided to enable the table to be sorted in ascending or descending order in accordance to a selected column. Each table row corresponds to a given crop/product. Edit controls may optionally be provided that enable entries to be edited and that enable an entire row of entries to be deleted.
Referring now to
The daily herb call DC report parses the crop sales data for each DC customer for each day, and identifies the corresponding purchase order (PO) and crop (e.g., herb) totals. In addition, the daily herb call sheet DC user interface generates a pallet map and pallet placards. For example, the illustrated table may include a pallet section, listing pallet numbers and the number of each crop/product (e.g., number of the actual crop, the number of cases, etc.) to be included in the corresponding pallet.
The pallet map specifies the specific crop/product makeup (e.g., based on crop/product cases) for each pallet for each purchase order.
The placard tool generates a printable pallet placard (e.g., a PDF document) that has the DC customer information, logo, delivery date and pallet contents (e.g., the crop type and packaging information). Optionally, the information printed on the placard may be in human readable text and/or in a machine readable optical indicia, such as one dimension or two dimensional (e.g., QR code) bar code. Having the placard information printed in a machine readable optical indicia enables the placard to be scanned at the greenhouse shipping area, while on the transport vehicle, and at the destination using an optical scanner, thereby facilitating inventory control and tracking. The placard may be placed in or on the pallet. Optionally, the placard may have an adhesive backing to enable it to be affixed to the pallet. Optionally, the placard may be inserted into a placard holder mounted to the pallet.
An example placard is illustrated in
The daily herb call sheet DC report user interface may include a table, with a separate column for each purchase order, and may identify for each product the quantity included in the purchase order and the customer that placed the order. A menu is provided via which the user may select a pick date for the report. An export control may be provided, which when activated, causes the report to be exported in a specified format (e.g., a spreadsheet).
For example, a pallet layout may take the quantity totals for each of the crops (e.g., herbs) to be placed on pallets, and selects, from largest quantity to smallest quantity, the number of each crop to be placed on a pallet so as to correspond to a maximum number. For example, if the maximum number of crops that are to be placed on a pallet is 100, and if the shipment includes 170 Basil cases, 100 Cilantro cases, and 60 Parsley cases the pallet tool may build pallet layout as follows:
Optionally, where there are multiple pallets, the pallet builder may be configured to attempt to layout the pallets so that each or a subset of pallets contains the same or similar number of crops. Thus, if two or more pallets contain different numbers of crop cases according to an initial layout generated by the pallet builder, and one of the pallets is assigned less than a threshold number of my cases, the pallet builder may generate a new layout that better equalizes the number of cases on two or more pallets. Thus, if one pallet is full and another pallet has less than the threshold number of cases, certain cases may be reallocated from the full pallet to the less-than-full pallet to thereby better avoid the shifting of cases during transportation (and the resulting potential damage to the crops).
In the foregoing example, the threshold number of cases may be 40. Because pallet 4 has less than 30 cases and pallet 3 is full with 100 cases, the pallet builder may generate new layouts for pallets 3 and 4 so that each has the same number of cases as follows:
Certain modules and user interfaces will now be described that enable the control and access to user and organizational data. For example, optionally all users in a given organization may be granted the same level of access and control of such data. Optionally instead, different users or classes of users (e.g., upper level managers, mid-level managers, low level managers, non-managers) may be granted different levels of access and control of such data. For example, upper level managers may be given access and control to all user data, while non-managers may be provided with limited or no control or access to such user and organizational data.
Referring now to
A control may be provided which enables additional users to be added to the organization. Optionally, the table may identify a function/title for a given user and/or user data and control access and use rights. Optionally, search fields may be provided for each column configured to receive search text. A search engine may be provided that searches for matching entries in the corresponding column and provides corresponding matching search results.
An Organizations module may be provided that is configured to provide access controls for third party partner farms (which may optionally include greenhouse). Each such third party farm may be provided with its own unique administration access. The system may require the third party partner farm administrator to supply access authentication data (e.g., user identifier and password and/or biometric data, such as a fingerprint, face print, iris pattern, etc.) in order to access the third party partner farm's user data and/or certain other data disclosed herein. The authorized administrator by then be provided with a user interface (e.g., the user interface described above with respect to
Additionally, a given third party partner farm administrator may be provided with the ability to add in products not associated with the system operator to the third party partner farm portal. Thus, third party partner farm may be provided the ability to manage internal products in addition to those being provided to the crop management system operator. Where the third party partner farm is providing a given product/crop to both the system operator and its own customers, the system may enable the third party partner farm system administrator to duplicate an entry created for a crop/product for the system operator to be used in a corresponding table of crops/products being supplied to the third party partner farm's other customers.
Referring now to
A Products module may be provided that enables an authorized user to assign one or more product data feeds from an enterprise resource planning to corresponding organizations. For example, a third party partner farm system administrator may perform the feed assignment for crops/products being provided to its own customers (as opposed to the system operator who may distribute the crops/products to its customers). Optionally, by default, all crops/products are owned or being provided to the system operator.
Optionally, the crops/products listed in the manage products user interface illustrated in
Optionally, the crops/products available to a given DSD customer may be controlled via a menu (e.g., presented via a pop-up user interface) listing user-selectable (and de-selectable) crops/products. If a given crop/product item is selected via the menu, it may be made available to the DSD customer for order via a corresponding product list. If a given crop/product is deselected, the crop/product will not be listed in the product list provided to the DSD customer, and so may not be ordered by the DSD customer.
Optionally, the DSD customers daily route information is accessed from memory and displayed via the user interface. Optionally, such route information may be edited by the user. The daily route information may be used to generate the daily herb call sheet DSD, and enables users to make route adjustments in real time, while maintaining the set default information.
Referring now to
Optionally an administrator user interface may be provided via which a user (e.g., an authorized administrator) may specify minimum order quantities (on a crop/product-crop/product basis and/or for the overall order). In response to the minimum order quantities specification, the DSD Order form may be configured to prevent submission of an order if the quantity total is not greater than or equal to the minimum order quantities specification.
Optionally an administrator user interface may be provided via which a user (e.g., an authorized administrator) may input or select marketing messages and/or crop/product information that will be displayed via specified or all DSD Ordering user interfaces.
Optionally, the system may automatically generate and transmit messages (e.g., SMS/MMS messages, email messages, voice call messages, messages configured to be presented via a webpage or dedicated application, etc.) reminding direct customers or distributors of order dates and providing links to orders or the DSD Ordering user interface. For example, the system may track when or how often a DSD customer typically places an order for crops/products, predict a date when the DSD customer likely intends to place another order, and may automatically generate a reminder message a specified number of days, hours (or other time period) prior to the predicted date, reminding the DSD customer regarding the option to place an order for such date. Optionally, the message may include a link to a default order, automatically populated with order information (e.g., the quantity of each crop/product) from the previously placed order, where the DSD customer can activate an order control (e.g., a one click order approval control) to place the order using the automatically populated order information.
Referring now to
Referring now to
Similar graphs and reports may be generated for customer-specific sales of crops/products, shipping costs, crop/product shipment rejections, dumps, and sow totals.
An example plant height/weight user interface will now be described. The plant height/weight user interface is configured to be populated (e.g., directly from a database via user input) with the average (or other statistical central tendencies) plant height and average plant weight for the inventory in a given greenhouse (e.g., for all weeks). The plant height/weight data may be used by an environmental effect algorithm. The plant height/weight user interface may be populated for each sow week and crop/product type combination that is planted in the greenhouse. The plant height/weight user interface may be populated in real time using data from the availability report and analysis data generated from the output of one or more sensors (e.g., an unmanned vehicle camera system, which may include multi-spectral cameras). The weight data may be used to measure/determine moisture levels in the growth media.
Optionally, the plant height/weight data may be populated with plant health data obtained via one or more sensors. For example, a sensor-equipped unmanned vehicle path within a greenhouse may be generated using a mapping system. The unmanned vehicle (which may comprise an aerial or non-aerial vehicle) may follow the mapped out path and capture high resolution photographs of the greenhouse crops.
The vehicle camera system may include a visible light camera, a near-infrared light camera, an infrared light camera, and/or cameras configured to capture other light wavelengths to thereby capture hyperspectral images (which may comprise frames of a video captured by the unmanned vehicle). Such images and the values observed by the sensors planted in the crop soil may be utilized to determine the presence and/or to predict the possibility of plant diseases and pests.
For example, the images captured by the unmanned vehicle may be submitted to and processed by an artificial intelligence engine hosted on a local or remote system. Optionally, the artificial intelligence engine may include a machine learning engine that utilizes one or more probabilistic graphical models. Optionally, the learning engine may comprise a neural network having an input layer, an output layer, and one or more hidden layers. The hidden layers may include neurons connected by weights, the weights corresponding to the strength of the connection between neurons. During a training process, when a neural layer is trained on an input, the difference between the predicted and true output causes an update in the weights via a backpropagation process.
The artificial intelligence engine may analyze images for respective crops, and may identify the crop color(s), the crop size, the presence or presence likelihood of insects, and/or the presence or presence likelihood of a crop disease. When certain states (e.g., disease states or insect infestation states) are identified or estimated to be present with at least a threshold confidence factor, a corresponding may be generated identifying the state and optionally a confidence factor. The alert may be transmitted via a messaging service (e.g., an SMS/MMS messaging service, an email, a dedicated application hosted on a user device, via a SaaS webpage, etc.) to one or more destinations (e.g., the grower, an administrator participating in the crop management, etc.).
Other user interfaces and reports may include a crop spacing report and a time period-based (weekly) crop production report. The crop spacing report may be dynamically generated and may assign the task of plant spacing within a greenhouse based upon the specified spacing days (e.g., in the WTF table for each plant, such as each herb). The time period-based (weekly) crop production report may be dynamically generated using a demand planning algorithm, such as that described elsewhere herein, defining the daily sow schedule for sowing respective crops for respective time periods (e.g., each week).
Examples of a product report (also referred to as a product summary), a pesticide schedule (also referred to as a spray schedule), and an availability report are respectively illustrated in
Referring to the product summary illustrated in
The pesticide spray schedule may be dynamically generated for the greenhouse grower based upon the specific plant at issue (e.g., a particular herb type), the sow, spacing and/or pick dates. The pesticide spray schedule may be periodically updated (e.g., once a week or other period) and electronically provided to the grower, assigning and scheduling spray tasks using the foregoing criteria. It is understood that while the term “spray” may be used, other techniques of applying the pesticide may be used, such as foggers. The pesticide spray schedule as illustrated in
The example availability report illustrated in
Optionally, some or all of the reports may be generated in batch mode rather than in real time. This enables the reports to be generated at a time of relatively low computer resource utilization (e.g., process, memory, network utilization), such as late at night or early in the morning (e.g., 10:00 PM to 4:00 AM), thereby avoiding overloading computer resources and slowing down computer processing.
An environmental impact algorithm, such as that discussed elsewhere herein) is configured to identify a quantifiable correlation between external and internal environmental conditions at the greenhouse and the plant growth for each crop (e.g., herb) type. For example, the greenhouse environmental conditions may include moisture content of the growth medium (e.g., soil), CO2 levels, irrigation water pH levels, greenhouse temperature, greenhouse airflow, internal and/or external humidity, sunlight intensity, and/or rain. External environmental conditions may include temperature and humidity data in areas where greenhouses are located and/or along a route via which crops are to be transported.
The environmental impact algorithm may utilize regression analysis (e.g., linear and/or non-linear regression analysis) and/or non-linear curve fitting.
For example, regression analysis may be utilized to identify, quantify, and connect the long term impact of historical and/or current weather conditions on plant weight, plant height, and/or plant yields at a greenhouse. As the weather changes and environmental conditions change at the greenhouse the environmental impact algorithm may be used to attempt to calculate the effect of such weather changes and environment conditions on the time (e.g., weeks or days) to finish each crop type, optionally in real time, providing visibility into potential future availability issues for the crops (e.g., where the weather changes and environment conditions will cause an insufficient amount of crops to be available at given time period to satisfy the demand at such time period).
As noted above, in certain instances there may be an oversupply of a crop (e.g., where the crop availability for a given time period exceeds the demand for the crop). Conventionally, such oversupply would be sold at a loss or destroyed. In order to prevent such waste of crops, optionally an online marketplace may be provided via which such crops in oversupply may be auctioned off. The online auction marketplace may receive and provide data to the crop management system and may enable producers to identify surplus inventory they want to make available for sale/acquisition in the online auction marketplace. For example, the producers may identify the crop type, the quantity available for acquisition, the date of availability, the location of the crop, shipping charge (if any) and where the producer is willing to ship the crops too. The crop may then be posted on the auction platform, and buyers may bid against other buyers to purchase the crops (e.g., where the highest bidder wins the auction). The producer may then ship the crop to the winning bidder. Optionally, buyers need to be verified prior to being permitted to bid for posted crops.
Referring now to
At block 802, a determination is made as to whether a training process is to be initiated. For example, the determination may be made based on a calendared date (e.g., the beginning of a season), a recurring time period, in response to a previous prediction that differed by the actual demand/orders for a given time period (e.g., a week) by more than a threshold amount, in response to a user instruction, or otherwise.
In response to determining that a learning process is to be initiated, at block 804 an initial rolling average period is selected to be used in making a prediction. The initial rolling average period may be a default period (e.g., 4 weeks), where there may be different default periods for different seasons, or the default period may be the last rolling average period selected for use in making predictions. At block 805, the rolling average demand/order for the selected period in the current year may be calculated.
At block 806, the calculated rolling average demand/order may be compared to a demand/order value from the previous year. The demand/order value from the previous year may be based on a calculated rolling average demand/order for the selected period from the previous year. Optionally, demand/order value from the previous year may be based on the actual demand/order from the same week (e.g., week 42) from the previous year. For example, the comparison may be made by subtracting the demand/order value from the previous year from the calculated rolling average demand/order for the selected period in the current year (or vice versa), and dividing the subtraction difference by the calculated rolling average demand/order to determine a percentage difference.
At block 808, the calculated rolling average demand/order for the selected period in the current year and the calculated difference may be utilized to generate a demand/order prediction for a specific time period (e.g., the week just past). For example, if the percentage difference is +20%, the prediction for the specific period may be the calculated rolling average demand/order for the selected period multiplied by 1+0.20 (1.20). The prediction may then be adjusted at block 810 using known anomalies/exceptions (e.g., the loss of a customer whose orders were included in the previous year's demand/orders, but was no longer a customer during the during the selected period in the current year; the addition of a new customer after the period in the prior year; a change in SKU, and/or the like).
At block 812, the prediction (optionally adjusted at block 810) is compared to the actual demand/orders for the specific time period to determine the accuracy and correctness of the prediction. For example, the prediction (optionally adjusted at block 810) may be subtracted from the actual demand/orders for the specific time period to generate a corresponding difference. At block 812, a determination may be made as to whether the difference is greater than a specified difference threshold. If the difference is less than the difference threshold, at block 816, the current selected rolling average period may be used in making further predictions.
If the difference is greater than the difference threshold, at block 814, the rolling average time period may be adjusted (e.g., by the specified amount, such as an increase or decrease of a week or other time period). The training process may continue repeating until the difference threshold is determined, at block 812, to be less than the specified threshold, or until a specified number of iterations of the process has been performed.
An aspect of the present disclosure relates to a networked greenhouse system configured to enhance greenhouse sowing and picking performance, the networked greenhouse system comprising: a network interface configured to communicate over a network with a plurality of greenhouse computer systems; at least one processing device operable to: access historical order data for a first crop for a first period of time from a previous year relative to a current year; generate a rolling average of orders for the first crop for a second time period from the current year; use the accessed historical order data for the first crop for the first period of time from the previous year and the rolling average of orders for the first crop for the second time period from the current year to generate a prediction of orders for the first crop for a third time period; based at least in part on generated prediction of orders for the first crop for the third time period, initiate a sowing a corresponding quantity of the first crop in at least a first greenhouse; receive, from a remote system, orders for greenhouse crops including the first crop; and transmit, using the network interface, crop pick instructions to a first of the plurality of greenhouse computer systems to thereby effect a corresponding harvest of at least the first crop.
Optionally, the networked greenhouse system is configured to: determine if a model configured to predict orders of the first crop is to be trained based at least in part on a training schedule; at least partly in response to determining that the model configured to predict orders of the first crop is to be trained based at least in part on the training schedule: access an initial time period for which a rolling average is to be calculated to be used in predicting orders for the first crop; make a prediction of orders for the first crop for a fourth time period using the model based in part on the rolling average for the initial time period; compare the prediction of orders for the first crop for the fourth time period made using the model based in part on the rolling average for the initial time period with actual orders for the first crop for the fourth time period; at least partly in response to determining that the prediction of orders for the first crop for the fourth time period made using the model based in part on the rolling average for the initial time period differs from the actual orders for the first crop for the fourth time period by more than a first threshold: select a different time period for which a second rolling average is to be calculated to be used in predicting orders for the first crop; make a second prediction of orders for the first crop for the fourth time period using the model based in part on the different rolling average for the different time period; compare the prediction of orders for the first crop for the fourth time period made using the model based in part on the rolling average for the different time period with actual orders for the first crop for the fourth time period; at least partly in response to determining that the prediction of orders for the first crop for the fourth time period made using the model based in part on the rolling average for the different time period differs from the actual orders for the first crop for the fourth time period by less than the first threshold, use the different time period for calculating rolling averages in making order predictions for a fifth time period.
Optionally, the networked greenhouse system is configured to generate the prediction of orders for the first crop for the third time period based in part on one or more exceptions, comprising a loss of a crop customer, an addition of a crop customer, and/or a change of SKU.
Optionally, the networked greenhouse system is configured to: store inventory data for components needed to sow and ship one or more crop types, the components comprising seeds, soil, containers, sleeves, and trays; access order predictions for one or more crops; at least partly in response to determining that there will be insufficient components in order to grow and/or ship crops corresponding to the order predictions for one or more crops, initiate an order for one or more components.
Optionally, the networked greenhouse system is configured to: generate and populate a user interface comprising: an identification of a first plurality of crop customers and one or more locations for each of the first plurality of crop customers; an identification of, for respective crops, a crop quantity ordered by respective locations of respective crop customers; an identification of, for respective crops, a crop quantity shipped by respective locations of respective crop customers; an identification of, for respective crops, a crop quantity delivered to respective locations of respective crop customers based on data provided by the respective crop customers; and a generated fill rate for respective orders for respective crops for respective locations of respective crop customers.
Optionally, the networked greenhouse system is configured to: generate and populate a user interface comprising: demand data for a previous year; demand data for a specific week for the previous year; demand data for a specific week in a current year; a generated average demand for a specified number of weeks; and predicted demand data for the specific in the current year.
Optionally, the networked greenhouse system is configured to: determine, for a fourth time period, whether available crops of a first type from one or more greenhouses are less than demand for crops of the first type from the one or more greenhouses; at least partly in response to determining for the fourth time period that available crops of the first type from the one or more greenhouses are less than demand for crops of the first type from the one or more greenhouses, determine if crops of the first type from the one or more greenhouses scheduled to be harvested during a fifth time period, the fifth time period after the fourth time period, are ready to be harvested during the fourth time period; and at least partly in response to determining that crops of the first type from the one or more greenhouses scheduled to be harvested during the fifth time period are ready to be harvested during the fourth time period, cause at least a portion of the crops of the first type from the one or more greenhouses scheduled to be harvested during the fifth time period that are ready to be harvested during the fourth time period to be harvested during the fourth time period.
Optionally, the networked greenhouse system is configured to: access images captured by an unmanned vehicle while navigating the first greenhouse; use a learning engine to determine sizes and colors of at least a portion of the crops in the first greenhouse, the learning engine comprising an input layer, an output layer, and one or more hidden layers comprising neurons associated with weights; determine, for a fourth time period, whether available crops from the first greenhouse is less than demand for crops from the first greenhouse; based at least in part on the crop sizes, determined using the learning engine, determine whether crops in the first greenhouse, scheduled to be harvested during a fifth time period, the fifth time period after the fourth time period, will be ready to harvest during the fourth time period; and at least partly in response to determining that crops from the first greenhouse scheduled to be harvested during the fifth time period are ready to be harvested during the fourth time period, cause at least a portion of the crops from the first greenhouse scheduled to be harvested during the fifth time period that are ready to be harvested during the fourth time period, to be harvested during the fourth time period.
Optionally, the networked greenhouse system is configured to: generate pesticide application instructions for at least the first greenhouse based at least in part on the generated prediction of orders for the first crop for the third time period; and transmit the pesticide application instructions to a greenhouse computer system associated with the first greenhouse to effect execution of the pesticide application instructions.
Optionally, the networked greenhouse system is configured to: predict demand for a greenhouse crop based in part on crop order data from a direct to store delivery online order.
Optionally, the networked greenhouse system is configured to: dynamically generate spacing instructions for at least one greenhouse, wherein the spacing instructions comprise plant spacing execution operations.
Optionally, the networked greenhouse system is configured to: generate a sow report interface configured to be populated with a time period identifier, a sow date, a crop identifier, and a tray type; and use data used to populate the sow report to generate an available greenhouse inventory report.
Optionally, the networked greenhouse system is configured to: generate an electronic demand planning document, indicating for a plurality of different crops, in what time period a given crop, in the plurality of different crops, is to be harvested and indicating how much of the given crop is to be harvested, and a rolling demand factor for the given crop.
Optionally, the networked greenhouse system is configured to: provide a first user interface configured to enable an authorized user to individually specify for a plurality of different customers which crops are to be available for acquisition for respective customers and which crops are not to be available for acquisition for respective customers; receive, via the first user interface a first specification for a first customer indicating a first set of crops that are to be available for acquisition by the first customer, and a second set of crops that are not to be available for acquisition by the first customer; receive, via the first user interface a first specification for a first customer indicating a first set of crops that are to be available for acquisition by the first customer, and a second set of crops that are not to be available for acquisition by the first customer; receive, via the first user interface a second specification for a second customer indicating a third set of crops that are to be available for acquisition by the first customer, and a fourth set of crops that are not to be available for acquisition by the first customer, wherein the first set is different than the third set, and the second set is different than the fourth set; provide a first crop order form for display on a display of the first customer, the first crop order form including entries for the first set of crops and excluding entries for the second set of crops; and provide a second crop order form for display on a display of the second customer, the second crop order form including entries for the third set of crops and excluding entries for the fourth set of crops.
Optionally, the networked greenhouse system is configured to predict crop availability for one or more periods of times based at least in part greenhouse sensor readings, comprising temperature sensor readings, moisture sensor readings, ph sensor readings, and CO2 sensor readings.
An aspect of the present disclosure relates to computerized-method configured to enhance greenhouse performance, the method comprising: accessing, using a computer system comprising a processor, memory, and a network interface, historical order data for a first crop for a first period of time from a previous year relative to a current year; generating a rolling average of orders for the first crop for a second time period from the current year; using the accessed historical order data for the first crop for the first period of time from the previous year and the rolling average of orders for the first crop for the second time period from the current year to generate a prediction of orders for the first crop for a third time period; and based at least in part on generated prediction of orders for the first crop for the third time period, initiating a sowing a corresponding quantity of the first crop in at least a first greenhouse; receiving, from a remote system, orders for greenhouse crops including the first crop; transmitting, using the network interface, crop pick instructions to a first greenhouse computer system to thereby effect a corresponding harvest of at least the first crop.
Optionally, the method further comprises: determining if a model configured to predict orders of the first crop is to be trained based at least in part on a training schedule; at least partly in response to determining that the model configured to predict orders of the first crop is to be trained based at least in part on the training schedule: accessing an initial time period for which a rolling average is to be calculated to be used in predicting orders for the first crop; making a prediction of orders for the first crop for a fourth time period using the model based in part on the rolling average for the initial time period; comparing the prediction of orders for the first crop for the fourth time period made using the model based in part on the rolling average for the initial time period with actual orders for the first crop for the fourth time period; at least partly in response to determining that the prediction of orders for the first crop for the fourth time period made using the model based in part on the rolling average for the initial time period differs from the actual orders for the first crop for the fourth time period by more than a first threshold: selecting a different time period for which a second rolling average is to be calculated to be used in predicting orders for the first crop; making a second prediction of orders for the first crop for the fourth time period using the model based in part on the different rolling average for the different time period; comparing the prediction of orders for the first crop for the fourth time period made using the model based in part on the rolling average for the different time period with actual orders for the first crop for the fourth time period; at least partly in response to determining that the prediction of orders for the first crop for the fourth time period made using the model based in part on the rolling average for the different time period differs from the actual orders for the first crop for the fourth time period by less than the first threshold, using the different time period for calculating rolling averages in making order predictions for a fifth time period.
Optionally, the method further comprises generating the prediction of orders for the first crop for the third time period based in part on one or more exceptions, comprising a loss of a crop customer, an addition of a crop customer, and/or a change of SKU.
Optionally, the method further comprises: storing inventory data for components needed to sow and ship one or more crop types, the components comprising seeds, soil, containers, sleeves, and trays; accessing order predictions for one or more crops; and at least partly in response to determining that there will be insufficient components in order to grow and/or ship crops corresponding to the order predictions for one or more crops, initiate an order for one or more components.
Optionally, the method further comprises: generating and populating a user interface comprising: an identification of a first plurality of crop customers and one or more locations for each of the first plurality of crop customers; an identification of, for respective crops, a crop quantity ordered by respective locations of respective crop customers; an identification of, for respective crops, a crop quantity shipped by respective locations of respective crop customers; an identification of, for respective crops, a crop quantity delivered to respective locations of respective crop customers based on data provided by the respective crop customers; and a generated fill rate for respective orders for respective crops for respective locations of respective crop customers.
Optionally, the method further comprises: generating and populating a user interface comprising: demand data for a previous year; demand data for a specific week for the previous year; demand data for a specific week in a current year; a generated average demand for a specified number of weeks; and predicted demand data for the specific in the current year.
Optionally, the method further comprises: determining, for a fourth time period, whether available crops of a first type from one or more greenhouses are less than demand for crops of the first type from the one or more greenhouses; at least partly in response to determining for the fourth time period that available crops of the first type from the one or more greenhouses are less than demand for crops of the first type from the one or more greenhouses, determining if crops of the first type from the one or more greenhouses scheduled to be harvested during a fifth time period, the fifth time period after the fourth time period, are ready to be harvested during the fourth time period; and at least partly in response to determining that crops of the first type from the one or more greenhouses scheduled to be harvested during the fifth time period are ready to be harvested during the fourth time period, causing at least a portion of the crops of the first type from the one or more greenhouses scheduled to be harvested during the fifth time period that are ready to be harvested during the fourth time period to be harvested during the fourth time period.
Optionally, the method further comprises: accessing images captured by an unmanned vehicle while navigating the first greenhouse; using a learning engine to determine sizes and colors of at least a portion of the crops in the first greenhouse, the learning engine comprising an input layer, an output layer, and one or more hidden layers comprising neurons associated with weights; determining, for a fourth time period, whether available crops from the first greenhouse is less than demand for crops from the first greenhouse; based at least in part on the crop sizes, determined using the learning engine, determining whether crops in the first greenhouse, scheduled to be harvested during a fifth time period, the fifth time period after the fourth time period, will be ready to harvest during the fourth time period; and at least partly in response to determining that crops from the first greenhouse scheduled to be harvested during the fifth time period are ready to be harvested during the fourth time period, causing at least a portion of the crops from the first greenhouse scheduled to be harvested during the fifth time period that are ready to be harvested during the fourth time period, to be harvested during the fourth time period.
Optionally, the method further comprises: generating pesticide application instructions for at least the first greenhouse based at least in part on the generated prediction of orders for the first crop for the third time period; and transmitting the pesticide application instructions to a greenhouse computer system associated with the first greenhouse to effect execution of the pesticide application instructions.
Optionally, the method further comprises: predicting demand for a greenhouse crop based in part on crop order data from a direct to store delivery online order.
Optionally, the method further comprises: dynamically generating spacing instructions for at least one greenhouse, wherein the spacing instructions comprise plant spacing execution operations.
Optionally, the method further comprises: generating a sow report interface configured to be populated with a time period identifier, a sow date, a crop identifier, and a tray type; and using data used to populate the sow report to generate an available greenhouse inventory report.
Optionally, the method further comprises: generating an electronic demand planning document, indicating for a plurality of different crops, in what time period a given crop, in the plurality of different crops, is to be harvested and indicating how much of the given crop is to be harvested, and a rolling demand factor for the given crop.
Optionally, the method further comprises: providing a first user interface configured to enable an authorized user to individually specify for a plurality of different customers which crops are to be available for acquisition for respective customers and which crops are not to be available for acquisition for respective customers; receiving, via the first user interface a first specification for a first customer indicating a first set of crops that are to be available for acquisition by the first customer, and a second set of crops that are not to be available for acquisition by the first customer; receiving, via the first user interface a first specification for a first customer indicating a first set of crops that are to be available for acquisition by the first customer, and a second set of crops that are not to be available for acquisition by the first customer; receiving, via the first user interface a second specification for a second customer indicating a third set of crops that are to be available for acquisition by the first customer, and a fourth set of crops that are not to be available for acquisition by the first customer, wherein the first set is different than the third set, and the second set is different than the fourth set; providing a first crop order form for display on a display of the first customer, the first crop order form including entries for the first set of crops and excluding entries for the second set of crops; and providing a second crop order form for display on a display of the second customer, the second crop order form including entries for the third set of crops and excluding entries for the fourth set of crops.
Optionally, the method further comprises predicting crop availability for one or more periods of times based at least in part greenhouse sensor readings, comprising temperature sensor readings, moisture sensor readings, ph sensor readings, and CO2 sensor readings.
Thus, systems and methods are described that are configured to manage greenhouse crop harvest and transport timing and yields, that provide real time data updates, and that utilize predictions and demand data to perform crop allocations.
The methods and processes described herein may have fewer or additional steps or states and the steps or states may be performed in a different order. Not all steps or states need to be reached. The methods and processes described herein may be embodied in, and fully or partially automated via, software code modules executed by one or more general purpose computers. The code modules may be stored in any type of computer-readable medium or other computer storage device. Some or all of the methods may alternatively be embodied in whole or in part in specialized computer hardware. The systems described herein may optionally include displays, user input devices (e.g., touchscreen, keyboard, mouse, voice recognition, etc.), network interfaces, etc.
The results of the disclosed methods may be stored in any type of computer data repository, such as relational databases and flat file systems that use volatile and/or non-volatile memory (e.g., magnetic disk storage, optical storage, EEPROM and/or solid state RAM).
The various illustrative logical blocks, modules, routines, and algorithm steps described in connection with the embodiments disclosed herein can be implemented as electronic hardware, computer software, or combinations of both. To clearly illustrate this interchangeability of hardware and software, various illustrative components, blocks, modules, and steps have been described above generally in terms of their functionality. Whether such functionality is implemented as hardware or software depends upon the particular application and design constraints imposed on the overall system. The described functionality can be implemented in varying ways for each particular application, but such implementation decisions should not be interpreted as causing a departure from the scope of the disclosure.
Moreover, the various illustrative logical blocks and modules described in connection with the embodiments disclosed herein can be implemented or performed by a machine, such as a general purpose processor device, a digital signal processor (DSP), an application specific integrated circuit (ASIC), a field programmable gate array (FPGA) or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to perform the functions described herein. A general purpose processor device can be a microprocessor, but in the alternative, the processor device can be a controller, microcontroller, or state machine, combinations of the same, or the like. A processor device can include electrical circuitry configured to process computer-executable instructions. In another embodiment, a processor device includes an FPGA or other programmable device that performs logic operations without processing computer-executable instructions. A processor device can also be implemented as a combination of computing devices, e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration. Although described herein primarily with respect to digital technology, a processor device may also include primarily analog components. A computing environment can include any type of computer system, including, but not limited to, a computer system based on a microprocessor, a mainframe computer, a digital signal processor, a portable computing device, a device controller, or a computational engine within an appliance, to name a few.
The elements of a method, process, routine, or algorithm described in connection with the embodiments disclosed herein can be embodied directly in hardware, in a software module executed by a processor device, or in a combination of the two. A software module can reside in RAM memory, flash memory, ROM memory, EPROM memory, EEPROM memory, registers, hard disk, a removable disk, a CD-ROM, or any other form of a non-transitory computer-readable storage medium. An exemplary storage medium can be coupled to the processor device such that the processor device can read information from, and write information to, the storage medium. In the alternative, the storage medium can be integral to the processor device. The processor device and the storage medium can reside in an ASIC. The ASIC can reside in a user terminal. In the alternative, the processor device and the storage medium can reside as discrete components in a user terminal.
Conditional language used herein, such as, among others, “can,” “may,” “might,” “may,” “e.g.,” and the like, unless specifically stated otherwise, or otherwise understood within the context as used, is generally intended to convey that certain embodiments include, while other embodiments do not include, certain features, elements and/or steps. Thus, such conditional language is not generally intended to imply that features, elements and/or steps are in any way required for one or more embodiments or that one or more embodiments necessarily include logic for deciding, with or without other input or prompting, whether these features, elements and/or steps are included or are to be performed in any particular embodiment. The terms “comprising,” “including,” “having,” and the like are synonymous and are used inclusively, in an open-ended fashion, and do not exclude additional elements, features, acts, operations, and so forth. Also, the term “or” is used in its inclusive sense (and not in its exclusive sense) so that when used, for example, to connect a list of elements, the term “or” means one, some, or all of the elements in the list.
Disjunctive language such as the phrase “at least one of X, Y, Z,” unless specifically stated otherwise, is otherwise understood with the context as used in general to present that an item, term, etc., may be either X, Y, or Z, or any combination thereof (e.g., X, Y, and/or Z). Thus, such disjunctive language is not generally intended to, and should not, imply that certain embodiments require at least one of X, at least one of Y, or at least one of Z to each be present.
While the phrase “click” may be used with respect to a user selecting a control, menu selection, or the like, other user inputs may be used, such as voice commands, text entry, gestures, etc. User inputs may, by way of example, be provided via an interface, such as via text fields, wherein a user enters text, and/or via a menu selection (e.g., a drop down menu, a list or other arrangement via which the user can check via a check box or otherwise make a selection or selections, a group of individually selectable icons, etc.). When the user provides an input or activates a control, a corresponding computing system may perform the corresponding operation. Some or all of the data, inputs and instructions provided by a user may optionally be stored in a system data store (e.g., a database), from which the system may access and retrieve such data, inputs, and instructions. The notifications/alerts and user interfaces described herein may be provided via a Web page, a dedicated or non-dedicated phone application, computer application, a short messaging service message (e.g., SMS, MMS, etc.), instant messaging, email, push notification, audibly, a pop-up interface, and/or otherwise.
The user terminals described herein may be in the form of a mobile communication device (e.g., a cell phone), laptop, tablet computer, interactive television, game console, media streaming device, head-wearable display, networked watch, etc. The user terminals may optionally include displays, user input devices (e.g., touchscreen, keyboard, mouse, voice recognition, etc.), network interfaces, etc.
While the above detailed description has shown, described, and pointed out novel features as applied to various embodiments, it can be understood that various omissions, substitutions, and changes in the form and details of the devices or algorithms illustrated can be made without departing from the spirit of the disclosure. As can be recognized, certain embodiments described herein can be embodied within a form that does not provide all of the features and benefits set forth herein, as some features can be used or practiced separately from others. The scope of certain embodiments disclosed herein is indicated by the appended claims rather than by the foregoing description. All changes which come within the meaning and range of equivalency of the claims are to be embraced within their scope.
Number | Date | Country | |
---|---|---|---|
Parent | 17451537 | Oct 2021 | US |
Child | 17813464 | US | |
Parent | 17103569 | Nov 2020 | US |
Child | 17451537 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17813464 | Jul 2022 | US |
Child | 18517810 | US |