digraph G {
0 [id="node0" labelType="html" label="<br><b>MapPartitions</b><br><br>" tooltip="MapPartitions org.apache.spark.sql.internal.ToScalaUDF$$$Lambda/0x00000008020ce360@5acb80da, obj#1007775: com.sap.s4hana.eureka.business.crporderquantitykpicalculation.dto.KpiCalculationResult"];
1 [id="node1" labelType="html" label="<br><b>DeserializeToObject</b><br><br>" tooltip="DeserializeToObject initializejavabean(newInstance(class com.sap.s4hana.eureka.business.crporderquantitykpiservice.core.calculation.PartitionableKpiCalculationArgument), (setConfiguration,initializejavabean(newInstance(class com.sap.s4hana.eureka.business.crporderquantitykpicalculation.dto.Configuration), (setNames,invoke(mapobjects(lambdavariable(MapObject, StringType, false, -1), invoke(lambdavariable(MapObject, StringType, false, -1).toString()), configuration#1007502.names, None).array())), (setValues,invoke(mapobjects(lambdavariable(MapObject, StringType, false, -2), invoke(lambdavariable(MapObject, StringType, false, -2).toString()), configuration#1007502.values, None).array())))), (setExecutionID,assertnotnull(executionID#1007631)), (setPlantOperatingTimesArray,invoke(mapobjects(lambdavariable(MapObject, StructField(plantId,StringType,true), StructField(weekdays,ArrayType(IntegerType,false),false), StructField(openingTimes,ArrayType(StructType(StructField(hour,IntegerType,true),StructField(minute,IntegerType,true),StructField(second,IntegerType,true)),false),true), StructField(closingTimes,ArrayType(StructType(StructField(hour,IntegerType,true),StructField(minute,IntegerType,true),StructField(second,IntegerType,true)),false),true), false, -3), initializejavabean(newInstance(class com.sap.s4hana.eureka.business.crporderquantitykpicalculation.dto.PlantOperatingTimes), (setClosingTimes,invoke(mapobjects(lambdavariable(MapObject, StructField(hour,IntegerType,true), StructField(minute,IntegerType,true), StructField(second,IntegerType,true), false, -4), initializejavabean(newInstance(class com.sap.s4hana.eureka.business.crporderquantitykpicalculation.dto.TimeOfDay), (setHour,assertnotnull(lambdavariable(MapObject, StructField(hour,IntegerType,true), StructField(minute,IntegerType,true), StructField(second,IntegerType,true), false, -4).hour)), (setMinute,assertnotnull(lambdavariable(MapObject, StructField(hour,IntegerType,true), StructField(minute,IntegerType,true), StructField(second,IntegerType,true), false, -4).minute)), (setSecond,assertnotnull(lambdavariable(MapObject, StructField(hour,IntegerType,true), StructField(minute,IntegerType,true), StructField(second,IntegerType,true), false, -4).second))), lambdavariable(MapObject, StructField(plantId,StringType,true), StructField(weekdays,ArrayType(IntegerType,false),false), StructField(openingTimes,ArrayType(StructType(StructField(hour,IntegerType,true),StructField(minute,IntegerType,true),StructField(second,IntegerType,true)),false),true), StructField(closingTimes,ArrayType(StructType(StructField(hour,IntegerType,true),StructField(minute,IntegerType,true),StructField(second,IntegerType,true)),false),true), false, -3).closingTimes, None).array())), (setOpeningTimes,invoke(mapobjects(lambdavariable(MapObject, StructField(hour,IntegerType,true), StructField(minute,IntegerType,true), StructField(second,IntegerType,true), false, -5), initializejavabean(newInstance(class com.sap.s4hana.eureka.business.crporderquantitykpicalculation.dto.TimeOfDay), (setHour,assertnotnull(lambdavariable(MapObject, StructField(hour,IntegerType,true), StructField(minute,IntegerType,true), StructField(second,IntegerType,true), false, -5).hour)), (setMinute,assertnotnull(lambdavariable(MapObject, StructField(hour,IntegerType,true), StructField(minute,IntegerType,true), StructField(second,IntegerType,true), false, -5).minute)), (setSecond,assertnotnull(lambdavariable(MapObject, StructField(hour,IntegerType,true), StructField(minute,IntegerType,true), StructField(second,IntegerType,true), false, -5).second))), lambdavariable(MapObject, StructField(plantId,StringType,true), StructField(weekdays,ArrayType(IntegerType,false),false), StructField(openingTimes,ArrayType(StructType(StructField(hour,IntegerType,true),StructField(minute,IntegerType,true),StructField(second,IntegerType,true)),false),true), StructField(closingTimes,ArrayType(StructType(StructField(hour,IntegerType,true),StructField(minute,IntegerType,true),StructField(second,IntegerType,true)),false),true), false, -3).openingTimes, None).array())), (setPlantId,invoke(lambdavariable(MapObject, StructField(plantId,StringType,true), StructField(weekdays,ArrayType(IntegerType,false),false), StructField(openingTimes,ArrayType(StructType(StructField(hour,IntegerType,true),StructField(minute,IntegerType,true),StructField(second,IntegerType,true)),false),true), StructField(closingTimes,ArrayType(StructType(StructField(hour,IntegerType,true),StructField(minute,IntegerType,true),StructField(second,IntegerType,true)),false),true), false, -3).plantId.toString())), (setWeekdays,invoke(mapobjects(lambdavariable(MapObject, IntegerType, false, -6), static_invoke(java.time.DayOfWeek.valueOf(invoke(cast(lambdavariable(MapObject, IntegerType, false, -6) as string).toString()))), lambdavariable(MapObject, StructField(plantId,StringType,true), StructField(weekdays,ArrayType(IntegerType,false),false), StructField(openingTimes,ArrayType(StructType(StructField(hour,IntegerType,true),StructField(minute,IntegerType,true),StructField(second,IntegerType,true)),false),true), StructField(closingTimes,ArrayType(StructType(StructField(hour,IntegerType,true),StructField(minute,IntegerType,true),StructField(second,IntegerType,true)),false),true), false, -3).weekdays, None).array()))), plantOperatingTimesArray#1007633, None).array())), (setProdPlantQuantityInformation,invoke(mapobjects(lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7), initializejavabean(newInstance(class com.sap.s4hana.eureka.business.crporderquantitykpicalculation.dto.ProdPlantQuantityInformation), (setDemand,initializejavabean(newInstance(class com.sap.s4hana.eureka.business.crporderquantitykpicalculation.dto.Demand), (setDayBucketDemands,invoke(mapobjects(lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(anchorDatetimes,ArrayType(TimestampType,true),true), StructField(anchorWeekdays,ArrayType(StringType,true),true), StructField(anchorIndices,ArrayType(IntegerType,true),true), true, -8), if (isnull(lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(anchorDatetimes,ArrayType(TimestampType,true),true), StructField(anchorWeekdays,ArrayType(StringType,true),true), StructField(anchorIndices,ArrayType(IntegerType,true),true), true, -8))) null else initializejavabean(newInstance(class com.sap.s4hana.eureka.business.crporderquantitykpicalculation.dto.DayBucketDemand), (setAnchorIndices,invoke(mapobjects(lambdavariable(MapObject, IntegerType, true, -9), assertnotnull(lambdavariable(MapObject, IntegerType, true, -9)), lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(anchorDatetimes,ArrayType(TimestampType,true),true), StructField(anchorWeekdays,ArrayType(StringType,true),true), StructField(anchorIndices,ArrayType(IntegerType,true),true), true, -8).anchorIndices, None).toIntArray())), (setConsiderVariance,assertnotnull(lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(anchorDatetimes,ArrayType(TimestampType,true),true), StructField(anchorWeekdays,ArrayType(StringType,true),true), StructField(anchorIndices,ArrayType(IntegerType,true),true), true, -8).considerVariance)), (setAnchorDatetimes,invoke(mapobjects(lambdavariable(MapObject, TimestampType, true, -10), static_invoke(DateTimeUtils.toJavaTimestamp(lambdavariable(MapObject, TimestampType, true, -10))), lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(anchorDatetimes,ArrayType(TimestampType,true),true), StructField(anchorWeekdays,ArrayType(StringType,true),true), StructField(anchorIndices,ArrayType(IntegerType,true),true), true, -8).anchorDatetimes, None).array())), (setDemandChannel,invoke(lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(anchorDatetimes,ArrayType(TimestampType,true),true), StructField(anchorWeekdays,ArrayType(StringType,true),true), StructField(anchorIndices,ArrayType(IntegerType,true),true), true, -8).demandChannel.toString())), (setDemandStream,invoke(lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(anchorDatetimes,ArrayType(TimestampType,true),true), StructField(anchorWeekdays,ArrayType(StringType,true),true), StructField(anchorIndices,ArrayType(IntegerType,true),true), true, -8).demandStream.toString())), (setAnchorWeekdays,invoke(mapobjects(lambdavariable(MapObject, StringType, true, -11), static_invoke(java.time.DayOfWeek.valueOf(invoke(lambdavariable(MapObject, StringType, true, -11).toString()))), lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(anchorDatetimes,ArrayType(TimestampType,true),true), StructField(anchorWeekdays,ArrayType(StringType,true),true), StructField(anchorIndices,ArrayType(IntegerType,true),true), true, -8).anchorWeekdays, None).array())), (setDemandVariances,invoke(mapobjects(lambdavariable(MapObject, DoubleType, true, -12), assertnotnull(lambdavariable(MapObject, DoubleType, true, -12)), lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(anchorDatetimes,ArrayType(TimestampType,true),true), StructField(anchorWeekdays,ArrayType(StringType,true),true), StructField(anchorIndices,ArrayType(IntegerType,true),true), true, -8).demandVariances, None).toDoubleArray())), (setDemandValues,invoke(mapobjects(lambdavariable(MapObject, DoubleType, true, -13), assertnotnull(lambdavariable(MapObject, DoubleType, true, -13)), lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(anchorDatetimes,ArrayType(TimestampType,true),true), StructField(anchorWeekdays,ArrayType(StringType,true),true), StructField(anchorIndices,ArrayType(IntegerType,true),true), true, -8).demandValues, None).toDoubleArray()))), lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).demand.dayBucketDemands, None).array())), (setPointInTimeDemands,invoke(mapobjects(lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandDatetimes,ArrayType(TimestampType,true),true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(horizonStartDatetime,TimestampType,true), StructField(horizonEndDatetime,TimestampType,true), true, -14), if (isnull(lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandDatetimes,ArrayType(TimestampType,true),true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(horizonStartDatetime,TimestampType,true), StructField(horizonEndDatetime,TimestampType,true), true, -14))) null else initializejavabean(newInstance(class com.sap.s4hana.eureka.business.crporderquantitykpicalculation.dto.PointInTimeDemand), (setHorizonStartDatetime,static_invoke(DateTimeUtils.toJavaTimestamp(lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandDatetimes,ArrayType(TimestampType,true),true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(horizonStartDatetime,TimestampType,true), StructField(horizonEndDatetime,TimestampType,true), true, -14).horizonStartDatetime))), (setDemandDatetimes,invoke(mapobjects(lambdavariable(MapObject, TimestampType, true, -15), static_invoke(DateTimeUtils.toJavaTimestamp(lambdavariable(MapObject, TimestampType, true, -15))), lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandDatetimes,ArrayType(TimestampType,true),true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(horizonStartDatetime,TimestampType,true), StructField(horizonEndDatetime,TimestampType,true), true, -14).demandDatetimes, None).array())), (setDemandStream,invoke(lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandDatetimes,ArrayType(TimestampType,true),true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(horizonStartDatetime,TimestampType,true), StructField(horizonEndDatetime,TimestampType,true), true, -14).demandStream.toString())), (setConsiderVariance,assertnotnull(lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandDatetimes,ArrayType(TimestampType,true),true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(horizonStartDatetime,TimestampType,true), StructField(horizonEndDatetime,TimestampType,true), true, -14).considerVariance)), (setDemandChannel,invoke(lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandDatetimes,ArrayType(TimestampType,true),true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(horizonStartDatetime,TimestampType,true), StructField(horizonEndDatetime,TimestampType,true), true, -14).demandChannel.toString())), (setHorizonEndDatetime,static_invoke(DateTimeUtils.toJavaTimestamp(lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandDatetimes,ArrayType(TimestampType,true),true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(horizonStartDatetime,TimestampType,true), StructField(horizonEndDatetime,TimestampType,true), true, -14).horizonEndDatetime))), (setDemandVariances,invoke(mapobjects(lambdavariable(MapObject, DoubleType, true, -16), assertnotnull(lambdavariable(MapObject, DoubleType, true, -16)), lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandDatetimes,ArrayType(TimestampType,true),true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(horizonStartDatetime,TimestampType,true), StructField(horizonEndDatetime,TimestampType,true), true, -14).demandVariances, None).toDoubleArray())), (setDemandValues,invoke(mapobjects(lambdavariable(MapObject, DoubleType, true, -17), assertnotnull(lambdavariable(MapObject, DoubleType, true, -17)), lambdavariable(MapObject, StructField(demandChannel,StringType,true), StructField(demandStream,StringType,true), StructField(considerVariance,BooleanType,true), StructField(demandDatetimes,ArrayType(TimestampType,true),true), StructField(demandValues,ArrayType(DoubleType,true),true), StructField(demandVariances,ArrayType(DoubleType,true),true), StructField(horizonStartDatetime,TimestampType,true), StructField(horizonEndDatetime,TimestampType,true), true, -14).demandValues, None).toDoubleArray()))), lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).demand.pointInTimeDemands, None).array())))), (setSchedule,initializejavabean(newInstance(class com.sap.s4hana.eureka.business.crporderquantitykpicalculation.dto.Schedule), (setAvailabilityDatetime,static_invoke(DateTimeUtils.toJavaTimestamp(lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).schedule.availabilityDatetime))), (setDemandPeriodEndDatetime,static_invoke(DateTimeUtils.toJavaTimestamp(lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).schedule.demandPeriodEndDatetime))), (setOrderDatetime,static_invoke(DateTimeUtils.toJavaTimestamp(lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).schedule.orderDatetime))), (setShelfLifeEndDatetime,static_invoke(DateTimeUtils.toJavaTimestamp(lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).schedule.shelfLifeEndDatetime))))), (setPlantId,invoke(lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).plantId.toString())), (setRequestedQuantities,invoke(mapobjects(lambdavariable(MapObject, DoubleType, true, -18), assertnotnull(lambdavariable(MapObject, DoubleType, true, -18)), lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).requestedQuantities, None).toDoubleArray())), (setConfiguration,initializejavabean(newInstance(class com.sap.s4hana.eureka.business.crporderquantitykpicalculation.dto.Configuration), (setNames,invoke(mapobjects(lambdavariable(MapObject, StringType, true, -19), invoke(lambdavariable(MapObject, StringType, true, -19).toString()), lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).configuration.names, None).array())), (setValues,invoke(mapobjects(lambdavariable(MapObject, StringType, true, -20), invoke(lambdavariable(MapObject, StringType, true, -20).toString()), lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).configuration.values, None).array())))), (setProductId,invoke(lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).productId.toString())), (setOpenGoodsMovements,initializejavabean(newInstance(class com.sap.s4hana.eureka.business.crporderquantitykpicalculation.dto.OpenGoodsMovements), (setAvailabilityDatetimes,invoke(mapobjects(lambdavariable(MapObject, TimestampType, true, -21), static_invoke(DateTimeUtils.toJavaTimestamp(lambdavariable(MapObject, TimestampType, true, -21))), lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).openGoodsMovements.availabilityDatetimes, None).array())), (setOrderDatetimes,invoke(mapobjects(lambdavariable(MapObject, TimestampType, true, -22), static_invoke(DateTimeUtils.toJavaTimestamp(lambdavariable(MapObject, TimestampType, true, -22))), lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).openGoodsMovements.orderDatetimes, None).array())), (setQuantities,invoke(mapobjects(lambdavariable(MapObject, DoubleType, true, -23), assertnotnull(lambdavariable(MapObject, DoubleType, true, -23)), lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).openGoodsMovements.quantities, None).toDoubleArray())), (setShelfLifeEndDatetimes,invoke(mapobjects(lambdavariable(MapObject, TimestampType, true, -24), static_invoke(DateTimeUtils.toJavaTimestamp(lambdavariable(MapObject, TimestampType, true, -24))), lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).openGoodsMovements.shelfLifeEndDatetimes, None).array())))), (setStock,initializejavabean(newInstance(class com.sap.s4hana.eureka.business.crporderquantitykpicalculation.dto.Stock), (setStockBatchQuantities,invoke(mapobjects(lambdavariable(MapObject, DoubleType, true, -25), assertnotnull(lambdavariable(MapObject, DoubleType, true, -25)), lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).stock.stockBatchQuantities, None).toDoubleArray())), (setStockBatchShelfLifeEndDatetimes,invoke(mapobjects(lambdavariable(MapObject, TimestampType, true, -26), static_invoke(DateTimeUtils.toJavaTimestamp(lambdavariable(MapObject, TimestampType, true, -26))), lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).stock.stockBatchShelfLifeEndDatetimes, None).array())), (setStockDatetime,static_invoke(DateTimeUtils.toJavaTimestamp(lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).stock.stockDatetime))))), (setTimeDependentSettings,initializejavabean(newInstance(class com.sap.s4hana.eureka.business.crporderquantitykpicalculation.dto.TimeDependentSettings), (setEndDatetimes,invoke(mapobjects(lambdavariable(MapObject, TimestampType, true, -27), static_invoke(DateTimeUtils.toJavaTimestamp(lambdavariable(MapObject, TimestampType, true, -27))), lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).timeDependentSettings.endDatetimes, None).array())), (setNames,invoke(mapobjects(lambdavariable(MapObject, StringType, true, -28), invoke(lambdavariable(MapObject, StringType, true, -28).toString()), lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).timeDependentSettings.names, None).array())), (setStartDatetimes,invoke(mapobjects(lambdavariable(MapObject, TimestampType, true, -29), static_invoke(DateTimeUtils.toJavaTimestamp(lambdavariable(MapObject, TimestampType, true, -29))), lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).timeDependentSettings.startDatetimes, None).array())), (setValues,invoke(mapobjects(lambdavariable(MapObject, DoubleType, true, -30), assertnotnull(lambdavariable(MapObject, DoubleType, true, -30)), lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).timeDependentSettings.values, None).toDoubleArray())))), (setOutboundUnit,assertnotnull(lambdavariable(MapObject, StructField(productId,StringType,true), StructField(plantId,StringType,true), StructField(requestedQuantities,ArrayType(DoubleType,true),false), StructField(outboundUnit,DoubleType,true), StructField(stock,StructType(StructField(stockBatchQuantities,ArrayType(DoubleType,true),true),StructField(stockBatchShelfLifeEndDatetimes,ArrayType(TimestampType,true),true),StructField(stockDatetime,TimestampType,true)),false), StructField(demand,StructType(StructField(dayBucketDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(anchorDatetimes,ArrayType(TimestampType,true),true),StructField(anchorWeekdays,ArrayType(StringType,true),true),StructField(anchorIndices,ArrayType(IntegerType,true),true)),true),true),StructField(pointInTimeDemands,ArrayType(StructType(StructField(demandChannel,StringType,true),StructField(demandStream,StringType,true),StructField(considerVariance,BooleanType,true),StructField(demandDatetimes,ArrayType(TimestampType,true),true),StructField(demandValues,ArrayType(DoubleType,true),true),StructField(demandVariances,ArrayType(DoubleType,true),true),StructField(horizonStartDatetime,TimestampType,true),StructField(horizonEndDatetime,TimestampType,true)),true),true)),false), StructField(schedule,StructType(StructField(orderDatetime,TimestampType,true),StructField(availabilityDatetime,TimestampType,true),StructField(demandPeriodEndDatetime,TimestampType,true),StructField(shelfLifeEndDatetime,TimestampType,false)),false), StructField(openGoodsMovements,StructType(StructField(orderDatetimes,ArrayType(TimestampType,true),true),StructField(availabilityDatetimes,ArrayType(TimestampType,true),true),StructField(quantities,ArrayType(DoubleType,true),true),StructField(shelfLifeEndDatetimes,ArrayType(TimestampType,true),true)),false), StructField(timeDependentSettings,StructType(StructField(endDatetimes,ArrayType(TimestampType,true),true),StructField(names,ArrayType(StringType,true),true),StructField(startDatetimes,ArrayType(TimestampType,true),true),StructField(values,ArrayType(DoubleType,true),true)),false), StructField(configuration,StructType(StructField(names,ArrayType(StringType,true),false),StructField(values,ArrayType(StringType,true),false)),false), false, -7).outboundUnit))), prodPlantQuantityInformation#1007632, None).array()))), obj#1007772: com.sap.s4hana.eureka.business.crporderquantitykpiservice.core.calculation.PartitionableKpiCalculationArgument"];
subgraph cluster2 {
isCluster="true";
id="cluster2";
label="WholeStageCodegen (17)";
tooltip="WholeStageCodegen (17)";
3 [id="node3" labelType="html" label="<br><b>BroadcastNestedLoopJoin</b><br><br>" tooltip="BroadcastNestedLoopJoin BuildRight, Cross"];
}
4 [id="node4" labelType="html" label="<br><b>ObjectHashAggregate</b><br><br>" tooltip="ObjectHashAggregate(keys=[executionID#1007631], functions=[collect_list(ProductPlantQuantityInformation#1007630, 0, 0), collect_set(plantOperatingTimes#1006338, 0, 0)])"];
5 [id="node5" labelType="html" label="<b>Exchange</b><br><br>number of partitions: 37" tooltip="Exchange hashpartitioning(executionID#1007631, 37), ENSURE_REQUIREMENTS, [plan_id=1632793]"];
6 [id="node6" labelType="html" label="<br><b>ObjectHashAggregate</b><br><br>" tooltip="ObjectHashAggregate(keys=[executionID#1007631], functions=[partial_collect_list(ProductPlantQuantityInformation#1007630, 0, 0), partial_collect_set(plantOperatingTimes#1006338, 0, 0)])"];
subgraph cluster7 {
isCluster="true";
id="cluster7";
label="WholeStageCodegen (14)";
tooltip="WholeStageCodegen (14)";
8 [id="node8" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [plantOperatingTimes#1006338, struct(productId, product#1006339, plantId, plant#1006340, requestedQuantities, requestedQuantities#1007504, outboundUnit, outboundUnit#1006341, stock, struct(stockBatchQuantities, stockBatchQuantities#1006343, stockBatchShelfLifeEndDatetimes, stockBatchShelfLifeEndDatetimes#1006344, stockDatetime, stockDatetime#1006342), demand, struct(dayBucketDemands, dayBucketDemands#1006345, pointInTimeDemands, pointInTimeDemands#1006346), schedule, schedule#1006381, openGoodsMovements, struct(orderDatetimes, CASE WHEN (isnotnull(openGoodsMovementOrderDatetimes#1006375) AND isnotnull(openGoodsMovementQuantities#1006347)) THEN openGoodsMovementOrderDatetimes#1006375 ELSE [] END, availabilityDatetimes, CASE WHEN (isnotnull(openGoodsMovementAvailabilityDatetimes#1006348) AND isnotnull(openGoodsMovementQuantities#1006347)) THEN openGoodsMovementAvailabilityDatetimes#1006348 ELSE [] END, quantities, CASE WHEN isnotnull(openGoodsMovementQuantities#1006347) THEN openGoodsMovementQuantities#1006347 ELSE [] END, shelfLifeEndDatetimes, CASE WHEN (isnotnull(openGoodsMovementShelfLifeEndDatetimes#1006349) AND isnotnull(openGoodsMovementQuantities#1006347)) THEN openGoodsMovementShelfLifeEndDatetimes#1006349 ELSE [] END), timeDependentSettings, struct(endDatetimes, timeDependentSettingsEndDatetime#1006353, names, timeDependentSettingsName#1006351, startDatetimes, timeDependentSettingsStartDatetime#1006352, values, timeDependentSettingsValue#1006354), configuration, configuration#1006512) AS ProductPlantQuantityInformation#1007630, cast(abs((xxhash64(product#1006339, plant#1006340, 42) % 37)) as int) AS executionID#1007631]"];
9 [id="node9" labelType="html" label="<br><b>SortMergeJoin</b><br><br>" tooltip="SortMergeJoin [product#1006339, plant#1006340], [product#1007607, plant#1007608], Inner"];
}
subgraph cluster10 {
isCluster="true";
id="cluster10";
label="WholeStageCodegen (10)";
tooltip="WholeStageCodegen (10)";
11 [id="node11" labelType="html" label="<br><b>Sort</b><br><br>" tooltip="Sort [product#1006339 ASC NULLS FIRST, plant#1006340 ASC NULLS FIRST], false, 0"];
}
12 [id="node12" labelType="html" label="<b>Exchange</b><br><br>number of partitions: 37" tooltip="Exchange hashpartitioning(product#1006339, plant#1006340, 37), ENSURE_REQUIREMENTS, [plan_id=1632755]"];
13 [id="node13" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [product#1006339, plant#1006340, stockDatetime#1006342, outboundUnit#1006341, stockBatchQuantities#1006343, stockBatchShelfLifeEndDatetimes#1006344, dayBucketDemands#1006345, pointInTimeDemands#1006346, openGoodsMovementAvailabilityDatetimes#1006348, openGoodsMovementQuantities#1006347, openGoodsMovementShelfLifeEndDatetimes#1006349, timeDependentSettingsName#1006351, timeDependentSettingsStartDatetime#1006352, timeDependentSettingsEndDatetime#1006353, timeDependentSettingsValue#1006354, openGoodsMovementOrderDatetimes#1006375, plantOperatingTimes#1006338, schedule#1006381, struct(names, transform(configurations#1006485, lambdafunction(lambda x#1006513.explodedConf.configurationName, lambda x#1006513, false)), values, transform(configurations#1006485, lambdafunction(lambda x#1006514.explodedConf.configurationValue, lambda x#1006514, false))) AS configuration#1006512]"];
14 [id="node14" labelType="html" label="<br><b>ObjectHashAggregate</b><br><br>" tooltip="ObjectHashAggregate(keys=[0_1_10000000678#1008545, product#1006339, plant#1006340, stockDatetime#1006342, outboundUnit#1006341, stockBatchQuantities#1006343, stockBatchShelfLifeEndDatetimes#1006344, dayBucketDemands#1006345, pointInTimeDemands#1006346, openGoodsMovementAvailabilityDatetimes#1006348, openGoodsMovementQuantities#1006347, openGoodsMovementShelfLifeEndDatetimes#1006349, timeDependentSettingsName#1006351, timeDependentSettingsStartDatetime#1006352, timeDependentSettingsEndDatetime#1006353, timeDependentSettingsValue#1006354, openGoodsMovementOrderDatetimes#1006375, plantOperatingTimes#1006338, schedule#1006381], functions=[collect_list(struct(confPos, confPos#1006382, explodedConf, explodedConf#1006383), 0, 0)])"];
15 [id="node15" labelType="html" label="<b>Exchange</b><br><br>number of partitions: 37" tooltip="Exchange hashpartitioning(0_1_10000000678#1008545, product#1006339, plant#1006340, stockDatetime#1006342, outboundUnit#1006341, stockBatchQuantities#1006343, stockBatchShelfLifeEndDatetimes#1006344, dayBucketDemands#1006345, pointInTimeDemands#1006346, openGoodsMovementAvailabilityDatetimes#1006348, openGoodsMovementQuantities#1006347, openGoodsMovementShelfLifeEndDatetimes#1006349, timeDependentSettingsName#1006351, timeDependentSettingsStartDatetime#1006352, timeDependentSettingsEndDatetime#1006353, timeDependentSettingsValue#1006354, openGoodsMovementOrderDatetimes#1006375, plantOperatingTimes#1006338, schedule#1006381, 37), ENSURE_REQUIREMENTS, [plan_id=1632733]"];
16 [id="node16" labelType="html" label="<br><b>ObjectHashAggregate</b><br><br>" tooltip="ObjectHashAggregate(keys=[0_1_10000000678 AS 0_1_10000000678#1008545, product#1006339, plant#1006340, stockDatetime#1006342, knownfloatingpointnormalized(normalizenanandzero(outboundUnit#1006341)) AS outboundUnit#1006341, knownfloatingpointnormalized(transform(stockBatchQuantities#1006343, lambdafunction(knownfloatingpointnormalized(normalizenanandzero(lambda arg#1008546)), lambda arg#1008546, false))) AS stockBatchQuantities#1006343, stockBatchShelfLifeEndDatetimes#1006344, knownfloatingpointnormalized(transform(dayBucketDemands#1006345, lambdafunction(knownfloatingpointnormalized(if (isnull(lambda arg#1008547)) null else named_struct(demandChannel, lambda arg#1008547.demandChannel, demandStream, lambda arg#1008547.demandStream, considerVariance, lambda arg#1008547.considerVariance, demandValues, knownfloatingpointnormalized(transform(lambda arg#1008547.demandValues, lambdafunction(knownfloatingpointnormalized(normalizenanandzero(lambda arg#1008548)), lambda arg#1008548, false))), demandVariances, knownfloatingpointnormalized(transform(lambda arg#1008547.demandVariances, lambdafunction(knownfloatingpointnormalized(normalizenanandzero(lambda arg#1008549)), lambda arg#1008549, false))), anchorDatetimes, lambda arg#1008547.anchorDatetimes, anchorWeekdays, lambda arg#1008547.anchorWeekdays, anchorIndices, lambda arg#1008547.anchorIndices)), lambda arg#1008547, false))) AS dayBucketDemands#1006345, knownfloatingpointnormalized(transform(pointInTimeDemands#1006346, lambdafunction(knownfloatingpointnormalized(if (isnull(lambda arg#1008550)) null else named_struct(demandChannel, lambda arg#1008550.demandChannel, demandStream, lambda arg#1008550.demandStream, considerVariance, lambda arg#1008550.considerVariance, demandDatetimes, lambda arg#1008550.demandDatetimes, demandValues, knownfloatingpointnormalized(transform(lambda arg#1008550.demandValues, lambdafunction(knownfloatingpointnormalized(normalizenanandzero(lambda arg#1008551)), lambda arg#1008551, false))), demandVariances, knownfloatingpointnormalized(transform(lambda arg#1008550.demandVariances, lambdafunction(knownfloatingpointnormalized(normalizenanandzero(lambda arg#1008552)), lambda arg#1008552, false))), horizonStartDatetime, lambda arg#1008550.horizonStartDatetime, horizonEndDatetime, lambda arg#1008550.horizonEndDatetime)), lambda arg#1008550, false))) AS pointInTimeDemands#1006346, openGoodsMovementAvailabilityDatetimes#1006348, knownfloatingpointnormalized(transform(openGoodsMovementQuantities#1006347, lambdafunction(knownfloatingpointnormalized(normalizenanandzero(lambda arg#1008553)), lambda arg#1008553, false))) AS openGoodsMovementQuantities#1006347, openGoodsMovementShelfLifeEndDatetimes#1006349, timeDependentSettingsName#1006351, timeDependentSettingsStartDatetime#1006352, timeDependentSettingsEndDatetime#1006353, knownfloatingpointnormalized(transform(timeDependentSettingsValue#1006354, lambdafunction(knownfloatingpointnormalized(normalizenanandzero(lambda arg#1008554)), lambda arg#1008554, false))) AS timeDependentSettingsValue#1006354, openGoodsMovementOrderDatetimes#1006375, plantOperatingTimes#1006338, schedule#1006381], functions=[partial_collect_list(struct(confPos, confPos#1006382, explodedConf, explodedConf#1006383), 0, 0)])"];
subgraph cluster17 {
isCluster="true";
id="cluster17";
label="WholeStageCodegen (9)";
tooltip="WholeStageCodegen (9)";
18 [id="node18" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [product#1006339, plant#1006340, stockDatetime#1006342, outboundUnit#1006341, stockBatchQuantities#1006343, stockBatchShelfLifeEndDatetimes#1006344, dayBucketDemands#1006345, pointInTimeDemands#1006346, openGoodsMovementAvailabilityDatetimes#1006348, openGoodsMovementQuantities#1006347, openGoodsMovementShelfLifeEndDatetimes#1006349, timeDependentSettingsName#1006351, timeDependentSettingsStartDatetime#1006352, timeDependentSettingsEndDatetime#1006353, timeDependentSettingsValue#1006354, openGoodsMovementOrderDatetimes#1006375, plantOperatingTimes#1006338, schedule#1006381, confPos#1006382, explodedConf#1006383]"];
19 [id="node19" labelType="html" label="<br><b>SortMergeJoin</b><br><br>" tooltip="SortMergeJoin [distance#1006388L, product#1006339, plant#1006340, configurationName#1006384], [minDistance#1006390L, product#1006449, plant#1006450, configurationName#1006481], Inner"];
}
subgraph cluster20 {
isCluster="true";
id="cluster20";
label="WholeStageCodegen (4)";
tooltip="WholeStageCodegen (4)";
21 [id="node21" labelType="html" label="<br><b>Sort</b><br><br>" tooltip="Sort [distance#1006388L ASC NULLS FIRST, product#1006339 ASC NULLS FIRST, plant#1006340 ASC NULLS FIRST, configurationName#1006384 ASC NULLS FIRST], false, 0"];
}
22 [id="node22" labelType="html" label="<b>Exchange</b><br><br>number of partitions: 37" tooltip="Exchange hashpartitioning(distance#1006388L, product#1006339, plant#1006340, configurationName#1006384, 37), ENSURE_REQUIREMENTS, [plan_id=1632561]"];
subgraph cluster23 {
isCluster="true";
id="cluster23";
label="WholeStageCodegen (3)";
tooltip="WholeStageCodegen (3)";
24 [id="node24" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [product#1006339, plant#1006340, stockDatetime#1006342, outboundUnit#1006341, stockBatchQuantities#1006343, stockBatchShelfLifeEndDatetimes#1006344, dayBucketDemands#1006345, pointInTimeDemands#1006346, openGoodsMovementAvailabilityDatetimes#1006348, openGoodsMovementQuantities#1006347, openGoodsMovementShelfLifeEndDatetimes#1006349, timeDependentSettingsName#1006351, timeDependentSettingsStartDatetime#1006352, timeDependentSettingsEndDatetime#1006353, timeDependentSettingsValue#1006354, openGoodsMovementOrderDatetimes#1006375, plantOperatingTimes#1006338, schedule#1006381, confPos#1006382, explodedConf#1006383, explodedConf#1006383.configurationName AS configurationName#1006384, (cast(schedule#1006381.orderDatetime as bigint) - CASE WHEN isnull(explodedConf#1006383.configurationValidityDatetime) THEN 0 ELSE cast(explodedConf#1006383.configurationValidityDatetime as bigint) END) AS distance#1006388L]"];
25 [id="node25" labelType="html" label="<br><b>Filter</b><br><br>" tooltip="Filter (((CASE WHEN isnull(explodedConf#1006383.configurationValidityDatetime) THEN 0 ELSE cast(explodedConf#1006383.configurationValidityDatetime as bigint) END <= cast(schedule#1006381.orderDatetime as bigint)) AND isnotnull((cast(schedule#1006381.orderDatetime as bigint) - CASE WHEN isnull(explodedConf#1006383.configurationValidityDatetime) THEN 0 ELSE cast(explodedConf#1006383.configurationValidityDatetime as bigint) END))) AND isnotnull(explodedConf#1006383.configurationName))"];
26 [id="node26" labelType="html" label="<br><b>Generate</b><br><br>" tooltip="Generate posexplode(configuration#1006350), [product#1006339, plant#1006340, stockDatetime#1006342, outboundUnit#1006341, stockBatchQuantities#1006343, stockBatchShelfLifeEndDatetimes#1006344, dayBucketDemands#1006345, pointInTimeDemands#1006346, openGoodsMovementAvailabilityDatetimes#1006348, openGoodsMovementQuantities#1006347, openGoodsMovementShelfLifeEndDatetimes#1006349, timeDependentSettingsName#1006351, timeDependentSettingsStartDatetime#1006352, timeDependentSettingsEndDatetime#1006353, timeDependentSettingsValue#1006354, openGoodsMovementOrderDatetimes#1006375, plantOperatingTimes#1006338, schedule#1006381], true, [confPos#1006382, explodedConf#1006383]"];
27 [id="node27" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [product#1006339, plant#1006340, stockDatetime#1006342, outboundUnit#1006341, stockBatchQuantities#1006343, stockBatchShelfLifeEndDatetimes#1006344, dayBucketDemands#1006345, pointInTimeDemands#1006346, openGoodsMovementAvailabilityDatetimes#1006348, openGoodsMovementQuantities#1006347, openGoodsMovementShelfLifeEndDatetimes#1006349, timeDependentSettingsName#1006351, timeDependentSettingsStartDatetime#1006352, timeDependentSettingsEndDatetime#1006353, timeDependentSettingsValue#1006354, configuration#1006350, openGoodsMovementOrderDatetimes#1006375, plantOperatingTimes#1006338, struct(orderDatetime, stockDatetime#1006342, availabilityDatetime, periodStart#943636, demandPeriodEndDatetime, periodEnd#943637, shelfLifeEndDatetime, 2199-01-01 00:00:00) AS schedule#1006381]"];
28 [id="node28" labelType="html" label="<br><b>BroadcastHashJoin</b><br><br>" tooltip="BroadcastHashJoin [product#1006339, plant#1006340], [product#943634, plant#943635], Inner, BuildRight, false"];
29 [id="node29" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [product#1006339, plant#1006340, stockDatetime#1006342, outboundUnit#1006341, stockBatchQuantities#1006343, stockBatchShelfLifeEndDatetimes#1006344, dayBucketDemands#1006345, pointInTimeDemands#1006346, openGoodsMovementAvailabilityDatetimes#1006348, openGoodsMovementQuantities#1006347, openGoodsMovementShelfLifeEndDatetimes#1006349, timeDependentSettingsName#1006351, timeDependentSettingsStartDatetime#1006352, timeDependentSettingsEndDatetime#1006353, timeDependentSettingsValue#1006354, configuration#1006350, openGoodsMovementAvailabilityDatetimes#1006348 AS openGoodsMovementOrderDatetimes#1006375, cast(struct(plantId, plant#1006340, weekdays, [], openingTimes, [], closingTimes, []) as struct<plantId:string,weekdays:array<int>,openingTimes:array<struct<hour:int,minute:int,second:int>>,closingTimes:array<struct<hour:int,minute:int,second:int>>>) AS plantOperatingTimes#1006338]"];
}
30 [id="node30" labelType="html" label="<b>Exchange</b><br><br>number of partitions: 37" tooltip="Exchange hashpartitioning(product#1006339, plant#1006340, 37), REPARTITION_BY_NUM, [plan_id=1632546]"];
subgraph cluster31 {
isCluster="true";
id="cluster31";
label="WholeStageCodegen (1)";
tooltip="WholeStageCodegen (1)";
32 [id="node32" labelType="html" label="<br><b>Filter</b><br><br>" tooltip="Filter ((isnotnull(product#1006339) AND isnotnull(plant#1006340)) AND isnotnull(stockDatetime#1006342))"];
33 [id="node33" labelType="html" label="<br><b>ColumnarToRow</b><br><br>" tooltip="ColumnarToRow"];
}
34 [id="node34" labelType="html" label="<b>Scan parquet </b><br><br>number of files read: 37<br>metadata time: 1 ms<br>size of files read: 1903.1 KiB" tooltip="FileScan parquet [product#1006339,plant#1006340,outboundUnit#1006341,stockDatetime#1006342,stockBatchQuantities#1006343,stockBatchShelfLifeEndDatetimes#1006344,dayBucketDemands#1006345,pointInTimeDemands#1006346,openGoodsMovementQuantities#1006347,openGoodsMovementAvailabilityDatetimes#1006348,openGoodsMovementShelfLifeEndDatetimes#1006349,configuration#1006350,timeDependentSettingsName#1006351,timeDependentSettingsStartDatetime#1006352,timeDependentSettingsEndDatetime#1006353,timeDependentSettingsValue#1006354] Batched: true, DataFilters: [isnotnull(product#1006339), isnotnull(plant#1006340), isnotnull(stockDatetime#1006342)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://770f0770-bd0c-456f-b83b-9649926e0857.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(product), IsNotNull(plant), IsNotNull(stockDatetime)], ReadSchema: struct<product:string,plant:string,outboundUnit:double,stockDatetime:timestamp,stockBatchQuantiti..."];
35 [id="node35" labelType="html" label="<b>BroadcastExchange</b><br><br>time to broadcast: 0 ms<br>time to build: 1 ms<br>time to collect: 239 ms<br>number of output rows: 51<br>data size: 2.0 MiB" tooltip="BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, true], input[1, string, true]),false), [plan_id=1632553]"];
subgraph cluster36 {
isCluster="true";
id="cluster36";
label="WholeStageCodegen (2)\n \nduration: total (min, med, max (stageId: taskId))\n61 ms (0 ms, 0 ms, 6 ms (stage 104734.0: task 346281))";
tooltip="WholeStageCodegen (2)";
37 [id="node37" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [product#943634, plant#943635, periodStart#943636, periodEnd#943637]"];
38 [id="node38" labelType="html" label="<b>Filter</b><br><br>number of output rows: 51" tooltip="Filter (((isnotnull(shardId#943631) AND (0_1_10000000678 = shardId#943631)) AND isnotnull(product#943634)) AND isnotnull(plant#943635))"];
}
39 [id="node39" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 51" tooltip="InMemoryTableScan [periodEnd#943637, periodStart#943636, plant#943635, product#943634, shardId#943631], [isnotnull(shardId#943631), (0_1_10000000678 = shardId#943631), isnotnull(product#943634), isnotnull(plant#943635)]"];
40 [id="node40" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(product#943634, plant#943635, 37), REPARTITION_BY_NUM, [plan_id=1631937]"];
subgraph cluster41 {
isCluster="true";
id="cluster41";
label="WholeStageCodegen (1)";
tooltip="WholeStageCodegen (1)";
42 [id="node42" labelType="html" label="<br><b>Scan ExistingRDD</b><br><br>" tooltip="Scan ExistingRDD[shardId#943631,worklistShardItemId#943632L,version#943633,product#943634,plant#943635,periodStart#943636,periodEnd#943637,qty#943638]"];
}
subgraph cluster43 {
isCluster="true";
id="cluster43";
label="WholeStageCodegen (8)";
tooltip="WholeStageCodegen (8)";
44 [id="node44" labelType="html" label="<br><b>Sort</b><br><br>" tooltip="Sort [minDistance#1006390L ASC NULLS FIRST, product#1006449 ASC NULLS FIRST, plant#1006450 ASC NULLS FIRST, configurationName#1006481 ASC NULLS FIRST], false, 0"];
}
45 [id="node45" labelType="html" label="<b>Exchange</b><br><br>number of partitions: 37" tooltip="Exchange hashpartitioning(minDistance#1006390L, product#1006449, plant#1006450, configurationName#1006481, 37), ENSURE_REQUIREMENTS, [plan_id=1632703]"];
subgraph cluster46 {
isCluster="true";
id="cluster46";
label="WholeStageCodegen (7)";
tooltip="WholeStageCodegen (7)";
47 [id="node47" labelType="html" label="<br><b>Filter</b><br><br>" tooltip="Filter isnotnull(minDistance#1006390L)"];
48 [id="node48" labelType="html" label="<br><b>HashAggregate</b><br><br>" tooltip="HashAggregate(keys=[product#1006449, plant#1006450, configurationName#1006481], functions=[min(distance#1006483L)])"];
49 [id="node49" labelType="html" label="<br><b>HashAggregate</b><br><br>" tooltip="HashAggregate(keys=[product#1006449, plant#1006450, configurationName#1006481], functions=[partial_min(distance#1006483L)])"];
50 [id="node50" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [product#1006449, plant#1006450, explodedConf#1006480.configurationName AS configurationName#1006481, (cast(schedule#1006478.orderDatetime as bigint) - CASE WHEN isnull(explodedConf#1006480.configurationValidityDatetime) THEN 0 ELSE cast(explodedConf#1006480.configurationValidityDatetime as bigint) END) AS distance#1006483L]"];
51 [id="node51" labelType="html" label="<br><b>Filter</b><br><br>" tooltip="Filter ((CASE WHEN isnull(explodedConf#1006480.configurationValidityDatetime) THEN 0 ELSE cast(explodedConf#1006480.configurationValidityDatetime as bigint) END <= cast(schedule#1006478.orderDatetime as bigint)) AND isnotnull(explodedConf#1006480.configurationName))"];
52 [id="node52" labelType="html" label="<br><b>Generate</b><br><br>" tooltip="Generate posexplode(configuration#1006460), [product#1006449, plant#1006450, schedule#1006478], true, [confPos#1006479, explodedConf#1006480]"];
53 [id="node53" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [product#1006449, plant#1006450, configuration#1006460, struct(orderDatetime, stockDatetime#1006452, availabilityDatetime, periodStart#1006474, demandPeriodEndDatetime, periodEnd#1006475, shelfLifeEndDatetime, 2199-01-01 00:00:00) AS schedule#1006478]"];
54 [id="node54" labelType="html" label="<br><b>BroadcastHashJoin</b><br><br>" tooltip="BroadcastHashJoin [product#1006449, plant#1006450], [product#1006472, plant#1006473], Inner, BuildRight, false"];
}
55 [id="node55" labelType="html" label="<b>Exchange</b><br><br>number of partitions: 37" tooltip="Exchange hashpartitioning(product#1006449, plant#1006450, 37), REPARTITION_BY_NUM, [plan_id=1632570]"];
subgraph cluster56 {
isCluster="true";
id="cluster56";
label="WholeStageCodegen (5)";
tooltip="WholeStageCodegen (5)";
57 [id="node57" labelType="html" label="<br><b>Filter</b><br><br>" tooltip="Filter ((isnotnull(product#1006449) AND isnotnull(plant#1006450)) AND isnotnull(stockDatetime#1006452))"];
58 [id="node58" labelType="html" label="<br><b>ColumnarToRow</b><br><br>" tooltip="ColumnarToRow"];
}
59 [id="node59" labelType="html" label="<b>Scan parquet </b><br><br>number of files read: 37<br>metadata time: 107 ms<br>size of files read: 1903.1 KiB" tooltip="FileScan parquet [product#1006449,plant#1006450,stockDatetime#1006452,configuration#1006460] Batched: true, DataFilters: [isnotnull(product#1006449), isnotnull(plant#1006450), isnotnull(stockDatetime#1006452)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://770f0770-bd0c-456f-b83b-9649926e0857.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(product), IsNotNull(plant), IsNotNull(stockDatetime)], ReadSchema: struct<product:string,plant:string,stockDatetime:timestamp,configuration:array<struct<configurati..."];
subgraph cluster60 {
isCluster="true";
id="cluster60";
label="WholeStageCodegen (13)";
tooltip="WholeStageCodegen (13)";
61 [id="node61" labelType="html" label="<br><b>Sort</b><br><br>" tooltip="Sort [product#1007607 ASC NULLS FIRST, plant#1007608 ASC NULLS FIRST], false, 0"];
}
62 [id="node62" labelType="html" label="<b>Exchange</b><br><br>number of partitions: 37" tooltip="Exchange hashpartitioning(product#1007607, plant#1007608, 37), ENSURE_REQUIREMENTS, [plan_id=1632616]"];
63 [id="node63" labelType="html" label="<br><b>Union</b><br><br>" tooltip="Union"];
64 [id="node64" labelType="html" label="<br><b>ObjectHashAggregate</b><br><br>" tooltip="ObjectHashAggregate(keys=[product#1007607, plant#1007608], functions=[collect_list(qty#1007611, 0, 0)])"];
65 [id="node65" labelType="html" label="<b>Exchange</b><br><br>number of partitions: 37" tooltip="Exchange hashpartitioning(product#1007607, plant#1007608, 37), ENSURE_REQUIREMENTS, [plan_id=1632609]"];
66 [id="node66" labelType="html" label="<br><b>ObjectHashAggregate</b><br><br>" tooltip="ObjectHashAggregate(keys=[product#1007607, plant#1007608], functions=[partial_collect_list(qty#1007611, 0, 0)])"];
subgraph cluster67 {
isCluster="true";
id="cluster67";
label="WholeStageCodegen (11)";
tooltip="WholeStageCodegen (11)";
68 [id="node68" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [product#1007607, plant#1007608, qty#1007611]"];
69 [id="node69" labelType="html" label="<br><b>Filter</b><br><br>" tooltip="Filter (((isNewlyCalculated#1006777 AND isnotnull(qty#1007611)) AND isnotnull(product#1007607)) AND isnotnull(plant#1007608))"];
}
70 [id="node70" labelType="html" label="<br><b>InMemoryTableScan</b><br><br>" tooltip="InMemoryTableScan [isNewlyCalculated#1006777, plant#1007608, product#1007607, qty#1007611], [isNewlyCalculated#1006777, isnotnull(qty#1007611), isnotnull(product#1007607), isnotnull(plant#1007608)]"];
71 [id="node71" labelType="html" label="<br><b>Union</b><br><br>" tooltip="Union"];
subgraph cluster72 {
isCluster="true";
id="cluster72";
label="WholeStageCodegen (5)\n \nduration: total (min, med, max (stageId: taskId))\n112 ms (0 ms, 0 ms, 12 ms (stage 104833.0: task 346641))";
tooltip="WholeStageCodegen (5)";
73 [id="node73" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635, qty#943638, null AS demandChannel#1006774, null AS demandStream#1006775, [] AS kpis#1006809, true AS isNewlyCalculated#1006777]"];
74 [id="node74" labelType="html" label="<b>SortMergeJoin</b><br><br>number of output rows: 51<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104833.0: task 346641))" tooltip="SortMergeJoin [coalesce(shardId#943631, ), isnull(shardId#943631), coalesce(worklistShardItemId#943632L, 0), isnull(worklistShardItemId#943632L), coalesce(version#943633, 0), isnull(version#943633), coalesce(product#943634, ), isnull(product#943634), coalesce(plant#943635, ), isnull(plant#943635), knownfloatingpointnormalized(normalizenanandzero(coalesce(qty#943638, 0.0))), isnull(qty#943638)], [coalesce(shardId#1006766, ), isnull(shardId#1006766), coalesce(worklistShardItemId#1006767L, 0), isnull(worklistShardItemId#1006767L), coalesce(version#1006768, 0), isnull(version#1006768), coalesce(product#1006769, ), isnull(product#1006769), coalesce(plant#1006770, ), isnull(plant#1006770), knownfloatingpointnormalized(normalizenanandzero(coalesce(qty#1006541, 0.0))), isnull(qty#1006541)], LeftAnti"];
}
subgraph cluster75 {
isCluster="true";
id="cluster75";
label="WholeStageCodegen (1)\n \nduration: total (min, med, max (stageId: taskId))\n3.2 s (3 ms, 8 ms, 316 ms (stage 104833.0: task 346645))";
tooltip="WholeStageCodegen (1)";
76 [id="node76" labelType="html" label="<b>Sort</b><br><br>sort time total (min, med, max (stageId: taskId))<br>1 ms (0 ms, 0 ms, 1 ms (stage 104833.0: task 346644))<br>peak memory total (min, med, max (stageId: taskId))<br>56.3 MiB (64.0 KiB, 2.1 MiB, 2.1 MiB (stage 104833.0: task 346641))<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104833.0: task 346641))" tooltip="Sort [coalesce(shardId#943631, ) ASC NULLS FIRST, isnull(shardId#943631) ASC NULLS FIRST, coalesce(worklistShardItemId#943632L, 0) ASC NULLS FIRST, isnull(worklistShardItemId#943632L) ASC NULLS FIRST, coalesce(version#943633, 0) ASC NULLS FIRST, isnull(version#943633) ASC NULLS FIRST, coalesce(product#943634, ) ASC NULLS FIRST, isnull(product#943634) ASC NULLS FIRST, coalesce(plant#943635, ) ASC NULLS FIRST, isnull(plant#943635) ASC NULLS FIRST, knownfloatingpointnormalized(normalizenanandzero(coalesce(qty#943638, 0.0))) ASC NULLS FIRST, isnull(qty#943638) ASC NULLS FIRST], false, 0"];
}
77 [id="node77" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 51<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 51<br>local bytes read total (min, med, max (stageId: taskId))<br>6.3 KiB (176.0 B, 177.0 B, 530.0 B (stage 104833.0: task 346652))<br>merged fetch fallback count: 0<br>local blocks read: 36<br>remote merged chunks fetched: 0<br>remote blocks read: 12<br>data size total (min, med, max (stageId: taskId))<br>6.8 KiB (136.0 B, 272.0 B, 680.0 B (stage 104832.0: task 346410))<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time total (min, med, max (stageId: taskId))<br>10 ms (0 ms, 0 ms, 0 ms (stage 104832.0: task 346452))<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time total (min, med, max (stageId: taskId))<br>0 ms (0 ms, 0 ms, 0 ms (stage 104833.0: task 346641))<br>remote bytes read total (min, med, max (stageId: taskId))<br>2.1 KiB (176.0 B, 177.0 B, 354.0 B (stage 104833.0: task 346662))<br>number of partitions: 37<br>remote reqs duration total (min, med, max (stageId: taskId))<br>2 ms (0 ms, 0 ms, 2 ms (stage 104833.0: task 346643))<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written total (min, med, max (stageId: taskId))<br>8.4 KiB (177.0 B, 358.0 B, 721.0 B (stage 104832.0: task 346410))" tooltip="Exchange hashpartitioning(coalesce(shardId#943631, ), isnull(shardId#943631), coalesce(worklistShardItemId#943632L, 0), isnull(worklistShardItemId#943632L), coalesce(version#943633, 0), isnull(version#943633), coalesce(product#943634, ), isnull(product#943634), coalesce(plant#943635, ), isnull(plant#943635), knownfloatingpointnormalized(normalizenanandzero(coalesce(qty#943638, 0.0))), isnull(qty#943638), 37), ENSURE_REQUIREMENTS, [plan_id=1632167]"];
78 [id="node78" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 51" tooltip="InMemoryTableScan [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635, qty#943638]"];
79 [id="node79" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(product#943634, plant#943635, 37), REPARTITION_BY_NUM, [plan_id=1631937]"];
subgraph cluster80 {
isCluster="true";
id="cluster80";
label="WholeStageCodegen (1)";
tooltip="WholeStageCodegen (1)";
81 [id="node81" labelType="html" label="<br><b>Scan ExistingRDD</b><br><br>" tooltip="Scan ExistingRDD[shardId#943631,worklistShardItemId#943632L,version#943633,product#943634,plant#943635,periodStart#943636,periodEnd#943637,qty#943638]"];
}
subgraph cluster82 {
isCluster="true";
id="cluster82";
label="WholeStageCodegen (4)\n \nduration: total (min, med, max (stageId: taskId))\n915 ms (1 ms, 8 ms, 162 ms (stage 104833.0: task 346643))";
tooltip="WholeStageCodegen (4)";
83 [id="node83" labelType="html" label="<b>Sort</b><br><br>sort time total (min, med, max (stageId: taskId))<br>0 ms (0 ms, 0 ms, 0 ms (stage 104833.0: task 346641))<br>peak memory total (min, med, max (stageId: taskId))<br>1728.0 KiB (64.0 KiB, 64.0 KiB, 64.0 KiB (stage 104833.0: task 346641))<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104833.0: task 346641))" tooltip="Sort [coalesce(shardId#1006766, ) ASC NULLS FIRST, isnull(shardId#1006766) ASC NULLS FIRST, coalesce(worklistShardItemId#1006767L, 0) ASC NULLS FIRST, isnull(worklistShardItemId#1006767L) ASC NULLS FIRST, coalesce(version#1006768, 0) ASC NULLS FIRST, isnull(version#1006768) ASC NULLS FIRST, coalesce(product#1006769, ) ASC NULLS FIRST, isnull(product#1006769) ASC NULLS FIRST, coalesce(plant#1006770, ) ASC NULLS FIRST, isnull(plant#1006770) ASC NULLS FIRST, knownfloatingpointnormalized(normalizenanandzero(coalesce(qty#1006541, 0.0))) ASC NULLS FIRST, isnull(qty#1006541) ASC NULLS FIRST], false, 0"];
}
84 [id="node84" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>number of partitions: 37<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(coalesce(shardId#1006766, ), isnull(shardId#1006766), coalesce(worklistShardItemId#1006767L, 0), isnull(worklistShardItemId#1006767L), coalesce(version#1006768, 0), isnull(version#1006768), coalesce(product#1006769, ), isnull(product#1006769), coalesce(plant#1006770, ), isnull(plant#1006770), knownfloatingpointnormalized(normalizenanandzero(coalesce(qty#1006541, 0.0))), isnull(qty#1006541), 37), ENSURE_REQUIREMENTS, [plan_id=1632187]"];
85 [id="node85" labelType="html" label="<br><b>Union</b><br><br>" tooltip="Union"];
86 [id="node86" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 0" tooltip="InMemoryTableScan [shardId#1006766, worklistShardItemId#1006767L, version#1006768, product#1006769, plant#1006770, qty#1006541]"];
subgraph cluster87 {
isCluster="true";
id="cluster87";
label="WholeStageCodegen (7)\n \nduration: total (min, med, max (stageId: taskId))\n30 ms (0 ms, 0 ms, 3 ms (stage 104831.0: task 346570))";
tooltip="WholeStageCodegen (7)";
88 [id="node88" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635, cachedQty#1006539 AS qty#1006541, demandChannel#1006534, demandStream#1006535, cachedKpis#1006540 AS kpis#1006542]"];
89 [id="node89" labelType="html" label="<b>SortMergeJoin</b><br><br>number of output rows: 0<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104831.0: task 346570))" tooltip="SortMergeJoin [worklistShardItemId#943632L, shardId#943631], [cachedWorklistShardItemId#1006538L, cachedShardId#1006537], Inner"];
}
subgraph cluster90 {
isCluster="true";
id="cluster90";
label="WholeStageCodegen (4)\n \nduration: total (min, med, max (stageId: taskId))\n1.8 s (0 ms, 1 ms, 151 ms (stage 104831.0: task 346575))";
tooltip="WholeStageCodegen (4)";
91 [id="node91" labelType="html" label="<b>Sort</b><br><br>sort time total (min, med, max (stageId: taskId))<br>0 ms (0 ms, 0 ms, 0 ms (stage 104831.0: task 346570))<br>peak memory total (min, med, max (stageId: taskId))<br>2.3 MiB (64.0 KiB, 64.0 KiB, 64.0 KiB (stage 104831.0: task 346570))<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104831.0: task 346570))" tooltip="Sort [worklistShardItemId#943632L ASC NULLS FIRST, shardId#943631 ASC NULLS FIRST], false, 0"];
}
92 [id="node92" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>number of partitions: 37<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(worklistShardItemId#943632L, shardId#943631, 37), ENSURE_REQUIREMENTS, [plan_id=1632055]"];
subgraph cluster93 {
isCluster="true";
id="cluster93";
label="WholeStageCodegen (3)\n \nduration: total (min, med, max (stageId: taskId))\n64 ms (0 ms, 1 ms, 6 ms (stage 104830.0: task 346495))";
tooltip="WholeStageCodegen (3)";
94 [id="node94" labelType="html" label="<b>HashAggregate</b><br><br>spill size: 0.0 B<br>time in aggregation build total (min, med, max (stageId: taskId))<br>7 ms (0 ms, 0 ms, 2 ms (stage 104830.0: task 346498))<br>peak memory total (min, med, max (stageId: taskId))<br>9.3 MiB (256.0 KiB, 256.0 KiB, 256.0 KiB (stage 104830.0: task 346505))<br>number of output rows: 0<br>number of sort fallback tasks: 0<br>avg hash probes per key: 0" tooltip="HashAggregate(keys=[plant#943635, shardId#943631, version#943633, worklistShardItemId#943632L, product#943634], functions=[])"];
}
95 [id="node95" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>number of partitions: 37<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(plant#943635, shardId#943631, version#943633, worklistShardItemId#943632L, product#943634, 37), ENSURE_REQUIREMENTS, [plan_id=1632051]"];
subgraph cluster96 {
isCluster="true";
id="cluster96";
label="WholeStageCodegen (2)\n \nduration: total (min, med, max (stageId: taskId))\n1.6 s (4 ms, 8 ms, 151 ms (stage 104828.0: task 346447))";
tooltip="WholeStageCodegen (2)";
97 [id="node97" labelType="html" label="<b>HashAggregate</b><br><br>spill size: 0.0 B<br>time in aggregation build total (min, med, max (stageId: taskId))<br>227 ms (3 ms, 6 ms, 9 ms (stage 104828.0: task 346447))<br>peak memory total (min, med, max (stageId: taskId))<br>9.3 MiB (256.0 KiB, 256.0 KiB, 256.0 KiB (stage 104828.0: task 346466))<br>number of output rows: 0<br>number of sort fallback tasks: 0<br>avg hash probes per key: 0" tooltip="HashAggregate(keys=[plant#943635, shardId#943631, version#943633, worklistShardItemId#943632L, product#943634], functions=[])"];
98 [id="node98" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635]"];
99 [id="node99" labelType="html" label="<b>BroadcastHashJoin</b><br><br>number of output rows: 0" tooltip="BroadcastHashJoin [worklistShardItemId#943632L, shardId#943631], [cachedWorklistShardItemId#1006528L, cachedShardId#1006527], Inner, BuildLeft, ((qty#943638 = cachedQty#1006529) OR isnull(qty#943638)), false"];
107 [id="node107" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006521 AS cachedShardId#1006527, worklistShardItemId#1006522L AS cachedWorklistShardItemId#1006528L, qty#1006523 AS cachedQty#1006529]"];
108 [id="node108" labelType="html" label="<b>Filter</b><br><br>number of output rows: 6,177" tooltip="Filter (isnotnull(worklistShardItemId#1006522L) AND isnotnull(shardId#1006521))"];
109 [id="node109" labelType="html" label="<b>Scan ExistingRDD</b><br><br>number of output rows: 6,177" tooltip="Scan ExistingRDD[shardId#1006521,worklistShardItemId#1006522L,qty#1006523,demandChannel#1006524,demandStream#1006525,kpis#1006526]"];
}
100 [id="node100" labelType="html" label="<b>BroadcastExchange</b><br><br>time to broadcast: 0 ms<br>time to build: 1 ms<br>time to collect: 409 ms<br>number of output rows: 51<br>data size: 2.0 MiB" tooltip="BroadcastExchange HashedRelationBroadcastMode(List(input[1, bigint, false], input[0, string, false]),false), [plan_id=1632045]"];
subgraph cluster101 {
isCluster="true";
id="cluster101";
label="WholeStageCodegen (1)\n \nduration: total (min, med, max (stageId: taskId))\n9 ms (0 ms, 0 ms, 3 ms (stage 104736.0: task 346285))";
tooltip="WholeStageCodegen (1)";
102 [id="node102" labelType="html" label="<b>Filter</b><br><br>number of output rows: 51" tooltip="Filter (isnotnull(worklistShardItemId#943632L) AND isnotnull(shardId#943631))"];
}
103 [id="node103" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 51" tooltip="InMemoryTableScan [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635, qty#943638], [isnotnull(worklistShardItemId#943632L), isnotnull(shardId#943631)]"];
104 [id="node104" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(product#943634, plant#943635, 37), REPARTITION_BY_NUM, [plan_id=1631937]"];
subgraph cluster105 {
isCluster="true";
id="cluster105";
label="WholeStageCodegen (1)";
tooltip="WholeStageCodegen (1)";
106 [id="node106" labelType="html" label="<br><b>Scan ExistingRDD</b><br><br>" tooltip="Scan ExistingRDD[shardId#943631,worklistShardItemId#943632L,version#943633,product#943634,plant#943635,periodStart#943636,periodEnd#943637,qty#943638]"];
}
subgraph cluster110 {
isCluster="true";
id="cluster110";
label="WholeStageCodegen (6)\n \nduration: 0 ms";
tooltip="WholeStageCodegen (6)";
111 [id="node111" labelType="html" label="<b>Sort</b><br><br>sort time: 0 ms<br>peak memory: 0.0 B<br>spill size: 0.0 B" tooltip="Sort [cachedWorklistShardItemId#1006538L ASC NULLS FIRST, cachedShardId#1006537 ASC NULLS FIRST], false, 0"];
}
112 [id="node112" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 6,177<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read total (min, med, max (stageId: taskId))<br>300.0 KiB (3.3 KiB, 7.3 KiB, 17.7 KiB (stage 104831.0: task 346579))<br>merged fetch fallback count: 0<br>local blocks read: 379<br>remote merged chunks fetched: 0<br>remote blocks read: 785<br>data size total (min, med, max (stageId: taskId))<br>3.3 MiB (88.7 KiB, 92.1 KiB, 95.9 KiB (stage 104829.0: task 346405))<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time total (min, med, max (stageId: taskId))<br>75 ms (1 ms, 1 ms, 2 ms (stage 104829.0: task 346451))<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read total (min, med, max (stageId: taskId))<br>610.9 KiB (6.2 KiB, 17.5 KiB, 27.3 KiB (stage 104831.0: task 346589))<br>number of partitions: 37<br>remote reqs duration total (min, med, max (stageId: taskId))<br>152 ms (0 ms, 4 ms, 13 ms (stage 104831.0: task 346576))<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written total (min, med, max (stageId: taskId))<br>1048.5 KiB (25.8 KiB, 28.2 KiB, 30.6 KiB (stage 104829.0: task 346450))" tooltip="Exchange hashpartitioning(cachedWorklistShardItemId#1006538L, cachedShardId#1006537, 37), ENSURE_REQUIREMENTS, [plan_id=1632061]"];
subgraph cluster113 {
isCluster="true";
id="cluster113";
label="WholeStageCodegen (5)\n \nduration: total (min, med, max (stageId: taskId))\n1.8 s (7 ms, 13 ms, 107 ms (stage 104829.0: task 346387))";
tooltip="WholeStageCodegen (5)";
114 [id="node114" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006531 AS cachedShardId#1006537, worklistShardItemId#1006532L AS cachedWorklistShardItemId#1006538L, qty#1006533 AS cachedQty#1006539, demandChannel#1006534, demandStream#1006535, kpis#1006536 AS cachedKpis#1006540]"];
115 [id="node115" labelType="html" label="<b>Filter</b><br><br>number of output rows: 6,177" tooltip="Filter (isnotnull(worklistShardItemId#1006532L) AND isnotnull(shardId#1006531))"];
116 [id="node116" labelType="html" label="<b>Scan ExistingRDD</b><br><br>number of output rows: 6,177" tooltip="Scan ExistingRDD[shardId#1006531,worklistShardItemId#1006532L,qty#1006533,demandChannel#1006534,demandStream#1006535,kpis#1006536]"];
}
subgraph cluster117 {
isCluster="true";
id="cluster117";
label="WholeStageCodegen (3)\n \nduration: total (min, med, max (stageId: taskId))\n501 ms (4 ms, 8 ms, 48 ms (stage 104831.0: task 346537))";
tooltip="WholeStageCodegen (3)";
118 [id="node118" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006748, worklistShardItemId#1006749L, version#1006750, product#1006751, plant#1006752, qty#1006755]"];
119 [id="node119" labelType="html" label="<b>BroadcastHashJoin</b><br><br>number of output rows: 0" tooltip="BroadcastHashJoin [worklistShardItemId#1006749L, shardId#1006748], [cachedWorklistShardItemId#1006763L, cachedShardId#1006762], Inner, BuildLeft, false"];
127 [id="node127" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006756 AS cachedShardId#1006762, worklistShardItemId#1006757L AS cachedWorklistShardItemId#1006763L]"];
128 [id="node128" labelType="html" label="<b>Filter</b><br><br>number of output rows: 6,177" tooltip="Filter (isnotnull(worklistShardItemId#1006757L) AND isnotnull(shardId#1006756))"];
129 [id="node129" labelType="html" label="<b>Scan ExistingRDD</b><br><br>number of output rows: 6,177" tooltip="Scan ExistingRDD[shardId#1006756,worklistShardItemId#1006757L,qty#1006758,demandChannel#1006759,demandStream#1006760,kpis#1006761]"];
}
120 [id="node120" labelType="html" label="<b>BroadcastExchange</b><br><br>time to broadcast: 0 ms<br>time to build: 0 ms<br>time to collect: 398 ms<br>number of output rows: 0<br>data size: 0.0 B" tooltip="BroadcastExchange HashedRelationBroadcastMode(List(input[1, bigint, false], input[0, string, false]),false), [plan_id=1632181]"];
subgraph cluster121 {
isCluster="true";
id="cluster121";
label="WholeStageCodegen (2)\n \nduration: total (min, med, max (stageId: taskId))\n12 ms (0 ms, 0 ms, 3 ms (stage 104735.0: task 346356))";
tooltip="WholeStageCodegen (2)";
122 [id="node122" labelType="html" label="<b>Filter</b><br><br>number of output rows: 0" tooltip="Filter ((isnull(qty#1006755) AND isnotnull(worklistShardItemId#1006749L)) AND isnotnull(shardId#1006748))"];
}
123 [id="node123" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 0" tooltip="InMemoryTableScan [shardId#1006748, worklistShardItemId#1006749L, version#1006750, product#1006751, plant#1006752, qty#1006755], [isnull(qty#1006755), isnotnull(worklistShardItemId#1006749L), isnotnull(shardId#1006748)]"];
124 [id="node124" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(product#943634, plant#943635, 37), REPARTITION_BY_NUM, [plan_id=1631937]"];
subgraph cluster125 {
isCluster="true";
id="cluster125";
label="WholeStageCodegen (1)";
tooltip="WholeStageCodegen (1)";
126 [id="node126" labelType="html" label="<br><b>Scan ExistingRDD</b><br><br>" tooltip="Scan ExistingRDD[shardId#943631,worklistShardItemId#943632L,version#943633,product#943634,plant#943635,periodStart#943636,periodEnd#943637,qty#943638]"];
}
subgraph cluster130 {
isCluster="true";
id="cluster130";
label="WholeStageCodegen (6)\n \nduration: total (min, med, max (stageId: taskId))\n2.0 s (0 ms, 0 ms, 230 ms (stage 104833.0: task 346611))";
tooltip="WholeStageCodegen (6)";
131 [id="node131" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006779, worklistShardItemId#1006780L, version#1006781, product#1006782, plant#1006783, qty#1006807, demandChannel#1006800, demandStream#1006801, kpis#1006808, false AS isNewlyCalculated#1006778]"];
}
132 [id="node132" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 0" tooltip="InMemoryTableScan [demandChannel#1006800, demandStream#1006801, kpis#1006808, plant#1006783, product#1006782, qty#1006807, shardId#1006779, version#1006781, worklistShardItemId#1006780L]"];
subgraph cluster133 {
isCluster="true";
id="cluster133";
label="WholeStageCodegen (7)\n \nduration: total (min, med, max (stageId: taskId))\n30 ms (0 ms, 0 ms, 3 ms (stage 104831.0: task 346570))";
tooltip="WholeStageCodegen (7)";
134 [id="node134" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635, cachedQty#1006539 AS qty#1006541, demandChannel#1006534, demandStream#1006535, cachedKpis#1006540 AS kpis#1006542]"];
135 [id="node135" labelType="html" label="<b>SortMergeJoin</b><br><br>number of output rows: 0<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104831.0: task 346570))" tooltip="SortMergeJoin [worklistShardItemId#943632L, shardId#943631], [cachedWorklistShardItemId#1006538L, cachedShardId#1006537], Inner"];
}
subgraph cluster136 {
isCluster="true";
id="cluster136";
label="WholeStageCodegen (4)\n \nduration: total (min, med, max (stageId: taskId))\n1.8 s (0 ms, 1 ms, 151 ms (stage 104831.0: task 346575))";
tooltip="WholeStageCodegen (4)";
137 [id="node137" labelType="html" label="<b>Sort</b><br><br>sort time total (min, med, max (stageId: taskId))<br>0 ms (0 ms, 0 ms, 0 ms (stage 104831.0: task 346570))<br>peak memory total (min, med, max (stageId: taskId))<br>2.3 MiB (64.0 KiB, 64.0 KiB, 64.0 KiB (stage 104831.0: task 346570))<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104831.0: task 346570))" tooltip="Sort [worklistShardItemId#943632L ASC NULLS FIRST, shardId#943631 ASC NULLS FIRST], false, 0"];
}
138 [id="node138" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>number of partitions: 37<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(worklistShardItemId#943632L, shardId#943631, 37), ENSURE_REQUIREMENTS, [plan_id=1632055]"];
subgraph cluster139 {
isCluster="true";
id="cluster139";
label="WholeStageCodegen (3)\n \nduration: total (min, med, max (stageId: taskId))\n64 ms (0 ms, 1 ms, 6 ms (stage 104830.0: task 346495))";
tooltip="WholeStageCodegen (3)";
140 [id="node140" labelType="html" label="<b>HashAggregate</b><br><br>spill size: 0.0 B<br>time in aggregation build total (min, med, max (stageId: taskId))<br>7 ms (0 ms, 0 ms, 2 ms (stage 104830.0: task 346498))<br>peak memory total (min, med, max (stageId: taskId))<br>9.3 MiB (256.0 KiB, 256.0 KiB, 256.0 KiB (stage 104830.0: task 346505))<br>number of output rows: 0<br>number of sort fallback tasks: 0<br>avg hash probes per key: 0" tooltip="HashAggregate(keys=[plant#943635, shardId#943631, version#943633, worklistShardItemId#943632L, product#943634], functions=[])"];
}
141 [id="node141" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>number of partitions: 37<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(plant#943635, shardId#943631, version#943633, worklistShardItemId#943632L, product#943634, 37), ENSURE_REQUIREMENTS, [plan_id=1632051]"];
subgraph cluster142 {
isCluster="true";
id="cluster142";
label="WholeStageCodegen (2)\n \nduration: total (min, med, max (stageId: taskId))\n1.6 s (4 ms, 8 ms, 151 ms (stage 104828.0: task 346447))";
tooltip="WholeStageCodegen (2)";
143 [id="node143" labelType="html" label="<b>HashAggregate</b><br><br>spill size: 0.0 B<br>time in aggregation build total (min, med, max (stageId: taskId))<br>227 ms (3 ms, 6 ms, 9 ms (stage 104828.0: task 346447))<br>peak memory total (min, med, max (stageId: taskId))<br>9.3 MiB (256.0 KiB, 256.0 KiB, 256.0 KiB (stage 104828.0: task 346466))<br>number of output rows: 0<br>number of sort fallback tasks: 0<br>avg hash probes per key: 0" tooltip="HashAggregate(keys=[plant#943635, shardId#943631, version#943633, worklistShardItemId#943632L, product#943634], functions=[])"];
144 [id="node144" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635]"];
145 [id="node145" labelType="html" label="<b>BroadcastHashJoin</b><br><br>number of output rows: 0" tooltip="BroadcastHashJoin [worklistShardItemId#943632L, shardId#943631], [cachedWorklistShardItemId#1006528L, cachedShardId#1006527], Inner, BuildLeft, ((qty#943638 = cachedQty#1006529) OR isnull(qty#943638)), false"];
153 [id="node153" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006521 AS cachedShardId#1006527, worklistShardItemId#1006522L AS cachedWorklistShardItemId#1006528L, qty#1006523 AS cachedQty#1006529]"];
154 [id="node154" labelType="html" label="<b>Filter</b><br><br>number of output rows: 6,177" tooltip="Filter (isnotnull(worklistShardItemId#1006522L) AND isnotnull(shardId#1006521))"];
155 [id="node155" labelType="html" label="<b>Scan ExistingRDD</b><br><br>number of output rows: 6,177" tooltip="Scan ExistingRDD[shardId#1006521,worklistShardItemId#1006522L,qty#1006523,demandChannel#1006524,demandStream#1006525,kpis#1006526]"];
}
146 [id="node146" labelType="html" label="<b>BroadcastExchange</b><br><br>time to broadcast: 0 ms<br>time to build: 1 ms<br>time to collect: 409 ms<br>number of output rows: 51<br>data size: 2.0 MiB" tooltip="BroadcastExchange HashedRelationBroadcastMode(List(input[1, bigint, false], input[0, string, false]),false), [plan_id=1632045]"];
subgraph cluster147 {
isCluster="true";
id="cluster147";
label="WholeStageCodegen (1)\n \nduration: total (min, med, max (stageId: taskId))\n9 ms (0 ms, 0 ms, 3 ms (stage 104736.0: task 346285))";
tooltip="WholeStageCodegen (1)";
148 [id="node148" labelType="html" label="<b>Filter</b><br><br>number of output rows: 51" tooltip="Filter (isnotnull(worklistShardItemId#943632L) AND isnotnull(shardId#943631))"];
}
149 [id="node149" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 51" tooltip="InMemoryTableScan [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635, qty#943638], [isnotnull(worklistShardItemId#943632L), isnotnull(shardId#943631)]"];
150 [id="node150" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(product#943634, plant#943635, 37), REPARTITION_BY_NUM, [plan_id=1631937]"];
subgraph cluster151 {
isCluster="true";
id="cluster151";
label="WholeStageCodegen (1)";
tooltip="WholeStageCodegen (1)";
152 [id="node152" labelType="html" label="<br><b>Scan ExistingRDD</b><br><br>" tooltip="Scan ExistingRDD[shardId#943631,worklistShardItemId#943632L,version#943633,product#943634,plant#943635,periodStart#943636,periodEnd#943637,qty#943638]"];
}
subgraph cluster156 {
isCluster="true";
id="cluster156";
label="WholeStageCodegen (6)\n \nduration: 0 ms";
tooltip="WholeStageCodegen (6)";
157 [id="node157" labelType="html" label="<b>Sort</b><br><br>sort time: 0 ms<br>peak memory: 0.0 B<br>spill size: 0.0 B" tooltip="Sort [cachedWorklistShardItemId#1006538L ASC NULLS FIRST, cachedShardId#1006537 ASC NULLS FIRST], false, 0"];
}
158 [id="node158" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 6,177<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read total (min, med, max (stageId: taskId))<br>300.0 KiB (3.3 KiB, 7.3 KiB, 17.7 KiB (stage 104831.0: task 346579))<br>merged fetch fallback count: 0<br>local blocks read: 379<br>remote merged chunks fetched: 0<br>remote blocks read: 785<br>data size total (min, med, max (stageId: taskId))<br>3.3 MiB (88.7 KiB, 92.1 KiB, 95.9 KiB (stage 104829.0: task 346405))<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time total (min, med, max (stageId: taskId))<br>75 ms (1 ms, 1 ms, 2 ms (stage 104829.0: task 346451))<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read total (min, med, max (stageId: taskId))<br>610.9 KiB (6.2 KiB, 17.5 KiB, 27.3 KiB (stage 104831.0: task 346589))<br>number of partitions: 37<br>remote reqs duration total (min, med, max (stageId: taskId))<br>152 ms (0 ms, 4 ms, 13 ms (stage 104831.0: task 346576))<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written total (min, med, max (stageId: taskId))<br>1048.5 KiB (25.8 KiB, 28.2 KiB, 30.6 KiB (stage 104829.0: task 346450))" tooltip="Exchange hashpartitioning(cachedWorklistShardItemId#1006538L, cachedShardId#1006537, 37), ENSURE_REQUIREMENTS, [plan_id=1632061]"];
subgraph cluster159 {
isCluster="true";
id="cluster159";
label="WholeStageCodegen (5)\n \nduration: total (min, med, max (stageId: taskId))\n1.8 s (7 ms, 13 ms, 107 ms (stage 104829.0: task 346387))";
tooltip="WholeStageCodegen (5)";
160 [id="node160" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006531 AS cachedShardId#1006537, worklistShardItemId#1006532L AS cachedWorklistShardItemId#1006538L, qty#1006533 AS cachedQty#1006539, demandChannel#1006534, demandStream#1006535, kpis#1006536 AS cachedKpis#1006540]"];
161 [id="node161" labelType="html" label="<b>Filter</b><br><br>number of output rows: 6,177" tooltip="Filter (isnotnull(worklistShardItemId#1006532L) AND isnotnull(shardId#1006531))"];
162 [id="node162" labelType="html" label="<b>Scan ExistingRDD</b><br><br>number of output rows: 6,177" tooltip="Scan ExistingRDD[shardId#1006531,worklistShardItemId#1006532L,qty#1006533,demandChannel#1006534,demandStream#1006535,kpis#1006536]"];
}
subgraph cluster163 {
isCluster="true";
id="cluster163";
label="WholeStageCodegen (12)";
tooltip="WholeStageCodegen (12)";
164 [id="node164" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [product#1007515, plant#1007516, [] AS requestedQuantities#1007503]"];
165 [id="node165" labelType="html" label="<br><b>Filter</b><br><br>" tooltip="Filter (((isNewlyCalculated#1007571 AND isnull(qty#1007519)) AND isnotnull(product#1007515)) AND isnotnull(plant#1007516))"];
}
166 [id="node166" labelType="html" label="<br><b>InMemoryTableScan</b><br><br>" tooltip="InMemoryTableScan [isNewlyCalculated#1007571, plant#1007516, product#1007515, qty#1007519], [isNewlyCalculated#1007571, isnull(qty#1007519), isnotnull(product#1007515), isnotnull(plant#1007516)]"];
167 [id="node167" labelType="html" label="<br><b>Union</b><br><br>" tooltip="Union"];
subgraph cluster168 {
isCluster="true";
id="cluster168";
label="WholeStageCodegen (5)\n \nduration: total (min, med, max (stageId: taskId))\n112 ms (0 ms, 0 ms, 12 ms (stage 104833.0: task 346641))";
tooltip="WholeStageCodegen (5)";
169 [id="node169" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635, qty#943638, null AS demandChannel#1006774, null AS demandStream#1006775, [] AS kpis#1006809, true AS isNewlyCalculated#1006777]"];
170 [id="node170" labelType="html" label="<b>SortMergeJoin</b><br><br>number of output rows: 51<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104833.0: task 346641))" tooltip="SortMergeJoin [coalesce(shardId#943631, ), isnull(shardId#943631), coalesce(worklistShardItemId#943632L, 0), isnull(worklistShardItemId#943632L), coalesce(version#943633, 0), isnull(version#943633), coalesce(product#943634, ), isnull(product#943634), coalesce(plant#943635, ), isnull(plant#943635), knownfloatingpointnormalized(normalizenanandzero(coalesce(qty#943638, 0.0))), isnull(qty#943638)], [coalesce(shardId#1006766, ), isnull(shardId#1006766), coalesce(worklistShardItemId#1006767L, 0), isnull(worklistShardItemId#1006767L), coalesce(version#1006768, 0), isnull(version#1006768), coalesce(product#1006769, ), isnull(product#1006769), coalesce(plant#1006770, ), isnull(plant#1006770), knownfloatingpointnormalized(normalizenanandzero(coalesce(qty#1006541, 0.0))), isnull(qty#1006541)], LeftAnti"];
}
subgraph cluster171 {
isCluster="true";
id="cluster171";
label="WholeStageCodegen (1)\n \nduration: total (min, med, max (stageId: taskId))\n3.2 s (3 ms, 8 ms, 316 ms (stage 104833.0: task 346645))";
tooltip="WholeStageCodegen (1)";
172 [id="node172" labelType="html" label="<b>Sort</b><br><br>sort time total (min, med, max (stageId: taskId))<br>1 ms (0 ms, 0 ms, 1 ms (stage 104833.0: task 346644))<br>peak memory total (min, med, max (stageId: taskId))<br>56.3 MiB (64.0 KiB, 2.1 MiB, 2.1 MiB (stage 104833.0: task 346641))<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104833.0: task 346641))" tooltip="Sort [coalesce(shardId#943631, ) ASC NULLS FIRST, isnull(shardId#943631) ASC NULLS FIRST, coalesce(worklistShardItemId#943632L, 0) ASC NULLS FIRST, isnull(worklistShardItemId#943632L) ASC NULLS FIRST, coalesce(version#943633, 0) ASC NULLS FIRST, isnull(version#943633) ASC NULLS FIRST, coalesce(product#943634, ) ASC NULLS FIRST, isnull(product#943634) ASC NULLS FIRST, coalesce(plant#943635, ) ASC NULLS FIRST, isnull(plant#943635) ASC NULLS FIRST, knownfloatingpointnormalized(normalizenanandzero(coalesce(qty#943638, 0.0))) ASC NULLS FIRST, isnull(qty#943638) ASC NULLS FIRST], false, 0"];
}
173 [id="node173" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 51<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 51<br>local bytes read total (min, med, max (stageId: taskId))<br>6.3 KiB (176.0 B, 177.0 B, 530.0 B (stage 104833.0: task 346652))<br>merged fetch fallback count: 0<br>local blocks read: 36<br>remote merged chunks fetched: 0<br>remote blocks read: 12<br>data size total (min, med, max (stageId: taskId))<br>6.8 KiB (136.0 B, 272.0 B, 680.0 B (stage 104832.0: task 346410))<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time total (min, med, max (stageId: taskId))<br>10 ms (0 ms, 0 ms, 0 ms (stage 104832.0: task 346452))<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time total (min, med, max (stageId: taskId))<br>0 ms (0 ms, 0 ms, 0 ms (stage 104833.0: task 346641))<br>remote bytes read total (min, med, max (stageId: taskId))<br>2.1 KiB (176.0 B, 177.0 B, 354.0 B (stage 104833.0: task 346662))<br>number of partitions: 37<br>remote reqs duration total (min, med, max (stageId: taskId))<br>2 ms (0 ms, 0 ms, 2 ms (stage 104833.0: task 346643))<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written total (min, med, max (stageId: taskId))<br>8.4 KiB (177.0 B, 358.0 B, 721.0 B (stage 104832.0: task 346410))" tooltip="Exchange hashpartitioning(coalesce(shardId#943631, ), isnull(shardId#943631), coalesce(worklistShardItemId#943632L, 0), isnull(worklistShardItemId#943632L), coalesce(version#943633, 0), isnull(version#943633), coalesce(product#943634, ), isnull(product#943634), coalesce(plant#943635, ), isnull(plant#943635), knownfloatingpointnormalized(normalizenanandzero(coalesce(qty#943638, 0.0))), isnull(qty#943638), 37), ENSURE_REQUIREMENTS, [plan_id=1632167]"];
174 [id="node174" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 51" tooltip="InMemoryTableScan [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635, qty#943638]"];
175 [id="node175" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(product#943634, plant#943635, 37), REPARTITION_BY_NUM, [plan_id=1631937]"];
subgraph cluster176 {
isCluster="true";
id="cluster176";
label="WholeStageCodegen (1)";
tooltip="WholeStageCodegen (1)";
177 [id="node177" labelType="html" label="<br><b>Scan ExistingRDD</b><br><br>" tooltip="Scan ExistingRDD[shardId#943631,worklistShardItemId#943632L,version#943633,product#943634,plant#943635,periodStart#943636,periodEnd#943637,qty#943638]"];
}
subgraph cluster178 {
isCluster="true";
id="cluster178";
label="WholeStageCodegen (4)\n \nduration: total (min, med, max (stageId: taskId))\n915 ms (1 ms, 8 ms, 162 ms (stage 104833.0: task 346643))";
tooltip="WholeStageCodegen (4)";
179 [id="node179" labelType="html" label="<b>Sort</b><br><br>sort time total (min, med, max (stageId: taskId))<br>0 ms (0 ms, 0 ms, 0 ms (stage 104833.0: task 346641))<br>peak memory total (min, med, max (stageId: taskId))<br>1728.0 KiB (64.0 KiB, 64.0 KiB, 64.0 KiB (stage 104833.0: task 346641))<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104833.0: task 346641))" tooltip="Sort [coalesce(shardId#1006766, ) ASC NULLS FIRST, isnull(shardId#1006766) ASC NULLS FIRST, coalesce(worklistShardItemId#1006767L, 0) ASC NULLS FIRST, isnull(worklistShardItemId#1006767L) ASC NULLS FIRST, coalesce(version#1006768, 0) ASC NULLS FIRST, isnull(version#1006768) ASC NULLS FIRST, coalesce(product#1006769, ) ASC NULLS FIRST, isnull(product#1006769) ASC NULLS FIRST, coalesce(plant#1006770, ) ASC NULLS FIRST, isnull(plant#1006770) ASC NULLS FIRST, knownfloatingpointnormalized(normalizenanandzero(coalesce(qty#1006541, 0.0))) ASC NULLS FIRST, isnull(qty#1006541) ASC NULLS FIRST], false, 0"];
}
180 [id="node180" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>number of partitions: 37<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(coalesce(shardId#1006766, ), isnull(shardId#1006766), coalesce(worklistShardItemId#1006767L, 0), isnull(worklistShardItemId#1006767L), coalesce(version#1006768, 0), isnull(version#1006768), coalesce(product#1006769, ), isnull(product#1006769), coalesce(plant#1006770, ), isnull(plant#1006770), knownfloatingpointnormalized(normalizenanandzero(coalesce(qty#1006541, 0.0))), isnull(qty#1006541), 37), ENSURE_REQUIREMENTS, [plan_id=1632187]"];
181 [id="node181" labelType="html" label="<br><b>Union</b><br><br>" tooltip="Union"];
182 [id="node182" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 0" tooltip="InMemoryTableScan [shardId#1006766, worklistShardItemId#1006767L, version#1006768, product#1006769, plant#1006770, qty#1006541]"];
subgraph cluster183 {
isCluster="true";
id="cluster183";
label="WholeStageCodegen (7)\n \nduration: total (min, med, max (stageId: taskId))\n30 ms (0 ms, 0 ms, 3 ms (stage 104831.0: task 346570))";
tooltip="WholeStageCodegen (7)";
184 [id="node184" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635, cachedQty#1006539 AS qty#1006541, demandChannel#1006534, demandStream#1006535, cachedKpis#1006540 AS kpis#1006542]"];
185 [id="node185" labelType="html" label="<b>SortMergeJoin</b><br><br>number of output rows: 0<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104831.0: task 346570))" tooltip="SortMergeJoin [worklistShardItemId#943632L, shardId#943631], [cachedWorklistShardItemId#1006538L, cachedShardId#1006537], Inner"];
}
subgraph cluster186 {
isCluster="true";
id="cluster186";
label="WholeStageCodegen (4)\n \nduration: total (min, med, max (stageId: taskId))\n1.8 s (0 ms, 1 ms, 151 ms (stage 104831.0: task 346575))";
tooltip="WholeStageCodegen (4)";
187 [id="node187" labelType="html" label="<b>Sort</b><br><br>sort time total (min, med, max (stageId: taskId))<br>0 ms (0 ms, 0 ms, 0 ms (stage 104831.0: task 346570))<br>peak memory total (min, med, max (stageId: taskId))<br>2.3 MiB (64.0 KiB, 64.0 KiB, 64.0 KiB (stage 104831.0: task 346570))<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104831.0: task 346570))" tooltip="Sort [worklistShardItemId#943632L ASC NULLS FIRST, shardId#943631 ASC NULLS FIRST], false, 0"];
}
188 [id="node188" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>number of partitions: 37<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(worklistShardItemId#943632L, shardId#943631, 37), ENSURE_REQUIREMENTS, [plan_id=1632055]"];
subgraph cluster189 {
isCluster="true";
id="cluster189";
label="WholeStageCodegen (3)\n \nduration: total (min, med, max (stageId: taskId))\n64 ms (0 ms, 1 ms, 6 ms (stage 104830.0: task 346495))";
tooltip="WholeStageCodegen (3)";
190 [id="node190" labelType="html" label="<b>HashAggregate</b><br><br>spill size: 0.0 B<br>time in aggregation build total (min, med, max (stageId: taskId))<br>7 ms (0 ms, 0 ms, 2 ms (stage 104830.0: task 346498))<br>peak memory total (min, med, max (stageId: taskId))<br>9.3 MiB (256.0 KiB, 256.0 KiB, 256.0 KiB (stage 104830.0: task 346505))<br>number of output rows: 0<br>number of sort fallback tasks: 0<br>avg hash probes per key: 0" tooltip="HashAggregate(keys=[plant#943635, shardId#943631, version#943633, worklistShardItemId#943632L, product#943634], functions=[])"];
}
191 [id="node191" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>number of partitions: 37<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(plant#943635, shardId#943631, version#943633, worklistShardItemId#943632L, product#943634, 37), ENSURE_REQUIREMENTS, [plan_id=1632051]"];
subgraph cluster192 {
isCluster="true";
id="cluster192";
label="WholeStageCodegen (2)\n \nduration: total (min, med, max (stageId: taskId))\n1.6 s (4 ms, 8 ms, 151 ms (stage 104828.0: task 346447))";
tooltip="WholeStageCodegen (2)";
193 [id="node193" labelType="html" label="<b>HashAggregate</b><br><br>spill size: 0.0 B<br>time in aggregation build total (min, med, max (stageId: taskId))<br>227 ms (3 ms, 6 ms, 9 ms (stage 104828.0: task 346447))<br>peak memory total (min, med, max (stageId: taskId))<br>9.3 MiB (256.0 KiB, 256.0 KiB, 256.0 KiB (stage 104828.0: task 346466))<br>number of output rows: 0<br>number of sort fallback tasks: 0<br>avg hash probes per key: 0" tooltip="HashAggregate(keys=[plant#943635, shardId#943631, version#943633, worklistShardItemId#943632L, product#943634], functions=[])"];
194 [id="node194" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635]"];
195 [id="node195" labelType="html" label="<b>BroadcastHashJoin</b><br><br>number of output rows: 0" tooltip="BroadcastHashJoin [worklistShardItemId#943632L, shardId#943631], [cachedWorklistShardItemId#1006528L, cachedShardId#1006527], Inner, BuildLeft, ((qty#943638 = cachedQty#1006529) OR isnull(qty#943638)), false"];
203 [id="node203" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006521 AS cachedShardId#1006527, worklistShardItemId#1006522L AS cachedWorklistShardItemId#1006528L, qty#1006523 AS cachedQty#1006529]"];
204 [id="node204" labelType="html" label="<b>Filter</b><br><br>number of output rows: 6,177" tooltip="Filter (isnotnull(worklistShardItemId#1006522L) AND isnotnull(shardId#1006521))"];
205 [id="node205" labelType="html" label="<b>Scan ExistingRDD</b><br><br>number of output rows: 6,177" tooltip="Scan ExistingRDD[shardId#1006521,worklistShardItemId#1006522L,qty#1006523,demandChannel#1006524,demandStream#1006525,kpis#1006526]"];
}
196 [id="node196" labelType="html" label="<b>BroadcastExchange</b><br><br>time to broadcast: 0 ms<br>time to build: 1 ms<br>time to collect: 409 ms<br>number of output rows: 51<br>data size: 2.0 MiB" tooltip="BroadcastExchange HashedRelationBroadcastMode(List(input[1, bigint, false], input[0, string, false]),false), [plan_id=1632045]"];
subgraph cluster197 {
isCluster="true";
id="cluster197";
label="WholeStageCodegen (1)\n \nduration: total (min, med, max (stageId: taskId))\n9 ms (0 ms, 0 ms, 3 ms (stage 104736.0: task 346285))";
tooltip="WholeStageCodegen (1)";
198 [id="node198" labelType="html" label="<b>Filter</b><br><br>number of output rows: 51" tooltip="Filter (isnotnull(worklistShardItemId#943632L) AND isnotnull(shardId#943631))"];
}
199 [id="node199" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 51" tooltip="InMemoryTableScan [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635, qty#943638], [isnotnull(worklistShardItemId#943632L), isnotnull(shardId#943631)]"];
200 [id="node200" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(product#943634, plant#943635, 37), REPARTITION_BY_NUM, [plan_id=1631937]"];
subgraph cluster201 {
isCluster="true";
id="cluster201";
label="WholeStageCodegen (1)";
tooltip="WholeStageCodegen (1)";
202 [id="node202" labelType="html" label="<br><b>Scan ExistingRDD</b><br><br>" tooltip="Scan ExistingRDD[shardId#943631,worklistShardItemId#943632L,version#943633,product#943634,plant#943635,periodStart#943636,periodEnd#943637,qty#943638]"];
}
subgraph cluster206 {
isCluster="true";
id="cluster206";
label="WholeStageCodegen (6)\n \nduration: 0 ms";
tooltip="WholeStageCodegen (6)";
207 [id="node207" labelType="html" label="<b>Sort</b><br><br>sort time: 0 ms<br>peak memory: 0.0 B<br>spill size: 0.0 B" tooltip="Sort [cachedWorklistShardItemId#1006538L ASC NULLS FIRST, cachedShardId#1006537 ASC NULLS FIRST], false, 0"];
}
208 [id="node208" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 6,177<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read total (min, med, max (stageId: taskId))<br>300.0 KiB (3.3 KiB, 7.3 KiB, 17.7 KiB (stage 104831.0: task 346579))<br>merged fetch fallback count: 0<br>local blocks read: 379<br>remote merged chunks fetched: 0<br>remote blocks read: 785<br>data size total (min, med, max (stageId: taskId))<br>3.3 MiB (88.7 KiB, 92.1 KiB, 95.9 KiB (stage 104829.0: task 346405))<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time total (min, med, max (stageId: taskId))<br>75 ms (1 ms, 1 ms, 2 ms (stage 104829.0: task 346451))<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read total (min, med, max (stageId: taskId))<br>610.9 KiB (6.2 KiB, 17.5 KiB, 27.3 KiB (stage 104831.0: task 346589))<br>number of partitions: 37<br>remote reqs duration total (min, med, max (stageId: taskId))<br>152 ms (0 ms, 4 ms, 13 ms (stage 104831.0: task 346576))<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written total (min, med, max (stageId: taskId))<br>1048.5 KiB (25.8 KiB, 28.2 KiB, 30.6 KiB (stage 104829.0: task 346450))" tooltip="Exchange hashpartitioning(cachedWorklistShardItemId#1006538L, cachedShardId#1006537, 37), ENSURE_REQUIREMENTS, [plan_id=1632061]"];
subgraph cluster209 {
isCluster="true";
id="cluster209";
label="WholeStageCodegen (5)\n \nduration: total (min, med, max (stageId: taskId))\n1.8 s (7 ms, 13 ms, 107 ms (stage 104829.0: task 346387))";
tooltip="WholeStageCodegen (5)";
210 [id="node210" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006531 AS cachedShardId#1006537, worklistShardItemId#1006532L AS cachedWorklistShardItemId#1006538L, qty#1006533 AS cachedQty#1006539, demandChannel#1006534, demandStream#1006535, kpis#1006536 AS cachedKpis#1006540]"];
211 [id="node211" labelType="html" label="<b>Filter</b><br><br>number of output rows: 6,177" tooltip="Filter (isnotnull(worklistShardItemId#1006532L) AND isnotnull(shardId#1006531))"];
212 [id="node212" labelType="html" label="<b>Scan ExistingRDD</b><br><br>number of output rows: 6,177" tooltip="Scan ExistingRDD[shardId#1006531,worklistShardItemId#1006532L,qty#1006533,demandChannel#1006534,demandStream#1006535,kpis#1006536]"];
}
subgraph cluster213 {
isCluster="true";
id="cluster213";
label="WholeStageCodegen (3)\n \nduration: total (min, med, max (stageId: taskId))\n501 ms (4 ms, 8 ms, 48 ms (stage 104831.0: task 346537))";
tooltip="WholeStageCodegen (3)";
214 [id="node214" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006748, worklistShardItemId#1006749L, version#1006750, product#1006751, plant#1006752, qty#1006755]"];
215 [id="node215" labelType="html" label="<b>BroadcastHashJoin</b><br><br>number of output rows: 0" tooltip="BroadcastHashJoin [worklistShardItemId#1006749L, shardId#1006748], [cachedWorklistShardItemId#1006763L, cachedShardId#1006762], Inner, BuildLeft, false"];
223 [id="node223" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006756 AS cachedShardId#1006762, worklistShardItemId#1006757L AS cachedWorklistShardItemId#1006763L]"];
224 [id="node224" labelType="html" label="<b>Filter</b><br><br>number of output rows: 6,177" tooltip="Filter (isnotnull(worklistShardItemId#1006757L) AND isnotnull(shardId#1006756))"];
225 [id="node225" labelType="html" label="<b>Scan ExistingRDD</b><br><br>number of output rows: 6,177" tooltip="Scan ExistingRDD[shardId#1006756,worklistShardItemId#1006757L,qty#1006758,demandChannel#1006759,demandStream#1006760,kpis#1006761]"];
}
216 [id="node216" labelType="html" label="<b>BroadcastExchange</b><br><br>time to broadcast: 0 ms<br>time to build: 0 ms<br>time to collect: 398 ms<br>number of output rows: 0<br>data size: 0.0 B" tooltip="BroadcastExchange HashedRelationBroadcastMode(List(input[1, bigint, false], input[0, string, false]),false), [plan_id=1632181]"];
subgraph cluster217 {
isCluster="true";
id="cluster217";
label="WholeStageCodegen (2)\n \nduration: total (min, med, max (stageId: taskId))\n12 ms (0 ms, 0 ms, 3 ms (stage 104735.0: task 346356))";
tooltip="WholeStageCodegen (2)";
218 [id="node218" labelType="html" label="<b>Filter</b><br><br>number of output rows: 0" tooltip="Filter ((isnull(qty#1006755) AND isnotnull(worklistShardItemId#1006749L)) AND isnotnull(shardId#1006748))"];
}
219 [id="node219" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 0" tooltip="InMemoryTableScan [shardId#1006748, worklistShardItemId#1006749L, version#1006750, product#1006751, plant#1006752, qty#1006755], [isnull(qty#1006755), isnotnull(worklistShardItemId#1006749L), isnotnull(shardId#1006748)]"];
220 [id="node220" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(product#943634, plant#943635, 37), REPARTITION_BY_NUM, [plan_id=1631937]"];
subgraph cluster221 {
isCluster="true";
id="cluster221";
label="WholeStageCodegen (1)";
tooltip="WholeStageCodegen (1)";
222 [id="node222" labelType="html" label="<br><b>Scan ExistingRDD</b><br><br>" tooltip="Scan ExistingRDD[shardId#943631,worklistShardItemId#943632L,version#943633,product#943634,plant#943635,periodStart#943636,periodEnd#943637,qty#943638]"];
}
subgraph cluster226 {
isCluster="true";
id="cluster226";
label="WholeStageCodegen (6)\n \nduration: total (min, med, max (stageId: taskId))\n2.0 s (0 ms, 0 ms, 230 ms (stage 104833.0: task 346611))";
tooltip="WholeStageCodegen (6)";
227 [id="node227" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006779, worklistShardItemId#1006780L, version#1006781, product#1006782, plant#1006783, qty#1006807, demandChannel#1006800, demandStream#1006801, kpis#1006808, false AS isNewlyCalculated#1006778]"];
}
228 [id="node228" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 0" tooltip="InMemoryTableScan [demandChannel#1006800, demandStream#1006801, kpis#1006808, plant#1006783, product#1006782, qty#1006807, shardId#1006779, version#1006781, worklistShardItemId#1006780L]"];
subgraph cluster229 {
isCluster="true";
id="cluster229";
label="WholeStageCodegen (7)\n \nduration: total (min, med, max (stageId: taskId))\n30 ms (0 ms, 0 ms, 3 ms (stage 104831.0: task 346570))";
tooltip="WholeStageCodegen (7)";
230 [id="node230" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635, cachedQty#1006539 AS qty#1006541, demandChannel#1006534, demandStream#1006535, cachedKpis#1006540 AS kpis#1006542]"];
231 [id="node231" labelType="html" label="<b>SortMergeJoin</b><br><br>number of output rows: 0<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104831.0: task 346570))" tooltip="SortMergeJoin [worklistShardItemId#943632L, shardId#943631], [cachedWorklistShardItemId#1006538L, cachedShardId#1006537], Inner"];
}
subgraph cluster232 {
isCluster="true";
id="cluster232";
label="WholeStageCodegen (4)\n \nduration: total (min, med, max (stageId: taskId))\n1.8 s (0 ms, 1 ms, 151 ms (stage 104831.0: task 346575))";
tooltip="WholeStageCodegen (4)";
233 [id="node233" labelType="html" label="<b>Sort</b><br><br>sort time total (min, med, max (stageId: taskId))<br>0 ms (0 ms, 0 ms, 0 ms (stage 104831.0: task 346570))<br>peak memory total (min, med, max (stageId: taskId))<br>2.3 MiB (64.0 KiB, 64.0 KiB, 64.0 KiB (stage 104831.0: task 346570))<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104831.0: task 346570))" tooltip="Sort [worklistShardItemId#943632L ASC NULLS FIRST, shardId#943631 ASC NULLS FIRST], false, 0"];
}
234 [id="node234" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>number of partitions: 37<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(worklistShardItemId#943632L, shardId#943631, 37), ENSURE_REQUIREMENTS, [plan_id=1632055]"];
subgraph cluster235 {
isCluster="true";
id="cluster235";
label="WholeStageCodegen (3)\n \nduration: total (min, med, max (stageId: taskId))\n64 ms (0 ms, 1 ms, 6 ms (stage 104830.0: task 346495))";
tooltip="WholeStageCodegen (3)";
236 [id="node236" labelType="html" label="<b>HashAggregate</b><br><br>spill size: 0.0 B<br>time in aggregation build total (min, med, max (stageId: taskId))<br>7 ms (0 ms, 0 ms, 2 ms (stage 104830.0: task 346498))<br>peak memory total (min, med, max (stageId: taskId))<br>9.3 MiB (256.0 KiB, 256.0 KiB, 256.0 KiB (stage 104830.0: task 346505))<br>number of output rows: 0<br>number of sort fallback tasks: 0<br>avg hash probes per key: 0" tooltip="HashAggregate(keys=[plant#943635, shardId#943631, version#943633, worklistShardItemId#943632L, product#943634], functions=[])"];
}
237 [id="node237" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>number of partitions: 37<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(plant#943635, shardId#943631, version#943633, worklistShardItemId#943632L, product#943634, 37), ENSURE_REQUIREMENTS, [plan_id=1632051]"];
subgraph cluster238 {
isCluster="true";
id="cluster238";
label="WholeStageCodegen (2)\n \nduration: total (min, med, max (stageId: taskId))\n1.6 s (4 ms, 8 ms, 151 ms (stage 104828.0: task 346447))";
tooltip="WholeStageCodegen (2)";
239 [id="node239" labelType="html" label="<b>HashAggregate</b><br><br>spill size: 0.0 B<br>time in aggregation build total (min, med, max (stageId: taskId))<br>227 ms (3 ms, 6 ms, 9 ms (stage 104828.0: task 346447))<br>peak memory total (min, med, max (stageId: taskId))<br>9.3 MiB (256.0 KiB, 256.0 KiB, 256.0 KiB (stage 104828.0: task 346466))<br>number of output rows: 0<br>number of sort fallback tasks: 0<br>avg hash probes per key: 0" tooltip="HashAggregate(keys=[plant#943635, shardId#943631, version#943633, worklistShardItemId#943632L, product#943634], functions=[])"];
240 [id="node240" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635]"];
241 [id="node241" labelType="html" label="<b>BroadcastHashJoin</b><br><br>number of output rows: 0" tooltip="BroadcastHashJoin [worklistShardItemId#943632L, shardId#943631], [cachedWorklistShardItemId#1006528L, cachedShardId#1006527], Inner, BuildLeft, ((qty#943638 = cachedQty#1006529) OR isnull(qty#943638)), false"];
249 [id="node249" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006521 AS cachedShardId#1006527, worklistShardItemId#1006522L AS cachedWorklistShardItemId#1006528L, qty#1006523 AS cachedQty#1006529]"];
250 [id="node250" labelType="html" label="<b>Filter</b><br><br>number of output rows: 6,177" tooltip="Filter (isnotnull(worklistShardItemId#1006522L) AND isnotnull(shardId#1006521))"];
251 [id="node251" labelType="html" label="<b>Scan ExistingRDD</b><br><br>number of output rows: 6,177" tooltip="Scan ExistingRDD[shardId#1006521,worklistShardItemId#1006522L,qty#1006523,demandChannel#1006524,demandStream#1006525,kpis#1006526]"];
}
242 [id="node242" labelType="html" label="<b>BroadcastExchange</b><br><br>time to broadcast: 0 ms<br>time to build: 1 ms<br>time to collect: 409 ms<br>number of output rows: 51<br>data size: 2.0 MiB" tooltip="BroadcastExchange HashedRelationBroadcastMode(List(input[1, bigint, false], input[0, string, false]),false), [plan_id=1632045]"];
subgraph cluster243 {
isCluster="true";
id="cluster243";
label="WholeStageCodegen (1)\n \nduration: total (min, med, max (stageId: taskId))\n9 ms (0 ms, 0 ms, 3 ms (stage 104736.0: task 346285))";
tooltip="WholeStageCodegen (1)";
244 [id="node244" labelType="html" label="<b>Filter</b><br><br>number of output rows: 51" tooltip="Filter (isnotnull(worklistShardItemId#943632L) AND isnotnull(shardId#943631))"];
}
245 [id="node245" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 51" tooltip="InMemoryTableScan [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635, qty#943638], [isnotnull(worklistShardItemId#943632L), isnotnull(shardId#943631)]"];
246 [id="node246" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(product#943634, plant#943635, 37), REPARTITION_BY_NUM, [plan_id=1631937]"];
subgraph cluster247 {
isCluster="true";
id="cluster247";
label="WholeStageCodegen (1)";
tooltip="WholeStageCodegen (1)";
248 [id="node248" labelType="html" label="<br><b>Scan ExistingRDD</b><br><br>" tooltip="Scan ExistingRDD[shardId#943631,worklistShardItemId#943632L,version#943633,product#943634,plant#943635,periodStart#943636,periodEnd#943637,qty#943638]"];
}
subgraph cluster252 {
isCluster="true";
id="cluster252";
label="WholeStageCodegen (6)\n \nduration: 0 ms";
tooltip="WholeStageCodegen (6)";
253 [id="node253" labelType="html" label="<b>Sort</b><br><br>sort time: 0 ms<br>peak memory: 0.0 B<br>spill size: 0.0 B" tooltip="Sort [cachedWorklistShardItemId#1006538L ASC NULLS FIRST, cachedShardId#1006537 ASC NULLS FIRST], false, 0"];
}
254 [id="node254" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 6,177<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read total (min, med, max (stageId: taskId))<br>300.0 KiB (3.3 KiB, 7.3 KiB, 17.7 KiB (stage 104831.0: task 346579))<br>merged fetch fallback count: 0<br>local blocks read: 379<br>remote merged chunks fetched: 0<br>remote blocks read: 785<br>data size total (min, med, max (stageId: taskId))<br>3.3 MiB (88.7 KiB, 92.1 KiB, 95.9 KiB (stage 104829.0: task 346405))<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time total (min, med, max (stageId: taskId))<br>75 ms (1 ms, 1 ms, 2 ms (stage 104829.0: task 346451))<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read total (min, med, max (stageId: taskId))<br>610.9 KiB (6.2 KiB, 17.5 KiB, 27.3 KiB (stage 104831.0: task 346589))<br>number of partitions: 37<br>remote reqs duration total (min, med, max (stageId: taskId))<br>152 ms (0 ms, 4 ms, 13 ms (stage 104831.0: task 346576))<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written total (min, med, max (stageId: taskId))<br>1048.5 KiB (25.8 KiB, 28.2 KiB, 30.6 KiB (stage 104829.0: task 346450))" tooltip="Exchange hashpartitioning(cachedWorklistShardItemId#1006538L, cachedShardId#1006537, 37), ENSURE_REQUIREMENTS, [plan_id=1632061]"];
subgraph cluster255 {
isCluster="true";
id="cluster255";
label="WholeStageCodegen (5)\n \nduration: total (min, med, max (stageId: taskId))\n1.8 s (7 ms, 13 ms, 107 ms (stage 104829.0: task 346387))";
tooltip="WholeStageCodegen (5)";
256 [id="node256" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006531 AS cachedShardId#1006537, worklistShardItemId#1006532L AS cachedWorklistShardItemId#1006538L, qty#1006533 AS cachedQty#1006539, demandChannel#1006534, demandStream#1006535, kpis#1006536 AS cachedKpis#1006540]"];
257 [id="node257" labelType="html" label="<b>Filter</b><br><br>number of output rows: 6,177" tooltip="Filter (isnotnull(worklistShardItemId#1006532L) AND isnotnull(shardId#1006531))"];
258 [id="node258" labelType="html" label="<b>Scan ExistingRDD</b><br><br>number of output rows: 6,177" tooltip="Scan ExistingRDD[shardId#1006531,worklistShardItemId#1006532L,qty#1006533,demandChannel#1006534,demandStream#1006535,kpis#1006536]"];
}
259 [id="node259" labelType="html" label="<b>BroadcastExchange</b><br><br>time to broadcast: 0 ms<br>time to build: 0 ms<br>time to collect: 2.2 s<br>number of output rows: 1<br>data size: 392.0 B" tooltip="BroadcastExchange IdentityBroadcastMode, [plan_id=1632637]"];
subgraph cluster260 {
isCluster="true";
id="cluster260";
label="WholeStageCodegen (16)\n \nduration: total (min, med, max (stageId: taskId))\n148 ms (0 ms, 0 ms, 14 ms (stage 104834.0: task 346680))";
tooltip="WholeStageCodegen (16)";
261 [id="node261" labelType="html" label="<b>HashAggregate</b><br><br>spill size: 0.0 B<br>time in aggregation build total (min, med, max (stageId: taskId))<br>27 ms (0 ms, 0 ms, 4 ms (stage 104834.0: task 346680))<br>peak memory total (min, med, max (stageId: taskId))<br>9.3 MiB (256.0 KiB, 256.0 KiB, 256.0 KiB (stage 104834.0: task 346678))<br>number of output rows: 1<br>number of sort fallback tasks: 0<br>avg hash probes per key: 0" tooltip="HashAggregate(keys=[1#1008561], functions=[])"];
}
262 [id="node262" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 27<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 27<br>local bytes read: 1125.0 B<br>merged fetch fallback count: 0<br>local blocks read: 15<br>remote merged chunks fetched: 0<br>remote blocks read: 12<br>data size total (min, med, max (stageId: taskId))<br>432.0 B (16.0 B, 16.0 B, 16.0 B (stage 104833.0: task 346641))<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time total (min, med, max (stageId: taskId))<br>13 ms (0 ms, 0 ms, 0 ms (stage 104833.0: task 346664))<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 900.0 B<br>number of partitions: 37<br>remote reqs duration: 1 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written total (min, med, max (stageId: taskId))<br>2025.0 B (75.0 B, 75.0 B, 75.0 B (stage 104833.0: task 346641))" tooltip="Exchange hashpartitioning(1#1008561, 37), ENSURE_REQUIREMENTS, [plan_id=1632633]"];
subgraph cluster263 {
isCluster="true";
id="cluster263";
label="WholeStageCodegen (15)\n \nduration: total (min, med, max (stageId: taskId))\n842 ms (0 ms, 1 ms, 92 ms (stage 104833.0: task 346616))";
tooltip="WholeStageCodegen (15)";
264 [id="node264" labelType="html" label="<b>HashAggregate</b><br><br>spill size: 0.0 B<br>time in aggregation build total (min, med, max (stageId: taskId))<br>24 ms (0 ms, 0 ms, 3 ms (stage 104833.0: task 346613))<br>peak memory total (min, med, max (stageId: taskId))<br>18.5 MiB (256.0 KiB, 256.0 KiB, 256.0 KiB (stage 104833.0: task 346612))<br>number of output rows: 27<br>number of sort fallback tasks: 0<br>avg hash probes per key: 0" tooltip="HashAggregate(keys=[1 AS 1#1008561], functions=[])"];
265 [id="node265" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project"];
266 [id="node266" labelType="html" label="<b>Filter</b><br><br>number of output rows: 51" tooltip="Filter isNewlyCalculated#1007722: boolean"];
}
267 [id="node267" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 51" tooltip="InMemoryTableScan [isNewlyCalculated#1007722], [isNewlyCalculated#1007722]"];
268 [id="node268" labelType="html" label="<br><b>Union</b><br><br>" tooltip="Union"];
subgraph cluster269 {
isCluster="true";
id="cluster269";
label="WholeStageCodegen (5)\n \nduration: total (min, med, max (stageId: taskId))\n112 ms (0 ms, 0 ms, 12 ms (stage 104833.0: task 346641))";
tooltip="WholeStageCodegen (5)";
270 [id="node270" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635, qty#943638, null AS demandChannel#1006774, null AS demandStream#1006775, [] AS kpis#1006809, true AS isNewlyCalculated#1006777]"];
271 [id="node271" labelType="html" label="<b>SortMergeJoin</b><br><br>number of output rows: 51<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104833.0: task 346641))" tooltip="SortMergeJoin [coalesce(shardId#943631, ), isnull(shardId#943631), coalesce(worklistShardItemId#943632L, 0), isnull(worklistShardItemId#943632L), coalesce(version#943633, 0), isnull(version#943633), coalesce(product#943634, ), isnull(product#943634), coalesce(plant#943635, ), isnull(plant#943635), knownfloatingpointnormalized(normalizenanandzero(coalesce(qty#943638, 0.0))), isnull(qty#943638)], [coalesce(shardId#1006766, ), isnull(shardId#1006766), coalesce(worklistShardItemId#1006767L, 0), isnull(worklistShardItemId#1006767L), coalesce(version#1006768, 0), isnull(version#1006768), coalesce(product#1006769, ), isnull(product#1006769), coalesce(plant#1006770, ), isnull(plant#1006770), knownfloatingpointnormalized(normalizenanandzero(coalesce(qty#1006541, 0.0))), isnull(qty#1006541)], LeftAnti"];
}
subgraph cluster272 {
isCluster="true";
id="cluster272";
label="WholeStageCodegen (1)\n \nduration: total (min, med, max (stageId: taskId))\n3.2 s (3 ms, 8 ms, 316 ms (stage 104833.0: task 346645))";
tooltip="WholeStageCodegen (1)";
273 [id="node273" labelType="html" label="<b>Sort</b><br><br>sort time total (min, med, max (stageId: taskId))<br>1 ms (0 ms, 0 ms, 1 ms (stage 104833.0: task 346644))<br>peak memory total (min, med, max (stageId: taskId))<br>56.3 MiB (64.0 KiB, 2.1 MiB, 2.1 MiB (stage 104833.0: task 346641))<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104833.0: task 346641))" tooltip="Sort [coalesce(shardId#943631, ) ASC NULLS FIRST, isnull(shardId#943631) ASC NULLS FIRST, coalesce(worklistShardItemId#943632L, 0) ASC NULLS FIRST, isnull(worklistShardItemId#943632L) ASC NULLS FIRST, coalesce(version#943633, 0) ASC NULLS FIRST, isnull(version#943633) ASC NULLS FIRST, coalesce(product#943634, ) ASC NULLS FIRST, isnull(product#943634) ASC NULLS FIRST, coalesce(plant#943635, ) ASC NULLS FIRST, isnull(plant#943635) ASC NULLS FIRST, knownfloatingpointnormalized(normalizenanandzero(coalesce(qty#943638, 0.0))) ASC NULLS FIRST, isnull(qty#943638) ASC NULLS FIRST], false, 0"];
}
274 [id="node274" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 51<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 51<br>local bytes read total (min, med, max (stageId: taskId))<br>6.3 KiB (176.0 B, 177.0 B, 530.0 B (stage 104833.0: task 346652))<br>merged fetch fallback count: 0<br>local blocks read: 36<br>remote merged chunks fetched: 0<br>remote blocks read: 12<br>data size total (min, med, max (stageId: taskId))<br>6.8 KiB (136.0 B, 272.0 B, 680.0 B (stage 104832.0: task 346410))<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time total (min, med, max (stageId: taskId))<br>10 ms (0 ms, 0 ms, 0 ms (stage 104832.0: task 346452))<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time total (min, med, max (stageId: taskId))<br>0 ms (0 ms, 0 ms, 0 ms (stage 104833.0: task 346641))<br>remote bytes read total (min, med, max (stageId: taskId))<br>2.1 KiB (176.0 B, 177.0 B, 354.0 B (stage 104833.0: task 346662))<br>number of partitions: 37<br>remote reqs duration total (min, med, max (stageId: taskId))<br>2 ms (0 ms, 0 ms, 2 ms (stage 104833.0: task 346643))<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written total (min, med, max (stageId: taskId))<br>8.4 KiB (177.0 B, 358.0 B, 721.0 B (stage 104832.0: task 346410))" tooltip="Exchange hashpartitioning(coalesce(shardId#943631, ), isnull(shardId#943631), coalesce(worklistShardItemId#943632L, 0), isnull(worklistShardItemId#943632L), coalesce(version#943633, 0), isnull(version#943633), coalesce(product#943634, ), isnull(product#943634), coalesce(plant#943635, ), isnull(plant#943635), knownfloatingpointnormalized(normalizenanandzero(coalesce(qty#943638, 0.0))), isnull(qty#943638), 37), ENSURE_REQUIREMENTS, [plan_id=1632167]"];
275 [id="node275" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 51" tooltip="InMemoryTableScan [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635, qty#943638]"];
276 [id="node276" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(product#943634, plant#943635, 37), REPARTITION_BY_NUM, [plan_id=1631937]"];
subgraph cluster277 {
isCluster="true";
id="cluster277";
label="WholeStageCodegen (1)";
tooltip="WholeStageCodegen (1)";
278 [id="node278" labelType="html" label="<br><b>Scan ExistingRDD</b><br><br>" tooltip="Scan ExistingRDD[shardId#943631,worklistShardItemId#943632L,version#943633,product#943634,plant#943635,periodStart#943636,periodEnd#943637,qty#943638]"];
}
subgraph cluster279 {
isCluster="true";
id="cluster279";
label="WholeStageCodegen (4)\n \nduration: total (min, med, max (stageId: taskId))\n915 ms (1 ms, 8 ms, 162 ms (stage 104833.0: task 346643))";
tooltip="WholeStageCodegen (4)";
280 [id="node280" labelType="html" label="<b>Sort</b><br><br>sort time total (min, med, max (stageId: taskId))<br>0 ms (0 ms, 0 ms, 0 ms (stage 104833.0: task 346641))<br>peak memory total (min, med, max (stageId: taskId))<br>1728.0 KiB (64.0 KiB, 64.0 KiB, 64.0 KiB (stage 104833.0: task 346641))<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104833.0: task 346641))" tooltip="Sort [coalesce(shardId#1006766, ) ASC NULLS FIRST, isnull(shardId#1006766) ASC NULLS FIRST, coalesce(worklistShardItemId#1006767L, 0) ASC NULLS FIRST, isnull(worklistShardItemId#1006767L) ASC NULLS FIRST, coalesce(version#1006768, 0) ASC NULLS FIRST, isnull(version#1006768) ASC NULLS FIRST, coalesce(product#1006769, ) ASC NULLS FIRST, isnull(product#1006769) ASC NULLS FIRST, coalesce(plant#1006770, ) ASC NULLS FIRST, isnull(plant#1006770) ASC NULLS FIRST, knownfloatingpointnormalized(normalizenanandzero(coalesce(qty#1006541, 0.0))) ASC NULLS FIRST, isnull(qty#1006541) ASC NULLS FIRST], false, 0"];
}
281 [id="node281" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>number of partitions: 37<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(coalesce(shardId#1006766, ), isnull(shardId#1006766), coalesce(worklistShardItemId#1006767L, 0), isnull(worklistShardItemId#1006767L), coalesce(version#1006768, 0), isnull(version#1006768), coalesce(product#1006769, ), isnull(product#1006769), coalesce(plant#1006770, ), isnull(plant#1006770), knownfloatingpointnormalized(normalizenanandzero(coalesce(qty#1006541, 0.0))), isnull(qty#1006541), 37), ENSURE_REQUIREMENTS, [plan_id=1632187]"];
282 [id="node282" labelType="html" label="<br><b>Union</b><br><br>" tooltip="Union"];
283 [id="node283" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 0" tooltip="InMemoryTableScan [shardId#1006766, worklistShardItemId#1006767L, version#1006768, product#1006769, plant#1006770, qty#1006541]"];
subgraph cluster284 {
isCluster="true";
id="cluster284";
label="WholeStageCodegen (7)\n \nduration: total (min, med, max (stageId: taskId))\n30 ms (0 ms, 0 ms, 3 ms (stage 104831.0: task 346570))";
tooltip="WholeStageCodegen (7)";
285 [id="node285" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635, cachedQty#1006539 AS qty#1006541, demandChannel#1006534, demandStream#1006535, cachedKpis#1006540 AS kpis#1006542]"];
286 [id="node286" labelType="html" label="<b>SortMergeJoin</b><br><br>number of output rows: 0<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104831.0: task 346570))" tooltip="SortMergeJoin [worklistShardItemId#943632L, shardId#943631], [cachedWorklistShardItemId#1006538L, cachedShardId#1006537], Inner"];
}
subgraph cluster287 {
isCluster="true";
id="cluster287";
label="WholeStageCodegen (4)\n \nduration: total (min, med, max (stageId: taskId))\n1.8 s (0 ms, 1 ms, 151 ms (stage 104831.0: task 346575))";
tooltip="WholeStageCodegen (4)";
288 [id="node288" labelType="html" label="<b>Sort</b><br><br>sort time total (min, med, max (stageId: taskId))<br>0 ms (0 ms, 0 ms, 0 ms (stage 104831.0: task 346570))<br>peak memory total (min, med, max (stageId: taskId))<br>2.3 MiB (64.0 KiB, 64.0 KiB, 64.0 KiB (stage 104831.0: task 346570))<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104831.0: task 346570))" tooltip="Sort [worklistShardItemId#943632L ASC NULLS FIRST, shardId#943631 ASC NULLS FIRST], false, 0"];
}
289 [id="node289" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>number of partitions: 37<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(worklistShardItemId#943632L, shardId#943631, 37), ENSURE_REQUIREMENTS, [plan_id=1632055]"];
subgraph cluster290 {
isCluster="true";
id="cluster290";
label="WholeStageCodegen (3)\n \nduration: total (min, med, max (stageId: taskId))\n64 ms (0 ms, 1 ms, 6 ms (stage 104830.0: task 346495))";
tooltip="WholeStageCodegen (3)";
291 [id="node291" labelType="html" label="<b>HashAggregate</b><br><br>spill size: 0.0 B<br>time in aggregation build total (min, med, max (stageId: taskId))<br>7 ms (0 ms, 0 ms, 2 ms (stage 104830.0: task 346498))<br>peak memory total (min, med, max (stageId: taskId))<br>9.3 MiB (256.0 KiB, 256.0 KiB, 256.0 KiB (stage 104830.0: task 346505))<br>number of output rows: 0<br>number of sort fallback tasks: 0<br>avg hash probes per key: 0" tooltip="HashAggregate(keys=[plant#943635, shardId#943631, version#943633, worklistShardItemId#943632L, product#943634], functions=[])"];
}
292 [id="node292" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>number of partitions: 37<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(plant#943635, shardId#943631, version#943633, worklistShardItemId#943632L, product#943634, 37), ENSURE_REQUIREMENTS, [plan_id=1632051]"];
subgraph cluster293 {
isCluster="true";
id="cluster293";
label="WholeStageCodegen (2)\n \nduration: total (min, med, max (stageId: taskId))\n1.6 s (4 ms, 8 ms, 151 ms (stage 104828.0: task 346447))";
tooltip="WholeStageCodegen (2)";
294 [id="node294" labelType="html" label="<b>HashAggregate</b><br><br>spill size: 0.0 B<br>time in aggregation build total (min, med, max (stageId: taskId))<br>227 ms (3 ms, 6 ms, 9 ms (stage 104828.0: task 346447))<br>peak memory total (min, med, max (stageId: taskId))<br>9.3 MiB (256.0 KiB, 256.0 KiB, 256.0 KiB (stage 104828.0: task 346466))<br>number of output rows: 0<br>number of sort fallback tasks: 0<br>avg hash probes per key: 0" tooltip="HashAggregate(keys=[plant#943635, shardId#943631, version#943633, worklistShardItemId#943632L, product#943634], functions=[])"];
295 [id="node295" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635]"];
296 [id="node296" labelType="html" label="<b>BroadcastHashJoin</b><br><br>number of output rows: 0" tooltip="BroadcastHashJoin [worklistShardItemId#943632L, shardId#943631], [cachedWorklistShardItemId#1006528L, cachedShardId#1006527], Inner, BuildLeft, ((qty#943638 = cachedQty#1006529) OR isnull(qty#943638)), false"];
304 [id="node304" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006521 AS cachedShardId#1006527, worklistShardItemId#1006522L AS cachedWorklistShardItemId#1006528L, qty#1006523 AS cachedQty#1006529]"];
305 [id="node305" labelType="html" label="<b>Filter</b><br><br>number of output rows: 6,177" tooltip="Filter (isnotnull(worklistShardItemId#1006522L) AND isnotnull(shardId#1006521))"];
306 [id="node306" labelType="html" label="<b>Scan ExistingRDD</b><br><br>number of output rows: 6,177" tooltip="Scan ExistingRDD[shardId#1006521,worklistShardItemId#1006522L,qty#1006523,demandChannel#1006524,demandStream#1006525,kpis#1006526]"];
}
297 [id="node297" labelType="html" label="<b>BroadcastExchange</b><br><br>time to broadcast: 0 ms<br>time to build: 1 ms<br>time to collect: 409 ms<br>number of output rows: 51<br>data size: 2.0 MiB" tooltip="BroadcastExchange HashedRelationBroadcastMode(List(input[1, bigint, false], input[0, string, false]),false), [plan_id=1632045]"];
subgraph cluster298 {
isCluster="true";
id="cluster298";
label="WholeStageCodegen (1)\n \nduration: total (min, med, max (stageId: taskId))\n9 ms (0 ms, 0 ms, 3 ms (stage 104736.0: task 346285))";
tooltip="WholeStageCodegen (1)";
299 [id="node299" labelType="html" label="<b>Filter</b><br><br>number of output rows: 51" tooltip="Filter (isnotnull(worklistShardItemId#943632L) AND isnotnull(shardId#943631))"];
}
300 [id="node300" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 51" tooltip="InMemoryTableScan [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635, qty#943638], [isnotnull(worklistShardItemId#943632L), isnotnull(shardId#943631)]"];
301 [id="node301" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(product#943634, plant#943635, 37), REPARTITION_BY_NUM, [plan_id=1631937]"];
subgraph cluster302 {
isCluster="true";
id="cluster302";
label="WholeStageCodegen (1)";
tooltip="WholeStageCodegen (1)";
303 [id="node303" labelType="html" label="<br><b>Scan ExistingRDD</b><br><br>" tooltip="Scan ExistingRDD[shardId#943631,worklistShardItemId#943632L,version#943633,product#943634,plant#943635,periodStart#943636,periodEnd#943637,qty#943638]"];
}
subgraph cluster307 {
isCluster="true";
id="cluster307";
label="WholeStageCodegen (6)\n \nduration: 0 ms";
tooltip="WholeStageCodegen (6)";
308 [id="node308" labelType="html" label="<b>Sort</b><br><br>sort time: 0 ms<br>peak memory: 0.0 B<br>spill size: 0.0 B" tooltip="Sort [cachedWorklistShardItemId#1006538L ASC NULLS FIRST, cachedShardId#1006537 ASC NULLS FIRST], false, 0"];
}
309 [id="node309" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 6,177<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read total (min, med, max (stageId: taskId))<br>300.0 KiB (3.3 KiB, 7.3 KiB, 17.7 KiB (stage 104831.0: task 346579))<br>merged fetch fallback count: 0<br>local blocks read: 379<br>remote merged chunks fetched: 0<br>remote blocks read: 785<br>data size total (min, med, max (stageId: taskId))<br>3.3 MiB (88.7 KiB, 92.1 KiB, 95.9 KiB (stage 104829.0: task 346405))<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time total (min, med, max (stageId: taskId))<br>75 ms (1 ms, 1 ms, 2 ms (stage 104829.0: task 346451))<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read total (min, med, max (stageId: taskId))<br>610.9 KiB (6.2 KiB, 17.5 KiB, 27.3 KiB (stage 104831.0: task 346589))<br>number of partitions: 37<br>remote reqs duration total (min, med, max (stageId: taskId))<br>152 ms (0 ms, 4 ms, 13 ms (stage 104831.0: task 346576))<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written total (min, med, max (stageId: taskId))<br>1048.5 KiB (25.8 KiB, 28.2 KiB, 30.6 KiB (stage 104829.0: task 346450))" tooltip="Exchange hashpartitioning(cachedWorklistShardItemId#1006538L, cachedShardId#1006537, 37), ENSURE_REQUIREMENTS, [plan_id=1632061]"];
subgraph cluster310 {
isCluster="true";
id="cluster310";
label="WholeStageCodegen (5)\n \nduration: total (min, med, max (stageId: taskId))\n1.8 s (7 ms, 13 ms, 107 ms (stage 104829.0: task 346387))";
tooltip="WholeStageCodegen (5)";
311 [id="node311" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006531 AS cachedShardId#1006537, worklistShardItemId#1006532L AS cachedWorklistShardItemId#1006538L, qty#1006533 AS cachedQty#1006539, demandChannel#1006534, demandStream#1006535, kpis#1006536 AS cachedKpis#1006540]"];
312 [id="node312" labelType="html" label="<b>Filter</b><br><br>number of output rows: 6,177" tooltip="Filter (isnotnull(worklistShardItemId#1006532L) AND isnotnull(shardId#1006531))"];
313 [id="node313" labelType="html" label="<b>Scan ExistingRDD</b><br><br>number of output rows: 6,177" tooltip="Scan ExistingRDD[shardId#1006531,worklistShardItemId#1006532L,qty#1006533,demandChannel#1006534,demandStream#1006535,kpis#1006536]"];
}
subgraph cluster314 {
isCluster="true";
id="cluster314";
label="WholeStageCodegen (3)\n \nduration: total (min, med, max (stageId: taskId))\n501 ms (4 ms, 8 ms, 48 ms (stage 104831.0: task 346537))";
tooltip="WholeStageCodegen (3)";
315 [id="node315" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006748, worklistShardItemId#1006749L, version#1006750, product#1006751, plant#1006752, qty#1006755]"];
316 [id="node316" labelType="html" label="<b>BroadcastHashJoin</b><br><br>number of output rows: 0" tooltip="BroadcastHashJoin [worklistShardItemId#1006749L, shardId#1006748], [cachedWorklistShardItemId#1006763L, cachedShardId#1006762], Inner, BuildLeft, false"];
324 [id="node324" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006756 AS cachedShardId#1006762, worklistShardItemId#1006757L AS cachedWorklistShardItemId#1006763L]"];
325 [id="node325" labelType="html" label="<b>Filter</b><br><br>number of output rows: 6,177" tooltip="Filter (isnotnull(worklistShardItemId#1006757L) AND isnotnull(shardId#1006756))"];
326 [id="node326" labelType="html" label="<b>Scan ExistingRDD</b><br><br>number of output rows: 6,177" tooltip="Scan ExistingRDD[shardId#1006756,worklistShardItemId#1006757L,qty#1006758,demandChannel#1006759,demandStream#1006760,kpis#1006761]"];
}
317 [id="node317" labelType="html" label="<b>BroadcastExchange</b><br><br>time to broadcast: 0 ms<br>time to build: 0 ms<br>time to collect: 398 ms<br>number of output rows: 0<br>data size: 0.0 B" tooltip="BroadcastExchange HashedRelationBroadcastMode(List(input[1, bigint, false], input[0, string, false]),false), [plan_id=1632181]"];
subgraph cluster318 {
isCluster="true";
id="cluster318";
label="WholeStageCodegen (2)\n \nduration: total (min, med, max (stageId: taskId))\n12 ms (0 ms, 0 ms, 3 ms (stage 104735.0: task 346356))";
tooltip="WholeStageCodegen (2)";
319 [id="node319" labelType="html" label="<b>Filter</b><br><br>number of output rows: 0" tooltip="Filter ((isnull(qty#1006755) AND isnotnull(worklistShardItemId#1006749L)) AND isnotnull(shardId#1006748))"];
}
320 [id="node320" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 0" tooltip="InMemoryTableScan [shardId#1006748, worklistShardItemId#1006749L, version#1006750, product#1006751, plant#1006752, qty#1006755], [isnull(qty#1006755), isnotnull(worklistShardItemId#1006749L), isnotnull(shardId#1006748)]"];
321 [id="node321" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(product#943634, plant#943635, 37), REPARTITION_BY_NUM, [plan_id=1631937]"];
subgraph cluster322 {
isCluster="true";
id="cluster322";
label="WholeStageCodegen (1)";
tooltip="WholeStageCodegen (1)";
323 [id="node323" labelType="html" label="<br><b>Scan ExistingRDD</b><br><br>" tooltip="Scan ExistingRDD[shardId#943631,worklistShardItemId#943632L,version#943633,product#943634,plant#943635,periodStart#943636,periodEnd#943637,qty#943638]"];
}
subgraph cluster327 {
isCluster="true";
id="cluster327";
label="WholeStageCodegen (6)\n \nduration: total (min, med, max (stageId: taskId))\n2.0 s (0 ms, 0 ms, 230 ms (stage 104833.0: task 346611))";
tooltip="WholeStageCodegen (6)";
328 [id="node328" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006779, worklistShardItemId#1006780L, version#1006781, product#1006782, plant#1006783, qty#1006807, demandChannel#1006800, demandStream#1006801, kpis#1006808, false AS isNewlyCalculated#1006778]"];
}
329 [id="node329" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 0" tooltip="InMemoryTableScan [demandChannel#1006800, demandStream#1006801, kpis#1006808, plant#1006783, product#1006782, qty#1006807, shardId#1006779, version#1006781, worklistShardItemId#1006780L]"];
subgraph cluster330 {
isCluster="true";
id="cluster330";
label="WholeStageCodegen (7)\n \nduration: total (min, med, max (stageId: taskId))\n30 ms (0 ms, 0 ms, 3 ms (stage 104831.0: task 346570))";
tooltip="WholeStageCodegen (7)";
331 [id="node331" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635, cachedQty#1006539 AS qty#1006541, demandChannel#1006534, demandStream#1006535, cachedKpis#1006540 AS kpis#1006542]"];
332 [id="node332" labelType="html" label="<b>SortMergeJoin</b><br><br>number of output rows: 0<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104831.0: task 346570))" tooltip="SortMergeJoin [worklistShardItemId#943632L, shardId#943631], [cachedWorklistShardItemId#1006538L, cachedShardId#1006537], Inner"];
}
subgraph cluster333 {
isCluster="true";
id="cluster333";
label="WholeStageCodegen (4)\n \nduration: total (min, med, max (stageId: taskId))\n1.8 s (0 ms, 1 ms, 151 ms (stage 104831.0: task 346575))";
tooltip="WholeStageCodegen (4)";
334 [id="node334" labelType="html" label="<b>Sort</b><br><br>sort time total (min, med, max (stageId: taskId))<br>0 ms (0 ms, 0 ms, 0 ms (stage 104831.0: task 346570))<br>peak memory total (min, med, max (stageId: taskId))<br>2.3 MiB (64.0 KiB, 64.0 KiB, 64.0 KiB (stage 104831.0: task 346570))<br>spill size total (min, med, max (stageId: taskId))<br>0.0 B (0.0 B, 0.0 B, 0.0 B (stage 104831.0: task 346570))" tooltip="Sort [worklistShardItemId#943632L ASC NULLS FIRST, shardId#943631 ASC NULLS FIRST], false, 0"];
}
335 [id="node335" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>number of partitions: 37<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(worklistShardItemId#943632L, shardId#943631, 37), ENSURE_REQUIREMENTS, [plan_id=1632055]"];
subgraph cluster336 {
isCluster="true";
id="cluster336";
label="WholeStageCodegen (3)\n \nduration: total (min, med, max (stageId: taskId))\n64 ms (0 ms, 1 ms, 6 ms (stage 104830.0: task 346495))";
tooltip="WholeStageCodegen (3)";
337 [id="node337" labelType="html" label="<b>HashAggregate</b><br><br>spill size: 0.0 B<br>time in aggregation build total (min, med, max (stageId: taskId))<br>7 ms (0 ms, 0 ms, 2 ms (stage 104830.0: task 346498))<br>peak memory total (min, med, max (stageId: taskId))<br>9.3 MiB (256.0 KiB, 256.0 KiB, 256.0 KiB (stage 104830.0: task 346505))<br>number of output rows: 0<br>number of sort fallback tasks: 0<br>avg hash probes per key: 0" tooltip="HashAggregate(keys=[plant#943635, shardId#943631, version#943633, worklistShardItemId#943632L, product#943634], functions=[])"];
}
338 [id="node338" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>number of partitions: 37<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(plant#943635, shardId#943631, version#943633, worklistShardItemId#943632L, product#943634, 37), ENSURE_REQUIREMENTS, [plan_id=1632051]"];
subgraph cluster339 {
isCluster="true";
id="cluster339";
label="WholeStageCodegen (2)\n \nduration: total (min, med, max (stageId: taskId))\n1.6 s (4 ms, 8 ms, 151 ms (stage 104828.0: task 346447))";
tooltip="WholeStageCodegen (2)";
340 [id="node340" labelType="html" label="<b>HashAggregate</b><br><br>spill size: 0.0 B<br>time in aggregation build total (min, med, max (stageId: taskId))<br>227 ms (3 ms, 6 ms, 9 ms (stage 104828.0: task 346447))<br>peak memory total (min, med, max (stageId: taskId))<br>9.3 MiB (256.0 KiB, 256.0 KiB, 256.0 KiB (stage 104828.0: task 346466))<br>number of output rows: 0<br>number of sort fallback tasks: 0<br>avg hash probes per key: 0" tooltip="HashAggregate(keys=[plant#943635, shardId#943631, version#943633, worklistShardItemId#943632L, product#943634], functions=[])"];
341 [id="node341" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635]"];
342 [id="node342" labelType="html" label="<b>BroadcastHashJoin</b><br><br>number of output rows: 0" tooltip="BroadcastHashJoin [worklistShardItemId#943632L, shardId#943631], [cachedWorklistShardItemId#1006528L, cachedShardId#1006527], Inner, BuildLeft, ((qty#943638 = cachedQty#1006529) OR isnull(qty#943638)), false"];
350 [id="node350" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006521 AS cachedShardId#1006527, worklistShardItemId#1006522L AS cachedWorklistShardItemId#1006528L, qty#1006523 AS cachedQty#1006529]"];
351 [id="node351" labelType="html" label="<b>Filter</b><br><br>number of output rows: 6,177" tooltip="Filter (isnotnull(worklistShardItemId#1006522L) AND isnotnull(shardId#1006521))"];
352 [id="node352" labelType="html" label="<b>Scan ExistingRDD</b><br><br>number of output rows: 6,177" tooltip="Scan ExistingRDD[shardId#1006521,worklistShardItemId#1006522L,qty#1006523,demandChannel#1006524,demandStream#1006525,kpis#1006526]"];
}
343 [id="node343" labelType="html" label="<b>BroadcastExchange</b><br><br>time to broadcast: 0 ms<br>time to build: 1 ms<br>time to collect: 409 ms<br>number of output rows: 51<br>data size: 2.0 MiB" tooltip="BroadcastExchange HashedRelationBroadcastMode(List(input[1, bigint, false], input[0, string, false]),false), [plan_id=1632045]"];
subgraph cluster344 {
isCluster="true";
id="cluster344";
label="WholeStageCodegen (1)\n \nduration: total (min, med, max (stageId: taskId))\n9 ms (0 ms, 0 ms, 3 ms (stage 104736.0: task 346285))";
tooltip="WholeStageCodegen (1)";
345 [id="node345" labelType="html" label="<b>Filter</b><br><br>number of output rows: 51" tooltip="Filter (isnotnull(worklistShardItemId#943632L) AND isnotnull(shardId#943631))"];
}
346 [id="node346" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 51" tooltip="InMemoryTableScan [shardId#943631, worklistShardItemId#943632L, version#943633, product#943634, plant#943635, qty#943638], [isnotnull(worklistShardItemId#943632L), isnotnull(shardId#943631)]"];
347 [id="node347" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(product#943634, plant#943635, 37), REPARTITION_BY_NUM, [plan_id=1631937]"];
subgraph cluster348 {
isCluster="true";
id="cluster348";
label="WholeStageCodegen (1)";
tooltip="WholeStageCodegen (1)";
349 [id="node349" labelType="html" label="<br><b>Scan ExistingRDD</b><br><br>" tooltip="Scan ExistingRDD[shardId#943631,worklistShardItemId#943632L,version#943633,product#943634,plant#943635,periodStart#943636,periodEnd#943637,qty#943638]"];
}
subgraph cluster353 {
isCluster="true";
id="cluster353";
label="WholeStageCodegen (6)\n \nduration: 0 ms";
tooltip="WholeStageCodegen (6)";
354 [id="node354" labelType="html" label="<b>Sort</b><br><br>sort time: 0 ms<br>peak memory: 0.0 B<br>spill size: 0.0 B" tooltip="Sort [cachedWorklistShardItemId#1006538L ASC NULLS FIRST, cachedShardId#1006537 ASC NULLS FIRST], false, 0"];
}
355 [id="node355" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 6,177<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read total (min, med, max (stageId: taskId))<br>300.0 KiB (3.3 KiB, 7.3 KiB, 17.7 KiB (stage 104831.0: task 346579))<br>merged fetch fallback count: 0<br>local blocks read: 379<br>remote merged chunks fetched: 0<br>remote blocks read: 785<br>data size total (min, med, max (stageId: taskId))<br>3.3 MiB (88.7 KiB, 92.1 KiB, 95.9 KiB (stage 104829.0: task 346405))<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time total (min, med, max (stageId: taskId))<br>75 ms (1 ms, 1 ms, 2 ms (stage 104829.0: task 346451))<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read total (min, med, max (stageId: taskId))<br>610.9 KiB (6.2 KiB, 17.5 KiB, 27.3 KiB (stage 104831.0: task 346589))<br>number of partitions: 37<br>remote reqs duration total (min, med, max (stageId: taskId))<br>152 ms (0 ms, 4 ms, 13 ms (stage 104831.0: task 346576))<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written total (min, med, max (stageId: taskId))<br>1048.5 KiB (25.8 KiB, 28.2 KiB, 30.6 KiB (stage 104829.0: task 346450))" tooltip="Exchange hashpartitioning(cachedWorklistShardItemId#1006538L, cachedShardId#1006537, 37), ENSURE_REQUIREMENTS, [plan_id=1632061]"];
subgraph cluster356 {
isCluster="true";
id="cluster356";
label="WholeStageCodegen (5)\n \nduration: total (min, med, max (stageId: taskId))\n1.8 s (7 ms, 13 ms, 107 ms (stage 104829.0: task 346387))";
tooltip="WholeStageCodegen (5)";
357 [id="node357" labelType="html" label="<br><b>Project</b><br><br>" tooltip="Project [shardId#1006531 AS cachedShardId#1006537, worklistShardItemId#1006532L AS cachedWorklistShardItemId#1006538L, qty#1006533 AS cachedQty#1006539, demandChannel#1006534, demandStream#1006535, kpis#1006536 AS cachedKpis#1006540]"];
358 [id="node358" labelType="html" label="<b>Filter</b><br><br>number of output rows: 6,177" tooltip="Filter (isnotnull(worklistShardItemId#1006532L) AND isnotnull(shardId#1006531))"];
359 [id="node359" labelType="html" label="<b>Scan ExistingRDD</b><br><br>number of output rows: 6,177" tooltip="Scan ExistingRDD[shardId#1006531,worklistShardItemId#1006532L,qty#1006533,demandChannel#1006534,demandStream#1006535,kpis#1006536]"];
}
1->0;
3->1;
4->3;
5->4;
6->5;
8->6;
9->8;
11->9;
12->11;
13->12;
14->13;
15->14;
16->15;
18->16;
19->18;
21->19;
22->21;
24->22;
25->24;
26->25;
27->26;
28->27;
29->28;
30->29;
32->30;
33->32;
34->33;
35->28;
37->35;
38->37;
39->38;
40->39;
42->40;
44->19;
45->44;
47->45;
48->47;
49->48;
50->49;
51->50;
52->51;
53->52;
54->53;
55->54;
57->55;
58->57;
59->58;
35->54;
61->9;
62->61;
63->62;
64->63;
65->64;
66->65;
68->66;
69->68;
70->69;
71->70;
73->71;
74->73;
76->74;
77->76;
78->77;
79->78;
81->79;
83->74;
84->83;
85->84;
86->85;
88->86;
89->88;
91->89;
92->91;
94->92;
95->94;
97->95;
98->97;
99->98;
100->99;
102->100;
103->102;
104->103;
106->104;
107->99;
108->107;
109->108;
111->89;
112->111;
114->112;
115->114;
116->115;
118->85;
119->118;
120->119;
122->120;
123->122;
124->123;
126->124;
127->119;
128->127;
129->128;
131->71;
132->131;
134->132;
135->134;
137->135;
138->137;
140->138;
141->140;
143->141;
144->143;
145->144;
146->145;
148->146;
149->148;
150->149;
152->150;
153->145;
154->153;
155->154;
157->135;
158->157;
160->158;
161->160;
162->161;
164->63;
165->164;
166->165;
167->166;
169->167;
170->169;
172->170;
173->172;
174->173;
175->174;
177->175;
179->170;
180->179;
181->180;
182->181;
184->182;
185->184;
187->185;
188->187;
190->188;
191->190;
193->191;
194->193;
195->194;
196->195;
198->196;
199->198;
200->199;
202->200;
203->195;
204->203;
205->204;
207->185;
208->207;
210->208;
211->210;
212->211;
214->181;
215->214;
216->215;
218->216;
219->218;
220->219;
222->220;
223->215;
224->223;
225->224;
227->167;
228->227;
230->228;
231->230;
233->231;
234->233;
236->234;
237->236;
239->237;
240->239;
241->240;
242->241;
244->242;
245->244;
246->245;
248->246;
249->241;
250->249;
251->250;
253->231;
254->253;
256->254;
257->256;
258->257;
259->3;
261->259;
262->261;
264->262;
265->264;
266->265;
267->266;
268->267;
270->268;
271->270;
273->271;
274->273;
275->274;
276->275;
278->276;
280->271;
281->280;
282->281;
283->282;
285->283;
286->285;
288->286;
289->288;
291->289;
292->291;
294->292;
295->294;
296->295;
297->296;
299->297;
300->299;
301->300;
303->301;
304->296;
305->304;
306->305;
308->286;
309->308;
311->309;
312->311;
313->312;
315->282;
316->315;
317->316;
319->317;
320->319;
321->320;
323->321;
324->316;
325->324;
326->325;
328->268;
329->328;
331->329;
332->331;
334->332;
335->334;
337->335;
338->337;
340->338;
341->340;
342->341;
343->342;
345->343;
346->345;
347->346;
349->347;
350->342;
351->350;
352->351;
354->332;
355->354;
357->355;
358->357;
359->358;
}