Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

223 heatload graph #288

Merged
merged 32 commits into from
Jan 15, 2025
Merged

Conversation

derekvmcintire
Copy link
Contributor

@derekvmcintire derekvmcintire commented Dec 18, 2024

Questions to answer:

  1. The data from lastResult has an average_heat_load that is higher than the maximum_heat_load, which causes the average point and line to be above the maximum. Is there a better data set that I should be using, or am I misunderstanding the data? In general, am I using the correct data here? And are my calculations correct? They are based off of the document in the issue comments, but the console.log listed in the issue was logging the balance_point_graph records, which I am not using.
  2. Question Mark Icon - should this be a tool tip? What should the tool tip display?
  3. Do we need more points along the lines? Right now I have drawn the lines based on only three points (start, design temp, design set point)

Work Done

Using the JSON data in lastResult, I did the following:

  • parse JSON data using the Reviver function
  • pass the parsed data to the HeatLoadAnalysis component (routes/_heat+/heatloadanalysis.tsx)
  • use the existing SummaryOutputSchema type for the parsed summary data
  • pass data to the Graphs component (components/ui.../HeatLoadAnalysis.tsx)
  • pass data from the Graphs component to the HeatLoad component for display
  • Calculate max heat load and avg heat load for the start (design temp - 10f), design temp and design set point
  • Set min and max values
  • Create the legend, and axis labels
  • Display lines and points
  • Create custom tool tip
  • Create ChartGrid component to display important values below the chart
  • Style accordingly

Testing

  • manually checked the UI to see the data points populated in the scatter chart
  • ran tests script (7 failing, but looks like they are also failing on the main branch so I am assuming this is unrelated)

Notes

  • I broke the component up into multiple files, but I was a bit unsure on the placement of those files, let me know if I should change anything about the file structure.
  • I am just prop drilling the data through the Graphs component for now. We could create a context to share this data or at least avoid prop drilling here.

Observations

  • the naming of the files/components is a little confusing, I am not sure if the pattern is intentional where routes.../heatloadanalysis.tsx and components.../HeatLoadAnalysis.tsx are meant to compliment each other.
  • There are many typescript errors and the tsconfig file seems to need some attention, but I didn't make any changes there.

Screenshots:

Desktop View:
Screenshot 2024-12-19 at 11 42 04 AM

Tool tip:
Screenshot 2024-12-19 at 7 55 52 PM

Mobile View:
Screenshot 2024-12-19 at 5 18 36 PM

maxValue = Math.max(maxValue, maxLine, avgLine)
}

const minY = Math.max(0, Math.floor((minValue * 0.8) / 10000) * 10000) // 20% buffer
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

might want to put some of these hardcoded files into a configuration file

<Label
value="Heat Load (BTU/h)"
position="left"
angle={-90}
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

can we move the label more to the center easily?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Was not able to get to this

@derekvmcintire
Copy link
Contributor Author

Screen shot after addressing PR comments:

Screenshot 2025-01-09 at 12 59 41 PM


const X_AXIS_BUFFER_PERCENTAGE_MAX = 1.3; // 30% buffer
const Y_AXIS_ROUNDING_UNIT = 10000; // Rounding unit for minY and maxY
const Y_AXIS_MIN_VALUE = 0; // Always start the Y axis at 0
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Added constants for these numbers

const Y_AXIS_ROUNDING_UNIT = 10000; // Rounding unit for minY and maxY
const Y_AXIS_MIN_VALUE = 0; // Always start the Y axis at 0

const roundDownToNearestTen = (n: number) => Math.floor(n / 10) * 10; // Used for determining the start temperature on the X axis
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Made this a function for clarity

// seet min and max Y axis values
const minY = Y_AXIS_MIN_VALUE
const adjustedMaxYValue = maxValue * X_AXIS_BUFFER_PERCENTAGE_MAX;
const maxY = Math.ceil(adjustedMaxYValue / Y_AXIS_ROUNDING_UNIT) * Y_AXIS_ROUNDING_UNIT
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

min and max values here are now more readable

unit="°F"
dataKey="temperature"
name="Outdoor Temperature"
domain={[minTemperature, maxTemperature]}
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

updated to min/max instead of start/end

</ResponsiveContainer>
<CustomLegend />
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Created a custom legend after discovering it was only working by accident

import { buildHeatLoadGraphData } from '../utility/build-heat-load-graph-data'
import { HeatLoadGraphToolTip } from './HeatLoadGraphToolTip'
import { CustomLegend } from './HeatLoadGraphLegend'
import { DESIGN_SET_POINT } from '../../../../../global_constants'
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

moved design set point to a constant

@@ -0,0 +1 @@
export const DESIGN_SET_POINT = 70 // Design set point (70°F), defined in external documentation - https://docs.google.com/document/d/16WlqY3ofq4xpalsfwRuYBWMbeUHfXRvbWU69xxVNCGM/edit?tab=t.0
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

added link to google doc for reference

<div className="min-w-[625px] rounded-lg shadow-lg">
<span className="mb-4 text-lg font-semibold">
Heating System Demand
<Icon name="question-mark-circled" className="ps-1" size="md" />
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Did not implement tool tip yet, should probably be a follow up ticket

designSetPoint: number,
): number {
return Math.max(0, (designSetPoint - temperature) * whole_home_heat_loss_rate)
}
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Removed rounding

@thadk thadk merged commit ab29024 into codeforboston:main Jan 15, 2025
8 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants