From 22835a9d956418ed72b692fa54fe626aeb267bfc Mon Sep 17 00:00:00 2001 From: Matt Prilliman Date: Tue, 3 Oct 2023 10:32:13 -0500 Subject: [PATCH 01/15] Setting up checks for user input tilt angles, likely to be incorporated into track_mode --- ssc/cmod_pvsamv1.cpp | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/ssc/cmod_pvsamv1.cpp b/ssc/cmod_pvsamv1.cpp index 09f23ecd4..c2b12a4d6 100644 --- a/ssc/cmod_pvsamv1.cpp +++ b/ssc/cmod_pvsamv1.cpp @@ -1130,10 +1130,25 @@ void cm_pvsamv1::exec() throw exec_error("pvsamv1", "The measured temperature array must be the size of nrecords per year"); } + std::vector user_tilt_angles; user_tilt_angles.reserve(nrec); + size_t user_tilt_angles_size; + int use_user_tilt_angles = (as_integer("use_user_tilt_angles") == 1 && is_assigned("user_tilt_angles_array")); + if (as_integer("use_user_tilt_angles") == 1 && is_assigned("user_tilt_angles_array")) { + user_tilt_angles = as_vector_ssc_number_t("user_tilt_angles_array"); + user_tilt_angles_size = user_tilt_angles.size(); + if (user_tilt_angles_size != nrec) + throw exec_error("pvsamv1", "The measured temperature array must be the size of nrecords per year"); + } + //overwrite tilt with latitude if flag is set- can't do this in PVIOManager because need latitude from weather file //also check here for tilt > 0 for tracking systems, since this is a very uncommon configuration but an easy mistake to make for (size_t nn = 0; nn < num_subarrays; nn++) { + if (as_integer("use_user_tilt_angles") == 1 && is_assigned("user_tilt_angles_array")) { + Subarrays[nn]->trackMode = irrad::FIXED_TILT; + Subarrays[nn]->tiltDegrees = 0; //reset to 0 to then be replaced in loop? + Subarrays[nn]->backtrackingEnabled = false; //account for backtracking in user-specified angles [deg] + } if (Subarrays[nn]->tiltEqualLatitude) Subarrays[nn]->tiltDegrees = std::abs(Irradiance->weatherHeader.lat); if (Subarrays[nn]->trackMode == irrad::SINGLE_AXIS && Subarrays[nn]->tiltDegrees > 0 && !Subarrays[nn]->Module->isBifacial) @@ -1497,6 +1512,11 @@ void cm_pvsamv1::exec() || Subarrays[nn]->nStrings < 1) continue; // skip disabled subarrays + if (as_integer("use_user_tilt_angles") == 1 && is_assigned("user_tilt_angles_array")) { + Subarrays[nn]->tiltDegrees = user_tilt_angles[inrec]; + + } + irrad irr(Irradiance->weatherRecord, Irradiance->weatherHeader, Irradiance->skyModel, Irradiance->radiationMode, Subarrays[nn]->trackMode, Irradiance->useWeatherFileAlbedo, Irradiance->instantaneous, Subarrays[nn]->backtrackingEnabled, false, From f6ec275f142fb83da7aa3c5c7584c3e42ebcd684 Mon Sep 17 00:00:00 2001 From: Matt Prilliman Date: Thu, 12 Oct 2023 09:09:15 -0500 Subject: [PATCH 02/15] Setting up framework for custom rotation angles --- shared/lib_irradproc.cpp | 4 +++- shared/lib_irradproc.h | 2 +- shared/lib_pv_io_manager.cpp | 2 ++ shared/lib_pv_io_manager.h | 2 ++ ssc/cmod_pvsamv1.cpp | 7 ++++--- 5 files changed, 12 insertions(+), 5 deletions(-) diff --git a/shared/lib_irradproc.cpp b/shared/lib_irradproc.cpp index 35db1295a..353f4945a 100644 --- a/shared/lib_irradproc.cpp +++ b/shared/lib_irradproc.cpp @@ -1224,6 +1224,8 @@ void incidence(int mode, double tilt, double sazm, double rlim, double zen, rot = backtracking_rotation; } + /*Check if custom tilt angles enabled, apply timeseries value*/ + /* Find tilt angle for the tracking surface */ arg = cos(xtilt) * cos(rot); if (arg < -1.0) @@ -1766,7 +1768,7 @@ irrad::irrad(weather_record wf, weather_header hdr, double groundCoverageRatioIn, double slopeTiltIn, double slopeAzmIn, std::vector monthlyTiltDegrees, std::vector userSpecifiedAlbedo, poaDecompReq *poaAllIn, - bool useSpatialAlbedos, const util::matrix_t* userSpecifiedSpatialAlbedos, bool enableSubhourlyClipping) : + bool useSpatialAlbedos, const util::matrix_t* userSpecifiedSpatialAlbedos, bool enableSubhourlyClipping, bool useCustomTiltAngles) : skyModel(skyModelIn), radiationMode(radiationModeIn), trackingMode(trackModeIn), enableBacktrack(backtrackingEnabled), forceToStow(forceToStowIn), delt(dtHour), tiltDegrees(tiltDegreesIn), surfaceAzimuthDegrees(azimuthDegreesIn), diff --git a/shared/lib_irradproc.h b/shared/lib_irradproc.h index 864aff360..61ec9a122 100644 --- a/shared/lib_irradproc.h +++ b/shared/lib_irradproc.h @@ -1055,7 +1055,7 @@ class irrad double dtHour, double tiltDegrees, double azimuthDegrees, double trackerRotationLimitDegrees, double stowAngleDegreesIn, double groundCoverageRatio, double slopeTilt, double slopeAzm, std::vector monthlyTiltDegrees, std::vector userSpecifiedAlbedo, poaDecompReq* poaAllIn, - bool useSpatialAlbedos = false, const util::matrix_t* userSpecifiedSpatialAlbedos = nullptr, bool enableSubhourlyClipping = false); + bool useSpatialAlbedos = false, const util::matrix_t* userSpecifiedSpatialAlbedos = nullptr, bool enableSubhourlyClipping = false, bool useCustomTiltAngles = false); /// Construct the irrad class with an Irradiance_IO() object and Subarray_IO() object irrad(); diff --git a/shared/lib_pv_io_manager.cpp b/shared/lib_pv_io_manager.cpp index dcc4146de..11d7d90b6 100644 --- a/shared/lib_pv_io_manager.cpp +++ b/shared/lib_pv_io_manager.cpp @@ -376,6 +376,8 @@ Subarray_IO::Subarray_IO(compute_module* cm, const std::string& cmName, size_t s if (monthlyTiltDegrees[i] < 0.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + " monthly tilt angles cannot be negative."); } } + /* Insert checks for custom tilt angles here*/ + //azimuth required for fixed tilt, single axis, and seasonal tilt- can't check for this in variable table so check here azimuthDegrees = std::numeric_limits::quiet_NaN(); if (trackMode == irrad::FIXED_TILT || trackMode == irrad::SINGLE_AXIS || trackMode == irrad::SEASONAL_TILT) diff --git a/shared/lib_pv_io_manager.h b/shared/lib_pv_io_manager.h index c745f48ad..a1a5347ee 100644 --- a/shared/lib_pv_io_manager.h +++ b/shared/lib_pv_io_manager.h @@ -465,6 +465,8 @@ struct Subarray_IO double slopeTilt; // Angle of sloped terrain [degrees] double slopeAzm; // azimuth of sloped terrain relative to tracker azimuth [degrees] double tiltDegrees; // The surface tilt [degrees] + flag useCustomTiltAngles; // Use custom timeseries rotation angles + std::vector customTiltAngles; //Custom timeseries rotation angles [degrees] double azimuthDegrees; // The surface azimuth [degrees] int trackMode; // The tracking mode [0 = fixed, 1 = single-axis tracking, 2 = two-axis tracking, 3 = azimuth-axis tracking, 4 = seasonal-tilt double trackerRotationLimitDegrees; // The rotational limit of the tracker [degrees] diff --git a/ssc/cmod_pvsamv1.cpp b/ssc/cmod_pvsamv1.cpp index a81825409..a3ad405ef 100644 --- a/ssc/cmod_pvsamv1.cpp +++ b/ssc/cmod_pvsamv1.cpp @@ -1139,8 +1139,8 @@ void cm_pvsamv1::exec() for (size_t nn = 0; nn < num_subarrays; nn++) { if (as_integer("use_user_tilt_angles") == 1 && is_assigned("user_tilt_angles_array")) { - Subarrays[nn]->trackMode = irrad::FIXED_TILT; - Subarrays[nn]->tiltDegrees = 0; //reset to 0 to then be replaced in loop? + Subarrays[nn]->trackMode = irrad::SINGLE_AXIS; + //Subarrays[nn]->tiltDegrees = 0; //reset to 0 to then be replaced in loop? Subarrays[nn]->backtrackingEnabled = false; //account for backtracking in user-specified angles [deg] } if (Subarrays[nn]->tiltEqualLatitude) @@ -1506,10 +1506,11 @@ void cm_pvsamv1::exec() || Subarrays[nn]->nStrings < 1) continue; // skip disabled subarrays + /* if (as_integer("use_user_tilt_angles") == 1 && is_assigned("user_tilt_angles_array")) { Subarrays[nn]->tiltDegrees = user_tilt_angles[inrec]; - } + }*/ irrad irr(Irradiance->weatherRecord, Irradiance->weatherHeader, Irradiance->skyModel, Irradiance->radiationMode, Subarrays[nn]->trackMode, From 080f9867bc8ace69dd5a865cbe925bc03c2a82cf Mon Sep 17 00:00:00 2001 From: Matt Prilliman Date: Wed, 18 Oct 2023 20:14:02 -0500 Subject: [PATCH 03/15] Passing custom rotation angles to irradproc incidence angle --- shared/lib_irradproc.cpp | 25 ++++++++++++++++++------- shared/lib_irradproc.h | 10 ++++++++-- shared/lib_pv_io_manager.cpp | 9 ++++++++- ssc/cmod_pvsamv1.cpp | 12 ++++++------ 4 files changed, 40 insertions(+), 16 deletions(-) diff --git a/shared/lib_irradproc.cpp b/shared/lib_irradproc.cpp index 353f4945a..35b635ee7 100644 --- a/shared/lib_irradproc.cpp +++ b/shared/lib_irradproc.cpp @@ -1142,7 +1142,7 @@ solarpos_spa(int year, int month, int day, int hour, double minute, double secon void incidence(int mode, double tilt, double sazm, double rlim, double zen, double azm, bool en_backtrack, double gcr, double slope_tilt, double slope_azm, - bool force_to_stow, double stow_angle_deg, double angle[5]) { + bool force_to_stow, double stow_angle_deg, bool useCustomAngle, double customAngle, double angle[5]) { /* Calculate panel orientation, angle of incidence with beam radiation, and tracker rotation angles (where applicable). @@ -1225,6 +1225,9 @@ void incidence(int mode, double tilt, double sazm, double rlim, double zen, } /*Check if custom tilt angles enabled, apply timeseries value*/ + if (useCustomAngle) { + rot = customAngle * DTOR; //overwrite rotation angle with input from array + } /* Find tilt angle for the tracking surface */ arg = cos(xtilt) * cos(rot); @@ -1768,7 +1771,7 @@ irrad::irrad(weather_record wf, weather_header hdr, double groundCoverageRatioIn, double slopeTiltIn, double slopeAzmIn, std::vector monthlyTiltDegrees, std::vector userSpecifiedAlbedo, poaDecompReq *poaAllIn, - bool useSpatialAlbedos, const util::matrix_t* userSpecifiedSpatialAlbedos, bool enableSubhourlyClipping, bool useCustomTiltAngles) : + bool useSpatialAlbedos, const util::matrix_t* userSpecifiedSpatialAlbedos, bool enableSubhourlyClipping, bool useCustomTiltAngles, double customTiltAngles) : skyModel(skyModelIn), radiationMode(radiationModeIn), trackingMode(trackModeIn), enableBacktrack(backtrackingEnabled), forceToStow(forceToStowIn), delt(dtHour), tiltDegrees(tiltDegreesIn), surfaceAzimuthDegrees(azimuthDegreesIn), @@ -1797,6 +1800,8 @@ irrad::irrad(weather_record wf, weather_header hdr, set_subhourly_clipping(enableSubhourlyClipping); + set_custom_tilt_angles(useCustomTiltAngles, customTiltAngle); + if (radiationMode == irrad::DN_DF) set_beam_diffuse(wf.dn, wf.df); else if (radiationMode == irrad::DN_GH) set_global_beam(wf.gh, wf.dn); else if (radiationMode == irrad::GH_DF) set_global_diffuse(wf.gh, wf.df); @@ -1990,6 +1995,12 @@ void irrad::set_subhourly_clipping(bool enable) if (enable) this->enableSubhourlyClipping = true; } +void irrad::set_custom_tilt_angles(bool enable, double angle) +{ + this->useCustomTiltAngles = enable; + this->customTiltAngle = angle; +} + void irrad::set_sky_model(int sm, double alb, const std::vector &albSpatial) { this->skyModel = sm; this->albedo = alb; @@ -2178,7 +2189,7 @@ int irrad::calc() { // compute incidence angles onto fixed or tracking surface incidence(trackingMode, tiltDegrees, surfaceAzimuthDegrees, rotationLimitDegrees, sunAnglesRadians[1], sunAnglesRadians[0], - enableBacktrack, groundCoverageRatio, slopeTilt, slopeAzm, forceToStow, stowAngleDegrees, surfaceAnglesRadians); + enableBacktrack, groundCoverageRatio, slopeTilt, slopeAzm, forceToStow, stowAngleDegrees, useCustomTiltAngles, customTiltAngle, surfaceAnglesRadians); if (radiationMode < irrad::POA_R) { double hextra = sunAnglesRadians[8]; double hbeam = directNormal * @@ -2578,7 +2589,7 @@ void irrad::getFrontSurfaceIrradiances(double pvFrontShadeFraction, double rowTo // Calculate irradiance components for a 90 degree tilt to get horizon brightening double angleTmp[5] = {0, 0, 0, 0, 0}; // ([0] = incidence angle, [1] = tilt) incidence(0, 90.0, 180.0, 45.0, solarZenithRadians, solarAzimuthRadians, this->enableBacktrack, - this->groundCoverageRatio, this->slopeTilt, this->slopeAzm, this->forceToStow, this->stowAngleDegrees, angleTmp); + this->groundCoverageRatio, this->slopeTilt, this->slopeAzm, this->forceToStow, this->stowAngleDegrees, this->useCustomTiltAngles, this->customTiltAngle, angleTmp); perez(0, calculatedDirectNormal, calculatedDiffuseHorizontal, albedo, angleTmp[0], angleTmp[1], solarZenithRadians, poa, diffc); double horizonDiffuse = diffc[2]; @@ -2714,7 +2725,7 @@ void irrad::getFrontSurfaceIrradiances(double pvFrontShadeFraction, double rowTo // Calculate and add direct and circumsolar irradiance components incidence(0, tiltRadians * RTOD, surfaceAzimuthRadians * RTOD, 45.0, solarZenithRadians, solarAzimuthRadians, this->enableBacktrack, this->groundCoverageRatio, this->slopeTilt, this->slopeAzm, - this->forceToStow, this->stowAngleDegrees, surfaceAnglesRadians); + this->forceToStow, this->stowAngleDegrees, this->useCustomTiltAngles, this->customTiltAngle, surfaceAnglesRadians); perez(0, calculatedDirectNormal, calculatedDiffuseHorizontal, albedo, surfaceAnglesRadians[0], surfaceAnglesRadians[1], solarZenithRadians, poa, diffc); @@ -2759,7 +2770,7 @@ void irrad::getBackSurfaceIrradiances(double pvBackShadeFraction, double rowToRo // Calculate components for a 90 degree tilt to get horizon brightening double surfaceAnglesRadians90[5] = {0, 0, 0, 0, 0}; incidence(0, 90.0, 180.0, 45.0, solarZenithRadians, solarAzimuthRadians, this->enableBacktrack, - this->groundCoverageRatio, this->slopeTilt, this->slopeAzm, this->forceToStow, this->stowAngleDegrees, surfaceAnglesRadians90); + this->groundCoverageRatio, this->slopeTilt, this->slopeAzm, this->forceToStow, this->stowAngleDegrees, this->useCustomTiltAngles, this->customTiltAngle, surfaceAnglesRadians90); perez(0, calculatedDirectNormal, calculatedDiffuseHorizontal, albedo, surfaceAnglesRadians90[0], surfaceAnglesRadians90[1], solarZenithRadians, planeOfArrayIrradianceRear, diffuseIrradianceRear); double horizonDiffuse = diffuseIrradianceRear[2]; @@ -2959,7 +2970,7 @@ void irrad::getBackSurfaceIrradiances(double pvBackShadeFraction, double rowToRo // Calculate and add direct and circumsolar irradiance components incidence(0, 180.0 - tiltRadians * RTOD, (surfaceAzimuthRadians * RTOD - 180.0), 45.0, solarZenithRadians, solarAzimuthRadians, this->enableBacktrack, - this->groundCoverageRatio, this->slopeTilt, this->slopeAzm, this->forceToStow, this->stowAngleDegrees, surfaceAnglesRadians); + this->groundCoverageRatio, this->slopeTilt, this->slopeAzm, this->forceToStow, this->stowAngleDegrees, this->useCustomTiltAngles, this->customTiltAngle, surfaceAnglesRadians); perez(0, calculatedDirectNormal, calculatedDiffuseHorizontal, albedo, surfaceAnglesRadians[0], surfaceAnglesRadians[1], solarZenithRadians, planeOfArrayIrradianceRear, diffuseIrradianceRear); diff --git a/shared/lib_irradproc.h b/shared/lib_irradproc.h index 61ec9a122..8ba76fc4c 100644 --- a/shared/lib_irradproc.h +++ b/shared/lib_irradproc.h @@ -731,7 +731,7 @@ void solarpos_spa(int year, int month, int day, int hour, double minute, double * \param[out] angle[3] tracking axis rotation angle in radians, measured from surface normal of unrotating axis (only for 1 axis trackers) * \param[out] angle[4] backtracking difference (rot - ideal_rot) will be zero except in case of backtracking for 1 axis tracking */ -void incidence(int mode, double tilt, double sazm, double rlim, double zen, double azm, bool en_backtrack, double gcr, double slope_tilt, double slope_azm, bool force_to_stow, double stow_angle_deg, double angle[5]); +void incidence(int mode, double tilt, double sazm, double rlim, double zen, double azm, bool en_backtrack, double gcr, double slope_tilt, double slope_azm, bool force_to_stow, double stow_angle_deg, bool useCustomAngle, double customAngle, double angle[5]); /** @@ -991,6 +991,10 @@ class irrad //Enable subhourly clipping correction bool enableSubhourlyClipping; + //Custom rotation angles for single-axis trackers + bool useCustomTiltAngles; + double customTiltAngle; // custom tracker rotation angle in degrees + // Subarray properties double tiltDegrees; ///< Surface tilt of subarray in degrees double surfaceAzimuthDegrees; ///< Surface azimuth of subarray in degrees @@ -1055,7 +1059,7 @@ class irrad double dtHour, double tiltDegrees, double azimuthDegrees, double trackerRotationLimitDegrees, double stowAngleDegreesIn, double groundCoverageRatio, double slopeTilt, double slopeAzm, std::vector monthlyTiltDegrees, std::vector userSpecifiedAlbedo, poaDecompReq* poaAllIn, - bool useSpatialAlbedos = false, const util::matrix_t* userSpecifiedSpatialAlbedos = nullptr, bool enableSubhourlyClipping = false, bool useCustomTiltAngles = false); + bool useSpatialAlbedos = false, const util::matrix_t* userSpecifiedSpatialAlbedos = nullptr, bool enableSubhourlyClipping = false, bool useCustomTiltAngles = false, double customTiltAngle = 0); /// Construct the irrad class with an Irradiance_IO() object and Subarray_IO() object irrad(); @@ -1078,6 +1082,8 @@ class irrad //Set whether to use subhourly clipping model void set_subhourly_clipping(bool enable = false); + void set_custom_tilt_angles(bool enable = false, double angle = 0); + /// Set the sky model for the irradiance processor, using \link Irradiance_IO::SKYMODEL void set_sky_model(int skymodel, double albedo, const std::vector &albedoSpatial = std::vector()); diff --git a/shared/lib_pv_io_manager.cpp b/shared/lib_pv_io_manager.cpp index 11d7d90b6..5d64bc30f 100644 --- a/shared/lib_pv_io_manager.cpp +++ b/shared/lib_pv_io_manager.cpp @@ -358,6 +358,7 @@ Subarray_IO::Subarray_IO(compute_module* cm, const std::string& cmName, size_t s nModulesPerString = cm->as_integer(prefix + "modules_per_string"); mpptInput = cm->as_integer(prefix + "mppt_input"); trackMode = cm->as_integer(prefix + "track_mode"); + useCustomTiltAngles = cm->as_integer("use_custom_tilt_angles"); tiltEqualLatitude = 0; if (cm->is_assigned(prefix + "tilt_eq_lat")) tiltEqualLatitude = cm->as_boolean(prefix + "tilt_eq_lat"); @@ -376,8 +377,14 @@ Subarray_IO::Subarray_IO(compute_module* cm, const std::string& cmName, size_t s if (monthlyTiltDegrees[i] < 0.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + " monthly tilt angles cannot be negative."); } } + /* Insert checks for custom tilt angles here*/ - + if (cm->is_assigned("custom_tilt_angles_array") && useCustomTiltAngles == 1) { + customTiltAngles = cm->as_vector_double("custom_tilt_angle_array"); + for (int i = 0; i < customTiltAngles.size(); i++) { + if (customTiltAngles[i] < 0.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + "custom tilt angles cannot be negative."); + } + } //azimuth required for fixed tilt, single axis, and seasonal tilt- can't check for this in variable table so check here azimuthDegrees = std::numeric_limits::quiet_NaN(); if (trackMode == irrad::FIXED_TILT || trackMode == irrad::SINGLE_AXIS || trackMode == irrad::SEASONAL_TILT) diff --git a/ssc/cmod_pvsamv1.cpp b/ssc/cmod_pvsamv1.cpp index a3ad405ef..e5c788a4f 100644 --- a/ssc/cmod_pvsamv1.cpp +++ b/ssc/cmod_pvsamv1.cpp @@ -1126,9 +1126,9 @@ void cm_pvsamv1::exec() std::vector user_tilt_angles; user_tilt_angles.reserve(nrec); size_t user_tilt_angles_size; - int use_user_tilt_angles = (as_integer("use_user_tilt_angles") == 1 && is_assigned("user_tilt_angles_array")); - if (as_integer("use_user_tilt_angles") == 1 && is_assigned("user_tilt_angles_array")) { - user_tilt_angles = as_vector_ssc_number_t("user_tilt_angles_array"); + int use_custom_tilt_angles = (as_integer("use_custom_tilt_angles") == 1 && is_assigned("custom_tilt_angles_array")); + if (as_integer("use_custom_tilt_angles") == 1 && is_assigned("custom_tilt_angles_array")) { + user_tilt_angles = as_vector_ssc_number_t("custom_tilt_angles_array"); user_tilt_angles_size = user_tilt_angles.size(); if (user_tilt_angles_size != nrec) throw exec_error("pvsamv1", "The measured temperature array must be the size of nrecords per year"); @@ -1138,7 +1138,7 @@ void cm_pvsamv1::exec() //also check here for tilt > 0 for tracking systems, since this is a very uncommon configuration but an easy mistake to make for (size_t nn = 0; nn < num_subarrays; nn++) { - if (as_integer("use_user_tilt_angles") == 1 && is_assigned("user_tilt_angles_array")) { + if (as_integer("use_custom_tilt_angles") == 1 && is_assigned("custom_tilt_angles_array")) { Subarrays[nn]->trackMode = irrad::SINGLE_AXIS; //Subarrays[nn]->tiltDegrees = 0; //reset to 0 to then be replaced in loop? Subarrays[nn]->backtrackingEnabled = false; //account for backtracking in user-specified angles [deg] @@ -1507,7 +1507,7 @@ void cm_pvsamv1::exec() continue; // skip disabled subarrays /* - if (as_integer("use_user_tilt_angles") == 1 && is_assigned("user_tilt_angles_array")) { + if (as_integer("use_custom_tilt_angles") == 1 && is_assigned("custom_tilt_angles_array")) { Subarrays[nn]->tiltDegrees = user_tilt_angles[inrec]; }*/ @@ -1518,7 +1518,7 @@ void cm_pvsamv1::exec() Irradiance->dtHour, Subarrays[nn]->tiltDegrees, Subarrays[nn]->azimuthDegrees, Subarrays[nn]->trackerRotationLimitDegrees, 0.0, Subarrays[nn]->groundCoverageRatio, Subarrays[nn]->slopeTilt, Subarrays[nn]->slopeAzm, Subarrays[nn]->monthlyTiltDegrees, Irradiance->userSpecifiedMonthlyAlbedo, Subarrays[nn]->poa.poaAll.get(), - Irradiance->useSpatialAlbedos, &Irradiance->userSpecifiedMonthlySpatialAlbedos, as_boolean("enable_subhourly_clipping")); + Irradiance->useSpatialAlbedos, &Irradiance->userSpecifiedMonthlySpatialAlbedos, as_boolean("enable_subhourly_clipping"), as_boolean("use_custom_tilt_angles"), user_tilt_angles[inrec]); int code = irr.calc(); From 8ff0b98a062047886bd548716cfbec21ea2dfebc Mon Sep 17 00:00:00 2001 From: Matt Prilliman Date: Thu, 19 Oct 2023 14:40:02 -0500 Subject: [PATCH 04/15] Updated incidence calls throughout code, debugged custom rotation angles running through sdk --- shared/lib_irradproc.cpp | 2 +- shared/lib_irradproc.h | 2 ++ shared/lib_pv_io_manager.cpp | 4 ++-- ssc/cmod_pvsamv1.cpp | 2 ++ tcs/csp_solver_weatherreader.cpp | 2 +- test/shared_test/lib_irradproc_test.cpp | 8 ++++---- 6 files changed, 12 insertions(+), 8 deletions(-) diff --git a/shared/lib_irradproc.cpp b/shared/lib_irradproc.cpp index 35b635ee7..32781f226 100644 --- a/shared/lib_irradproc.cpp +++ b/shared/lib_irradproc.cpp @@ -1771,7 +1771,7 @@ irrad::irrad(weather_record wf, weather_header hdr, double groundCoverageRatioIn, double slopeTiltIn, double slopeAzmIn, std::vector monthlyTiltDegrees, std::vector userSpecifiedAlbedo, poaDecompReq *poaAllIn, - bool useSpatialAlbedos, const util::matrix_t* userSpecifiedSpatialAlbedos, bool enableSubhourlyClipping, bool useCustomTiltAngles, double customTiltAngles) : + bool useSpatialAlbedos, const util::matrix_t* userSpecifiedSpatialAlbedos, bool enableSubhourlyClipping, bool useCustomTiltAngles, double customTiltAngle) : skyModel(skyModelIn), radiationMode(radiationModeIn), trackingMode(trackModeIn), enableBacktrack(backtrackingEnabled), forceToStow(forceToStowIn), delt(dtHour), tiltDegrees(tiltDegreesIn), surfaceAzimuthDegrees(azimuthDegreesIn), diff --git a/shared/lib_irradproc.h b/shared/lib_irradproc.h index 8ba76fc4c..8a5578ca2 100644 --- a/shared/lib_irradproc.h +++ b/shared/lib_irradproc.h @@ -724,6 +724,8 @@ void solarpos_spa(int year, int month, int day, int hour, double minute, double * \param[in] slope_azm azimuth angle of slopted terrain relative to tracker azimuth in radians * \param[in] force_to_stow: force the single-axis tracking array to the stow angle specified in the next input * \param[in] stow_angle_deg: the angle to force the single-axis tracking array to stow to, in degrees +* \param[in] useCustomAngle: use custom rotation angles for single axis tracking 0/1 +* \param[in] customAngle: custom rotation angle to use, in degrees * \param[out] angle array of elements to return angles to calling function * \param[out] angle[0] incident angle in radians * \param[out] angle[1] tilt angle of surface from horizontal in radians diff --git a/shared/lib_pv_io_manager.cpp b/shared/lib_pv_io_manager.cpp index 5d64bc30f..8524277f0 100644 --- a/shared/lib_pv_io_manager.cpp +++ b/shared/lib_pv_io_manager.cpp @@ -380,7 +380,7 @@ Subarray_IO::Subarray_IO(compute_module* cm, const std::string& cmName, size_t s /* Insert checks for custom tilt angles here*/ if (cm->is_assigned("custom_tilt_angles_array") && useCustomTiltAngles == 1) { - customTiltAngles = cm->as_vector_double("custom_tilt_angle_array"); + customTiltAngles = cm->as_vector_double("custom_tilt_angles_array"); for (int i = 0; i < customTiltAngles.size(); i++) { if (customTiltAngles[i] < 0.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + "custom tilt angles cannot be negative."); } @@ -651,7 +651,7 @@ void PVSystem_IO::SetupPOAInput() if (tms[2] > 0) { - incidence(Subarrays[nn]->trackMode, Subarrays[nn]->tiltDegrees, Subarrays[nn]->azimuthDegrees, Subarrays[nn]->trackerRotationLimitDegrees, sun[1], sun[0], Subarrays[nn]->backtrackingEnabled, Subarrays[nn]->groundCoverageRatio, Subarrays[nn]->slopeTilt, Subarrays[nn]->slopeAzm, false, 0.0, angle); + incidence(Subarrays[nn]->trackMode, Subarrays[nn]->tiltDegrees, Subarrays[nn]->azimuthDegrees, Subarrays[nn]->trackerRotationLimitDegrees, sun[1], sun[0], Subarrays[nn]->backtrackingEnabled, Subarrays[nn]->groundCoverageRatio, Subarrays[nn]->slopeTilt, Subarrays[nn]->slopeAzm, false, 0.0, false, 0.0, angle); } else { angle[0] = -999; diff --git a/ssc/cmod_pvsamv1.cpp b/ssc/cmod_pvsamv1.cpp index e5c788a4f..27a04c1fc 100644 --- a/ssc/cmod_pvsamv1.cpp +++ b/ssc/cmod_pvsamv1.cpp @@ -77,6 +77,8 @@ static var_info _cm_vtab_pvsamv1[] = { {SSC_INPUT, SSC_NUMBER, "use_measured_temp", "Use measured temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, {SSC_INPUT, SSC_ARRAY, "measured_temp_array", "Measured module temperature", "C", "", "System Design", "use_measured_temp=1", "", "" }, + {SSC_INPUT, SSC_NUMBER, "use_custom_tilt_angles", "Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + {SSC_INPUT, SSC_ARRAY, "custom_tilt_angles_array", "Custom tracker rotation angles", "deg", "", "System Design", "use_custom_tilt_angles=1", "", "" }, // subarray 1 {SSC_INPUT, SSC_NUMBER, "subarray1_nstrings", "Sub-array 1 Number of parallel strings", "", "", "System Design", "", "INTEGER", "" }, diff --git a/tcs/csp_solver_weatherreader.cpp b/tcs/csp_solver_weatherreader.cpp index fd8cfc159..91efb6c9c 100644 --- a/tcs/csp_solver_weatherreader.cpp +++ b/tcs/csp_solver_weatherreader.cpp @@ -142,7 +142,7 @@ void C_csp_weatherreader::timestep_call(const C_csp_solver_sim_info& p_sim_info) if (sunn[2] > 0.0087) { /* sun elevation > 0.5 degrees */ - incidence(m_trackmode, m_tilt, m_azimuth, 45.0, sunn[1], sunn[0], 0, 0, 0, 0, false, 0.0, angle); + incidence(m_trackmode, m_tilt, m_azimuth, 45.0, sunn[1], sunn[0], 0, 0, 0, 0, false, 0.0, 0.0, 0.0, angle); perez(sunn[8], m_rec.dn, m_rec.df, 0.2, angle[0], angle[1], sunn[1], poa, diffc); // diffuse shading factor not enabled (set to 1.0 by default) } diff --git a/test/shared_test/lib_irradproc_test.cpp b/test/shared_test/lib_irradproc_test.cpp index 23ae9028a..2ec7abf64 100644 --- a/test/shared_test/lib_irradproc_test.cpp +++ b/test/shared_test/lib_irradproc_test.cpp @@ -365,7 +365,7 @@ TEST_F(NightCaseIrradProc, incidenceTest_lib_irradproc) { /* Just before sunrise test case */ sun_azm = 0.95662; sun_zen = 1.79457; - incidence(mode, tilt, azim, rotlim, sun_zen, sun_azm, backtrack_on, gcr, 0, 0, false, 0.0, angle); + incidence(mode, tilt, azim, rotlim, sun_zen, sun_azm, backtrack_on, gcr, 0, 0, false, 0.0, 0.0, 0.0, angle); solutions = { 1.89243, 0.174533, 3.14159, 0, 0 }; for (int i = 0; i < 5; i++) { EXPECT_NEAR(angle[i], solutions[i], e) << "before-sunrise case"; @@ -381,7 +381,7 @@ TEST_F(SunriseCaseIrradProc, incidenceTest_lib_irradproc) { sun_azm = 1.11047; sun_zen = 1.6031; - incidence(mode, tilt, azim, rotlim, sun_zen, sun_azm, backtrack_on, gcr, 0, 0, false, 0.0, angle); + incidence(mode, tilt, azim, rotlim, sun_zen, sun_azm, backtrack_on, gcr, 0, 0, false, 0.0, 0.0, 0.0, angle); solution = 1.67992; EXPECT_NEAR(angle[0], solution, e) << "sunrise case"; } @@ -395,7 +395,7 @@ TEST_F(DayCaseIrradProc, incidenceTest_lib_irradproc) { sun_azm = 0; sun_zen = 0; - incidence(mode, tilt, azim, rotlim, sun_zen, sun_azm, backtrack_on, gcr, 0, 0, false, 0.0, angle); + incidence(mode, tilt, azim, rotlim, sun_zen, sun_azm, backtrack_on, gcr, 0, 0, false, 0.0, 0.0, 0.0, angle); solution = 0.174533; EXPECT_NEAR(angle[0], solution, e) << "noon case"; } @@ -409,7 +409,7 @@ TEST_F(SunsetCaseIrradProc, incidenceTest_lib_irradproc) { sun_azm = 5.13947; sun_zen = 1.55886; - incidence(mode, tilt, azim, rotlim, sun_zen, sun_azm, backtrack_on, gcr, 0, 0, false, 0.0, angle); + incidence(mode, tilt, azim, rotlim, sun_zen, sun_azm, backtrack_on, gcr, 0, 0, false, 0.0, 0.0, 0.0, angle); solution = 1.631; EXPECT_NEAR(angle[0], solution, e) << "sunset case"; } From 0f00de78004bd2eff08ca0d052cf5b68ce3ddf3e Mon Sep 17 00:00:00 2001 From: Matt Prilliman Date: Fri, 20 Oct 2023 13:56:29 -0500 Subject: [PATCH 05/15] Applied user temperatures, tilt angles across subarrays; need to test --- shared/lib_pv_io_manager.cpp | 25 ++++++++++-- shared/lib_pv_io_manager.h | 2 + ssc/cmod_pvsamv1.cpp | 75 +++++++++++++++++++++--------------- 3 files changed, 67 insertions(+), 35 deletions(-) diff --git a/shared/lib_pv_io_manager.cpp b/shared/lib_pv_io_manager.cpp index 8524277f0..42166694c 100644 --- a/shared/lib_pv_io_manager.cpp +++ b/shared/lib_pv_io_manager.cpp @@ -358,7 +358,8 @@ Subarray_IO::Subarray_IO(compute_module* cm, const std::string& cmName, size_t s nModulesPerString = cm->as_integer(prefix + "modules_per_string"); mpptInput = cm->as_integer(prefix + "mppt_input"); trackMode = cm->as_integer(prefix + "track_mode"); - useCustomTiltAngles = cm->as_integer("use_custom_tilt_angles"); + useCustomTiltAngles = cm->as_integer(prefix + "use_custom_tilt_angles"); + useMeasuredTemp = cm->as_integer(prefix + "use_measured_temp"); tiltEqualLatitude = 0; if (cm->is_assigned(prefix + "tilt_eq_lat")) tiltEqualLatitude = cm->as_boolean(prefix + "tilt_eq_lat"); @@ -379,12 +380,28 @@ Subarray_IO::Subarray_IO(compute_module* cm, const std::string& cmName, size_t s } /* Insert checks for custom tilt angles here*/ - if (cm->is_assigned("custom_tilt_angles_array") && useCustomTiltAngles == 1) { - customTiltAngles = cm->as_vector_double("custom_tilt_angles_array"); + if (cm->is_assigned(prefix + "custom_tilt_angles_array") && useCustomTiltAngles == 1) { + customTiltAngles = cm->as_vector_double(prefix + "custom_tilt_angles_array"); for (int i = 0; i < customTiltAngles.size(); i++) { - if (customTiltAngles[i] < 0.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + "custom tilt angles cannot be negative."); + if (customTiltAngles[i] > 90.0 || customTiltAngles[i] < -90.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + "custom tilt angles cannot be outside of 90deg."); } } + else { + throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + " custom rotation angles required but not assigned."); + + } + + /* Insert checks for using measured temperature array*/ + if (cm->is_assigned(prefix + "measured_temp_array") && useMeasuredTemp == 1) { + measuredTempArray = cm->as_vector_double(prefix + "measured_temp_array"); + for (int i = 0; i < measuredTempArray.size(); i++) { + if (measuredTempArray[i] > 100.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + "custom tilt angles cannot be greater than 100degC."); + } + } + else { + throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + " custom rotation angles required but not assigned."); + + } //azimuth required for fixed tilt, single axis, and seasonal tilt- can't check for this in variable table so check here azimuthDegrees = std::numeric_limits::quiet_NaN(); if (trackMode == irrad::FIXED_TILT || trackMode == irrad::SINGLE_AXIS || trackMode == irrad::SEASONAL_TILT) diff --git a/shared/lib_pv_io_manager.h b/shared/lib_pv_io_manager.h index a1a5347ee..9da8bd91d 100644 --- a/shared/lib_pv_io_manager.h +++ b/shared/lib_pv_io_manager.h @@ -467,6 +467,8 @@ struct Subarray_IO double tiltDegrees; // The surface tilt [degrees] flag useCustomTiltAngles; // Use custom timeseries rotation angles std::vector customTiltAngles; //Custom timeseries rotation angles [degrees] + flag useMeasuredTemp; + std::vector measuredTempArray; double azimuthDegrees; // The surface azimuth [degrees] int trackMode; // The tracking mode [0 = fixed, 1 = single-axis tracking, 2 = two-axis tracking, 3 = azimuth-axis tracking, 4 = seasonal-tilt double trackerRotationLimitDegrees; // The rotational limit of the tracker [degrees] diff --git a/ssc/cmod_pvsamv1.cpp b/ssc/cmod_pvsamv1.cpp index 27a04c1fc..b99a8e10f 100644 --- a/ssc/cmod_pvsamv1.cpp +++ b/ssc/cmod_pvsamv1.cpp @@ -94,6 +94,8 @@ static var_info _cm_vtab_pvsamv1[] = { {SSC_INPUT, SSC_NUMBER, "subarray1_slope_tilt", "Sub-array 1 terrain tilt", "degrees", "", "System Design", "subarray1_track_mode=1", "MIN=0,MAX=90", "" }, {SSC_INPUT, SSC_NUMBER, "subarray1_slope_azm", "Sub-array 1 terrain azimuth", "degrees", "", "System Design", "subarray1_track_mode=1", "MIN=0,MAX=359.9", "" }, {SSC_INPUT, SSC_ARRAY, "subarray1_monthly_tilt", "Sub-array 1 monthly tilt input", "degrees", "", "System Design", "subarray1_track_mode=4", "LENGTH=12", "" }, + {SSC_INPUT, SSC_NUMBER, "subarray1_use_custom_tilt_angles", "Sub-array 1 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + {SSC_INPUT, SSC_ARRAY, "subarray1_custom_tilt_angles_array", "Sub-array 1 Custom tracker rotation angles", "deg", "", "System Design", "use_custom_tilt_angles=1", "", "" }, {SSC_INPUT, SSC_NUMBER, "subarray1_shading_en_string_option", "Enable Sub-array 1 shading string option", "0/1", "0=false,1=true", "Shading", "?=0", "BOOLEAN", "" }, {SSC_INPUT, SSC_NUMBER, "subarray1_shading_string_option", "Sub-array 1 shading string option", "", "0=shadingdb,1=average,2=maximum,3=minimum", "Shading", "?=-1", "INTEGER,MIN=-1,MAX=4","" }, @@ -182,6 +184,8 @@ static var_info _cm_vtab_pvsamv1[] = { { SSC_INPUT, SSC_MATRIX, "subarray2_shading_azal", "Sub-array 2 Azimuth x altitude beam shading losses", "%", "", "Shading", "?", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray2_shading_en_diff", "Enable Sub-array 2 Diffuse shading loss", "0/1", "0=false,1=true", "Shading", "?=0", "BOOLEAN", "" }, { SSC_INPUT, SSC_NUMBER, "subarray2_shading_diff", "Sub-array 2 Diffuse shading loss", "%", "", "Shading", "?", "", "" }, + { SSC_INPUT, SSC_NUMBER, "subarray2_use_custom_tilt_angles", "Sub-array 2 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + { SSC_INPUT, SSC_ARRAY, "subarray2_custom_tilt_angles_array", "Sub-array 2 Custom tracker rotation angles", "deg", "", "System Design", "use_custom_tilt_angles=1", "", "" }, @@ -206,6 +210,8 @@ static var_info _cm_vtab_pvsamv1[] = { { SSC_INPUT, SSC_NUMBER, "subarray3_slope_tilt", "Sub-array 3 terrain tilt", "degrees", "", "System Design", "subarray3_enable=1&subarray3_track_mode=1", "MIN=0,MAX=90", "" }, { SSC_INPUT, SSC_NUMBER, "subarray3_slope_azm", "Sub-array 3 terrain azimuth", "degrees", "", "System Design", "subarray3_enable=1&subarray3_track_mode=1", "MIN=0,MAX=359.9", "" }, { SSC_INPUT, SSC_ARRAY, "subarray3_monthly_tilt", "Sub-array 3 Monthly tilt input", "degrees", "", "System Design", "subarray3_enable=1&subarray3_track_mode=4", "LENGTH=12", "" }, + { SSC_INPUT, SSC_NUMBER, "subarray3_use_custom_tilt_angles", "Sub-array 3 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + { SSC_INPUT, SSC_ARRAY, "subarray3_custom_tilt_angles_array", "Sub-array 3 Custom tracker rotation angles", "deg", "", "System Design", "use_custom_tilt_angles=1", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray3_shading_en_string_option", "Enable Sub-array 3 shading string option", "0/1", "0=false,1=true", "Shading", "?=0", "BOOLEAN", "" }, { SSC_INPUT, SSC_NUMBER, "subarray3_shading_string_option", "Sub-array 3 shading string option", "", "0=shadingdb,1=average,2=maximum,3=minimum", "Shading", "?=-1", "INTEGER,MIN=-1,MAX=4","" }, @@ -242,6 +248,8 @@ static var_info _cm_vtab_pvsamv1[] = { { SSC_INPUT, SSC_NUMBER, "subarray4_slope_azm", "Sub-array 4 terrain azimuth", "degrees", "", "System Design", "subarray4_enable=1&subarray4_track_mode=1", "MIN=0,MAX=359.9", "" }, { SSC_INPUT, SSC_ARRAY, "subarray4_monthly_tilt", "Sub-array 4 Monthly tilt input", "degrees", "", "System Design", "subarray2_enable=1&subarray2_track_mode=4", "LENGTH=12", "" }, // { SSC_INPUT, SSC_TABLE, "subarray4_shading", "Sub-array 4 shading losses", "", "", "Shading", "?", "", "" }, + { SSC_INPUT, SSC_NUMBER, "subarray4_use_custom_tilt_angles", "Sub-array 4 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + { SSC_INPUT, SSC_ARRAY, "subarray4_custom_tilt_angles_array", "Sub-array 4 Custom tracker rotation angles", "deg", "", "System Design", "use_custom_tilt_angles=1", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray4_shading_en_string_option", "Enable Sub-array 4 shading string option", "0/1", "0=false,1=true", "Shading", "?=0", "BOOLEAN", "" }, { SSC_INPUT, SSC_NUMBER, "subarray4_shading_string_option", "Sub-array 4 shading string option", "", "0=shadingdb,1=average,2=maximum,3=minimum", "Shading", "?=-1", "INTEGER,MIN=-1,MAX=4","" }, @@ -1116,35 +1124,40 @@ void cm_pvsamv1::exec() double module_watts_stc = Subarrays[0]->Module->moduleWattsSTC; SharedInverter* sharedInverter = PVSystem->m_sharedInverter.get(); - std::vector measured_temp; measured_temp.reserve(nrec); - size_t measured_temp_size; - int use_measured_temp = (as_integer("use_measured_temp") == 1 && is_assigned("measured_temp_array")); - if (as_integer("use_measured_temp") == 1 && is_assigned("measured_temp_array")) { - measured_temp = as_vector_ssc_number_t("measured_temp_array"); - measured_temp_size = measured_temp.size(); - if (measured_temp_size != nrec) - throw exec_error("pvsamv1", "The measured temperature array must be the size of nrecords per year"); - } + - std::vector user_tilt_angles; user_tilt_angles.reserve(nrec); - size_t user_tilt_angles_size; - int use_custom_tilt_angles = (as_integer("use_custom_tilt_angles") == 1 && is_assigned("custom_tilt_angles_array")); - if (as_integer("use_custom_tilt_angles") == 1 && is_assigned("custom_tilt_angles_array")) { - user_tilt_angles = as_vector_ssc_number_t("custom_tilt_angles_array"); - user_tilt_angles_size = user_tilt_angles.size(); - if (user_tilt_angles_size != nrec) - throw exec_error("pvsamv1", "The measured temperature array must be the size of nrecords per year"); - } + //overwrite tilt with latitude if flag is set- can't do this in PVIOManager because need latitude from weather file //also check here for tilt > 0 for tracking systems, since this is a very uncommon configuration but an easy mistake to make for (size_t nn = 0; nn < num_subarrays; nn++) { - if (as_integer("use_custom_tilt_angles") == 1 && is_assigned("custom_tilt_angles_array")) { + std::vector user_tilt_angles; user_tilt_angles.reserve(nrec); + size_t user_tilt_angles_size; + int use_custom_tilt_angles = (as_integer("use_custom_tilt_angles") == 1 && is_assigned("custom_tilt_angles_array")); + if (Subarrays[nn]->useCustomTiltAngles == 1) { + user_tilt_angles = Subarrays[nn]->customTiltAngles; + user_tilt_angles_size = user_tilt_angles.size(); + if (user_tilt_angles_size != nrec) + throw exec_error("pvsamv1", "The custom rotation angle array must be the size of nrecords per year"); + } + + if (Subarrays[nn]->useCustomTiltAngles == 1) { Subarrays[nn]->trackMode = irrad::SINGLE_AXIS; //Subarrays[nn]->tiltDegrees = 0; //reset to 0 to then be replaced in loop? Subarrays[nn]->backtrackingEnabled = false; //account for backtracking in user-specified angles [deg] } + + std::vector measured_temp; measured_temp.reserve(nrec); + size_t measured_temp_size; + int use_measured_temp = (Subarrays[nn]->useMeasuredTemp == 1); + if (as_integer("use_measured_temp") == 1 && is_assigned("measured_temp_array")) { + measured_temp = Subarrays[nn]->measuredTempArray; + measured_temp_size = measured_temp.size(); + if (measured_temp_size != nrec) + throw exec_error("pvsamv1", "The measured temperature array must be the size of nrecords per year"); + } + if (Subarrays[nn]->tiltEqualLatitude) Subarrays[nn]->tiltDegrees = std::abs(Irradiance->weatherHeader.lat); if (Subarrays[nn]->trackMode == irrad::SINGLE_AXIS && Subarrays[nn]->tiltDegrees > 0 && !Subarrays[nn]->Module->isBifacial) @@ -1520,7 +1533,7 @@ void cm_pvsamv1::exec() Irradiance->dtHour, Subarrays[nn]->tiltDegrees, Subarrays[nn]->azimuthDegrees, Subarrays[nn]->trackerRotationLimitDegrees, 0.0, Subarrays[nn]->groundCoverageRatio, Subarrays[nn]->slopeTilt, Subarrays[nn]->slopeAzm, Subarrays[nn]->monthlyTiltDegrees, Irradiance->userSpecifiedMonthlyAlbedo, Subarrays[nn]->poa.poaAll.get(), - Irradiance->useSpatialAlbedos, &Irradiance->userSpecifiedMonthlySpatialAlbedos, as_boolean("enable_subhourly_clipping"), as_boolean("use_custom_tilt_angles"), user_tilt_angles[inrec]); + Irradiance->useSpatialAlbedos, &Irradiance->userSpecifiedMonthlySpatialAlbedos, as_boolean("enable_subhourly_clipping"), Subarrays[nn]->useCustomTiltAngles, Subarrays[nn]->customTiltAngles[inrec]); int code = irr.calc(); @@ -1680,8 +1693,8 @@ void cm_pvsamv1::exec() ((double)wf.hour) + wf.minute / 60.0, radmode, Subarrays[nn]->poa.usePOAFromWF); // voltage set to -1 for max power - if (use_measured_temp == 1) - tcell = measured_temp[inrec]; + if (Subarrays[nn]->useMeasuredTemp == 1) + tcell = Subarrays[nn]->measuredTempArray[inrec]; else (*Subarrays[nn]->Module->cellTempModel)(in, *Subarrays[nn]->Module->moduleModel, -1.0, tcell); } @@ -2085,8 +2098,8 @@ void cm_pvsamv1::exec() { double tcell = wf.tdry; // calculate cell temperature using selected temperature model - if (use_measured_temp == 1) - tcell = measured_temp[inrec]; + if (Subarrays[nn]->useMeasuredTemp == 1) + tcell = Subarrays[nn]->measuredTempArray[inrec]; else (*Subarrays[nn]->Module->cellTempModel)(in, *Subarrays[nn]->Module->moduleModel, V, tcell); // calculate module power output using conversion model previously specified @@ -2144,8 +2157,8 @@ void cm_pvsamv1::exec() if (stringVoltage != -1) module_voltage = stringVoltage / (double)Subarrays[nn]->nModulesPerString; // calculate cell temperature using selected temperature model // calculate module power output using conversion model previously specified - if (use_measured_temp == 1) - tcell = measured_temp[inrec]; + if (Subarrays[nn]->useMeasuredTemp == 1) + tcell = Subarrays[nn]->measuredTempArray[inrec]; else (*Subarrays[nn]->Module->cellTempModel)(in[nn], *Subarrays[nn]->Module->moduleModel, module_voltage, tcell); @@ -2265,8 +2278,8 @@ void cm_pvsamv1::exec() //recalculate power at the correct voltage double module_voltage = avgVoltage / (double)Subarrays[nn]->nModulesPerString; - if (use_measured_temp == 1) - tcell = measured_temp[inrec]; + if (Subarrays[nn]->useMeasuredTemp == 1) + tcell = Subarrays[nn]->measuredTempArray[inrec]; else (*Subarrays[nn]->Module->cellTempModel)(in[nn], *Subarrays[nn]->Module->moduleModel, module_voltage, tcell); (*Subarrays[nn]->Module->moduleModel)(in[nn], tcell, module_voltage, out[nn]); @@ -2307,9 +2320,9 @@ void cm_pvsamv1::exec() Subarrays[nn]->Module->dcPowerW = out[nn].Power; Subarrays[nn]->Module->dcEfficiency = out[nn].Efficiency * 100; Subarrays[nn]->Module->dcVoltage = out[nn].Voltage; - if (use_measured_temp) { - Subarrays[nn]->Module->temperatureCellCelcius = measured_temp[inrec]; - Subarrays[nn]->Module->temperatureCellCelciusSS = measured_temp[inrec]; + if (Subarrays[nn]->useMeasuredTemp) { + Subarrays[nn]->Module->temperatureCellCelcius = Subarrays[nn]->measuredTempArray[inrec]; + Subarrays[nn]->Module->temperatureCellCelciusSS = Subarrays[nn]->measuredTempArray[inrec]; } else { Subarrays[nn]->Module->temperatureCellCelcius = out[nn].CellTemp; From a8563a65cd9d5b6f85e80897b83ca072235abe1a Mon Sep 17 00:00:00 2001 From: Matt Prilliman Date: Fri, 20 Oct 2023 16:07:52 -0500 Subject: [PATCH 06/15] Fix custom angle check for when option is not selected --- shared/lib_pv_io_manager.cpp | 37 ++++++++++++++++++++---------------- ssc/cmod_pvsamv1.cpp | 36 +++++++++++++++++------------------ 2 files changed, 39 insertions(+), 34 deletions(-) diff --git a/shared/lib_pv_io_manager.cpp b/shared/lib_pv_io_manager.cpp index 42166694c..2f3ce272f 100644 --- a/shared/lib_pv_io_manager.cpp +++ b/shared/lib_pv_io_manager.cpp @@ -380,28 +380,33 @@ Subarray_IO::Subarray_IO(compute_module* cm, const std::string& cmName, size_t s } /* Insert checks for custom tilt angles here*/ - if (cm->is_assigned(prefix + "custom_tilt_angles_array") && useCustomTiltAngles == 1) { - customTiltAngles = cm->as_vector_double(prefix + "custom_tilt_angles_array"); - for (int i = 0; i < customTiltAngles.size(); i++) { - if (customTiltAngles[i] > 90.0 || customTiltAngles[i] < -90.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + "custom tilt angles cannot be outside of 90deg."); + if (useCustomTiltAngles == 1) { + if (cm->is_assigned(prefix + "custom_tilt_angles_array")) { + customTiltAngles = cm->as_vector_double(prefix + "custom_tilt_angles_array"); + for (int i = 0; i < customTiltAngles.size(); i++) { + if (customTiltAngles[i] > 90.0 || customTiltAngles[i] < -90.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + "custom tilt angles cannot be outside of 90deg."); + } + } + else { + throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + " custom rotation angles required but not assigned."); } } - else { - throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + " custom rotation angles required but not assigned."); - - } + + /* Insert checks for using measured temperature array*/ - if (cm->is_assigned(prefix + "measured_temp_array") && useMeasuredTemp == 1) { - measuredTempArray = cm->as_vector_double(prefix + "measured_temp_array"); - for (int i = 0; i < measuredTempArray.size(); i++) { - if (measuredTempArray[i] > 100.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + "custom tilt angles cannot be greater than 100degC."); + if (useMeasuredTemp == 1) { + if (cm->is_assigned(prefix + "measured_temp_array")) { + measuredTempArray = cm->as_vector_double(prefix + "measured_temp_array"); + for (int i = 0; i < measuredTempArray.size(); i++) { + if (measuredTempArray[i] > 100.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + "custom tilt angles cannot be greater than 100degC."); + } + } + else { + throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + " custom rotation angles required but not assigned."); } } - else { - throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + " custom rotation angles required but not assigned."); - - } + //azimuth required for fixed tilt, single axis, and seasonal tilt- can't check for this in variable table so check here azimuthDegrees = std::numeric_limits::quiet_NaN(); if (trackMode == irrad::FIXED_TILT || trackMode == irrad::SINGLE_AXIS || trackMode == irrad::SEASONAL_TILT) diff --git a/ssc/cmod_pvsamv1.cpp b/ssc/cmod_pvsamv1.cpp index b99a8e10f..962a79ade 100644 --- a/ssc/cmod_pvsamv1.cpp +++ b/ssc/cmod_pvsamv1.cpp @@ -95,7 +95,9 @@ static var_info _cm_vtab_pvsamv1[] = { {SSC_INPUT, SSC_NUMBER, "subarray1_slope_azm", "Sub-array 1 terrain azimuth", "degrees", "", "System Design", "subarray1_track_mode=1", "MIN=0,MAX=359.9", "" }, {SSC_INPUT, SSC_ARRAY, "subarray1_monthly_tilt", "Sub-array 1 monthly tilt input", "degrees", "", "System Design", "subarray1_track_mode=4", "LENGTH=12", "" }, {SSC_INPUT, SSC_NUMBER, "subarray1_use_custom_tilt_angles", "Sub-array 1 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, - {SSC_INPUT, SSC_ARRAY, "subarray1_custom_tilt_angles_array", "Sub-array 1 Custom tracker rotation angles", "deg", "", "System Design", "use_custom_tilt_angles=1", "", "" }, + {SSC_INPUT, SSC_ARRAY, "subarray1_custom_tilt_angles_array", "Sub-array 1 Custom tracker rotation angles", "deg", "", "System Design", "subarray1_use_custom_tilt_angles=1", "", "" }, + {SSC_INPUT, SSC_NUMBER, "subarray1_use_measured_temp", "Subarray 1 Use measured temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + {SSC_INPUT, SSC_ARRAY, "subarray1_measured_temp_array", "Subarray 1 Measured module temperature", "C", "", "System Design", "subarray1_use_measured_temp=1", "", "" }, {SSC_INPUT, SSC_NUMBER, "subarray1_shading_en_string_option", "Enable Sub-array 1 shading string option", "0/1", "0=false,1=true", "Shading", "?=0", "BOOLEAN", "" }, {SSC_INPUT, SSC_NUMBER, "subarray1_shading_string_option", "Sub-array 1 shading string option", "", "0=shadingdb,1=average,2=maximum,3=minimum", "Shading", "?=-1", "INTEGER,MIN=-1,MAX=4","" }, @@ -185,7 +187,9 @@ static var_info _cm_vtab_pvsamv1[] = { { SSC_INPUT, SSC_NUMBER, "subarray2_shading_en_diff", "Enable Sub-array 2 Diffuse shading loss", "0/1", "0=false,1=true", "Shading", "?=0", "BOOLEAN", "" }, { SSC_INPUT, SSC_NUMBER, "subarray2_shading_diff", "Sub-array 2 Diffuse shading loss", "%", "", "Shading", "?", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray2_use_custom_tilt_angles", "Sub-array 2 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, - { SSC_INPUT, SSC_ARRAY, "subarray2_custom_tilt_angles_array", "Sub-array 2 Custom tracker rotation angles", "deg", "", "System Design", "use_custom_tilt_angles=1", "", "" }, + { SSC_INPUT, SSC_ARRAY, "subarray2_custom_tilt_angles_array", "Sub-array 2 Custom tracker rotation angles", "deg", "", "System Design", "subarray2_use_custom_tilt_angles=1", "", "" }, + { SSC_INPUT, SSC_NUMBER, "subarray2_use_measured_temp", "Subarray 2 Use measured temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + { SSC_INPUT, SSC_ARRAY, "subarray2_measured_temp_array", "Subarray 2 Measured module temperature", "C", "", "System Design", "subarray2_use_measured_temp=1", "", "" }, @@ -211,7 +215,9 @@ static var_info _cm_vtab_pvsamv1[] = { { SSC_INPUT, SSC_NUMBER, "subarray3_slope_azm", "Sub-array 3 terrain azimuth", "degrees", "", "System Design", "subarray3_enable=1&subarray3_track_mode=1", "MIN=0,MAX=359.9", "" }, { SSC_INPUT, SSC_ARRAY, "subarray3_monthly_tilt", "Sub-array 3 Monthly tilt input", "degrees", "", "System Design", "subarray3_enable=1&subarray3_track_mode=4", "LENGTH=12", "" }, { SSC_INPUT, SSC_NUMBER, "subarray3_use_custom_tilt_angles", "Sub-array 3 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, - { SSC_INPUT, SSC_ARRAY, "subarray3_custom_tilt_angles_array", "Sub-array 3 Custom tracker rotation angles", "deg", "", "System Design", "use_custom_tilt_angles=1", "", "" }, + { SSC_INPUT, SSC_ARRAY, "subarray3_custom_tilt_angles_array", "Sub-array 3 Custom tracker rotation angles", "deg", "", "System Design", "subarray3_use_custom_tilt_angles=1", "", "" }, + { SSC_INPUT, SSC_NUMBER, "subarray3_use_measured_temp", "Subarray 3 Use measured temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + { SSC_INPUT, SSC_ARRAY, "subarray3_measured_temp_array", "Subarray 3 Measured module temperature", "C", "", "System Design", "subarray3_use_measured_temp=1", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray3_shading_en_string_option", "Enable Sub-array 3 shading string option", "0/1", "0=false,1=true", "Shading", "?=0", "BOOLEAN", "" }, { SSC_INPUT, SSC_NUMBER, "subarray3_shading_string_option", "Sub-array 3 shading string option", "", "0=shadingdb,1=average,2=maximum,3=minimum", "Shading", "?=-1", "INTEGER,MIN=-1,MAX=4","" }, @@ -249,7 +255,9 @@ static var_info _cm_vtab_pvsamv1[] = { { SSC_INPUT, SSC_ARRAY, "subarray4_monthly_tilt", "Sub-array 4 Monthly tilt input", "degrees", "", "System Design", "subarray2_enable=1&subarray2_track_mode=4", "LENGTH=12", "" }, // { SSC_INPUT, SSC_TABLE, "subarray4_shading", "Sub-array 4 shading losses", "", "", "Shading", "?", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray4_use_custom_tilt_angles", "Sub-array 4 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, - { SSC_INPUT, SSC_ARRAY, "subarray4_custom_tilt_angles_array", "Sub-array 4 Custom tracker rotation angles", "deg", "", "System Design", "use_custom_tilt_angles=1", "", "" }, + { SSC_INPUT, SSC_ARRAY, "subarray4_custom_tilt_angles_array", "Sub-array 4 Custom tracker rotation angles", "deg", "", "System Design", "subarray4_use_custom_tilt_angles=1", "", "" }, + { SSC_INPUT, SSC_NUMBER, "subarray4_use_measured_temp", "Subarray 4 Use measured temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + { SSC_INPUT, SSC_ARRAY, "subarray4_measured_temp_array", "Subarray 4 Measured module temperature", "C", "", "System Design", "subarray4_use_measured_temp=1", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray4_shading_en_string_option", "Enable Sub-array 4 shading string option", "0/1", "0=false,1=true", "Shading", "?=0", "BOOLEAN", "" }, { SSC_INPUT, SSC_NUMBER, "subarray4_shading_string_option", "Sub-array 4 shading string option", "", "0=shadingdb,1=average,2=maximum,3=minimum", "Shading", "?=-1", "INTEGER,MIN=-1,MAX=4","" }, @@ -1132,28 +1140,20 @@ void cm_pvsamv1::exec() //also check here for tilt > 0 for tracking systems, since this is a very uncommon configuration but an easy mistake to make for (size_t nn = 0; nn < num_subarrays; nn++) { - std::vector user_tilt_angles; user_tilt_angles.reserve(nrec); size_t user_tilt_angles_size; - int use_custom_tilt_angles = (as_integer("use_custom_tilt_angles") == 1 && is_assigned("custom_tilt_angles_array")); if (Subarrays[nn]->useCustomTiltAngles == 1) { - user_tilt_angles = Subarrays[nn]->customTiltAngles; - user_tilt_angles_size = user_tilt_angles.size(); + user_tilt_angles_size = Subarrays[nn]->customTiltAngles.size(); if (user_tilt_angles_size != nrec) throw exec_error("pvsamv1", "The custom rotation angle array must be the size of nrecords per year"); - } - - if (Subarrays[nn]->useCustomTiltAngles == 1) { Subarrays[nn]->trackMode = irrad::SINGLE_AXIS; //Subarrays[nn]->tiltDegrees = 0; //reset to 0 to then be replaced in loop? Subarrays[nn]->backtrackingEnabled = false; //account for backtracking in user-specified angles [deg] + } - std::vector measured_temp; measured_temp.reserve(nrec); size_t measured_temp_size; - int use_measured_temp = (Subarrays[nn]->useMeasuredTemp == 1); - if (as_integer("use_measured_temp") == 1 && is_assigned("measured_temp_array")) { - measured_temp = Subarrays[nn]->measuredTempArray; - measured_temp_size = measured_temp.size(); + if (Subarrays[nn]->useMeasuredTemp == 1) { + measured_temp_size = Subarrays[nn]->measuredTempArray.size(); if (measured_temp_size != nrec) throw exec_error("pvsamv1", "The measured temperature array must be the size of nrecords per year"); } @@ -1526,14 +1526,14 @@ void cm_pvsamv1::exec() Subarrays[nn]->tiltDegrees = user_tilt_angles[inrec]; }*/ - + double custom_tilt = (Subarrays[nn]->useCustomTiltAngles) ? Subarrays[nn]->customTiltAngles[inrec] : 0.0; irrad irr(Irradiance->weatherRecord, Irradiance->weatherHeader, Irradiance->skyModel, Irradiance->radiationMode, Subarrays[nn]->trackMode, Irradiance->useWeatherFileAlbedo, Irradiance->instantaneous, Subarrays[nn]->backtrackingEnabled, false, Irradiance->dtHour, Subarrays[nn]->tiltDegrees, Subarrays[nn]->azimuthDegrees, Subarrays[nn]->trackerRotationLimitDegrees, 0.0, Subarrays[nn]->groundCoverageRatio, Subarrays[nn]->slopeTilt, Subarrays[nn]->slopeAzm, Subarrays[nn]->monthlyTiltDegrees, Irradiance->userSpecifiedMonthlyAlbedo, Subarrays[nn]->poa.poaAll.get(), - Irradiance->useSpatialAlbedos, &Irradiance->userSpecifiedMonthlySpatialAlbedos, as_boolean("enable_subhourly_clipping"), Subarrays[nn]->useCustomTiltAngles, Subarrays[nn]->customTiltAngles[inrec]); + Irradiance->useSpatialAlbedos, &Irradiance->userSpecifiedMonthlySpatialAlbedos, as_boolean("enable_subhourly_clipping"), Subarrays[nn]->useCustomTiltAngles, custom_tilt); int code = irr.calc(); From 5d389f2c0dea6439e2907bf3184fb5bbb06c1be2 Mon Sep 17 00:00:00 2001 From: Matt Prilliman Date: Tue, 24 Oct 2023 10:19:15 -0500 Subject: [PATCH 07/15] Add ssc tests --- test/input_cases/pvsamv1_common_data.cpp | 6 + .../pvsamv1_data/custom_rot_angle_array.csv | 8760 +++++++++++++++++ .../pvsamv1_data/measured_temp_array.csv | 8760 +++++++++++++++++ test/ssc_test/cmod_pvsamv1_test.cpp | 57 + 4 files changed, 17583 insertions(+) create mode 100644 test/input_cases/pvsamv1_data/custom_rot_angle_array.csv create mode 100644 test/input_cases/pvsamv1_data/measured_temp_array.csv diff --git a/test/input_cases/pvsamv1_common_data.cpp b/test/input_cases/pvsamv1_common_data.cpp index 4f2ff1395..c72b59fcc 100644 --- a/test/input_cases/pvsamv1_common_data.cpp +++ b/test/input_cases/pvsamv1_common_data.cpp @@ -42,6 +42,8 @@ char subarray1_shading[256] = {}; char subarray2_shading[256] = {}; char temperature_path[256] = {}; char solar_resource_path_15min_fail[256] = {}; +char measured_temp_array_path[256] = {}; +char custom_rot_angle_array_path[256] = {}; int n1 = sprintf(solar_resource_path, "%s/test/input_cases/pvsamv1_data/USA AZ Phoenix (TMY2).csv", SSCDIR); int n2 = sprintf(load_profile_path, "%s/test/input_cases/pvsamv1_data/pvsamv1_residential_load.csv", SSCDIR); @@ -52,6 +54,8 @@ int n6 = sprintf(subarray1_shading, "%s/test/input_cases/pvsamv1_data/subarray1_ int n7 = sprintf(subarray2_shading, "%s/test/input_cases/pvsamv1_data/subarray2_shading_timestep.csv", SSCDIR); int n8 = sprintf(temperature_path, "%s/test/input_cases/battery_data/batt_room_temperature_celsius_60min.csv", SSCDIR); int n9 = sprintf(solar_resource_path_15min_fail, "%s/test/input_cases/pvsamv1_data/LosAngeles_WeatherFile_15min_timestamp_fail.csv", SSCDIR); +int n10 = sprintf(measured_temp_array_path, "%s/test/input_cases/pvsamv1_data/measured_temp_array.csv", SSCDIR); +int n11 = sprintf(custom_rot_angle_array_path, "%s/test/input_cases/pvsamv1_data/custom_rot_angle_array.csv", SSCDIR); /** @@ -100,6 +104,8 @@ void pvsamv_nofinancial_default(ssc_data_t& data) ssc_data_set_number(data, "subarray1_dcwiring_loss", 2); ssc_data_set_number(data, "subarray1_tracking_loss", 0); ssc_data_set_number(data, "subarray1_nameplate_loss", 0); + set_array(data, "subarray1_measured_temp_array", measured_temp_array_path, 8760); + set_array(data, "subarray1_custom_tilt_angles_array", custom_rot_angle_array_path, 8760); ssc_data_set_number(data, "subarray2_rear_soiling_loss", 0); ssc_data_set_number(data, "subarray2_rack_shading", 0); ssc_data_set_number(data, "subarray2_electrical_mismatch", 0); diff --git a/test/input_cases/pvsamv1_data/custom_rot_angle_array.csv b/test/input_cases/pvsamv1_data/custom_rot_angle_array.csv new file mode 100644 index 000000000..e7fd0dc85 --- /dev/null +++ b/test/input_cases/pvsamv1_data/custom_rot_angle_array.csv @@ -0,0 +1,8760 @@ +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-24.8588 +-0.582814 +23.7758 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-25.0015 +-0.776579 +23.5585 +44.9413 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-25.1381 +-0.967027 +23.3409 +44.7292 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-25.2684 +-1.15392 +23.1235 +44.515 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-25.3923 +-1.33698 +22.9062 +44.298 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-25.5097 +-1.51603 +22.6897 +44.0793 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-25.6203 +-1.69082 +22.4738 +43.8587 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-25.724 +-1.86116 +22.259 +43.6363 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-25.8208 +-2.02688 +22.0456 +43.4127 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-25.9111 +-2.18785 +21.834 +43.1885 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-25.9944 +-2.3439 +21.6244 +42.9638 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-26.0706 +-2.49485 +21.4166 +42.7381 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-26.1401 +-2.6406 +21.2112 +42.5122 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-26.2027 +-2.78103 +21.0083 +42.2864 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-26.2579 +-2.91597 +20.808 +42.0604 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-26.306 +-3.04542 +20.6109 +41.8354 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-26.3474 +-3.16918 +20.4168 +41.6106 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-26.3817 +-3.28721 +20.2262 +41.3871 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-26.4091 +-3.39947 +20.0392 +41.1651 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-26.4298 +-3.5058 +19.8559 +40.9441 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-26.4432 +-3.60617 +19.6764 +40.7247 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-26.4493 +-3.70047 +19.5006 +40.5063 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-26.4491 +-3.78878 +19.3294 +40.2907 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-26.4421 +-3.87102 +19.1627 +40.0779 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-26.4281 +-3.94712 +19.0003 +39.8668 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-26.4077 +-4.01714 +18.8427 +39.6591 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-26.3805 +-4.08104 +18.6895 +39.4532 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-26.3469 +-4.13882 +18.5411 +39.2505 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-26.3069 +-4.19058 +18.3977 +39.051 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-26.2606 +-4.23634 +18.2591 +38.8547 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-26.2081 +-4.27615 +18.1253 +38.6615 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-26.1168 +-4.33944 +17.9044 +38.3396 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-26.0485 +-4.36382 +17.7839 +38.1558 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-25.9746 +-4.38258 +17.6683 +37.9755 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-25.8952 +-4.39585 +17.5577 +37.799 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.9785 +-25.8104 +-4.40369 +17.4518 +37.6259 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.8303 +-25.7201 +-4.40623 +17.3507 +37.4563 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.677 +-25.6247 +-4.40365 +17.2542 +37.2901 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.518 +-25.5241 +-4.39601 +17.1621 +37.1271 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.3554 +-25.4193 +-4.38364 +17.0749 +36.9686 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.1891 +-25.3104 +-4.36665 +16.9924 +36.8142 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.0177 +-25.1968 +-4.34506 +16.9142 +36.663 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.8429 +-25.0791 +-4.3191 +16.8403 +36.5155 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.6637 +-24.9573 +-4.28886 +16.7703 +36.3709 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.4804 +-24.8315 +-4.25451 +16.7047 +36.2304 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.2938 +-24.7022 +-4.21624 +16.643 +36.0934 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.1041 +-24.5696 +-4.17418 +16.5855 +35.96 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.9113 +-24.4337 +-4.12846 +16.5318 +35.8301 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.7152 +-24.2945 +-4.07917 +16.4818 +35.7039 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.516 +-24.1522 +-4.02642 +16.4356 +35.5806 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.314 +-24.0069 +-3.97039 +16.3928 +35.4605 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.1093 +-23.8589 +-3.91118 +16.3536 +35.3439 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-41.9022 +-23.7083 +-3.84892 +16.3178 +35.2306 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-41.6923 +-23.555 +-3.78369 +16.2852 +35.1203 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-41.48 +-23.3993 +-3.71563 +16.2559 +35.0132 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-41.2657 +-23.2414 +-3.64487 +16.2297 +34.9094 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-41.0498 +-23.0817 +-3.57161 +16.2069 +34.8089 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-40.8318 +-22.9198 +-3.49586 +16.1869 +34.7112 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-40.6114 +-22.7557 +-3.41773 +16.1695 +34.616 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-40.5037 +-22.6748 +-3.37777 +16.1638 +34.573 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-40.2816 +-22.5084 +-3.29609 +16.1511 +34.483 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-40.0578 +-22.3405 +-3.21252 +16.1408 +34.3955 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-39.8326 +-22.1711 +-3.1272 +16.1327 +34.3102 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-39.6068 +-22.0009 +-3.04034 +16.127 +34.2278 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-39.3801 +-21.8298 +-2.95205 +16.1234 +34.1477 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-39.1522 +-21.6576 +-2.86244 +16.1214 +34.0692 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-38.9241 +-21.485 +-2.77172 +16.1215 +33.9936 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-38.6961 +-21.3122 +-2.68 +16.1233 +33.92 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-38.4675 +-21.1387 +-2.58737 +16.1266 +33.8482 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-38.2385 +-20.965 +-2.49395 +16.1313 +33.778 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-38.0095 +-20.7912 +-2.39988 +16.1374 +33.7098 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-37.7808 +-20.6174 +-2.30527 +16.1449 +33.6435 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-37.5526 +-20.4439 +-2.21021 +16.1536 +33.5788 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-37.324 +-20.2703 +-2.11475 +16.1632 +33.5153 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-37.0957 +-20.0968 +-2.01903 +16.1737 +33.453 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-36.8683 +-19.924 +-1.92314 +16.1852 +33.3924 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-36.6416 +-19.7517 +-1.82718 +16.1977 +33.3337 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-36.4157 +-19.58 +-1.73123 +16.2111 +33.2761 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-36.1906 +-19.409 +-1.63534 +16.2251 +33.2196 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-35.9663 +-19.2386 +-1.53961 +16.2395 +33.164 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-35.7429 +-19.0691 +-1.44415 +16.2545 +33.1096 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-35.5205 +-18.9004 +-1.34902 +16.2698 +33.0561 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-35.2995 +-18.7329 +-1.25434 +16.2857 +33.0037 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-35.0798 +-18.5665 +-1.16018 +16.3017 +32.9521 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-34.8611 +-18.4012 +-1.06663 +16.3178 +32.9011 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-34.6443 +-18.2373 +-0.973808 +16.3341 +32.8508 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-34.429 +-18.0748 +-0.881794 +16.3503 +32.8013 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-34.2159 +-17.914 +-0.790698 +16.3666 +32.7523 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-34.0041 +-17.7547 +-0.700598 +16.3825 +32.7036 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-33.7941 +-17.5969 +-0.611595 +16.398 +32.6551 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-33.5675 +-17.4275 +-0.517026 +16.4127 +32.6002 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-33.3628 +-17.2746 +-0.43154 +16.4264 +32.5513 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-33.1601 +-17.1236 +-0.347409 +16.4395 +32.5022 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.9597 +-16.9747 +-0.264687 +16.4521 +32.4534 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.7622 +-16.828 +-0.183424 +16.4641 +32.4048 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.5668 +-16.6834 +-0.103663 +16.4753 +32.356 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.3738 +-16.5409 +-0.0254527 +16.4858 +32.3071 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.1833 +-16.4007 +0.0511593 +16.4954 +32.258 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.9951 +-16.2626 +0.126123 +16.504 +32.2083 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.8102 +-16.1271 +0.199393 +16.5121 +32.1592 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.6281 +-15.9942 +0.270919 +16.5193 +32.11 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.4487 +-15.8636 +0.340645 +16.5254 +32.0602 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.272 +-15.7355 +0.408519 +16.5304 +32.0099 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.098 +-15.6099 +0.474482 +16.5344 +31.9593 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-30.9274 +-15.4871 +0.538489 +16.5372 +31.9083 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-30.7599 +-15.367 +0.600477 +16.5389 +31.8569 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-30.5953 +-15.2496 +0.660388 +16.5392 +31.8048 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.8251 +-30.4338 +-15.1349 +0.71817 +16.5383 +31.7521 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.6332 +-30.2757 +-15.0231 +0.773772 +16.5358 +31.6985 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.4449 +-30.1209 +-14.9143 +0.827148 +16.5321 +31.6445 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.2599 +-29.9694 +-14.8085 +0.878247 +16.5269 +31.5897 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.0785 +-29.8214 +-14.7056 +0.927031 +16.5202 +31.5341 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.9008 +-29.6768 +-14.6059 +0.973463 +16.512 +31.4777 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.7266 +-29.5358 +-14.5092 +1.01751 +16.5022 +31.4205 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.5563 +-29.3984 +-14.4156 +1.05915 +16.4909 +31.3625 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.3898 +-29.2646 +-14.3252 +1.09837 +16.478 +31.3037 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.227 +-29.1344 +-14.238 +1.13514 +16.4634 +31.2439 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.0683 +-29.008 +-14.154 +1.16948 +16.4474 +31.1833 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.9133 +-28.8851 +-14.0731 +1.20136 +16.4296 +31.1219 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.7621 +-28.7659 +-13.9954 +1.2308 +16.4102 +31.0594 +44.9036 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.5485 +-28.5961 +-13.8825 +1.27748 +16.3898 +30.9795 +44.7767 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.4066 +-28.4853 +-13.8119 +1.30175 +16.3673 +30.9159 +44.6805 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.268 +-28.3779 +-13.7443 +1.32367 +16.3433 +30.8513 +44.5837 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.1339 +-28.2745 +-13.6799 +1.34325 +16.3179 +30.7864 +44.4873 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.004 +-28.1748 +-13.6187 +1.36049 +16.2911 +30.7208 +44.3909 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-41.8782 +-28.0789 +-13.5607 +1.37538 +16.2628 +30.6545 +44.2944 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-41.7563 +-27.9868 +-13.5058 +1.38789 +16.233 +30.5874 +44.1977 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-41.6387 +-27.8984 +-13.4541 +1.39804 +16.2017 +30.5197 +44.1009 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-41.5251 +-27.8137 +-13.4055 +1.40581 +16.1689 +30.4511 +44.0039 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-41.4157 +-27.7327 +-13.3602 +1.4112 +16.1345 +30.3819 +43.9067 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-41.3103 +-27.6556 +-13.318 +1.41423 +16.0987 +30.312 +43.8096 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-41.2093 +-27.5823 +-13.2789 +1.4149 +16.0614 +30.2414 +43.7122 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-41.1124 +-27.5128 +-13.2431 +1.41322 +16.0227 +30.1701 +43.6149 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-41.0198 +-27.4472 +-13.2104 +1.40922 +15.9825 +30.0982 +43.5177 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.9315 +-27.3853 +-13.1809 +1.40292 +15.941 +30.0258 +43.4206 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.8475 +-27.3273 +-13.1545 +1.39435 +15.8981 +29.9529 +43.3235 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.7677 +-27.273 +-13.1312 +1.38354 +15.8538 +29.8794 +43.2267 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.6921 +-27.2225 +-13.111 +1.37055 +15.8083 +29.8055 +43.1301 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.6203 +-27.1755 +-13.0936 +1.3554 +15.7615 +29.7311 +43.0334 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.5533 +-27.1325 +-13.0794 +1.33817 +15.7137 +29.6566 +42.9377 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.4904 +-27.093 +-13.0681 +1.31891 +15.6647 +29.5818 +42.8421 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.4316 +-27.0572 +-13.0596 +1.29768 +15.6147 +29.5068 +42.7471 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.3769 +-27.025 +-13.054 +1.27453 +15.5637 +29.4317 +42.6527 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.3262 +-26.9961 +-13.051 +1.24953 +15.5118 +29.3565 +42.5588 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.2796 +-26.9708 +-13.0508 +1.22275 +15.459 +29.2813 +42.4656 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.2369 +-26.9488 +-13.0532 +1.19425 +15.4055 +29.2061 +42.3733 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.1981 +-26.9302 +-13.0582 +1.16411 +15.3513 +29.1313 +42.282 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.1631 +-26.9148 +-13.0656 +1.13238 +15.2964 +29.0566 +42.1914 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.1322 +-26.9028 +-13.0756 +1.09913 +15.241 +28.9822 +42.102 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.1054 +-26.8941 +-13.088 +1.06443 +15.1852 +28.9084 +42.0139 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.0822 +-26.8885 +-13.1027 +1.02832 +15.1289 +28.835 +41.9269 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.063 +-26.8877 +-13.123 +0.985945 +15.0659 +28.7544 +41.8326 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.0479 +-26.8889 +-13.1428 +0.946717 +15.0085 +28.6818 +41.7479 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.0366 +-26.8932 +-13.1649 +0.906128 +14.9507 +28.6097 +41.6644 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.0292 +-26.9006 +-13.1893 +0.864264 +14.8927 +28.5381 +41.5823 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.0255 +-26.9111 +-13.2158 +0.821202 +14.8344 +28.4672 +41.5017 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.0254 +-26.9246 +-13.2445 +0.777025 +14.7761 +28.3974 +41.4229 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.0289 +-26.9409 +-13.2751 +0.731822 +14.7178 +28.3282 +41.3456 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.0358 +-26.9599 +-13.3077 +0.685674 +14.6594 +28.2599 +41.2698 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.0461 +-26.9817 +-13.3421 +0.638684 +14.6012 +28.1928 +41.1959 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.0599 +-27.0061 +-13.3782 +0.590939 +14.5432 +28.1268 +41.124 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.0769 +-27.033 +-13.416 +0.542533 +14.4856 +28.0621 +41.0541 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.0971 +-27.0624 +-13.4553 +0.493556 +14.4284 +27.9987 +40.9864 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.1204 +-27.0941 +-13.4961 +0.444099 +14.3718 +27.9367 +40.9207 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.1467 +-27.1282 +-13.5383 +0.394251 +14.3157 +27.8763 +40.8576 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.176 +-27.1645 +-13.5819 +0.344098 +14.2604 +27.8175 +40.7966 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.2083 +-27.2029 +-13.6266 +0.29372 +14.2058 +27.7604 +40.7382 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.2433 +-27.2433 +-13.6725 +0.243197 +14.1521 +27.7051 +40.6823 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.2811 +-27.2858 +-13.7195 +0.192605 +14.0994 +27.6516 +40.6292 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.3215 +-27.3301 +-13.7675 +0.142016 +14.0476 +27.6001 +40.5785 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.3646 +-27.3763 +-13.8164 +0.0915009 +13.9969 +27.5505 +40.5307 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.4103 +-27.4243 +-13.8662 +0.041126 +13.9474 +27.5029 +40.4855 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.4584 +-27.474 +-13.9167 +-0.00904311 +13.899 +27.4574 +40.4434 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.509 +-27.5254 +-13.968 +-0.0589425 +13.852 +27.4142 +40.4042 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.562 +-27.5783 +-14.02 +-0.108509 +13.8062 +27.3731 +40.3677 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.6172 +-27.6328 +-14.0726 +-0.157678 +13.7619 +27.3343 +40.3346 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.6748 +-27.6888 +-14.1258 +-0.206387 +13.719 +27.298 +40.3045 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.7346 +-27.7462 +-14.1794 +-0.254571 +13.6777 +27.2641 +40.2776 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.7965 +-27.805 +-14.2335 +-0.302162 +13.638 +27.2327 +40.254 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.8605 +-27.865 +-14.2879 +-0.349089 +13.5999 +27.2038 +40.2336 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-40.9262 +-27.9261 +-14.3425 +-0.395279 +13.5635 +27.1774 +40.2165 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-41.0011 +-27.9956 +-14.4045 +-0.447473 +13.5226 +27.148 +40.1976 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-41.0704 +-28.0586 +-14.4592 +-0.491695 +13.4901 +27.1273 +40.1876 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-41.1413 +-28.1225 +-14.5137 +-0.534794 +13.4598 +27.1096 +40.1812 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-41.2137 +-28.1871 +-14.5681 +-0.576701 +13.4316 +27.095 +40.1787 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-41.2875 +-28.2523 +-14.6222 +-0.617353 +13.4057 +27.0834 +40.1798 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-41.3626 +-28.3181 +-14.676 +-0.656689 +13.382 +27.0749 +40.1847 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-41.4392 +-28.3844 +-14.7295 +-0.694658 +13.3607 +27.0696 +40.1936 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-41.5168 +-28.4512 +-14.7824 +-0.7312 +13.3416 +27.0674 +40.206 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-41.5954 +-28.5182 +-14.8348 +-0.766269 +13.325 +27.0685 +40.2224 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-41.6752 +-28.5856 +-14.8866 +-0.799816 +13.3109 +27.0728 +40.2428 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-41.7561 +-28.6535 +-14.9379 +-0.831797 +13.2993 +27.0805 +40.2671 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-41.8382 +-28.7216 +-14.9886 +-0.862163 +13.2903 +27.0916 +40.2955 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-41.921 +-28.7898 +-15.0385 +-0.890863 +13.2838 +27.106 +40.3278 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-42.0047 +-28.8582 +-15.0877 +-0.917851 +13.28 +27.1238 +40.3641 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-42.0892 +-28.9266 +-15.1361 +-0.943076 +13.2788 +27.145 +40.4045 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-42.1743 +-28.9949 +-15.1836 +-0.966484 +13.2803 +27.1697 +40.4487 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.2599 +-29.0631 +-15.2301 +-0.988021 +13.2846 +27.1979 +40.4971 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.3466 +-29.1314 +-15.2757 +-1.00764 +13.2918 +27.2298 +40.5499 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.4335 +-29.1995 +-15.3203 +-1.02528 +13.3018 +27.2653 +40.6067 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.521 +-29.2673 +-15.3637 +-1.04088 +13.3148 +27.3044 +40.6678 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.6088 +-29.3348 +-15.406 +-1.05439 +13.3307 +27.3472 +40.733 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.697 +-29.4019 +-15.4471 +-1.06574 +13.3497 +27.3938 +40.8025 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.7853 +-29.4685 +-15.4868 +-1.07487 +13.3717 +27.4441 +40.8762 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.8734 +-29.5344 +-15.525 +-1.08171 +13.3967 +27.4979 +40.9538 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.9623 +-29.6001 +-15.5621 +-1.08625 +13.4251 +27.5561 +41.0365 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.0511 +-29.6651 +-15.5976 +-1.08841 +13.4567 +27.6179 +41.1232 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.1397 +-29.7293 +-15.6316 +-1.08813 +13.4915 +27.6838 +41.2143 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.2278 +-29.7924 +-15.6638 +-1.08537 +13.5295 +27.7531 +41.3092 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.3162 +-29.8552 +-15.6946 +-1.08011 +13.571 +27.8269 +41.4092 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.4043 +-29.9169 +-15.7237 +-1.07231 +13.6157 +27.9046 +41.5133 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.4923 +-29.9779 +-15.7512 +-1.06193 +13.6639 +27.9863 +41.622 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.5484 +-30.0162 +-15.7674 +-1.05319 +13.6975 +28.0418 +41.6951 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.636 +-30.0757 +-15.792 +-1.0386 +13.7513 +28.13 +41.8107 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.7232 +-30.1342 +-15.8149 +-1.02139 +13.8084 +28.2221 +41.9307 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.8098 +-30.1917 +-15.836 +-1.00153 +13.8688 +28.3181 +42.0549 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.8964 +-30.2483 +-15.8554 +-0.97905 +13.9328 +28.4182 +42.1835 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.9824 +-30.3038 +-15.8729 +-0.953928 +14.0001 +28.5223 +42.3163 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.0681 +-30.3583 +-15.8887 +-0.92617 +14.0708 +28.6302 +42.4533 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.1532 +-30.4118 +-15.9027 +-0.895788 +14.1449 +28.7419 +42.5944 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.2378 +-30.4642 +-15.9149 +-0.86279 +14.2223 +28.8575 +42.7395 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.322 +-30.5157 +-15.9253 +-0.827197 +14.303 +28.9769 +42.8888 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.4059 +-30.5662 +-15.934 +-0.789024 +14.3871 +29.1002 +43.0421 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.4894 +-30.6158 +-15.941 +-0.748288 +14.4744 +29.2273 +43.1995 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.5726 +-30.6644 +-15.9463 +-0.705008 +14.5651 +29.3581 +43.3609 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.6553 +-30.712 +-15.9498 +-0.659198 +14.6589 +29.4926 +43.5262 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.7375 +-30.7587 +-15.9517 +-0.610875 +14.756 +29.6306 +43.6951 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.8195 +-30.8045 +-15.9519 +-0.560063 +14.8563 +29.7726 +43.8681 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.9011 +-30.8494 +-15.9505 +-0.50677 +14.9598 +29.918 +44.0449 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.9824 +-30.8934 +-15.9475 +-0.451011 +15.0665 +30.0671 +44.2253 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-30.9366 +-15.9428 +-0.392799 +15.1762 +30.2197 +44.4094 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-30.9786 +-15.9364 +-0.332143 +15.2891 +30.3756 +44.5969 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.02 +-15.9284 +-0.269058 +15.4051 +30.5352 +44.7883 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.0602 +-15.9188 +-0.203552 +15.5241 +30.6981 +44.9829 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.0998 +-15.9076 +-0.135641 +15.6463 +30.8647 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.1384 +-15.8948 +-0.0653338 +15.7715 +31.0344 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.1762 +-15.8805 +0.00735267 +15.8997 +31.2076 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.2132 +-15.8646 +0.0824009 +16.0309 +31.3842 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.2494 +-15.8472 +0.15979 +16.1652 +31.5641 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.2848 +-15.8282 +0.239494 +16.3023 +31.7472 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.3193 +-15.8077 +0.321482 +16.4423 +31.9333 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.353 +-15.7858 +0.405719 +16.5852 +32.1227 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.386 +-15.7624 +0.492165 +16.7309 +32.3151 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.4076 +-15.7428 +0.557823 +16.8396 +32.4575 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.4399 +-15.7174 +0.647668 +16.9898 +32.6549 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.4716 +-15.6908 +0.739588 +17.1426 +32.8552 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.5025 +-15.6628 +0.833531 +17.298 +33.0582 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.5331 +-15.6336 +0.929443 +17.456 +33.2639 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.5632 +-15.6034 +1.02726 +17.6164 +33.4724 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.5929 +-15.5721 +1.12691 +17.7793 +33.6835 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.6224 +-15.5398 +1.22833 +17.9445 +33.8971 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.6515 +-15.5065 +1.33143 +18.1118 +34.113 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.6805 +-15.4725 +1.43613 +18.2815 +34.3314 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.7095 +-15.4377 +1.54235 +18.4532 +34.552 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.7386 +-15.4024 +1.65 +18.6268 +34.7748 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.7677 +-15.3664 +1.75899 +18.8024 +34.9997 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.797 +-15.3299 +1.86922 +18.9798 +35.2264 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.8265 +-15.2931 +1.98061 +19.1588 +35.4549 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.8563 +-15.2559 +2.09307 +19.3394 +35.6852 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.8866 +-15.2185 +2.20649 +19.5216 +35.9172 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.9173 +-15.1811 +2.32081 +19.7051 +36.1504 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.9488 +-15.1436 +2.43593 +19.8901 +36.3854 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-31.9809 +-15.1061 +2.55176 +20.0762 +36.6216 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.0138 +-15.0688 +2.66822 +20.2636 +36.8591 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.0474 +-15.0317 +2.78523 +20.452 +37.0978 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.0817 +-14.9948 +2.90267 +20.6411 +37.3371 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.117 +-14.9583 +3.0205 +20.8313 +37.5776 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.1536 +-14.9223 +3.13867 +21.0225 +37.8193 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.1914 +-14.8869 +3.25704 +21.2143 +38.0617 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.2301 +-14.852 +3.37553 +21.4067 +38.3047 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.2701 +-14.8179 +3.49408 +21.5996 +38.5482 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.3115 +-14.7845 +3.61257 +21.793 +38.7922 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.3542 +-14.752 +3.73091 +21.9867 +39.0365 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.4329 +-14.6903 +3.95278 +22.3486 +39.4915 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.4803 +-14.6611 +4.06969 +22.5421 +39.7356 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.5292 +-14.6332 +4.18595 +22.7354 +39.9795 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.5803 +-14.6068 +4.30151 +22.9284 +40.2233 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.6333 +-14.5819 +4.41623 +23.1212 +40.4669 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.6882 +-14.5586 +4.53001 +23.3135 +40.7098 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.7454 +-14.5371 +4.64274 +23.5051 +40.9524 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.8044 +-14.5172 +4.75427 +23.696 +41.1938 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.866 +-14.4994 +4.8645 +23.886 +41.4345 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.9299 +-14.4836 +4.97328 +24.0749 +41.6741 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-32.9961 +-14.47 +5.08047 +24.2626 +41.9125 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-33.0647 +-14.4586 +5.18592 +24.4489 +42.1494 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-33.1362 +-14.4497 +5.28951 +24.6339 +42.3851 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-33.2104 +-14.4434 +5.39108 +24.8173 +42.6191 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-33.2874 +-14.4397 +5.49044 +24.9988 +42.8512 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-33.3674 +-14.4389 +5.58743 +25.1782 +43.0813 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-33.4503 +-14.4411 +5.6819 +25.3556 +43.3092 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-33.5366 +-14.4465 +5.77371 +25.5307 +43.535 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-33.6261 +-14.4552 +5.86266 +25.7033 +43.7584 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-33.7191 +-14.4672 +5.94862 +25.8733 +43.9792 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-33.8153 +-14.4828 +6.03137 +26.0404 +44.1971 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-33.9151 +-14.5021 +6.11081 +26.2046 +44.412 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-34.0185 +-14.5252 +6.18674 +26.3655 +44.6237 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-34.1253 +-14.552 +6.25902 +26.5231 +44.832 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-34.236 +-14.5831 +6.32754 +26.6773 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-34.3507 +-14.6183 +6.39216 +26.8279 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-34.4692 +-14.6576 +6.45272 +26.9748 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-34.5913 +-14.7012 +6.50906 +27.1176 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-34.7173 +-14.7492 +6.56111 +27.2564 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-34.8471 +-14.8016 +6.60874 +27.391 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-34.9806 +-14.8584 +6.65176 +27.5211 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-35.0759 +-14.9023 +6.67574 +27.6047 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-35.2161 +-14.967 +6.71083 +27.7273 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-35.3602 +-15.0365 +6.74098 +27.845 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-35.5084 +-15.1107 +6.7662 +27.9581 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-35.6601 +-15.1897 +6.78627 +28.066 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-35.8158 +-15.2736 +6.80116 +28.1688 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-35.9751 +-15.3622 +6.81071 +28.2663 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-36.1382 +-15.4558 +6.81487 +28.3585 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-36.3044 +-15.5541 +6.81347 +28.4449 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-36.4743 +-15.6573 +6.80637 +28.5252 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-36.6479 +-15.7656 +6.79359 +28.5998 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-36.8247 +-15.8787 +6.77498 +28.6688 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-37.0054 +-15.997 +6.75052 +28.7316 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-37.1894 +-16.1203 +6.72004 +28.7878 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-37.376 +-16.2483 +6.68331 +28.8374 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-37.566 +-16.3814 +6.64047 +28.8807 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-37.7593 +-16.5194 +6.59136 +28.9174 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-37.9552 +-16.6623 +6.53587 +28.947 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-38.1539 +-16.8102 +6.47399 +28.97 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-38.3555 +-16.9627 +6.40564 +28.9855 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-38.5596 +-17.1202 +6.33085 +28.9941 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-38.7661 +-17.2822 +6.24951 +28.9954 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-38.9745 +-17.4488 +6.1617 +28.9894 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-39.1856 +-17.6198 +6.06737 +28.976 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-39.3979 +-17.795 +5.96653 +28.9549 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-39.6116 +-17.9742 +5.85928 +28.9263 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-39.8258 +-18.1569 +5.74561 +28.8897 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-40.042 +-18.3439 +5.62577 +28.846 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-40.2598 +-18.5345 +5.4999 +28.7953 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-40.478 +-18.7285 +5.36806 +28.7373 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-40.7532 +-18.9761 +5.1953 +28.6556 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-40.9701 +-19.175 +5.05143 +28.5812 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-41.1867 +-19.3765 +4.90191 +28.499 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-41.4029 +-19.5804 +4.747 +28.4101 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-41.6186 +-19.7863 +4.58681 +28.3139 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-41.833 +-19.9939 +4.42144 +28.2099 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.046 +-20.2029 +4.25117 +28.0989 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.2572 +-20.4131 +4.07624 +27.981 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.4667 +-20.6242 +3.89688 +27.856 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.6732 +-20.8355 +3.7133 +27.7243 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-42.8784 +-21.0475 +3.52597 +27.5864 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.081 +-21.2596 +3.33502 +27.4422 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.2802 +-21.4709 +3.14078 +27.2915 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.4751 +-21.681 +2.94356 +27.1347 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.6669 +-21.8903 +2.74375 +26.9724 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-43.8547 +-22.0979 +2.54168 +26.8048 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.0386 +-22.304 +2.3377 +26.6323 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.2185 +-22.5081 +2.13213 +26.4549 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.3919 +-22.7087 +1.92524 +26.2723 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.5617 +-22.9074 +1.71753 +26.0862 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.7265 +-23.1028 +1.50922 +25.896 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-44.8855 +-23.2946 +1.30068 +25.7016 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-23.4825 +1.09219 +25.5034 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-45 +-23.6666 +0.884129 +25.3022 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-23.846 +0.676784 +25.0978 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-24.0215 +0.47047 +24.8911 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-24.192 +0.265481 +24.6818 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-24.3573 +0.0621079 +24.4704 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-24.5179 +-0.139363 +24.2578 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-24.6729 +-0.33865 +24.043 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +0 +-45 +-45 +-45 +-24.8222 +-0.535475 +23.8268 +45 +45 +45 +45 +0 +0 +0 +0 +0 +0 diff --git a/test/input_cases/pvsamv1_data/measured_temp_array.csv b/test/input_cases/pvsamv1_data/measured_temp_array.csv new file mode 100644 index 000000000..92a7fba0f --- /dev/null +++ b/test/input_cases/pvsamv1_data/measured_temp_array.csv @@ -0,0 +1,8760 @@ +7 +6 +6 +6 +6 +6 +6 +7 +17.8071 +26.821 +35.6768 +39.7611 +42.2981 +42.5244 +40.6416 +37.2547 +27.0189 +16 +14 +12 +12 +11 +10 +10 +10 +9 +9 +8 +8 +8 +8 +9 +18.0403 +26.6264 +33.6971 +39.0114 +41.9074 +42.4034 +41.5696 +37.5049 +26.3834 +16 +14 +13 +12 +11 +11 +10 +10 +9 +9 +8 +8 +8 +8 +9 +19.3454 +28.9975 +37.586 +40.7974 +36.585 +26.017 +28.9825 +36.1168 +27.5311 +18 +17 +15 +13 +11 +9 +9 +8 +7 +7 +7 +7 +6 +6 +7 +16.73 +25.7173 +34.5654 +42.785 +46.4237 +47.0238 +44.7954 +40.7924 +31.544 +20 +17 +14 +12 +11 +10 +9 +9 +8 +8 +8 +8 +8 +8 +9 +18.0767 +27.2455 +36.7095 +42.7383 +45.3428 +44.9162 +42.7963 +37.3514 +28.0634 +17 +17 +16 +14 +12 +10 +9 +9 +8 +7 +7 +6 +6 +6 +7 +16.9469 +26.6413 +36.613 +43.9232 +46.8804 +47.514 +44.4994 +37.4586 +25.9488 +15 +14 +13 +12 +11 +10 +10 +9 +8 +8 +7 +6 +6 +5 +7 +16.3361 +24.794 +33.5077 +40.3973 +44.1741 +43.7414 +41.0431 +35.2052 +24.5937 +13 +12 +11 +10 +9 +9 +8 +7 +6 +4 +4 +4 +5 +4 +5 +11.7736 +17.8067 +22.8767 +26.5817 +28.4662 +28.1899 +27.1444 +24.7016 +19.3116 +10 +8 +7 +6 +6 +6 +6 +6 +5 +4 +4 +4 +3 +3 +4 +8.24631 +22.5853 +33.0366 +38.2665 +39.4338 +32.3492 +37.163 +32.1044 +20.8998 +10 +10 +10 +9 +7 +5 +5 +4 +4 +4 +3 +3 +3 +3 +5 +14.607 +25.476 +37.8123 +46.9833 +49.4811 +39.9932 +40.3537 +27.195 +23.471 +12 +11 +11 +10 +10 +9 +8 +8 +8 +7 +7 +6 +6 +5 +6 +10.9711 +20.2749 +22.4436 +27.2741 +33.6219 +31.9235 +31.788 +30.2957 +18.2168 +12 +11 +9 +7 +6 +6 +6 +5 +5 +5 +5 +6 +6 +7 +7 +9.12832 +12.9891 +21.4878 +27.7037 +20.4759 +23.5011 +21.9185 +22.6132 +21.1873 +11.5547 +9 +8 +6 +4 +3 +3 +2 +2 +1 +1 +0 +0 +0 +2 +12.9847 +23.2521 +32.7384 +39.1204 +41.3364 +41.0412 +38.3311 +34.2788 +24.2855 +12.0239 +10 +8 +6 +6 +5 +4 +4 +4 +4 +4 +4 +4 +4 +5 +10.323 +19.08 +37.8913 +39.0855 +42.8332 +42.987 +33.8739 +21.6309 +17.8183 +16.0595 +15 +13 +12 +11 +9 +8 +7 +7 +7 +6 +6 +6 +6 +8 +11.1851 +16.752 +18.2566 +22.1093 +18.5866 +23.2343 +20.1844 +17.5548 +13.7071 +11.0441 +10 +9 +9 +9 +9 +9 +9 +9 +9 +9 +8 +7 +6 +7 +10.913 +24.0078 +31.4753 +28.2415 +31.8829 +30.2001 +28.1175 +31.4229 +24.05 +12.7735 +11 +11 +10 +9 +9 +8 +7 +7 +7 +8 +8 +7 +7 +8 +15.9224 +23.8177 +30.5955 +36.0228 +40.2905 +41.7862 +38.781 +32.0538 +23.2201 +13.8717 +12 +11 +10 +9 +8 +7 +6 +6 +5 +5 +4 +4 +4 +6 +15.8629 +26.0286 +36.4767 +41.3026 +44.6539 +44.7027 +40.7739 +34.6323 +25.0402 +14.0244 +12 +11 +10 +9 +8 +8 +8 +8 +7 +7 +6 +5 +4 +6 +15.9691 +25.1543 +35.7989 +43.2182 +49.3019 +52.3309 +48.4947 +39.825 +26.9422 +14.6888 +12 +12 +11 +10 +9 +7 +7 +7 +6 +6 +5 +5 +5 +6 +17.1055 +26.482 +36.4192 +42.1636 +44.014 +43.0216 +40.4911 +36.1901 +26.7877 +15.6707 +13 +13 +12 +11 +10 +9 +8 +8 +7 +7 +7 +8 +7 +8 +13.0439 +18.9923 +25.9292 +23.5948 +23.6928 +23.228 +28.1301 +26.7953 +21.8272 +15.3366 +14 +12 +11 +10 +8 +7 +6 +5 +4 +4 +4 +4 +4 +5 +12.8573 +16.8857 +24.1498 +28.0521 +35.2057 +30.2862 +27.3514 +19.3896 +17.6769 +12.3548 +11 +10 +9 +8 +7 +6 +5 +5 +4 +3 +3 +3 +3 +5 +10.7356 +22.0894 +24.6687 +23.1635 +23.9946 +24.5295 +24.4239 +14.9964 +12.9459 +9.3297 +9 +10 +10 +9 +7 +6 +5 +5 +5 +5 +5 +4 +3 +5 +13.0388 +19.6163 +24.5032 +27.7003 +29.3278 +28.9576 +28.547 +25.5987 +21.4697 +13.6043 +10 +8 +7 +6 +5 +5 +4 +3 +3 +3 +3 +3 +3 +5 +14.7112 +20.9557 +25.9253 +30.3608 +31.9853 +32.7576 +31.4701 +29.2821 +24.308 +16.1038 +12 +10 +9 +8 +6 +6 +5 +5 +4 +4 +3 +3 +3 +5 +15.2487 +25.865 +36.4449 +43.67 +47.9253 +48.2299 +44.7841 +38.6614 +28.772 +16.4806 +14 +14 +14 +13 +11 +11 +10 +9 +9 +10 +10 +9 +9 +10 +14.198 +22.3352 +25.1927 +27.0467 +25.9703 +27.3598 +27.5248 +23.861 +17.6124 +14.24 +13 +13 +12 +11 +10 +10 +9 +8 +7 +6 +6 +6 +7 +8 +15.773 +23.3863 +30.0266 +33.8695 +35.5257 +36.3429 +35.0744 +32.7575 +26.429 +16.2738 +12 +12 +11 +9 +9 +8 +7 +6 +6 +6 +6 +5 +5 +6 +15.6262 +24.7466 +34.2238 +39.8117 +42.349 +43.5512 +42.2267 +39.3317 +30.9563 +20.6387 +16 +14 +12 +10 +9 +8 +8 +7 +7 +6 +6 +6 +6 +8 +18.9576 +31.0008 +44.083 +50.4216 +54.323 +56.4328 +49.7496 +38.8378 +29.1867 +18.7492 +15 +14 +14 +13 +12 +11 +11 +10 +9 +9 +8 +8 +8 +9 +14.8886 +29.4107 +25.8676 +43.1396 +46.6096 +45.9659 +43.2421 +38.6235 +31.9014 +8.60779 +6 +4 +4 +3 +3 +3 +2 +2 +2 +1 +1 +0 +0 +2 +11.4523 +19.3977 +25.4194 +29.2473 +30.9079 +31.6563 +31.3922 +29.1226 +22.7502 +13.2561 +8 +6 +6 +5 +4 +4 +3 +3 +3 +3 +2 +2 +2 +5 +14.6308 +24.8498 +33.5583 +40.0426 +41.8989 +40.8277 +38.6701 +35.2024 +26.4342 +15.2656 +11 +11 +10 +9 +7 +5 +5 +4 +4 +4 +4 +4 +4 +6 +16.0484 +25.4928 +33.6375 +34.7075 +40.2191 +40.3648 +39.589 +33.8935 +28.0666 +19.0723 +14 +14 +12 +10 +8 +7 +7 +7 +7 +7 +6 +6 +6 +8 +18.8214 +28.1664 +38.5342 +44.8798 +48.246 +49.0786 +47.4933 +44.4451 +37.7333 +26.5135 +19 +16 +14 +12 +11 +10 +9 +9 +9 +9 +8 +8 +8 +11 +23.3634 +35.111 +44.4101 +50.9088 +52.9492 +51.5335 +49.1792 +45.0998 +35.7206 +23.2781 +17 +17 +16 +15 +14 +13 +12 +11 +10 +9 +9 +8 +8 +11.2533 +21.9238 +30.8899 +32.7753 +41.9576 +43.0551 +40.0695 +41.1836 +35.2113 +28.1388 +20.1367 +16 +14 +12 +11 +10 +10 +9 +9 +8 +8 +7 +7 +7 +9.55872 +20.102 +25.1375 +29.1673 +31.6918 +32.2949 +32.5696 +30.436 +26.299 +19.7007 +12.812 +9 +8 +7 +6 +6 +6 +6 +6 +5 +4 +4 +4 +3 +3.17919 +7.6724 +11.6875 +15.1021 +23.3923 +25.5942 +22.4893 +20.8307 +21.5395 +16.819 +8.74302 +3 +3 +3 +3 +3 +2 +1 +0 +0 +0 +-1 +-1 +0 +1.74822 +12.5422 +20.3069 +25.1482 +28.7988 +31.3006 +31.8376 +29.5386 +25.8843 +20.2811 +12.7371 +8 +7 +5 +4 +3 +3 +2 +2 +2 +1 +1 +1 +1 +4.55963 +17.0926 +27.5758 +38.2158 +41.2754 +46.2984 +49.637 +37.7101 +38.3272 +28.1261 +15.4665 +9 +8 +7 +6 +5 +5 +5 +4 +4 +3 +2 +1 +1 +5.15666 +18.1977 +27.4768 +37.3823 +45.3903 +49.361 +47.7941 +43.0095 +34.7387 +26.0754 +16.348 +10 +10 +10 +9 +8 +7 +6 +6 +5 +4 +4 +3 +3 +6.24932 +21.5539 +32.1831 +37.1311 +38.8487 +39.5082 +38.8795 +36.371 +32.2102 +26.5044 +18.1577 +13 +12 +12 +12 +11 +9 +7 +5 +4 +4 +4 +4 +5 +8.61735 +15.6864 +21.3989 +25.9678 +26.0864 +22.4751 +16.5542 +13.1794 +20.5587 +16.0676 +10.6116 +7 +7 +7 +7 +6 +5 +5 +5 +4 +4 +4 +4 +4 +5.47975 +9.03372 +16.4081 +22.221 +17.7986 +29.2736 +12.8845 +31.4745 +31.1964 +11.2987 +8.12254 +7 +5 +4 +4 +4 +4 +3 +3 +3 +3 +2 +2 +2 +4.22617 +13.5242 +22.8275 +31.2439 +37.8427 +42.6065 +44.4437 +42.0449 +35.8733 +26.7898 +13.8772 +6 +6 +6 +7 +6 +5 +4 +2 +2 +2 +2 +1 +2 +4.44303 +10.7738 +18.7908 +24.9516 +29.3212 +33.1676 +37.4516 +39.153 +34.5854 +28.3548 +17.5173 +10 +8 +6 +6 +5 +5 +5 +4 +4 +4 +3 +3 +4 +8.41823 +18.3618 +25.0197 +33.4951 +41.4141 +36.0581 +32.9578 +30.7896 +26.5568 +25.3352 +17.241 +15 +14 +12 +11 +11 +10 +10 +9 +9 +8 +7 +7 +7 +10.4876 +19.4914 +32.4287 +44.6034 +54.1999 +54.1961 +50.4276 +45.6847 +38.7002 +31.3723 +21.9391 +16 +15 +14 +13 +12 +11 +10 +9 +8 +6 +6 +5 +5 +10.1122 +22.5031 +32.0042 +40.7262 +47.7801 +53.7244 +54.8143 +49.0607 +40.2445 +30.3703 +20.7711 +15 +15 +14 +13 +13 +13 +13 +13 +12 +12 +11 +10 +9 +11.8854 +24.4346 +35.9485 +43.7371 +48.9977 +54.4316 +55.5789 +49.4718 +40.3321 +31.7069 +22.3504 +15 +14 +14 +14 +14 +13 +13 +12 +11 +10 +9 +8 +8 +11.5232 +20.8428 +28.6947 +36.8181 +38.955 +45.8132 +46.2285 +43.3513 +38.5424 +32.1593 +22.0589 +15 +15 +15 +14 +13 +12 +10 +9 +8 +8 +8 +8 +8 +11.6802 +19.1958 +34.1272 +39.5372 +44.7002 +47.4811 +45.0724 +41.4174 +35.6968 +24.6358 +20.3187 +15 +15 +14 +13 +12 +11 +10 +9 +9 +8 +8 +8 +8 +9.05932 +12.519 +14.1383 +23.3792 +29.5836 +31.5284 +30.9641 +28.4763 +25.0037 +18.9719 +14.4282 +9 +9 +8 +7 +6 +5 +4 +3 +3 +2 +2 +1 +2 +6.71602 +19.6195 +28.6531 +32.2643 +32.9638 +33.1798 +29.8797 +31.6561 +26.906 +21.6952 +13.52 +9 +9 +8 +8 +7 +7 +7 +7 +7 +6 +6 +6 +6 +8.41351 +14.422 +24.4826 +26.9984 +33.3698 +32.158 +27.844 +26.4533 +20.8966 +16.0965 +11.1119 +10 +10 +9 +9 +8 +8 +8 +7 +7 +7 +7 +6 +6 +8.27831 +13.7863 +26.0687 +26.8511 +30.0792 +34.8048 +23.8254 +28.4505 +33.7865 +27.731 +18.6527 +11 +10 +9 +8 +8 +7 +6 +6 +5 +5 +5 +4 +5 +12.212 +23.8348 +29.4627 +35.7483 +39.3216 +32.6307 +33.2948 +20.0045 +23.7451 +18.7299 +13.2362 +10 +9 +9 +9 +8 +7 +6 +6 +6 +6 +6 +5 +6 +9.32249 +15.8257 +24.7625 +18.2366 +15.6594 +28.5055 +12.8643 +13.6703 +22.6578 +14.1398 +27.7003 +18 +16 +16 +16 +16 +16 +15 +13 +12 +10 +10 +9 +10 +14.029 +21.4736 +31.9428 +43.1132 +54.9331 +55.2471 +49.2405 +46.7975 +44.118 +38.1292 +26.3036 +17 +17 +17 +17 +16 +14 +12 +11 +11 +10 +9 +9 +10 +14.5916 +24.5646 +37.3881 +48.8345 +54.09 +56.595 +60.5121 +57.1774 +51.3014 +41.8704 +24.1353 +19 +19 +18 +18 +17 +16 +15 +14 +14 +13 +12 +10 +11 +17.6642 +31.6805 +41.8841 +48.0046 +50.9736 +52.8803 +51.6768 +47.2252 +40.9058 +33.507 +24.4087 +17 +16 +15 +14 +13 +12 +12 +11 +11 +11 +10 +10 +11 +13.7518 +21.1045 +25.4117 +31.1578 +35.2692 +37.9104 +37.766 +35.0575 +32.9301 +30.9649 +21.9176 +14 +13 +12 +11 +11 +11 +11 +10 +9 +8 +7 +7 +8 +14.742 +24.5812 +34.6115 +45.4202 +54.3239 +60.2254 +63.7767 +58.4712 +49.2537 +38.9679 +26.0648 +17 +15 +15 +15 +14 +13 +12 +11 +11 +10 +10 +10 +11 +17.687 +27.7445 +37.7847 +44.7249 +48.191 +48.1845 +47.0197 +43.5359 +38.9828 +32.4671 +24.0677 +16 +15 +13 +12 +12 +12 +11 +9 +9 +9 +8 +8 +9 +15.8056 +24.1605 +16.1402 +17.8406 +17.0104 +21.9014 +19.3529 +19.6784 +23.7987 +19.1933 +12.1185 +10 +10 +9 +9 +8 +7 +6 +6 +5 +5 +5 +5 +5 +11.3157 +21.8147 +32.6193 +36.7117 +39.8003 +40.7792 +40.7573 +38.8352 +33.8483 +27.8798 +18.2135 +14 +13 +12 +12 +11 +10 +10 +10 +9 +9 +9 +9 +9 +15.2924 +23.5473 +31.5503 +37.8923 +44.0554 +47.28 +47.6086 +45.4058 +39.5851 +33.3879 +22.9784 +14 +12 +11 +10 +10 +11 +11 +10 +10 +9 +8 +7 +8 +12.0971 +21.0096 +32.4883 +42.4301 +50.8667 +55.9258 +55.0668 +50.1053 +43.1676 +35.1293 +24.7947 +15 +14 +13 +13 +12 +11 +10 +9 +9 +8 +7 +6 +7 +14.2848 +22.113 +28.3853 +34.746 +38.0265 +38.6937 +36.5138 +32.855 +28.8027 +22.4466 +18.1887 +13 +12 +11 +9 +9 +8 +7 +7 +6 +6 +6 +6 +6 +11.4118 +18.3799 +24.5873 +29.6675 +32.9248 +34.9289 +36.0793 +34.7321 +32.7072 +29.1838 +21.6856 +13 +11 +10 +9 +9 +8 +7 +7 +6 +6 +5 +5 +6 +12.8505 +25.027 +39.8588 +52.5615 +54.4637 +53.1129 +51.2633 +46.7961 +41.5984 +34.5572 +25.0033 +16 +16 +15 +14 +12 +10 +9 +9 +8 +8 +8 +8 +9 +16.7376 +28.6609 +40.5005 +46.9736 +45.396 +45.4863 +43.7466 +39.4788 +37.3594 +26.6703 +23.9537 +19 +17 +15 +13 +13 +14 +13 +11 +10 +10 +10 +10 +11 +16.6078 +21.4746 +29.0843 +37.4827 +39.4341 +39.8165 +39.4354 +38.4599 +35.5892 +31.2452 +24.3537 +18 +15 +13 +12 +11 +10 +10 +10 +9 +9 +9 +9 +9 +9.13357 +14.9105 +12.4548 +16.6645 +21.1829 +22.3881 +26.8073 +26.4106 +29.6652 +14.4373 +14.1453 +11 +10 +9 +8 +8 +8 +8 +7 +6 +5 +5 +4 +5 +10.577 +13.701 +14.9812 +23.563 +20.7145 +25.1694 +31.413 +37.9423 +36.2788 +23.5359 +14.7333 +10 +10 +9 +8 +7 +6 +6 +5 +5 +5 +6 +5 +6 +14.0136 +23.3528 +31.6042 +37.0182 +39.2703 +40.547 +40.573 +39.424 +34.7709 +29.3967 +21.6473 +15 +15 +15 +14 +13 +11 +10 +9 +9 +8 +8 +8 +9 +15.8448 +25.5735 +33.9914 +39.5878 +43.6006 +45.2507 +45.401 +43.1754 +38.659 +33.9145 +27.5899 +21 +19 +17 +15 +14 +13 +12 +12 +11 +10 +10 +10 +12 +20.7382 +29.1468 +40.1793 +57.1483 +59.9929 +58.0914 +56.4657 +54.6462 +50.2946 +43.6169 +31.2236 +19.254 +17 +15 +14 +15 +14 +12 +10 +10 +10 +10 +10 +11 +18.7193 +27.595 +35.4048 +42.5479 +47.7211 +50.6978 +51.3715 +50.1362 +45.864 +40.0209 +29.6181 +18.4062 +16 +15 +15 +15 +15 +14 +13 +11 +10 +9 +9 +10 +18.4293 +28.1791 +37.8611 +50.1632 +59.9339 +60.6011 +56.5479 +51.0524 +44.1599 +37.2834 +27.1919 +18.2968 +17 +16 +15 +14 +13 +12 +12 +11 +11 +10 +10 +11 +19.4883 +26.4763 +33.0827 +38.5252 +42.1012 +43.788 +43.2908 +40.6053 +36.2824 +31.147 +23.951 +16.2167 +15 +14 +14 +13 +12 +11 +10 +9 +9 +8 +8 +10 +19.2277 +27.6656 +38.7893 +52.0008 +57.7922 +56.9515 +54.9075 +50.7247 +44.6389 +37.3105 +28.8227 +21.343 +19 +19 +18 +16 +15 +13 +12 +12 +12 +11 +11 +12 +21.4031 +25.9034 +38.9142 +47.1646 +47.5245 +51.2681 +48.139 +42.2696 +34.1333 +30.4754 +27.6004 +21.1236 +19 +18 +16 +15 +15 +16 +16 +16 +16 +15 +13 +14 +16.1865 +19.8327 +23.6675 +32.8533 +38.5332 +35.5686 +31.0709 +26.4972 +29.5694 +24.6153 +20.596 +15.2277 +13 +11 +10 +10 +10 +9 +9 +8 +8 +8 +8 +9 +16.0229 +25.1014 +33.4117 +39.9966 +44.9621 +46.4521 +46.6737 +45.1813 +39.8917 +33.4107 +24.5283 +16.3523 +14 +13 +13 +13 +13 +13 +12 +11 +11 +10 +10 +11 +19.8753 +30.8832 +41.5778 +47.957 +51.8846 +54.1512 +54.7612 +53.3721 +46.908 +38.4903 +27.9045 +17.4436 +15 +15 +15 +14 +14 +14 +13 +12 +11 +10 +10 +12.2382 +22.2586 +34.4194 +45.5503 +51.8701 +53.4064 +53.5481 +53.2789 +50.1945 +45.0658 +39.1029 +29.3972 +21.3321 +19 +18 +18 +18 +17 +16 +15 +14 +13 +12 +12 +13.301 +23.8633 +35.6372 +44.648 +53.62 +60.0666 +60.9351 +59.9407 +58.1224 +51.581 +43.2734 +31.0882 +21.4838 +19 +18 +17 +15 +13 +12 +11 +11 +10 +10 +10 +12.3334 +19.9384 +26.0933 +32.7426 +36.8801 +39.8756 +41.4038 +40.7678 +36.2851 +31.8209 +27.3198 +33.6691 +25.477 +23 +23 +23 +21 +19 +18 +17 +16 +16 +15 +15 +16.3513 +25.1253 +36.9075 +49.7278 +61.7125 +67.8635 +65.349 +61.1353 +55.685 +50.0716 +44.5394 +35.3487 +26.5131 +25 +25 +24 +23 +23 +21 +18 +16 +15 +14 +14 +17.4235 +27.4726 +37.6162 +47.6679 +57.5761 +64.3324 +66.6737 +61.4984 +52.6487 +46.4713 +43.1401 +31.5109 +25.5272 +23 +21 +19 +18 +18 +17 +17 +16 +15 +14 +14 +16.6492 +25.4414 +34.6997 +42.536 +49.7854 +54.2487 +57.0217 +53.6436 +48.3022 +41.4777 +35.0729 +28.2986 +21.4227 +19 +18 +17 +16 +15 +15 +15 +14 +12 +11 +10 +11.3192 +17.965 +26.1363 +32.9079 +39.3253 +46.2845 +50.5237 +51.0545 +48.957 +44.5223 +38.3759 +29.3288 +19.5875 +17 +16 +16 +15 +13 +12 +11 +11 +10 +10 +10 +13.5811 +24.3753 +37.9261 +52.7152 +60.4631 +63.2921 +64.6068 +60.2239 +57.1364 +53.9306 +42.5376 +31.3095 +22.624 +21 +20 +19 +18 +17 +16 +16 +15 +15 +15 +15 +17.4006 +20.7859 +28.5853 +35.7023 +36.785 +32.823 +33.0504 +36.5611 +30.568 +39.5186 +28.9084 +28.6757 +21.3547 +19 +18 +16 +16 +15 +15 +15 +14 +13 +12 +12 +14.2858 +20.0578 +32.3689 +41.2732 +43.8933 +45.1706 +39.2943 +45.6523 +41.432 +37.0882 +31.9411 +25.2767 +19.3618 +17 +16 +15 +14 +13 +12 +11 +10 +10 +9 +9 +11.6606 +16.741 +25.4195 +29.8973 +43.4535 +41.7284 +46.1269 +50.1428 +42.8259 +36.6883 +29.4984 +20.0727 +15.6964 +13 +13 +13 +12 +12 +11 +10 +9 +8 +7 +6 +6.06691 +7.95787 +7.48592 +11.0258 +16.7661 +17.9811 +20.1287 +19.0095 +23.369 +27.2395 +20.8134 +14.2836 +7.1324 +6 +5 +5 +4 +4 +3 +3 +2 +2 +2 +2 +4.84271 +13.1249 +22.846 +32.8394 +40.611 +43.4546 +44.6786 +43.6661 +41.26 +36.8387 +30.6848 +22.873 +13.8822 +11 +10 +10 +10 +9 +8 +7 +5 +5 +5 +5 +7.91232 +17.7391 +28.7331 +38.8549 +47.6745 +55.5851 +56.3117 +57.5772 +50.9145 +43.7434 +36.7538 +28.3697 +19.8382 +17 +16 +16 +16 +15 +14 +12 +12 +11 +11 +11 +13.0514 +22.3267 +32.6384 +42.5685 +51.8098 +58.2662 +63.3267 +65.2774 +61.2343 +53.2299 +44.0133 +30.9724 +18.9881 +17 +16 +15 +15 +15 +15 +14 +12 +11 +10 +10 +14.0295 +23.2531 +32.0084 +41.2397 +48.7925 +54.8892 +56.9544 +52.5226 +45.0473 +37.5266 +31.7637 +26.0768 +19.4423 +16 +14 +13 +12 +11 +10 +9 +9 +8 +7 +7 +10.7831 +18.5776 +26.3029 +32.1459 +36.019 +40.1379 +42.1887 +43.0103 +41.2556 +38.5703 +33.9606 +27.125 +18.8852 +15 +14 +13 +12 +12 +11 +11 +10 +10 +9 +10 +13.8554 +20.784 +29.3235 +36.0722 +42.8867 +47.7846 +50.0202 +50.9008 +48.9171 +45.4875 +40.1806 +32.3379 +21.9333 +19 +18 +17 +16 +15 +14 +14 +13 +13 +12 +13 +17.0479 +26.9133 +36.109 +42.3681 +49.2965 +54.1424 +56.7671 +56.2405 +54.9537 +50.2 +44.5003 +35.8687 +25.0124 +22 +21 +21 +21 +21 +20 +19 +18 +17 +16 +16 +19.2864 +27.3075 +37.2496 +46.2927 +53.618 +54.6468 +53.981 +52.2485 +50.2127 +45.8775 +40.8002 +33.3981 +25.696 +22 +21 +19 +19 +19 +18 +17 +16 +15 +14 +14 +18.2492 +26.4666 +38.1134 +47.7247 +54.7416 +57.9889 +58.6881 +57.9896 +53.1082 +45.1017 +35.3595 +30.2421 +25.0934 +22 +21 +20 +19 +17 +16 +16 +15 +14 +14 +14 +18.2195 +25.4137 +33.7794 +42.7727 +52.1548 +54.7212 +59.9306 +59.5809 +53.0609 +47.1768 +37.5151 +30.5972 +23.7967 +21 +20 +18 +18 +17 +17 +17 +17 +17 +16 +16 +18.5194 +28.1381 +37.6712 +48.012 +54.0895 +67.8073 +66.9265 +62.7227 +60.7076 +52.2199 +43.2521 +33.8159 +24.0049 +20 +19 +18 +17 +16 +16 +16 +16 +15 +14 +14 +18.315 +25.4434 +32.3201 +39.1047 +44.6052 +47.7088 +49.4431 +48.8431 +45.3004 +41.2056 +36.4592 +30.1189 +24.5469 +21 +20 +18 +17 +16 +15 +14 +14 +13 +12 +13 +17.2886 +24.4879 +32.0833 +40.9163 +48.413 +52.7887 +54.6633 +54.2018 +51.6906 +46.0198 +39.4284 +32.0074 +23.7955 +20 +19 +18 +18 +17 +16 +15 +15 +15 +16 +16 +18.6862 +21.5109 +25.4102 +39.9626 +43.108 +48.3758 +49.3592 +46.4483 +43.6926 +39.0697 +33.698 +28.7947 +23.4818 +20 +19 +18 +17 +16 +15 +15 +14 +13 +13 +13 +16.4434 +23.444 +30.7478 +38.4837 +43.5425 +47.9347 +48.9994 +46.6193 +42.5166 +36.0824 +30.8048 +26.9297 +22.5794 +20 +19 +18 +16 +15 +14 +13 +12 +12 +12 +12 +15.2299 +22.784 +30.1346 +38.3978 +46.388 +52.8597 +55.2316 +53.9191 +50.3894 +43.8855 +37.1775 +30.4108 +22.7915 +19 +18 +17 +16 +16 +15 +14 +14 +13 +12 +13 +17.261 +23.5446 +29.819 +36.2773 +41.7552 +46.6252 +49.3824 +48.9168 +47.2884 +42.8676 +38.1241 +31.3499 +24.0882 +20 +18 +17 +15 +14 +13 +13 +12 +12 +11 +11 +15.42 +23.917 +31.4781 +38.6368 +45.3574 +50.4058 +54.4849 +55.4054 +52.9754 +47.1115 +40.0725 +32.954 +24.0583 +20 +18 +18 +18 +18 +17 +15 +14 +13 +13 +14 +19.1871 +31.1122 +41.9611 +50.5247 +53.5969 +55.8506 +58.7732 +61.1477 +61.6531 +54.7583 +44.2929 +34.9782 +26.0062 +22 +21 +20 +19 +17 +16 +15 +15 +14 +14 +15 +19.654 +26.8713 +33.8084 +39.2091 +43.9176 +46.7981 +48.4079 +48.44 +45.8268 +42.797 +37.9793 +32.0527 +23.7303 +20 +19 +17 +17 +16 +15 +15 +14 +13 +12 +12 +14.0487 +20.7564 +27.5698 +33.4119 +36.7254 +38.8731 +40.16 +39.8576 +38.6628 +35.6046 +31.9706 +36.7649 +27.3759 +24 +23 +23 +23 +22 +21 +20 +19 +18 +16 +17 +22.077 +31.353 +40.5355 +47.2325 +51.6611 +52.7659 +52.9801 +51.1312 +48.7158 +45.7584 +41.3663 +34.8909 +27.8231 +24 +22 +20 +19 +18 +18 +18 +19 +18 +16 +15 +20.4081 +30.9905 +41.7355 +51.4078 +59.3823 +63.4961 +65.171 +65.3782 +60.2012 +48.9274 +39.0861 +31.8387 +25.725 +23 +21 +19 +17 +16 +15 +14 +13 +13 +13 +13 +16.1624 +21.4388 +27.7745 +31.7439 +35.545 +38.7637 +41.3918 +41.576 +40.1575 +36.735 +32.2575 +27.4771 +19.3088 +15 +15 +14 +13 +12 +11 +11 +10 +10 +9 +10 +15.0747 +23.425 +32.0293 +38.1365 +43.5065 +46.3806 +48.4561 +48.8892 +46.3282 +41.1004 +36.3656 +29.5843 +21.5168 +17 +16 +15 +14 +13 +13 +12 +12 +11 +11 +12 +16.7727 +29.3661 +40.0381 +46.0386 +48.544 +48.9423 +48.4521 +47.6935 +45.9452 +41.6454 +36.5499 +30.6103 +22.9425 +19 +18 +17 +16 +16 +16 +15 +15 +15 +14 +14 +19.374 +29.0385 +41.5376 +49.8187 +51.762 +52.0053 +51.9206 +51.5485 +49.2919 +46.4914 +41.8405 +35.9616 +27.3837 +23 +22 +22 +21 +20 +19 +17 +16 +16 +15 +16 +21.174 +30.5424 +42.2844 +53.7969 +60.9648 +63.5508 +64.6898 +64.495 +62.7262 +57.7893 +50.1697 +40.9481 +30.4938 +26 +26 +25 +24 +23 +21 +20 +19 +19 +18 +19 +24.0404 +33.3104 +43.9599 +51.958 +60.6416 +70.3734 +76.1903 +71.1654 +64.1917 +58.0348 +51.049 +42.2922 +33.5421 +29 +28 +27 +26 +25 +24 +22 +21 +20 +19 +20 +25.5794 +36.9955 +50.6631 +59.0296 +61.3114 +60.4011 +59.1436 +57.9484 +55.3675 +51.1168 +46.3347 +39.7458 +31.1909 +27 +25 +24 +24 +24 +23 +22 +20 +19 +18 +19 +25.3243 +35.1939 +44.9902 +52.3837 +54.8744 +55.7155 +55.388 +54.5932 +52.2009 +48.4164 +44.2531 +37.9412 +30.9154 +27 +26 +24 +23 +23 +23 +22 +22 +21 +21 +21 +24.8813 +33.569 +41.5931 +48.3289 +53.707 +55.3904 +55.8712 +55.2607 +52.7454 +49.866 +45.5864 +39.0595 +31.9585 +28 +26 +25 +24 +24 +25 +24 +23 +21 +20 +20 +25.048 +33.6587 +41.1588 +47.2283 +51.0131 +52.6398 +53.4167 +53.5241 +51.7329 +48.1357 +41.1685 +35.1911 +30.579 +28 +26 +24 +23 +22 +22 +22 +22 +22 +21 +22 +26.0247 +34.0901 +42.2259 +51.1507 +59.8787 +55.6335 +66.8263 +60.8853 +56.2346 +48.8977 +43.7826 +37.3385 +31.163 +27 +25 +23 +23 +23 +23 +21 +19 +19 +18 +19 +23.1252 +32.4304 +42.6802 +50.4765 +53.8863 +54.7431 +54.386 +52.2903 +51.0215 +47.0448 +42.4729 +36.4506 +29.9855 +27 +25 +23 +22 +20 +19 +19 +19 +20 +20 +21 +25.6578 +35.9009 +46.0128 +51.2876 +54.8288 +56.1591 +56.458 +54.7597 +52.5013 +49.3934 +44.5898 +38.343 +31.0835 +27 +26 +24 +22 +21 +19 +19 +19 +20 +20 +19 +24.1056 +33.6234 +44.0064 +52.622 +58.4779 +60.4076 +59.7643 +57.9445 +54.9039 +50.3501 +45.1474 +39.1477 +29.4899 +25 +24 +23 +23 +23 +22 +22 +21 +20 +18 +19 +24.1875 +34.4305 +43.7812 +53.8629 +67.2639 +65.8481 +55.4571 +61.5084 +56.8619 +51.4673 +45.5277 +39.053 +31.1631 +27 +26 +25 +24 +23 +22 +21 +21 +22 +20 +20 +26.1046 +36.0961 +47.1639 +41.5029 +55.6671 +56.1762 +51.8393 +48.5796 +47.2924 +37.5367 +42.2486 +36.6434 +32.1368 +28 +26 +25 +25 +24 +23 +23 +22 +21 +20 +19 +19.0952 +23.0525 +25.2053 +32.8264 +37.8475 +34.0982 +39.3712 +41.1746 +43.5569 +36.5886 +33.0597 +29.1243 +27.1053 +25 +24 +24 +24 +23 +22 +21 +20 +19 +19 +20 +24.9069 +33.2492 +42.7407 +49.7397 +56.815 +62.088 +66.5049 +66.9339 +63.678 +55.2362 +47.9019 +40.514 +32.4562 +28 +26 +24 +23 +22 +21 +21 +21 +20 +19 +20 +24.1651 +31.8139 +40.585 +50.5637 +60.5692 +67.5765 +73.444 +72.9952 +69.281 +61.9743 +53.0637 +42.7339 +32.5265 +28 +28 +27 +26 +24 +22 +21 +20 +20 +19 +20 +25.4812 +35.3162 +47.2521 +56.4184 +64.1238 +69.487 +72.256 +70.3722 +65.2467 +58.1967 +51.0537 +43.6121 +34.9254 +30 +30 +29 +27 +25 +24 +23 +22 +21 +20 +21 +26.5293 +36.2432 +47.7209 +58.0655 +66.9495 +71.7289 +71.3584 +68.6764 +64.8312 +59.1958 +52.6752 +45.2005 +34.5827 +30 +29 +28 +27 +26 +25 +25 +24 +23 +22 +23 +28.554 +39.1161 +51.6568 +63.8361 +69.0513 +66.7864 +64.519 +62.3442 +59.0333 +54.6132 +49.9644 +43.9761 +35.6005 +31 +29 +27 +26 +25 +25 +24 +24 +25 +25 +25 +30.5477 +40.5334 +51.1551 +56.7986 +59.8448 +61.0969 +60.7106 +58.111 +54.9347 +50.6459 +46.2018 +41.8822 +34.9944 +31 +29 +27 +26 +25 +25 +25 +26 +25 +25 +25 +30.9626 +37.7182 +50.3953 +55.945 +59.137 +57.695 +56.0696 +53.9869 +52.0255 +49.4448 +45.1414 +40.3126 +33.9587 +30 +28 +27 +26 +25 +24 +23 +23 +23 +24 +25 +30.0544 +38.7954 +43.993 +51.5221 +57.4491 +65.6189 +74.9152 +75.8678 +62.3429 +47.9034 +47.2637 +39.0724 +29.349 +27 +25 +24 +23 +22 +22 +21 +19 +18 +18 +19 +23.1688 +29.418 +37.8763 +45.6261 +52.5613 +57.5584 +58.2195 +57.2948 +54.005 +49.6168 +43.8545 +37.8237 +30.5497 +26 +24 +23 +21 +21 +21 +20 +19 +18 +17 +18.2132 +23.7328 +32.4479 +43.2823 +55.5629 +59.6678 +61.2768 +61.868 +61.2665 +58.5398 +54.3333 +46.1605 +40.5686 +32.9495 +28 +27 +26 +26 +25 +24 +24 +23 +22 +21 +22.1943 +26.1509 +35.1215 +43.5484 +50.9195 +57.042 +60.0495 +60.5939 +60.171 +57.8335 +53.9304 +49.0237 +43.7812 +35.664 +31 +29 +28 +27 +25 +25 +24 +23 +22 +21 +22.2172 +28.353 +36.5826 +46.4967 +55.8217 +62.121 +64.6295 +64.0789 +61.6968 +57.6148 +53.7246 +48.9382 +43.1652 +33.9291 +29 +27 +27 +26 +26 +25 +24 +23 +22 +21 +22.2891 +28.9459 +39.6702 +49.8957 +60.3899 +68.2867 +71.0063 +69.9716 +63.7838 +61.7645 +57.0491 +50.9334 +43.6134 +35.7923 +31 +29 +28 +27 +27 +27 +26 +26 +25 +25 +25.1692 +30.0804 +37.5499 +45.2935 +51.0513 +55.5907 +58.2716 +58.7778 +56.7793 +55.1011 +51.0842 +47.02 +42.8737 +36.1544 +32 +30 +28 +26 +25 +25 +25 +23 +21 +21 +23.2736 +28.8186 +38.5191 +47.4473 +52.9491 +57.5877 +60.606 +61.0358 +59.8344 +56.644 +51.6063 +46.5149 +41.4575 +34.2006 +30 +28 +27 +25 +24 +23 +23 +24 +24 +23 +24.3911 +30.248 +40.048 +50.1147 +58.4982 +63.111 +66.0292 +66.6407 +65.0464 +63.1333 +57.8719 +51.1285 +44.4771 +35.376 +30 +28 +27 +26 +25 +24 +23 +23 +22 +21 +22.2132 +27.8269 +36.1565 +45.3917 +54.7182 +64.4222 +74.7487 +74.7989 +71.7017 +67.5091 +61.6991 +53.827 +46.0927 +35.475 +30 +29 +28 +27 +27 +26 +26 +25 +24 +23 +24.2254 +28.425 +37.755 +46.6042 +56.325 +66.4927 +74.3005 +73.5942 +68.7865 +64.0301 +57.8841 +51.5374 +45.8193 +37.3444 +32 +30 +29 +28 +28 +28 +27 +25 +23 +22 +24.253 +30.1098 +40.0249 +49.8204 +61.258 +68.5141 +69.9044 +67.5234 +64.9196 +60.4728 +56.2266 +51.09 +45.9228 +38.399 +33 +31 +30 +28 +27 +27 +26 +26 +26 +25 +25.2114 +30.1118 +37.4059 +44.2001 +48.6414 +52.1364 +53.9902 +54.8814 +55.1464 +53.4374 +51.131 +47.2692 +42.1024 +36.2629 +31 +29 +28 +26 +25 +24 +24 +24 +24 +23 +24.3158 +29.9753 +37.9772 +45.9306 +53.1834 +60.0448 +61.8827 +60.8382 +58.7068 +56.8774 +53.4249 +49.0117 +43.389 +36.2167 +31 +29 +28 +27 +25 +25 +25 +26 +26 +25 +25.2857 +30.4728 +39.1986 +49.3119 +57.5478 +61.3882 +60.1765 +61.5991 +60.0921 +56.9891 +53.9061 +49.7182 +44.4151 +37.0404 +31 +29 +28 +27 +25 +25 +25 +26 +25 +24 +24.2358 +30.3569 +38.6069 +48.556 +62.1466 +73.2928 +73.6843 +73.7974 +72.7175 +68.939 +63.0891 +54.7469 +47.2044 +38.2045 +33 +31 +30 +30 +30 +30 +29 +28 +28 +27 +27.2975 +31.8995 +40.164 +47.1476 +53.7323 +57.6014 +60.1852 +61.6899 +60.7429 +57.7747 +54.1428 +49.5879 +44.0836 +37.8795 +33 +31 +30 +29 +27 +26 +25 +25 +24 +24 +25.1865 +30.6154 +37.8158 +45.5383 +47.495 +56.21 +67.5185 +73.7914 +76.6721 +72.9874 +65.2778 +55.6344 +46.1947 +37.2722 +32 +30 +29 +27 +26 +26 +25 +25 +25 +25 +26.1642 +30.8051 +38.1225 +48.014 +56.9963 +61.4305 +61.7922 +61.3747 +59.8246 +57.7152 +53.1293 +48.1881 +42.9755 +36.441 +32 +30 +29 +28 +26 +26 +26 +26 +25 +25 +26.2597 +30.6168 +38.9579 +48.284 +56.244 +63.2762 +67.2419 +67.8509 +67.2916 +63.3495 +58.4827 +52.0123 +44.8646 +37.4021 +32 +30 +29 +28 +26 +25 +25 +25 +25 +24 +25.2358 +30.2326 +38.8611 +47.1386 +55.2039 +64.4959 +74.5405 +74.6716 +70.3755 +65.6398 +58.9659 +52.0868 +45.4856 +37.4131 +32 +30 +29 +27 +27 +27 +27 +26 +26 +26 +26.2305 +30.103 +37.9191 +46.179 +57.0956 +69.277 +73.8027 +70.0506 +66.9916 +62.9355 +57.676 +52.0373 +45.4751 +36.2965 +31.228 +29 +28 +27 +26 +25 +25 +25 +25 +24 +25.2597 +29.8743 +40.2606 +49.9984 +61.0385 +66.8377 +65.9893 +65.6337 +64.3506 +61.925 +57.949 +52.806 +46.2006 +36.8574 +30.2975 +28 +27 +26 +25 +24 +23 +23 +23 +23 +23.2358 +28.3563 +36.8697 +44.4769 +51.6309 +60.1646 +67.6146 +71.9217 +73.4275 +70.7968 +65.2593 +57.7225 +49.1352 +37.4201 +30.2313 +28 +27 +26 +26 +26 +25 +24 +23 +21 +22.2533 +28.7155 +38.5161 +47.4108 +58.4822 +68.8529 +71.4843 +69.4549 +65.2763 +61.2449 +55.8727 +49.5257 +42.8124 +34.8898 +30.1727 +28 +27 +26 +25 +24 +23 +22 +21 +21 +22.253 +28.9847 +38.3313 +48.1828 +58.105 +62.5722 +63.0235 +61.4421 +54.3909 +60.3989 +55.1012 +49.2971 +42.8559 +36.0119 +31.1764 +29 +28 +27 +26 +26 +26 +25 +24 +23 +24.2842 +28.8514 +36.6054 +43.7246 +55.6051 +61.08 +65.124 +61.1625 +63.1195 +62.3608 +57.0237 +50.0607 +43.5107 +36.0161 +31.1562 +29 +28 +27 +26 +25 +24 +23 +22 +21 +22.2313 +27.7924 +38.11 +49.6197 +59.9528 +63.6175 +63.632 +62.5684 +61.2362 +57.9251 +54.0205 +48.962 +43.161 +36.3396 +30.2736 +28 +27 +26 +25 +24 +24 +23 +23 +22 +23.2463 +28.6018 +38.1682 +49.1973 +60.5698 +69.284 +66.8488 +69.4978 +64.6247 +59.6367 +59.0786 +52.5573 +45.7734 +36.461 +30.2975 +28 +27 +27 +26 +25 +24 +22 +21 +21 +22.2533 +28.0047 +35.4766 +44.226 +53.5336 +64.1748 +72.5491 +77.1556 +75.7238 +71.3468 +64.1519 +54.7765 +45.2203 +36.4346 +32.1827 +30 +29 +28 +27 +26 +26 +25 +24 +23 +23.1844 +28.0481 +36.9053 +45.7915 +51.6555 +54.6761 +55.9083 +56.5388 +56.5362 +55.0389 +52.9207 +48.5356 +43.4726 +36.7383 +32.1723 +30 +29 +28 +28 +27 +26 +26 +26 +25 +26 +29.883 +38.3407 +48.597 +58.0739 +63.3828 +64.2118 +63.2328 +62.3372 +60.4758 +58.3412 +53.7628 +47.9407 +38.6141 +32.2122 +30 +29 +28 +28 +28 +28 +27 +26 +25 +26 +30.9215 +38.972 +46.3634 +53.9736 +61.6582 +67.5046 +70.9539 +71.261 +70.0681 +63.7759 +56.5434 +50.4337 +42.2006 +38.1394 +37 +36 +35 +34 +32 +31 +30 +29 +29 +30 +33.4066 +42.0849 +52.3465 +55.4448 +64.0896 +61.6335 +60.3853 +59.2312 +58.7602 +56.5317 +52.9574 +48.1306 +41.5282 +36.0697 +34 +33 +32 +32 +32 +31 +31 +30 +29 +29 +33.498 +39.9723 +46.0719 +51.8305 +55.0135 +57.714 +59.3455 +59.9423 +57.8263 +54.2171 +48.6017 +47.2255 +38.7071 +34.2398 +33 +32 +30 +28 +27 +25 +25 +25 +25 +25 +30.3052 +38.3476 +46.7456 +54.0513 +58.6875 +61.9682 +62.6612 +61.3815 +60.097 +55.8221 +50.8591 +46.1281 +38.2509 +33.2305 +31 +30 +29 +27 +27 +27 +26 +25 +24 +26 +30.6592 +37.8083 +45.4677 +51.7655 +56.9757 +59.787 +61.0481 +61.4624 +59.392 +56.0826 +51.0469 +45.6846 +38.9793 +34.2029 +32 +31 +30 +29 +28 +28 +28 +28 +28 +28 +32.5608 +40.1199 +46.8751 +52.0486 +56.5423 +58.4922 +58.9727 +58.3 +55.9122 +53.1544 +48.7173 +44.1673 +37.8942 +34.1943 +32 +31 +30 +29 +28 +28 +28 +28 +27 +27 +32.2559 +40.316 +47.9801 +54.1234 +59.0075 +61.5521 +62.3488 +61.8515 +59.2923 +56.2641 +51.6866 +46.9461 +39.1086 +34.1985 +33 +32 +31 +30 +28 +28 +28 +28 +27 +28 +32.1507 +39.3136 +46.855 +53.0132 +58.1918 +60.8051 +61.6459 +61.2131 +59.6997 +55.624 +52.1126 +47.4869 +40.0361 +35.1903 +33 +32 +31 +30 +29 +29 +29 +28 +27 +28 +31.9806 +39.9089 +48.7334 +56.3356 +63.1014 +66.9033 +67.6669 +67.0505 +64.7041 +60.8654 +55.3162 +49.5074 +41.685 +36.1968 +36 +35 +34 +33 +33 +33 +32 +31 +29 +30 +34.6521 +40.631 +47.3475 +54.3036 +59.8883 +66.5811 +70.5162 +70.4168 +67.2928 +62.0977 +56.7285 +46.1845 +37.9919 +34.0728 +34 +34 +34 +33 +33 +32 +32 +32 +32 +33 +36.3395 +40.835 +45.9479 +47.953 +58.1274 +62.9018 +64.7224 +63.9955 +60.4268 +55.2935 +50.4682 +43.8103 +36.9935 +33.0319 +32 +32 +32 +32 +32 +31 +30 +28 +28 +28 +31.9007 +37.8871 +44.215 +50.3841 +54.1792 +57.3903 +57.8338 +56.5725 +55.7938 +53.1925 +48.9726 +44.3644 +38.8054 +35.1356 +33 +32 +31 +30 +29 +29 +29 +28 +28 +28 +29.2977 +33.7717 +39.181 +46.8117 +56.1654 +61.0524 +59.9668 +58.0279 +55.833 +53.4774 +48.6709 +43.9325 +38.0461 +33.1533 +32 +31 +30 +29 +29 +29 +28 +27 +26 +26 +28.4766 +35.1918 +39.2745 +46.2283 +54.1473 +52.1531 +50.1152 +58.1184 +55.5991 +52.305 +47.2883 +42.6574 +37.263 +33 +32 +31 +30 +29 +28 +28 +28 +28 +28 +28 +32.4562 +41.1611 +48.9355 +55.361 +59.7047 +62.0612 +61.8078 +61.0574 +58.1462 +54.9436 +50.2464 +45.443 +38.3578 +34 +33 +32 +31 +30 +29 +29 +28 +27 +27 +28 +31.9028 +39.2444 +48.373 +55.8454 +58.0683 +57.4137 +57.1884 +56.5683 +55.7622 +52.3875 +48.8283 +44.9943 +40.576 +36 +34 +33 +32 +31 +30 +29 +28 +28 +28 +28 +31.5674 +37.601 +44.3753 +51.5681 +58.3828 +62.0051 +62.592 +61.372 +60.0137 +56.6637 +53.3975 +46.7223 +39.6205 +35 +34 +32 +31 +30 +29 +29 +28 +28 +28 +28 +31.6566 +38.3718 +46.2626 +54.0569 +61.0527 +65.5719 +67.0581 +66.1169 +63.1197 +59.2548 +53.7227 +45.439 +40.5452 +36 +35 +34 +32 +30 +29 +28 +27 +27 +27 +27 +28.9388 +32.7591 +43.3748 +56.7322 +62.3107 +64.4886 +63.2374 +60.9907 +58.0805 +53.3216 +48.7969 +42.9388 +36.7879 +32 +31 +31 +30 +28 +28 +28 +27 +27 +27 +26 +27.0438 +30.1346 +28.7004 +38.168 +45.1301 +47.7331 +50.5188 +53.7398 +53.2455 +50.7596 +46.5375 +38.5093 +32.7295 +29 +28 +28 +27 +27 +26 +26 +26 +25 +25 +25 +28.9157 +35.9391 +42.4062 +48.9412 +52.7041 +55.4762 +56.9799 +57.1707 +55.4241 +52.6384 +34.529 +33.5095 +32.1962 +31 +30 +29 +28 +28 +27 +27 +27 +26 +26 +26 +28.7907 +34.1082 +40.4259 +46.7224 +53.263 +57.7316 +60.6831 +57.1938 +55.5904 +51.9348 +44.4834 +38.7493 +34.0724 +31 +30 +30 +30 +29 +28 +27 +26 +26 +25 +25 +28.6471 +33.8767 +42.2502 +44.9574 +43.1733 +70.7275 +74.448 +72.0346 +65.1824 +58.371 +50.6561 +43.4417 +36.8977 +33 +32 +31 +30 +29 +28 +28 +27 +27 +27 +27 +28.8104 +35.4638 +40.9766 +48.0653 +52.4835 +54.8093 +55.9562 +56.4097 +55.0142 +52.6313 +49.4166 +43.7761 +35.5494 +31 +30 +29 +28 +28 +27 +27 +27 +27 +26 +26 +29.4635 +33.7424 +41.3829 +44.6963 +54.8982 +56.6614 +57.4495 +57.2654 +55.7751 +53.3956 +48.1091 +41.3946 +36.0622 +32 +32 +31 +30 +29 +28 +27 +27 +26 +26 +26 +29.6288 +35.9703 +39.1769 +51.1856 +57.539 +60.8603 +61.6366 +60.0813 +58.4448 +54.1944 +48.6391 +42.1044 +34.976 +31 +29 +28 +26 +25 +24 +24 +24 +24 +24 +24 +26.8254 +30.6389 +29.6302 +26.6269 +26.9586 +37.1735 +41.4636 +48.3672 +43.5277 +46.772 +44.4629 +37.7725 +29.7702 +26 +26 +26 +25 +25 +25 +25 +25 +24 +24 +25 +28.3302 +34.5042 +42.8366 +48.7734 +46.9055 +55.695 +59.1125 +58.9526 +59.2496 +43.6703 +50.8014 +43.9146 +35.7564 +31 +30 +29 +29 +28 +28 +27 +26 +26 +26 +26 +29.3962 +37.6169 +50.386 +58.1078 +60.4855 +61.3304 +60.066 +57.9803 +54.3334 +51.5476 +47.5047 +42.1711 +34.3993 +31 +30 +30 +29 +29 +28 +28 +28 +28 +28 +28 +31.7121 +38.7991 +47.4471 +54.7479 +58.952 +61.7549 +62.46 +61.1027 +59.0834 +54.8897 +49.1686 +39.053 +35.9282 +34 +32 +30 +29 +29 +28 +28 +28 +27 +27 +27 +28.2613 +30.9299 +28.784 +42.8023 +38.8637 +56.0862 +48.0544 +44.2667 +43.0954 +42.4152 +40.0488 +36.8307 +30.5954 +28 +27 +27 +26 +26 +26 +25 +25 +25 +25 +25 +28.7059 +34.3782 +39.5579 +45.9658 +53.2389 +60.0125 +60.8714 +42.5384 +45.3572 +49.5727 +40.5683 +35.1317 +30.5276 +28 +27 +27 +27 +26 +26 +25 +25 +25 +24 +24 +26.3304 +31.0465 +36.9016 +46.2761 +50.3947 +53.5766 +52.3279 +62.9635 +65.0242 +61.0198 +53.0895 +37.7822 +33.8633 +31 +30 +30 +29 +29 +28 +27 +27 +26 +25 +26 +29.3019 +36.8399 +50.2698 +54.35 +56.4083 +63.9567 +64.8044 +65.6798 +66.0204 +65.453 +56.9839 +41.1692 +32.0792 +28 +28 +27 +27 +26 +26 +25 +24 +24 +24 +24 +27.5234 +35.7381 +47.9202 +54.4907 +58.4683 +61.2663 +62.7533 +62.9292 +60.3128 +55.0502 +48.1558 +36.7568 +33.0238 +30 +30 +29 +28 +27 +26 +25 +25 +25 +25 +25 +28.0064 +30.2868 +41.3605 +50.6568 +60.2834 +68.8853 +69.4008 +64.2524 +59.5068 +54.4079 +48.0596 +41.4297 +34.6735 +31 +31 +30 +29 +28 +27 +27 +26 +26 +25 +26 +29.4093 +36.7184 +47.3116 +53.9592 +56.0683 +56.5047 +54.3725 +50.8244 +47.9743 +45.0484 +40.3859 +36.9708 +32.5383 +30 +28 +28 +27 +27 +26 +26 +25 +25 +25 +25 +27.792 +32.0084 +38.225 +34.0791 +34.6951 +36.4562 +41.5721 +44.0644 +46.0797 +43.9979 +40.5292 +36.6892 +33.0058 +30 +28 +28 +27 +27 +26 +26 +25 +25 +25 +25 +28.3436 +36.481 +45.8467 +54.3806 +56.6066 +57.615 +58.0496 +56.5127 +55.1253 +50.8792 +45.8345 +40.3991 +33.3774 +29 +28 +27 +27 +27 +26 +26 +25 +24 +23 +24 +27.306 +34.7736 +43.0275 +53.17 +65.5988 +73.325 +70.994 +67.7905 +65.1754 +59.1494 +52.1 +44.837 +36.0732 +32 +32 +32 +30 +29 +29 +28 +28 +28 +27 +27 +29.9957 +36.7252 +44.2672 +51.2695 +61.8252 +69.6353 +66.0356 +62.6466 +58.5304 +52.875 +45.3454 +40.3319 +35.9529 +32 +32 +31 +30 +30 +29 +29 +28 +28 +27 +28 +31.0688 +36.8354 +43.681 +55.0033 +63.8394 +68.3489 +65.0247 +60.024 +56.4003 +52.7542 +47.6014 +41.6723 +36.2215 +34 +33 +32 +31 +30 +29 +28 +28 +27 +27 +27 +28.5973 +32.3812 +38.0263 +42.2285 +45.3555 +47.4165 +50.1712 +47.2743 +46.8578 +44.5853 +41.5734 +37.6546 +33.8024 +31 +31 +31 +30 +29 +28 +28 +27 +27 +27 +27 +29.0744 +31.6217 +35.0688 +39.0367 +49.3264 +57.9573 +60.2305 +60.6671 +59.188 +54.5288 +48.507 +40.9396 +33.254 +31 +30 +29 +29 +28 +28 +27 +26 +26 +26 +26 +28.6469 +35.6792 +44.1294 +55.2336 +58.0469 +60.212 +58.0352 +44.0931 +50.2819 +45.6178 +40.4052 +35.8822 +31.8577 +30 +29 +28 +28 +28 +27 +27 +26 +26 +25 +24 +26.1955 +32.2947 +38.7691 +46.2069 +55.1063 +61.3366 +58.5496 +56.4411 +53.4058 +47.8121 +42.8988 +37.0427 +32.8498 +30 +29 +29 +28 +28 +27 +27 +26 +25 +24 +25 +28.1399 +34.3418 +43.9234 +50.7798 +58.177 +59.6916 +57.9135 +54.8292 +49.9695 +47.2878 +41.6906 +37.5705 +32.7211 +32 +31 +30 +28 +27 +27 +26 +26 +26 +25 +25 +28.3248 +33.6281 +41.2005 +50.5134 +60.4897 +65.8447 +64.1274 +59.5524 +55.8344 +50.4093 +43.2585 +37.8635 +32.2491 +30 +29 +28 +27 +26 +25 +25 +25 +25 +25 +25 +26.7554 +29.8807 +37.5011 +42.8274 +39.3583 +45.2629 +49.4041 +52.0622 +50.1369 +51.1892 +44.3681 +36.3311 +30.2529 +28 +28 +27 +27 +26 +26 +25 +25 +24 +24 +24 +26.9712 +32.1734 +39.4121 +50.1112 +60.5718 +59.9159 +55.8671 +56.1885 +52.7369 +47.5446 +42.7282 +38.0909 +31.8168 +29 +28 +27 +26 +26 +25 +24 +24 +24 +23 +24 +27.1513 +35.4067 +44.3602 +55.9497 +65.1402 +67.1554 +67.0097 +65.5971 +60.8577 +55.2027 +48.1127 +40.154 +33.2182 +31 +31 +30 +29 +28 +28 +27 +26 +24 +23 +23 +26.9521 +33.3972 +42.0638 +50.2496 +57.2414 +64.2157 +69.1959 +70.8064 +67.3737 +61.0259 +53.1829 +43.8016 +34.842 +31 +31 +30 +30 +29 +28 +28 +27 +26 +25 +25 +27.8058 +34.8997 +43.1277 +50.3719 +55.9969 +62.477 +67.7444 +71.0777 +70.9446 +65.8232 +55.2326 +44.6553 +35.628 +33 +33 +32 +30 +28 +26 +25 +25 +25 +25 +25 +27.9442 +35.1836 +43.5817 +51.2172 +61.8302 +66.152 +64.1236 +60.1747 +55.1936 +47.1234 +42.1436 +38.1968 +31.9017 +31 +30 +30 +29 +29 +28 +28 +27 +27 +27 +27 +29.933 +36.828 +47.6678 +57.5278 +62.6493 +64.4338 +65.1326 +61.7837 +57.0119 +48.662 +41.8072 +34.4165 +31.416 +30 +29 +28 +27 +27 +26 +26 +25 +25 +25 +25 +27.7298 +31.6845 +32.3458 +35.0967 +42.9463 +35.9004 +39.2598 +36.3352 +36.2836 +41.0338 +37.727 +33.6495 +29.6196 +28 +28 +27 +26 +26 +26 +25 +25 +25 +24 +25 +27.7852 +34.9727 +43.7962 +50.9716 +56.9387 +60.6865 +62.6833 +61.7827 +60.0277 +56.9882 +49.7438 +42.7003 +34.4896 +32 +31 +31 +30 +29 +29 +29 +28 +27 +26 +26 +28.0704 +33.6737 +32.9579 +36.4492 +51.4002 +58.4338 +61.9149 +59.5629 +55.4624 +50.8567 +42.6225 +35.954 +30.5797 +28 +27 +27 +26 +26 +26 +26 +26 +25 +25 +25 +25.1566 +28.1444 +34.9459 +48.86 +48.2562 +51.283 +65.8357 +62.7983 +56.6531 +50.5266 +44.5915 +34.9463 +31.6825 +30 +29 +29 +28 +27 +27 +26 +25 +25 +24 +24 +26.1167 +33.9474 +42.8356 +52.6383 +64.2045 +71.0928 +69.2947 +65.2346 +60.334 +54.4985 +47.3071 +39.5365 +32.9148 +30 +30 +29 +29 +28 +27 +27 +26 +25 +24 +24 +26.9055 +34.2719 +42.501 +50.9774 +58.7827 +65.7515 +70.1335 +69.2512 +64.0892 +56.9075 +49.5718 +41.8896 +32.0725 +30 +30 +29 +28 +26 +24 +23 +22 +21 +21 +21 +23.0727 +32.8382 +43.4664 +56.2406 +67.151 +74.539 +76.8308 +75.4409 +69.7928 +61.7183 +52.2366 +42.7667 +32.8299 +30 +30 +30 +30 +29 +27 +25 +24 +23 +23 +23 +26.7724 +33.0998 +39.5746 +44.7116 +49.2732 +52.0683 +53.4476 +52.1852 +51.2923 +47.6976 +43.6471 +39.2854 +34.436 +32 +32 +31 +30 +28 +27 +27 +26 +26 +26 +26 +27.8539 +35.3058 +42.4838 +48.4812 +52.8133 +54.9986 +54.9421 +53.8341 +51.2013 +47.8836 +41.2609 +35.8346 +33.3584 +31 +30 +29 +29 +28 +27 +27 +26 +26 +26 +26 +28.0052 +36.4013 +44.4165 +51.8355 +57.7937 +62.3948 +64.4338 +64.4537 +60.8849 +55.4491 +43.1247 +40.7446 +34.462 +32 +32 +32 +32 +31 +30 +29 +29 +29 +29 +29 +30.9213 +37.657 +47.3828 +48.2089 +50.7105 +48.078 +49.0095 +47.5471 +46.8969 +47.0109 +43.7232 +39.0936 +33.4332 +32 +31 +31 +30 +28 +26 +26 +26 +27 +27 +27 +29.0352 +38.7718 +47.0682 +60.1904 +64.9807 +62.7967 +60.4135 +61.334 +58.967 +54.1539 +48.6101 +42.1028 +34.5708 +32 +30 +30 +29 +28 +28 +27 +26 +26 +25 +25 +28.7185 +36.8664 +45.107 +54.8878 +63.906 +73.4209 +73.7073 +68.4793 +62.231 +55.2494 +48.8887 +41.9322 +35.3136 +33 +32 +31 +30 +28 +27 +26 +26 +25 +25 +25 +27.6786 +34.3764 +41.4515 +45.4914 +49.4183 +50.9906 +51.8345 +51.8066 +50.2627 +47.1278 +43.2969 +37.8966 +33.2693 +31 +30 +29 +29 +28 +27 +26 +25 +25 +24 +24 +26.2056 +30.0375 +35.8295 +40.7329 +48.7924 +51.559 +53.0881 +53.2066 +50.2951 +47.3467 +42.8668 +37.1923 +32.2413 +30 +29 +29 +28 +28 +27 +27 +27 +26 +26 +26 +27.7456 +34.7627 +45.6252 +55.081 +60.6626 +62.1339 +61.682 +55.5346 +51.6136 +44.3672 +36.0067 +35.3217 +31.2736 +30 +29 +28 +28 +27 +27 +26 +26 +26 +25 +25 +26.7415 +34.0183 +38.1237 +53.8989 +63.7179 +64.1019 +62.1163 +59.5064 +55.2207 +48.7574 +42.5037 +37.0817 +32.1838 +30 +30 +29 +28 +27 +26 +25 +25 +25 +25 +25 +26.8821 +35.6019 +47.7252 +55.9106 +55.4454 +54.61 +53.5856 +52.0483 +49.2073 +45.3506 +40.5115 +35.0935 +31.1646 +29 +28 +27 +27 +26 +26 +26 +25 +25 +24 +24 +25.662 +32.2315 +39.1637 +39.7569 +52.018 +49.2036 +45.4272 +49.2329 +42.7238 +43.9337 +38.74 +33.0557 +28.224 +26 +26 +25 +24 +24 +24 +23 +23 +23 +23 +23 +24.7888 +31.4473 +35.4875 +39.2321 +55.5143 +60.7403 +63.4966 +63.9207 +61.9864 +57.4714 +48.9479 +37.5493 +27.3522 +25 +25 +24 +24 +23 +23 +23 +22 +21 +20 +20 +21.5847 +30.396 +39.3205 +47.0509 +51.9206 +56.6354 +59.4155 +59.3206 +55.4475 +50.2821 +43.7216 +35.8522 +29.2225 +28 +28 +27 +24 +22 +21 +21 +20 +19 +19 +19 +21.6052 +30.9501 +40.078 +48.2765 +55.2835 +59.7118 +61.991 +61.8328 +58.3462 +52.8216 +46.5974 +37.9013 +29 +27 +26 +26 +25 +25 +24 +23 +22 +22 +21 +21 +23.6262 +34.35 +43.0104 +49.6601 +58.3206 +68.6488 +75.5116 +71.8546 +63.6474 +54.6765 +46.8863 +37.0341 +30 +28 +28 +28 +27 +25 +23 +22 +21 +21 +21 +21 +23.5141 +32.1609 +40.8085 +50.566 +63.3355 +66.0941 +63.1775 +60.8311 +56.5683 +50.7527 +45.0092 +37.5405 +32 +31 +30 +29 +28 +27 +26 +25 +25 +24 +23 +22 +24.5787 +35.0994 +46.5798 +53.9807 +57.1425 +57.5929 +57.1539 +56.1191 +52.2072 +48.1211 +43.4064 +36.7354 +31 +30 +29 +29 +28 +27 +26 +26 +25 +25 +25 +25 +26.5808 +35.7449 +45.2789 +54.3563 +67.0987 +72.9897 +71.1911 +69.1117 +64.1489 +56.8214 +48.7628 +38.9936 +30 +28 +27 +27 +26 +25 +24 +23 +23 +23 +23 +23 +24.6785 +35.3814 +46.9232 +53.1182 +57.9847 +63.6252 +66.2845 +64.7922 +60.0296 +53.2328 +46.9609 +36.861 +28 +26 +25 +25 +25 +25 +24 +23 +22 +20 +20 +19 +20.5412 +28.8933 +38.5162 +50.1386 +64.1558 +71.6015 +70.706 +68.2354 +65.7675 +60.7359 +52.347 +39.4629 +30 +29 +28 +27 +25 +23 +22 +22 +21 +21 +20 +20 +23.4704 +31.6715 +42.0282 +52.2504 +62.7774 +69.3166 +72.2232 +74.5057 +70.9607 +61.5945 +50.9393 +38.478 +30 +30 +29 +29 +28 +27 +25 +23 +22 +21 +21 +21 +23.4975 +33.5973 +45.4761 +56.8624 +67.968 +71.6585 +70.8483 +71.1331 +65.9329 +59.1839 +49.12 +38.6108 +30 +29 +29 +28 +26 +24 +22 +22 +21 +20 +20 +20 +21.4425 +30.8311 +41.7943 +54.243 +66.0122 +74.7691 +77.8476 +75.8859 +68.748 +60.1696 +51.9418 +39.7468 +31 +30 +29 +27 +25 +24 +23 +22 +22 +22 +21 +21 +23.4584 +33.3711 +44.0633 +55.1271 +62.1775 +65.1467 +64.2733 +53.8949 +54.3912 +48.4683 +42.7227 +36.9669 +34 +33 +31 +29 +29 +28 +27 +27 +27 +27 +27 +27 +28.0902 +31.7057 +35.6065 +40.7696 +43.3759 +42.6016 +43.9425 +41.4707 +41.759 +35.2146 +32.6708 +29.3216 +27 +26 +25 +25 +24 +23 +23 +23 +23 +22 +22 +22 +22.1792 +24.9083 +28.9855 +27.0746 +30.0738 +31.831 +32.8311 +32.2744 +31.0919 +31.2772 +31.4714 +27.1309 +25 +24 +23 +23 +22 +22 +22 +21 +21 +21 +21 +21 +22.152 +25.4163 +34.2631 +43.9044 +49.2493 +49.5357 +57.9615 +58.1571 +55.9791 +51.3623 +40.0321 +34.0135 +28 +27 +26 +25 +24 +24 +23 +23 +23 +22 +22 +21 +22.3645 +31.0882 +40.62 +50.307 +59.1817 +63.8149 +67.0784 +68.0103 +64.4836 +58.8227 +48.5427 +36.4323 +29 +27 +26 +26 +26 +26 +25 +23 +22 +21 +21 +21 +22.3155 +30.4704 +38.21 +44.6687 +50.4116 +53.1887 +54.6455 +54.0814 +52.1761 +47.7443 +42.7276 +34.533 +29 +28 +27 +27 +26 +26 +25 +25 +24 +24 +23 +22 +23.2097 +31.583 +41.635 +50.3866 +57.2807 +60.3448 +61.457 +60.3733 +56.7852 +50.9492 +45.1025 +36.1 +30 +28 +27 +26 +25 +25 +25 +25 +24 +24 +23 +22 +23.3038 +32.9406 +43.3377 +52.3174 +58.7515 +61.818 +61.6993 +58.7961 +55.1625 +50.2705 +44.2047 +36.6611 +31 +30 +29 +28 +27 +26 +26 +26 +25 +25 +24 +24 +25 +34.2817 +44.1883 +52.468 +58.1399 +61.2561 +61.1838 +58.9854 +55.6078 +50.442 +45.3304 +33.1281 +28 +26 +25 +25 +24 +23 +23 +22 +22 +21 +21 +21 +22 +30.0598 +40.526 +48.4812 +57.7043 +65.412 +63.9528 +60.9576 +56.1663 +50.1025 +42.4968 +33.1655 +29 +28 +27 +26 +26 +25 +25 +24 +23 +23 +22 +21 +22 +29.3101 +36.8192 +47.9924 +31.9157 +53.274 +51.3221 +39.6287 +31.6736 +30.7068 +36.6148 +29.1841 +25 +24 +23 +22 +21 +20 +19 +18 +18 +17 +17 +16 +17 +23.4722 +30.3482 +36.9486 +41.17 +44.0648 +45.7956 +45.3901 +41.9754 +37.7841 +33.0378 +24.6492 +19 +18 +18 +18 +18 +18 +17 +16 +14 +14 +13 +13 +14 +24.8203 +33.1487 +40.9942 +48.3075 +53.9736 +57.5134 +57.148 +53.5913 +46.9088 +37.8008 +27.4097 +22 +21 +20 +19 +18 +17 +16 +16 +15 +15 +14 +14 +15 +25.1201 +33.658 +42.6825 +51.6893 +57.7967 +58.6828 +57.1681 +52.3569 +45.4428 +35.622 +27.2689 +23 +23 +22 +21 +21 +21 +20 +20 +20 +19 +18 +17 +17 +24.0122 +32.6718 +38.6709 +49.4505 +56.8005 +59.8528 +57.7731 +52.422 +45.2035 +37.6016 +27.8458 +23 +23 +23 +22 +20 +18 +17 +17 +16 +16 +16 +15 +16 +25.3353 +34.5441 +44.5471 +53.6107 +58.7962 +61.5722 +61.399 +58.9129 +52.3766 +42.9391 +31.7225 +27 +25 +24 +24 +23 +23 +23 +23 +23 +24 +23 +22 +21 +24.4059 +30.8696 +39.6302 +47.8102 +60.6086 +68.0598 +67.093 +60.7874 +51.9113 +41.5624 +31.3498 +27 +25 +25 +24 +24 +23 +22 +22 +21 +21 +21 +20 +21 +29.7195 +40.7191 +49.8668 +53.6127 +55.053 +54.9419 +54.0468 +50.1282 +46.0282 +40.467 +32.0275 +29 +28 +27 +27 +26 +25 +24 +23 +22 +21 +20 +20 +21 +27.3056 +35.4234 +43.606 +50.3026 +53.5698 +55.046 +53.4484 +50.3772 +44.7667 +37.7571 +30.6906 +27 +27 +27 +26 +25 +24 +23 +22 +21 +20 +19 +18 +19 +29.045 +38.8842 +46.6583 +53.5215 +58.9989 +61.7501 +61.0011 +56.5319 +49.6523 +41.2735 +31.2787 +26 +26 +26 +26 +25 +23 +22 +20 +19 +18 +17 +17 +18 +27.5456 +38.0904 +45.4918 +49.4332 +63.5008 +48.3696 +50.4955 +54.5216 +50.6575 +41.7423 +29.7822 +25 +24 +24 +23 +22 +22 +21 +20 +19 +18 +17 +16 +17 +25.1393 +34.4609 +44.1189 +53.0044 +62.0762 +65.5296 +63.6369 +58.4403 +51.0455 +41.1605 +30.2631 +26 +26 +25 +24 +22 +20 +19 +18 +18 +17 +17 +16 +17 +27.9494 +39.3833 +48.1609 +56.0699 +61.5314 +64.6257 +62.7124 +57.2671 +49.5503 +40.3645 +30.8205 +28 +27 +26 +25 +25 +24 +24 +23 +21 +20 +18 +17 +18 +28.9719 +40.2366 +48.9729 +58.7941 +66.8552 +64.7932 +62.28 +57.3694 +49.9548 +40.4946 +29.6976 +27 +26 +25 +24 +24 +23 +23 +22 +21 +20 +19 +18 +18 +26.4167 +35.6609 +42.6855 +49.5205 +52.1172 +62.0438 +55.5656 +52.9239 +48.825 +36.4285 +27.9533 +24 +24 +24 +24 +24 +23 +21 +20 +19 +19 +18 +18 +18 +25.0415 +31.6829 +37.7076 +41.4188 +44.2682 +46.1639 +46.291 +44.1483 +39.8754 +34.8221 +27.0696 +24 +24 +23 +23 +23 +22 +21 +20 +19 +18 +18 +18 +18 +25.3678 +33.2865 +41.8948 +50.2028 +55.067 +56.5637 +55.3446 +51.068 +44.6423 +37.1078 +27.187 +25 +24 +23 +23 +22 +21 +20 +19 +19 +18 +17 +17 +17 +22.9593 +31.0881 +38.1932 +43.5611 +46.4352 +48.018 +48.0065 +45.6972 +42.2893 +36.6797 +27.933 +25 +23 +21 +20 +19 +19 +18 +18 +18 +17 +17 +17 +17 +23.8189 +32.2356 +41.6438 +48.1399 +51.0371 +52.2622 +51.9818 +49.3451 +45.7957 +38.8866 +29.029 +26 +25 +24 +23 +22 +22 +21 +21 +21 +21 +21 +21 +21 +28.1244 +37.9682 +48.2364 +57.2655 +60.9854 +63.2506 +63.8034 +61.4091 +53.6904 +43.4733 +32.3661 +29 +28 +27 +25 +23 +22 +22 +21 +21 +20 +20 +20 +20 +28.5585 +40.4988 +49.9155 +58.9804 +65.807 +66.4226 +63.8828 +57.6787 +49.5583 +40.9542 +29.7866 +27 +26 +26 +26 +26 +26 +25 +24 +22 +21 +20 +19 +19 +27.2526 +38.0598 +45.2966 +52.6713 +55.5216 +60.6739 +57.16 +52.0074 +44.8503 +38.5386 +30.6314 +28 +27 +26 +25 +25 +25 +25 +24 +23 +22 +21 +21 +21 +26.8912 +35.8951 +44.4721 +46.9456 +49.1042 +49.924 +43.8696 +39.4453 +33.0623 +30.6057 +27.1179 +27 +27 +26 +26 +25 +24 +23 +22 +22 +22 +21 +20 +20 +25.3779 +32.785 +40.361 +47.3038 +53.0083 +57.0836 +55.9694 +52.7995 +46.4356 +38.7649 +28.7259 +26 +25 +24 +23 +22 +21 +21 +20 +20 +19 +19 +19 +19 +26.7204 +36.8915 +48.9061 +60.448 +61.3968 +61.4533 +59.6029 +55.704 +49.2494 +40.2616 +28.7967 +25 +24 +24 +24 +24 +23 +22 +22 +22 +22 +21 +21 +22 +26.8867 +33.0073 +46.8297 +56.4339 +52.6723 +53.6896 +54.4781 +52.0222 +45.6692 +38.7697 +31.2665 +30 +30 +29 +28 +26 +25 +25 +25 +24 +24 +24 +24 +24 +29.2689 +32.0202 +42.0651 +39.1531 +52.0114 +56.9047 +60.9064 +55.9562 +41.0035 +34.4399 +26.1977 +24 +24 +24 +24 +24 +23 +23 +22 +22 +21 +20 +19 +19 +26.3873 +36.7823 +45.8636 +54.8629 +59.8177 +61.3042 +59.0467 +53.6169 +47.1902 +38.6419 +29 +27 +26 +25 +24 +23 +23 +23 +22 +21 +20 +20 +20 +20 +27.9694 +36.5731 +45.435 +48.9725 +51.5911 +47.9753 +44.3239 +44.8722 +39.1118 +33.7052 +27 +26 +25 +25 +26 +25 +24 +23 +22 +21 +20 +19 +19 +19 +24.0996 +31.1979 +37.4826 +42.0606 +43.4452 +41.2572 +41.3656 +42.1523 +33.6801 +29.8054 +21 +19 +18 +17 +16 +15 +15 +15 +15 +14 +14 +13 +13 +13 +19.8011 +29.3834 +39.9645 +48.5725 +53.5498 +56.1184 +57.8096 +55.3591 +43.3564 +33.615 +25 +22 +20 +18 +18 +17 +17 +16 +16 +16 +16 +15 +15 +15 +18.473 +29.0156 +35.5052 +37.7593 +45.913 +42.7642 +43.0085 +40.821 +37.0392 +30.3178 +24 +23 +21 +21 +20 +19 +18 +18 +17 +17 +17 +17 +17 +17 +18.1573 +22.3004 +24.9464 +27.9865 +30.7618 +35.2727 +39.1136 +32.4949 +40.2594 +31.0399 +21 +20 +19 +19 +19 +19 +18 +17 +15 +14 +14 +13 +12 +12 +18.2112 +27.6967 +34.1804 +40.9029 +44.9105 +46.2958 +44.8936 +40.5073 +35.3504 +28.982 +20 +20 +19 +19 +18 +18 +17 +16 +14 +13 +13 +12 +12 +12 +17.7934 +25.6075 +33.2228 +41.009 +47.6384 +53.3706 +54.6186 +51.3034 +44.4367 +32.8019 +20 +20 +19 +16 +14 +13 +13 +12 +12 +12 +11 +11 +11 +11 +18.2986 +28.9521 +37.8259 +46.9478 +48.4795 +50.1469 +45.7837 +44.5512 +33.4078 +24.5161 +22 +20 +19 +18 +18 +18 +18 +17 +16 +16 +15 +14 +14 +14 +21.2158 +33.0369 +35.7288 +42.9731 +49.2922 +46.4556 +45.0997 +42.2248 +38.7638 +27.9643 +21 +19 +18 +18 +18 +17 +17 +16 +16 +15 +14 +14 +13 +13 +18.4857 +31.6743 +37.8081 +51.0071 +50.5021 +51.9656 +49.7788 +43.2616 +36.6414 +30.0155 +23 +21 +21 +21 +20 +20 +20 +19 +18 +17 +17 +17 +16 +16 +19.8955 +31.2282 +41.0583 +47.6312 +48.6658 +44.7072 +47.6928 +43.7729 +39.521 +30.8203 +22 +21 +21 +21 +20 +19 +19 +18 +18 +17 +17 +16 +16 +16 +18.5742 +24.4351 +29.1645 +36.9173 +33.3456 +32.7249 +28.068 +28.6425 +27.0901 +23.9368 +19 +19 +19 +19 +18 +16 +15 +14 +14 +13 +12 +12 +11 +11 +16.732 +25.7844 +31.4972 +37.9395 +41.4415 +42.4859 +40.1386 +35.7119 +30.3572 +23.9698 +16 +14 +14 +14 +14 +14 +13 +12 +11 +10 +10 +9 +9 +9 +14.2284 +23.0749 +31.929 +40.2261 +45.8035 +47.2783 +46.5904 +42.962 +36.7735 +28.1443 +18 +16 +16 +16 +15 +14 +12 +11 +10 +10 +10 +9 +9 +9 +12.8917 +21.5551 +29.5558 +37.291 +43.2477 +45.6057 +45.2536 +42.2338 +37.3077 +28.291 +19 +17 +16 +16 +16 +16 +15 +14 +13 +12 +11 +11 +10 +10 +16.3677 +26.2087 +34.6054 +40.2099 +44.6143 +45.6004 +44.557 +42.0361 +37.6442 +28.7375 +19 +17 +16 +16 +17 +17 +16 +15 +14 +13 +13 +12 +11 +11 +15.3915 +22.4651 +26.6491 +31.278 +34.5893 +35.8374 +36.0371 +33.2298 +29.9336 +23.8598 +16 +15 +14 +12 +11 +10 +10 +10 +10 +10 +10 +10 +10 +10 +13.7403 +21.2924 +28.5998 +34.4182 +38.4293 +40.2015 +40.5688 +39.1178 +35.5281 +27.0811 +18 +17 +16 +14 +13 +12 +12 +11 +11 +11 +10 +10 +9 +9 +14.7561 +23.1054 +31.4837 +38.0045 +41.9194 +43.0081 +43.0651 +40.4284 +36.7115 +27.5748 +18 +16 +15 +14 +14 +13 +13 +12 +11 +10 +10 +9 +9 +9 +12.4445 +21.4416 +28.9828 +34.5219 +37.9311 +38.4358 +38.1231 +36.2094 +33.109 +27.6558 +18 +16 +14 +13 +12 +11 +10 +9 +9 +8 +8 +7 +7 +7 +11.9616 +21.3418 +29.3659 +36.3801 +40.9761 +42.3808 +42.4362 +41.298 +37.804 +28.3225 +17 +15 +14 +13 +12 +11 +11 +10 +10 +10 +10 +10 +10 +10 +13.4134 +22.5193 +30.3342 +36.6816 +40.013 +40.8117 +40.3542 +37.6235 +34.2614 +27.4058 +19 +18 +15 +13 +12 +12 +11 +10 +9 +9 +9 +9 +9 +9 +13.0408 +21.607 +27.338 +34.0159 +38.5236 +41.4211 +39.5787 +41.8114 +37.8729 +28.7394 +19 +17 +15 +14 +14 +13 +12 +12 +11 +11 +10 +10 +10 +10 +12.0652 +24.7517 +30.1564 +35.7068 +40.8655 +41.2165 +42.7388 +42.7436 +37.0719 +28.9789 +21 +20 +19 +17 +15 +14 +14 +14 +14 +14 +14 +13 +13 +13 +14.5476 +20.2739 +24.3841 +29.9155 +29.3307 +37.7922 +29.4009 +37.6697 +27.4855 +24.5269 +19 +18 +17 +16 +15 +15 +15 +15 +14 +14 +13 +12 +12 +12 +14.5046 +23.5165 +31.832 +39.3863 +44.3015 +46.729 +46.721 +41.9948 +36.1559 +26.1031 +17 +16 +16 +16 +15 +14 +13 +12 +12 +11 +10 +10 +10 +10 +13.1454 +24.4881 +32.995 +41.4789 +46.8118 +48.4047 +46.6231 +42.4399 +35.9545 +26.262 +17 +17 +17 +16 +15 +14 +13 +11 +11 +10 +10 +10 +10 +10 +11.1817 +18.6266 +25.4177 +30.1757 +33.1297 +31.8222 +32.6909 +30.5823 +26.7606 +20.3399 +15 +13 +12 +11 +10 +9 +8 +7 +6 +6 +5 +4 +3 +3 +4.36333 +10.2653 +14.9136 +22.4037 +25.1208 +26.6 +26.0053 +25.1045 +21.4713 +16.1325 +8 +6 +5 +4 +3 +2 +2 +1 +0 +0 +0 +0 +0 +0 +2.93969 +12.8077 +20.4091 +24.6902 +28.7551 +30.4265 +30.0313 +27.9169 +23.3592 +16.3892 +8 +6 +6 +6 +6 +5 +4 +3 +3 +2 +2 +2 +2 +2 +5.66242 +15.565 +25.7122 +33.7635 +36.8414 +37.8556 +37.3489 +33.639 +28.291 +14.9133 +10 +9 +9 +9 +9 +9 +8 +7 +6 +6 +6 +6 +5 +5 +7.62097 +17.761 +25.9267 +33.4679 +37.8191 +39.719 +38.6231 +34.6749 +29.6164 +20.7517 +17 +17 +16 +16 +16 +15 +15 +15 +14 +13 +12 +12 +11 +11 +12.9937 +22.5804 +29.1697 +35.2018 +39.2245 +42.0468 +42.9667 +39.5046 +34.5362 +26.3319 +18 +18 +18 +17 +16 +15 +14 +13 +12 +11 +11 +10 +10 +10 +12.92 +23.3192 +32.2302 +40.6184 +48.4041 +53.5305 +52.4475 +44.7306 +35.9722 +25.2247 +18 +18 +18 +17 +16 +15 +14 +14 +13 +13 +13 +12 +12 +11 +13.0976 +22.6217 +26.68 +33.98 +40.607 +43.3321 +42.2943 +38.7304 +33.3953 +25.9057 +18 +17 +17 +17 +16 +15 +14 +12 +12 +11 +11 +11 +11 +11 +12.2535 +18.8183 +25.0325 +40.6037 +48.351 +51.2824 +50.7621 +38.1041 +38.691 +28.4386 +20 +18 +17 +16 +16 +15 +15 +15 +15 +14 +14 +14 +13 +13 +14.1931 +19.8275 +33.4876 +35.3123 +44.3139 +45.904 +45.6306 +41.769 +37.3526 +28.5288 +20 +19 +18 +17 +17 +16 +15 +14 +13 +12 +12 +11 +11 +11 +12.2026 +19.0176 +24.9354 +31.829 +38.2479 +44.5904 +38.351 +31.5144 +27.6373 +21.9485 +19 +19 +18 +17 +16 +15 +14 +13 +13 +12 +11 +11 +10 +10 +11.884 +22.4654 +30.4113 +37.3197 +40.6233 +42.658 +42.3696 +38.6279 +33.6599 +25.1087 +16 +16 +16 +15 +14 +13 +11 +10 +10 +9 +9 +8 +8 +8 +9.76707 +21.3848 +30.0074 +38.8 +45.6956 +49.0148 +47.6 +40.9977 +33.804 +23.512 +15 +15 +15 +14 +13 +12 +10 +9 +8 +8 +8 +8 +7 +7 +8 +20.113 +30.6067 +36.5343 +39.471 +39.1629 +36.1431 +33.3462 +27.8906 +19.098 +13 +12 +11 +10 +9 +8 +6 +5 +4 +4 +3 +3 +3 +3 +4 +13.9512 +21.359 +27.2015 +30.4343 +31.288 +31.0047 +29.7025 +26.0622 +18.4441 +10 +10 +10 +9 +8 +7 +5 +5 +4 +4 +4 +3 +3 +3 +4 +15.4087 +25.694 +35.71 +42.038 +45.3705 +45.435 +41.5206 +34.073 +18.7994 +12 +12 +12 +10 +8 +7 +6 +6 +6 +6 +5 +5 +5 +5 +6 +17.2631 +26.5846 +27.356 +33.4447 +38.3653 +37.2915 +33.8019 +29.1124 +22.2658 +15 +13 +11 +11 +10 +9 +8 +7 +7 +7 +6 +6 +6 +7 +9 +18.301 +19.267 +24.7576 +28.5572 +25.0092 +23.5389 +22.5414 +19.4224 +16.1739 +13 +13 +12 +11 +10 +10 +10 +10 +11 +11 +10 +10 +9 +7 +7 +15.2157 +16.0335 +25.0921 +26.8542 +27.7638 +26.9415 +13.8109 +21.4726 +12.777 +8 +8 +8 +8 +8 +8 +8 +8 +7 +7 +7 +7 +7 +6 +7 +9.46835 +9.20776 +12.3853 +15.3713 +16.9799 +14.6907 +15.8645 +10.4124 +9.05374 +9 +8 +8 +8 +8 +7 +7 +6 +6 +6 +6 +5 +5 +4 +5 +16.5197 +26.3604 +32.6042 +37.9496 +40.0414 +36.024 +30.353 +23.3365 +11.5405 +8 +8 +8 +8 +7 +6 +5 +4 +3 +3 +3 +2 +2 +2 +3 +14.0382 +22.9073 +31.459 +37.4216 +39.3871 +37.4736 +33.0084 +26.2881 +18.1596 +10 +9 +9 +8 +7 +6 +5 +5 +5 +4 +4 +4 +4 +4 +5 +10.4911 +22.458 +23.6038 +26.541 +27.0355 +19.0037 +16.0365 +16.2378 +13.7971 +11 +10 +10 +10 +10 +10 +10 +9 +7 +6 +5 +3 +2 +1 +2 +9.65132 +16.362 +20.8656 +23.946 +26.2586 +26.9884 +24.7202 +21.1996 +15.0495 +7 +7 +6 +4 +3 +1 +0 +0 +0 +0 +0 +0 +0 +0 +1 +10.7643 +19.6876 +27.2994 +31.196 +33.3242 +33.1391 +31.1492 +23.356 +14.3221 +9 +8 +8 +7 +7 +7 +7 +6 +6 +5 +4 +3 +3 +3 +4 +14.5585 +24.2463 +33.0132 +38.1066 +41.3796 +41.1937 +37.4794 +27.3692 +18.707 +15 +12 +10 +10 +9 +9 +9 +9 +9 +8 +8 +8 +8 +7 +8 +18.5036 +27.8232 +37.3554 +41.2085 +43.9432 +35.8263 +33.1923 +21.4384 +21.518 +13 +12 +11 +11 +11 +11 +10 +10 +9 +8 +7 +6 +5 +5 +6 +14.6708 +23.0016 +29.7774 +34.3524 +37.3611 +37.1035 +34.3675 +21.7835 +15.2068 +13 +12 +11 +11 +10 +10 +9 +8 +7 +6 +6 +5 +5 +5 +5 +7.89442 +25.0347 +28.2045 +29.3346 +29.7691 +29.5 +26.8749 +23.4247 +17.5885 +11 +10 +9 +8 +7 +6 +5 +4 +3 +2 +2 +1 +1 +1 +2 +4.55814 +12.3485 +18.1764 +21.4604 +20.6781 +27.7903 +19.662 +17.48 +11.771 +7 +7 +6 +5 +5 +5 +4 +4 +4 +4 +4 +4 +3 +3 +4 +7.03366 +17.5267 +27.7303 +28.6486 +28.789 +27.6011 +29.4063 +24.1238 +15.9463 +9 +8 +7 +7 +7 +7 +7 +6 +6 +5 +4 +4 +3 +3 +4 +7.68397 +14.4232 +14.5894 +21.5031 +28.0239 +21.6728 +24.5858 +21.0684 +14.8406 +7 +6 +6 +5 +5 +5 +4 +3 +2 +1 +1 +0 +0 +0 +1 +10.6335 +19.2195 +27.1672 +32.1426 +36.3288 +38.0305 +35.6627 +30.0578 +18.5691 +6 +6 +6 +5 +3 +2 +1 +1 +1 +0 +0 +0 +0 +0 +1 +11.9281 +20.5459 +29.293 +37.2004 +42.8704 +31.0385 +27.8694 +22.3743 +15.8247 +10 +9 +8 +8 +9 +8 +7 +6 +5 +5 +5 +4 +4 +4 +4 +6.32979 +11.1726 +11.1684 +15.9517 +21.5881 +17.9135 +17.561 +14.4804 +9.58484 +7 +7 +7 +6 +5 +5 +4 +4 +4 +4 +3 +3 +3 +2 +3 +9.47673 +15.764 +21.4977 +25.3827 +27.8906 +27.4536 +20.4111 +22.0515 +16.5497 +17 +15 +12 +10 +9 +8 +7 diff --git a/test/ssc_test/cmod_pvsamv1_test.cpp b/test/ssc_test/cmod_pvsamv1_test.cpp index 3cd1d3746..fda1e867f 100644 --- a/test/ssc_test/cmod_pvsamv1_test.cpp +++ b/test/ssc_test/cmod_pvsamv1_test.cpp @@ -1109,6 +1109,58 @@ TEST_F(CMPvsamv1PowerIntegration_cmod_pvsamv1, SubhourlyClippingCorrectionModel) EXPECT_NEAR(subhourly_clipping_loss_percent, 0.74, m_error_tolerance_lo); } +TEST_F(CMPvsamv1PowerIntegration_cmod_pvsamv1, UseMeasuredTemp) { + + std::map pairs; + + pairs["subarray1_use_measured_temp"] = 1; + int pvsam_errors = modify_ssc_data_and_run_module(data, "pvsamv1", pairs); + + EXPECT_FALSE(pvsam_errors); + ssc_number_t annualEnergy; + int n1; + ssc_number_t* subarray1_cell_temp = ssc_data_get_array(data, "subarray1_celltemp", &n1); + EXPECT_NEAR(subarray1_cell_temp[8], 17.8071, 0.001); + ssc_data_get_number(data, "annual_energy", &annualEnergy); + EXPECT_NEAR(annualEnergy, 8725, 1.0); + + pairs["subarray1_use_measured_temp"] = 0; + pvsam_errors = modify_ssc_data_and_run_module(data, "pvsamv1", pairs); + + EXPECT_FALSE(pvsam_errors); + ssc_data_get_number(data, "annual_energy", &annualEnergy); + EXPECT_NEAR(annualEnergy, 8834, 1.0); + + + +} + +TEST_F(CMPvsamv1PowerIntegration_cmod_pvsamv1, UseCustomAngles) { + + std::map pairs; + + pairs["subarray1_use_custom_tilt_angles"] = 1; + int pvsam_errors = modify_ssc_data_and_run_module(data, "pvsamv1", pairs); + + EXPECT_FALSE(pvsam_errors); + ssc_number_t annualEnergy; + int n1; + ssc_number_t* subarray1_cell_temp = ssc_data_get_array(data, "subarray1_axisrot", &n1); + EXPECT_NEAR(subarray1_cell_temp[11], -24.8588, 0.001); + ssc_data_get_number(data, "annual_energy", &annualEnergy); + EXPECT_NEAR(annualEnergy, 11516, 1.0); + + pairs["subarray1_use_custom_tilt_angles"] = 0; + pvsam_errors = modify_ssc_data_and_run_module(data, "pvsamv1", pairs); + + EXPECT_FALSE(pvsam_errors); + ssc_data_get_number(data, "annual_energy", &annualEnergy); + EXPECT_NEAR(annualEnergy, 8834, 1.0); + + + +} + /// Test PVSAMv1 with all defaults and no-financial model- look at MPPT input 1 voltage at night TEST_F(CMPvsamv1PowerIntegration_cmod_pvsamv1, InverterNighttime) { @@ -1132,6 +1184,11 @@ TEST_F(CMPvsamv1PowerIntegration_cmod_pvsamv1, TiltEqualsLat) { int pvsam_errors = modify_ssc_data_and_run_module(data, "pvsamv1", pairs); EXPECT_FALSE(pvsam_errors); + + ssc_number_t annualEnergy; + ssc_data_get_number(data, "annual_energy", &annualEnergy); + EXPECT_NEAR(annualEnergy, 9258, 1.0) << "Bifacial annual energy from SAM version 2018.11.11 using Phoenix TMY2"; + if (!pvsam_errors) { ssc_number_t subarray1SurfaceTilt; From e052f87ac8dd60f49505b39b65d1a170147cd270 Mon Sep 17 00:00:00 2001 From: Matt Prilliman Date: Tue, 24 Oct 2023 11:25:02 -0500 Subject: [PATCH 08/15] Remove accidental tiltequalslat test addition --- test/ssc_test/cmod_pvsamv1_test.cpp | 5 ----- 1 file changed, 5 deletions(-) diff --git a/test/ssc_test/cmod_pvsamv1_test.cpp b/test/ssc_test/cmod_pvsamv1_test.cpp index fda1e867f..9513dc09c 100644 --- a/test/ssc_test/cmod_pvsamv1_test.cpp +++ b/test/ssc_test/cmod_pvsamv1_test.cpp @@ -1184,11 +1184,6 @@ TEST_F(CMPvsamv1PowerIntegration_cmod_pvsamv1, TiltEqualsLat) { int pvsam_errors = modify_ssc_data_and_run_module(data, "pvsamv1", pairs); EXPECT_FALSE(pvsam_errors); - - ssc_number_t annualEnergy; - ssc_data_get_number(data, "annual_energy", &annualEnergy); - EXPECT_NEAR(annualEnergy, 9258, 1.0) << "Bifacial annual energy from SAM version 2018.11.11 using Phoenix TMY2"; - if (!pvsam_errors) { ssc_number_t subarray1SurfaceTilt; From 96138f7d8d9c685a822a7d4b8aa181ec1253f90b Mon Sep 17 00:00:00 2001 From: Matt Prilliman Date: Tue, 24 Oct 2023 16:01:44 -0500 Subject: [PATCH 09/15] Set default use custom tilt angle boolean to 0 in irrad setup --- shared/lib_irradproc.cpp | 1 + 1 file changed, 1 insertion(+) diff --git a/shared/lib_irradproc.cpp b/shared/lib_irradproc.cpp index 32781f226..a9357c22d 100644 --- a/shared/lib_irradproc.cpp +++ b/shared/lib_irradproc.cpp @@ -1756,6 +1756,7 @@ void irrad::setup() { poaRearDirectDiffuse = 0.; poaRearRowReflections = 0.; poaRearSelfShaded = 0.; + useCustomTiltAngles = 0.; } From f061325815a5770c8fe968434d776605368b33e6 Mon Sep 17 00:00:00 2001 From: Matt Prilliman Date: Wed, 25 Oct 2023 16:48:56 -0500 Subject: [PATCH 10/15] Fix boolean check, rename variables to rotation angle, apply rotation limits --- shared/lib_irradproc.cpp | 29 +++++++++++--------- shared/lib_irradproc.h | 8 +++--- shared/lib_pv_io_manager.cpp | 14 +++++----- shared/lib_pv_io_manager.h | 4 +-- ssc/cmod_pvsamv1.cpp | 34 +++++++++--------------- test/input_cases/pvsamv1_common_data.cpp | 2 +- test/ssc_test/cmod_pvsamv1_test.cpp | 4 +-- 7 files changed, 45 insertions(+), 50 deletions(-) diff --git a/shared/lib_irradproc.cpp b/shared/lib_irradproc.cpp index a9357c22d..90d8b2758 100644 --- a/shared/lib_irradproc.cpp +++ b/shared/lib_irradproc.cpp @@ -1226,7 +1226,12 @@ void incidence(int mode, double tilt, double sazm, double rlim, double zen, /*Check if custom tilt angles enabled, apply timeseries value*/ if (useCustomAngle) { - rot = customAngle * DTOR; //overwrite rotation angle with input from array + if (rot < -rlim) /* Do not let rotation exceed physical constraints */ + rot = -rlim; + else if (rot > rlim) + rot = rlim; + else + rot = customAngle * DTOR; //overwrite rotation angle with input from array } /* Find tilt angle for the tracking surface */ @@ -1756,7 +1761,7 @@ void irrad::setup() { poaRearDirectDiffuse = 0.; poaRearRowReflections = 0.; poaRearSelfShaded = 0.; - useCustomTiltAngles = 0.; + useCustomRotAngles = 0.; } @@ -1772,7 +1777,7 @@ irrad::irrad(weather_record wf, weather_header hdr, double groundCoverageRatioIn, double slopeTiltIn, double slopeAzmIn, std::vector monthlyTiltDegrees, std::vector userSpecifiedAlbedo, poaDecompReq *poaAllIn, - bool useSpatialAlbedos, const util::matrix_t* userSpecifiedSpatialAlbedos, bool enableSubhourlyClipping, bool useCustomTiltAngles, double customTiltAngle) : + bool useSpatialAlbedos, const util::matrix_t* userSpecifiedSpatialAlbedos, bool enableSubhourlyClipping, bool useCustomRotAngles, double customRotAngle) : skyModel(skyModelIn), radiationMode(radiationModeIn), trackingMode(trackModeIn), enableBacktrack(backtrackingEnabled), forceToStow(forceToStowIn), delt(dtHour), tiltDegrees(tiltDegreesIn), surfaceAzimuthDegrees(azimuthDegreesIn), @@ -1801,7 +1806,7 @@ irrad::irrad(weather_record wf, weather_header hdr, set_subhourly_clipping(enableSubhourlyClipping); - set_custom_tilt_angles(useCustomTiltAngles, customTiltAngle); + set_custom_rot_angles(useCustomRotAngles, customRotAngle); if (radiationMode == irrad::DN_DF) set_beam_diffuse(wf.dn, wf.df); else if (radiationMode == irrad::DN_GH) set_global_beam(wf.gh, wf.dn); @@ -1996,10 +2001,10 @@ void irrad::set_subhourly_clipping(bool enable) if (enable) this->enableSubhourlyClipping = true; } -void irrad::set_custom_tilt_angles(bool enable, double angle) +void irrad::set_custom_rot_angles(bool enable, double angle) { - this->useCustomTiltAngles = enable; - this->customTiltAngle = angle; + this->useCustomRotAngles = enable; + this->customRotAngle = angle; } void irrad::set_sky_model(int sm, double alb, const std::vector &albSpatial) { @@ -2190,7 +2195,7 @@ int irrad::calc() { // compute incidence angles onto fixed or tracking surface incidence(trackingMode, tiltDegrees, surfaceAzimuthDegrees, rotationLimitDegrees, sunAnglesRadians[1], sunAnglesRadians[0], - enableBacktrack, groundCoverageRatio, slopeTilt, slopeAzm, forceToStow, stowAngleDegrees, useCustomTiltAngles, customTiltAngle, surfaceAnglesRadians); + enableBacktrack, groundCoverageRatio, slopeTilt, slopeAzm, forceToStow, stowAngleDegrees, useCustomRotAngles, customRotAngle, surfaceAnglesRadians); if (radiationMode < irrad::POA_R) { double hextra = sunAnglesRadians[8]; double hbeam = directNormal * @@ -2590,7 +2595,7 @@ void irrad::getFrontSurfaceIrradiances(double pvFrontShadeFraction, double rowTo // Calculate irradiance components for a 90 degree tilt to get horizon brightening double angleTmp[5] = {0, 0, 0, 0, 0}; // ([0] = incidence angle, [1] = tilt) incidence(0, 90.0, 180.0, 45.0, solarZenithRadians, solarAzimuthRadians, this->enableBacktrack, - this->groundCoverageRatio, this->slopeTilt, this->slopeAzm, this->forceToStow, this->stowAngleDegrees, this->useCustomTiltAngles, this->customTiltAngle, angleTmp); + this->groundCoverageRatio, this->slopeTilt, this->slopeAzm, this->forceToStow, this->stowAngleDegrees, this->useCustomRotAngles, this->customRotAngle, angleTmp); perez(0, calculatedDirectNormal, calculatedDiffuseHorizontal, albedo, angleTmp[0], angleTmp[1], solarZenithRadians, poa, diffc); double horizonDiffuse = diffc[2]; @@ -2726,7 +2731,7 @@ void irrad::getFrontSurfaceIrradiances(double pvFrontShadeFraction, double rowTo // Calculate and add direct and circumsolar irradiance components incidence(0, tiltRadians * RTOD, surfaceAzimuthRadians * RTOD, 45.0, solarZenithRadians, solarAzimuthRadians, this->enableBacktrack, this->groundCoverageRatio, this->slopeTilt, this->slopeAzm, - this->forceToStow, this->stowAngleDegrees, this->useCustomTiltAngles, this->customTiltAngle, surfaceAnglesRadians); + this->forceToStow, this->stowAngleDegrees, this->useCustomRotAngles, this->customRotAngle, surfaceAnglesRadians); perez(0, calculatedDirectNormal, calculatedDiffuseHorizontal, albedo, surfaceAnglesRadians[0], surfaceAnglesRadians[1], solarZenithRadians, poa, diffc); @@ -2771,7 +2776,7 @@ void irrad::getBackSurfaceIrradiances(double pvBackShadeFraction, double rowToRo // Calculate components for a 90 degree tilt to get horizon brightening double surfaceAnglesRadians90[5] = {0, 0, 0, 0, 0}; incidence(0, 90.0, 180.0, 45.0, solarZenithRadians, solarAzimuthRadians, this->enableBacktrack, - this->groundCoverageRatio, this->slopeTilt, this->slopeAzm, this->forceToStow, this->stowAngleDegrees, this->useCustomTiltAngles, this->customTiltAngle, surfaceAnglesRadians90); + this->groundCoverageRatio, this->slopeTilt, this->slopeAzm, this->forceToStow, this->stowAngleDegrees, this->useCustomRotAngles, this->customRotAngle, surfaceAnglesRadians90); perez(0, calculatedDirectNormal, calculatedDiffuseHorizontal, albedo, surfaceAnglesRadians90[0], surfaceAnglesRadians90[1], solarZenithRadians, planeOfArrayIrradianceRear, diffuseIrradianceRear); double horizonDiffuse = diffuseIrradianceRear[2]; @@ -2971,7 +2976,7 @@ void irrad::getBackSurfaceIrradiances(double pvBackShadeFraction, double rowToRo // Calculate and add direct and circumsolar irradiance components incidence(0, 180.0 - tiltRadians * RTOD, (surfaceAzimuthRadians * RTOD - 180.0), 45.0, solarZenithRadians, solarAzimuthRadians, this->enableBacktrack, - this->groundCoverageRatio, this->slopeTilt, this->slopeAzm, this->forceToStow, this->stowAngleDegrees, this->useCustomTiltAngles, this->customTiltAngle, surfaceAnglesRadians); + this->groundCoverageRatio, this->slopeTilt, this->slopeAzm, this->forceToStow, this->stowAngleDegrees, this->useCustomRotAngles, this->customRotAngle, surfaceAnglesRadians); perez(0, calculatedDirectNormal, calculatedDiffuseHorizontal, albedo, surfaceAnglesRadians[0], surfaceAnglesRadians[1], solarZenithRadians, planeOfArrayIrradianceRear, diffuseIrradianceRear); diff --git a/shared/lib_irradproc.h b/shared/lib_irradproc.h index 8a5578ca2..dd21d7a3c 100644 --- a/shared/lib_irradproc.h +++ b/shared/lib_irradproc.h @@ -994,8 +994,8 @@ class irrad bool enableSubhourlyClipping; //Custom rotation angles for single-axis trackers - bool useCustomTiltAngles; - double customTiltAngle; // custom tracker rotation angle in degrees + bool useCustomRotAngles; + double customRotAngle; // custom tracker rotation angle in degrees // Subarray properties double tiltDegrees; ///< Surface tilt of subarray in degrees @@ -1061,7 +1061,7 @@ class irrad double dtHour, double tiltDegrees, double azimuthDegrees, double trackerRotationLimitDegrees, double stowAngleDegreesIn, double groundCoverageRatio, double slopeTilt, double slopeAzm, std::vector monthlyTiltDegrees, std::vector userSpecifiedAlbedo, poaDecompReq* poaAllIn, - bool useSpatialAlbedos = false, const util::matrix_t* userSpecifiedSpatialAlbedos = nullptr, bool enableSubhourlyClipping = false, bool useCustomTiltAngles = false, double customTiltAngle = 0); + bool useSpatialAlbedos = false, const util::matrix_t* userSpecifiedSpatialAlbedos = nullptr, bool enableSubhourlyClipping = false, bool useCustomRotAngles = false, double customRotAngle = 0); /// Construct the irrad class with an Irradiance_IO() object and Subarray_IO() object irrad(); @@ -1084,7 +1084,7 @@ class irrad //Set whether to use subhourly clipping model void set_subhourly_clipping(bool enable = false); - void set_custom_tilt_angles(bool enable = false, double angle = 0); + void set_custom_rot_angles(bool enable = false, double angle = 0); /// Set the sky model for the irradiance processor, using \link Irradiance_IO::SKYMODEL void set_sky_model(int skymodel, double albedo, const std::vector &albedoSpatial = std::vector()); diff --git a/shared/lib_pv_io_manager.cpp b/shared/lib_pv_io_manager.cpp index 2f3ce272f..005a82db3 100644 --- a/shared/lib_pv_io_manager.cpp +++ b/shared/lib_pv_io_manager.cpp @@ -358,8 +358,8 @@ Subarray_IO::Subarray_IO(compute_module* cm, const std::string& cmName, size_t s nModulesPerString = cm->as_integer(prefix + "modules_per_string"); mpptInput = cm->as_integer(prefix + "mppt_input"); trackMode = cm->as_integer(prefix + "track_mode"); - useCustomTiltAngles = cm->as_integer(prefix + "use_custom_tilt_angles"); - useMeasuredTemp = cm->as_integer(prefix + "use_measured_temp"); + useCustomRotAngles = cm->as_boolean(prefix + "use_custom_rot_angles"); + useMeasuredTemp = cm->as_boolean(prefix + "use_measured_temp"); tiltEqualLatitude = 0; if (cm->is_assigned(prefix + "tilt_eq_lat")) tiltEqualLatitude = cm->as_boolean(prefix + "tilt_eq_lat"); @@ -380,11 +380,11 @@ Subarray_IO::Subarray_IO(compute_module* cm, const std::string& cmName, size_t s } /* Insert checks for custom tilt angles here*/ - if (useCustomTiltAngles == 1) { - if (cm->is_assigned(prefix + "custom_tilt_angles_array")) { - customTiltAngles = cm->as_vector_double(prefix + "custom_tilt_angles_array"); - for (int i = 0; i < customTiltAngles.size(); i++) { - if (customTiltAngles[i] > 90.0 || customTiltAngles[i] < -90.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + "custom tilt angles cannot be outside of 90deg."); + if (useCustomRotAngles == 1) { + if (cm->is_assigned(prefix + "custom_rot_angles_array")) { + customRotAngles = cm->as_vector_double(prefix + "custom_rot_angles_array"); + for (int i = 0; i < customRotAngles.size(); i++) { + if (customRotAngles[i] > 90.0 || customRotAngles[i] < -90.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + "custom tilt angles cannot be outside of 90deg."); } } else { diff --git a/shared/lib_pv_io_manager.h b/shared/lib_pv_io_manager.h index 9da8bd91d..2c03a3d71 100644 --- a/shared/lib_pv_io_manager.h +++ b/shared/lib_pv_io_manager.h @@ -465,8 +465,8 @@ struct Subarray_IO double slopeTilt; // Angle of sloped terrain [degrees] double slopeAzm; // azimuth of sloped terrain relative to tracker azimuth [degrees] double tiltDegrees; // The surface tilt [degrees] - flag useCustomTiltAngles; // Use custom timeseries rotation angles - std::vector customTiltAngles; //Custom timeseries rotation angles [degrees] + flag useCustomRotAngles; // Use custom timeseries rotation angles + std::vector customRotAngles; //Custom timeseries rotation angles [degrees] flag useMeasuredTemp; std::vector measuredTempArray; double azimuthDegrees; // The surface azimuth [degrees] diff --git a/ssc/cmod_pvsamv1.cpp b/ssc/cmod_pvsamv1.cpp index 962a79ade..0d92600f3 100644 --- a/ssc/cmod_pvsamv1.cpp +++ b/ssc/cmod_pvsamv1.cpp @@ -75,11 +75,6 @@ static var_info _cm_vtab_pvsamv1[] = { {SSC_INPUT, SSC_NUMBER, "calculate_rack_shading", "Calculate rack shading", "", "", "Losses", "?=0", "BOOLEAN", "" }, {SSC_INPUT, SSC_NUMBER, "calculate_bifacial_electrical_mismatch", "Calculate bifacial electrical mismatch", "", "", "Losses", "?=1", "BOOLEAN", "" }, - {SSC_INPUT, SSC_NUMBER, "use_measured_temp", "Use measured temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, - {SSC_INPUT, SSC_ARRAY, "measured_temp_array", "Measured module temperature", "C", "", "System Design", "use_measured_temp=1", "", "" }, - {SSC_INPUT, SSC_NUMBER, "use_custom_tilt_angles", "Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, - {SSC_INPUT, SSC_ARRAY, "custom_tilt_angles_array", "Custom tracker rotation angles", "deg", "", "System Design", "use_custom_tilt_angles=1", "", "" }, - // subarray 1 {SSC_INPUT, SSC_NUMBER, "subarray1_nstrings", "Sub-array 1 Number of parallel strings", "", "", "System Design", "", "INTEGER", "" }, {SSC_INPUT, SSC_NUMBER, "subarray1_modules_per_string", "Sub-array 1 Modules per string", "", "", "System Design", "*", "INTEGER,POSITIVE", "" }, @@ -94,8 +89,8 @@ static var_info _cm_vtab_pvsamv1[] = { {SSC_INPUT, SSC_NUMBER, "subarray1_slope_tilt", "Sub-array 1 terrain tilt", "degrees", "", "System Design", "subarray1_track_mode=1", "MIN=0,MAX=90", "" }, {SSC_INPUT, SSC_NUMBER, "subarray1_slope_azm", "Sub-array 1 terrain azimuth", "degrees", "", "System Design", "subarray1_track_mode=1", "MIN=0,MAX=359.9", "" }, {SSC_INPUT, SSC_ARRAY, "subarray1_monthly_tilt", "Sub-array 1 monthly tilt input", "degrees", "", "System Design", "subarray1_track_mode=4", "LENGTH=12", "" }, - {SSC_INPUT, SSC_NUMBER, "subarray1_use_custom_tilt_angles", "Sub-array 1 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, - {SSC_INPUT, SSC_ARRAY, "subarray1_custom_tilt_angles_array", "Sub-array 1 Custom tracker rotation angles", "deg", "", "System Design", "subarray1_use_custom_tilt_angles=1", "", "" }, + {SSC_INPUT, SSC_NUMBER, "subarray1_use_custom_rot_angles", "Sub-array 1 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + {SSC_INPUT, SSC_ARRAY, "subarray1_custom_rot_angles_array", "Sub-array 1 Custom tracker rotation angles", "deg", "", "System Design", "subarray1_use_custom_rot_angles=1", "", "" }, {SSC_INPUT, SSC_NUMBER, "subarray1_use_measured_temp", "Subarray 1 Use measured temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, {SSC_INPUT, SSC_ARRAY, "subarray1_measured_temp_array", "Subarray 1 Measured module temperature", "C", "", "System Design", "subarray1_use_measured_temp=1", "", "" }, @@ -186,8 +181,8 @@ static var_info _cm_vtab_pvsamv1[] = { { SSC_INPUT, SSC_MATRIX, "subarray2_shading_azal", "Sub-array 2 Azimuth x altitude beam shading losses", "%", "", "Shading", "?", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray2_shading_en_diff", "Enable Sub-array 2 Diffuse shading loss", "0/1", "0=false,1=true", "Shading", "?=0", "BOOLEAN", "" }, { SSC_INPUT, SSC_NUMBER, "subarray2_shading_diff", "Sub-array 2 Diffuse shading loss", "%", "", "Shading", "?", "", "" }, - { SSC_INPUT, SSC_NUMBER, "subarray2_use_custom_tilt_angles", "Sub-array 2 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, - { SSC_INPUT, SSC_ARRAY, "subarray2_custom_tilt_angles_array", "Sub-array 2 Custom tracker rotation angles", "deg", "", "System Design", "subarray2_use_custom_tilt_angles=1", "", "" }, + { SSC_INPUT, SSC_NUMBER, "subarray2_use_custom_rot_angles", "Sub-array 2 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + { SSC_INPUT, SSC_ARRAY, "subarray2_custom_rot_angles_array", "Sub-array 2 Custom tracker rotation angles", "deg", "", "System Design", "subarray2_use_custom_rot_angles=1", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray2_use_measured_temp", "Subarray 2 Use measured temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, { SSC_INPUT, SSC_ARRAY, "subarray2_measured_temp_array", "Subarray 2 Measured module temperature", "C", "", "System Design", "subarray2_use_measured_temp=1", "", "" }, @@ -214,8 +209,8 @@ static var_info _cm_vtab_pvsamv1[] = { { SSC_INPUT, SSC_NUMBER, "subarray3_slope_tilt", "Sub-array 3 terrain tilt", "degrees", "", "System Design", "subarray3_enable=1&subarray3_track_mode=1", "MIN=0,MAX=90", "" }, { SSC_INPUT, SSC_NUMBER, "subarray3_slope_azm", "Sub-array 3 terrain azimuth", "degrees", "", "System Design", "subarray3_enable=1&subarray3_track_mode=1", "MIN=0,MAX=359.9", "" }, { SSC_INPUT, SSC_ARRAY, "subarray3_monthly_tilt", "Sub-array 3 Monthly tilt input", "degrees", "", "System Design", "subarray3_enable=1&subarray3_track_mode=4", "LENGTH=12", "" }, - { SSC_INPUT, SSC_NUMBER, "subarray3_use_custom_tilt_angles", "Sub-array 3 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, - { SSC_INPUT, SSC_ARRAY, "subarray3_custom_tilt_angles_array", "Sub-array 3 Custom tracker rotation angles", "deg", "", "System Design", "subarray3_use_custom_tilt_angles=1", "", "" }, + { SSC_INPUT, SSC_NUMBER, "subarray3_use_custom_rot_angles", "Sub-array 3 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + { SSC_INPUT, SSC_ARRAY, "subarray3_custom_rot_angles_array", "Sub-array 3 Custom tracker rotation angles", "deg", "", "System Design", "subarray3_use_custom_rot_angles=1", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray3_use_measured_temp", "Subarray 3 Use measured temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, { SSC_INPUT, SSC_ARRAY, "subarray3_measured_temp_array", "Subarray 3 Measured module temperature", "C", "", "System Design", "subarray3_use_measured_temp=1", "", "" }, @@ -254,8 +249,8 @@ static var_info _cm_vtab_pvsamv1[] = { { SSC_INPUT, SSC_NUMBER, "subarray4_slope_azm", "Sub-array 4 terrain azimuth", "degrees", "", "System Design", "subarray4_enable=1&subarray4_track_mode=1", "MIN=0,MAX=359.9", "" }, { SSC_INPUT, SSC_ARRAY, "subarray4_monthly_tilt", "Sub-array 4 Monthly tilt input", "degrees", "", "System Design", "subarray2_enable=1&subarray2_track_mode=4", "LENGTH=12", "" }, // { SSC_INPUT, SSC_TABLE, "subarray4_shading", "Sub-array 4 shading losses", "", "", "Shading", "?", "", "" }, - { SSC_INPUT, SSC_NUMBER, "subarray4_use_custom_tilt_angles", "Sub-array 4 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, - { SSC_INPUT, SSC_ARRAY, "subarray4_custom_tilt_angles_array", "Sub-array 4 Custom tracker rotation angles", "deg", "", "System Design", "subarray4_use_custom_tilt_angles=1", "", "" }, + { SSC_INPUT, SSC_NUMBER, "subarray4_use_custom_rot_angles", "Sub-array 4 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + { SSC_INPUT, SSC_ARRAY, "subarray4_custom_rot_angles_array", "Sub-array 4 Custom tracker rotation angles", "deg", "", "System Design", "subarray4_use_custom_rot_angles=1", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray4_use_measured_temp", "Subarray 4 Use measured temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, { SSC_INPUT, SSC_ARRAY, "subarray4_measured_temp_array", "Subarray 4 Measured module temperature", "C", "", "System Design", "subarray4_use_measured_temp=1", "", "" }, @@ -1141,8 +1136,8 @@ void cm_pvsamv1::exec() for (size_t nn = 0; nn < num_subarrays; nn++) { size_t user_tilt_angles_size; - if (Subarrays[nn]->useCustomTiltAngles == 1) { - user_tilt_angles_size = Subarrays[nn]->customTiltAngles.size(); + if (Subarrays[nn]->useCustomRotAngles == 1) { + user_tilt_angles_size = Subarrays[nn]->customRotAngles.size(); if (user_tilt_angles_size != nrec) throw exec_error("pvsamv1", "The custom rotation angle array must be the size of nrecords per year"); Subarrays[nn]->trackMode = irrad::SINGLE_AXIS; @@ -1521,19 +1516,14 @@ void cm_pvsamv1::exec() || Subarrays[nn]->nStrings < 1) continue; // skip disabled subarrays - /* - if (as_integer("use_custom_tilt_angles") == 1 && is_assigned("custom_tilt_angles_array")) { - Subarrays[nn]->tiltDegrees = user_tilt_angles[inrec]; - - }*/ - double custom_tilt = (Subarrays[nn]->useCustomTiltAngles) ? Subarrays[nn]->customTiltAngles[inrec] : 0.0; + double custom_rot = (Subarrays[nn]->useCustomRotAngles) ? Subarrays[nn]->customRotAngles[inrec] : 0.0; irrad irr(Irradiance->weatherRecord, Irradiance->weatherHeader, Irradiance->skyModel, Irradiance->radiationMode, Subarrays[nn]->trackMode, Irradiance->useWeatherFileAlbedo, Irradiance->instantaneous, Subarrays[nn]->backtrackingEnabled, false, Irradiance->dtHour, Subarrays[nn]->tiltDegrees, Subarrays[nn]->azimuthDegrees, Subarrays[nn]->trackerRotationLimitDegrees, 0.0, Subarrays[nn]->groundCoverageRatio, Subarrays[nn]->slopeTilt, Subarrays[nn]->slopeAzm, Subarrays[nn]->monthlyTiltDegrees, Irradiance->userSpecifiedMonthlyAlbedo, Subarrays[nn]->poa.poaAll.get(), - Irradiance->useSpatialAlbedos, &Irradiance->userSpecifiedMonthlySpatialAlbedos, as_boolean("enable_subhourly_clipping"), Subarrays[nn]->useCustomTiltAngles, custom_tilt); + Irradiance->useSpatialAlbedos, &Irradiance->userSpecifiedMonthlySpatialAlbedos, as_boolean("enable_subhourly_clipping"), Subarrays[nn]->useCustomRotAngles, custom_rot); int code = irr.calc(); diff --git a/test/input_cases/pvsamv1_common_data.cpp b/test/input_cases/pvsamv1_common_data.cpp index c72b59fcc..673f15a6d 100644 --- a/test/input_cases/pvsamv1_common_data.cpp +++ b/test/input_cases/pvsamv1_common_data.cpp @@ -105,7 +105,7 @@ void pvsamv_nofinancial_default(ssc_data_t& data) ssc_data_set_number(data, "subarray1_tracking_loss", 0); ssc_data_set_number(data, "subarray1_nameplate_loss", 0); set_array(data, "subarray1_measured_temp_array", measured_temp_array_path, 8760); - set_array(data, "subarray1_custom_tilt_angles_array", custom_rot_angle_array_path, 8760); + set_array(data, "subarray1_custom_rot_angles_array", custom_rot_angle_array_path, 8760); ssc_data_set_number(data, "subarray2_rear_soiling_loss", 0); ssc_data_set_number(data, "subarray2_rack_shading", 0); ssc_data_set_number(data, "subarray2_electrical_mismatch", 0); diff --git a/test/ssc_test/cmod_pvsamv1_test.cpp b/test/ssc_test/cmod_pvsamv1_test.cpp index 9513dc09c..1ae87cec8 100644 --- a/test/ssc_test/cmod_pvsamv1_test.cpp +++ b/test/ssc_test/cmod_pvsamv1_test.cpp @@ -1139,7 +1139,7 @@ TEST_F(CMPvsamv1PowerIntegration_cmod_pvsamv1, UseCustomAngles) { std::map pairs; - pairs["subarray1_use_custom_tilt_angles"] = 1; + pairs["subarray1_use_custom_rot_angles"] = 1; int pvsam_errors = modify_ssc_data_and_run_module(data, "pvsamv1", pairs); EXPECT_FALSE(pvsam_errors); @@ -1150,7 +1150,7 @@ TEST_F(CMPvsamv1PowerIntegration_cmod_pvsamv1, UseCustomAngles) { ssc_data_get_number(data, "annual_energy", &annualEnergy); EXPECT_NEAR(annualEnergy, 11516, 1.0); - pairs["subarray1_use_custom_tilt_angles"] = 0; + pairs["subarray1_use_custom_rot_angles"] = 0; pvsam_errors = modify_ssc_data_and_run_module(data, "pvsamv1", pairs); EXPECT_FALSE(pvsam_errors); From 585b04cd8cf267ff0079a648cd0884f7180834ed Mon Sep 17 00:00:00 2001 From: Matt Prilliman Date: Wed, 25 Oct 2023 16:55:41 -0500 Subject: [PATCH 11/15] Removing rotation limit checks --- shared/lib_irradproc.cpp | 7 +------ 1 file changed, 1 insertion(+), 6 deletions(-) diff --git a/shared/lib_irradproc.cpp b/shared/lib_irradproc.cpp index 90d8b2758..8431ab6e1 100644 --- a/shared/lib_irradproc.cpp +++ b/shared/lib_irradproc.cpp @@ -1226,12 +1226,7 @@ void incidence(int mode, double tilt, double sazm, double rlim, double zen, /*Check if custom tilt angles enabled, apply timeseries value*/ if (useCustomAngle) { - if (rot < -rlim) /* Do not let rotation exceed physical constraints */ - rot = -rlim; - else if (rot > rlim) - rot = rlim; - else - rot = customAngle * DTOR; //overwrite rotation angle with input from array + rot = customAngle * DTOR; //overwrite rotation angle with input from array } /* Find tilt angle for the tracking surface */ From 581aded4943b958ff172c3a3cd8e26c183d63c04 Mon Sep 17 00:00:00 2001 From: Matt Prilliman Date: Thu, 26 Oct 2023 16:44:18 -0500 Subject: [PATCH 12/15] Update var names and lables for custom cell temps, custom tracker rotation angles --- shared/lib_irradproc.cpp | 2 +- shared/lib_pv_io_manager.cpp | 22 +++++------ shared/lib_pv_io_manager.h | 4 +- ssc/cmod_pvsamv1.cpp | 48 ++++++++++++------------ test/input_cases/pvsamv1_common_data.cpp | 6 +-- test/ssc_test/cmod_pvsamv1_test.cpp | 6 +-- 6 files changed, 44 insertions(+), 44 deletions(-) diff --git a/shared/lib_irradproc.cpp b/shared/lib_irradproc.cpp index 8431ab6e1..4d4fc5aec 100644 --- a/shared/lib_irradproc.cpp +++ b/shared/lib_irradproc.cpp @@ -1224,7 +1224,7 @@ void incidence(int mode, double tilt, double sazm, double rlim, double zen, rot = backtracking_rotation; } - /*Check if custom tilt angles enabled, apply timeseries value*/ + /*Check if custom tracker rotation angles enabled, apply timeseries value*/ if (useCustomAngle) { rot = customAngle * DTOR; //overwrite rotation angle with input from array } diff --git a/shared/lib_pv_io_manager.cpp b/shared/lib_pv_io_manager.cpp index 005a82db3..d6872606c 100644 --- a/shared/lib_pv_io_manager.cpp +++ b/shared/lib_pv_io_manager.cpp @@ -359,7 +359,7 @@ Subarray_IO::Subarray_IO(compute_module* cm, const std::string& cmName, size_t s mpptInput = cm->as_integer(prefix + "mppt_input"); trackMode = cm->as_integer(prefix + "track_mode"); useCustomRotAngles = cm->as_boolean(prefix + "use_custom_rot_angles"); - useMeasuredTemp = cm->as_boolean(prefix + "use_measured_temp"); + useCustomCellTemp = cm->as_boolean(prefix + "use_custom_cell_temp"); tiltEqualLatitude = 0; if (cm->is_assigned(prefix + "tilt_eq_lat")) tiltEqualLatitude = cm->as_boolean(prefix + "tilt_eq_lat"); @@ -379,31 +379,31 @@ Subarray_IO::Subarray_IO(compute_module* cm, const std::string& cmName, size_t s } } - /* Insert checks for custom tilt angles here*/ + /* Insert checks for custom tracker rotation angles here*/ if (useCustomRotAngles == 1) { if (cm->is_assigned(prefix + "custom_rot_angles_array")) { customRotAngles = cm->as_vector_double(prefix + "custom_rot_angles_array"); for (int i = 0; i < customRotAngles.size(); i++) { - if (customRotAngles[i] > 90.0 || customRotAngles[i] < -90.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + "custom tilt angles cannot be outside of 90deg."); + if (customRotAngles[i] > 90.0 || customRotAngles[i] < -90.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + "custom tracker rotation angles cannot be outside of 90deg."); } } else { - throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + " custom rotation angles required but not assigned."); + throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + " custom tracker rotation angles required but not assigned."); } } - /* Insert checks for using measured temperature array*/ - if (useMeasuredTemp == 1) { - if (cm->is_assigned(prefix + "measured_temp_array")) { - measuredTempArray = cm->as_vector_double(prefix + "measured_temp_array"); - for (int i = 0; i < measuredTempArray.size(); i++) { - if (measuredTempArray[i] > 100.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + "custom tilt angles cannot be greater than 100degC."); + /* Insert checks for using custom cell temperature array*/ + if (useCustomCellTemp == 1) { + if (cm->is_assigned(prefix + "custom_cell_temp_array")) { + customCellTempArray = cm->as_vector_double(prefix + "custom_cell_temp_array"); + for (int i = 0; i < customCellTempArray.size(); i++) { + if (customCellTempArray[i] > 100.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + " custom cell temperatures cannot be greater than 100degC."); } } else { - throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + " custom rotation angles required but not assigned."); + throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + " custom cell temperatures required but not assigned."); } } diff --git a/shared/lib_pv_io_manager.h b/shared/lib_pv_io_manager.h index 2c03a3d71..4e66ecf69 100644 --- a/shared/lib_pv_io_manager.h +++ b/shared/lib_pv_io_manager.h @@ -467,8 +467,8 @@ struct Subarray_IO double tiltDegrees; // The surface tilt [degrees] flag useCustomRotAngles; // Use custom timeseries rotation angles std::vector customRotAngles; //Custom timeseries rotation angles [degrees] - flag useMeasuredTemp; - std::vector measuredTempArray; + flag useCustomCellTemp; + std::vector customCellTempArray; double azimuthDegrees; // The surface azimuth [degrees] int trackMode; // The tracking mode [0 = fixed, 1 = single-axis tracking, 2 = two-axis tracking, 3 = azimuth-axis tracking, 4 = seasonal-tilt double trackerRotationLimitDegrees; // The rotational limit of the tracker [degrees] diff --git a/ssc/cmod_pvsamv1.cpp b/ssc/cmod_pvsamv1.cpp index 0d92600f3..cb71d4ddc 100644 --- a/ssc/cmod_pvsamv1.cpp +++ b/ssc/cmod_pvsamv1.cpp @@ -91,8 +91,8 @@ static var_info _cm_vtab_pvsamv1[] = { {SSC_INPUT, SSC_ARRAY, "subarray1_monthly_tilt", "Sub-array 1 monthly tilt input", "degrees", "", "System Design", "subarray1_track_mode=4", "LENGTH=12", "" }, {SSC_INPUT, SSC_NUMBER, "subarray1_use_custom_rot_angles", "Sub-array 1 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, {SSC_INPUT, SSC_ARRAY, "subarray1_custom_rot_angles_array", "Sub-array 1 Custom tracker rotation angles", "deg", "", "System Design", "subarray1_use_custom_rot_angles=1", "", "" }, - {SSC_INPUT, SSC_NUMBER, "subarray1_use_measured_temp", "Subarray 1 Use measured temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, - {SSC_INPUT, SSC_ARRAY, "subarray1_measured_temp_array", "Subarray 1 Measured module temperature", "C", "", "System Design", "subarray1_use_measured_temp=1", "", "" }, + {SSC_INPUT, SSC_NUMBER, "subarray1_use_custom_cell_temp", "Subarray 1 Use custom cell temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + {SSC_INPUT, SSC_ARRAY, "subarray1_custom_cell_temp_array", "Subarray 1 custom cell temperature", "C", "", "System Design", "subarray1_use_custom_cell_temp=1", "", "" }, {SSC_INPUT, SSC_NUMBER, "subarray1_shading_en_string_option", "Enable Sub-array 1 shading string option", "0/1", "0=false,1=true", "Shading", "?=0", "BOOLEAN", "" }, {SSC_INPUT, SSC_NUMBER, "subarray1_shading_string_option", "Sub-array 1 shading string option", "", "0=shadingdb,1=average,2=maximum,3=minimum", "Shading", "?=-1", "INTEGER,MIN=-1,MAX=4","" }, @@ -183,8 +183,8 @@ static var_info _cm_vtab_pvsamv1[] = { { SSC_INPUT, SSC_NUMBER, "subarray2_shading_diff", "Sub-array 2 Diffuse shading loss", "%", "", "Shading", "?", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray2_use_custom_rot_angles", "Sub-array 2 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, { SSC_INPUT, SSC_ARRAY, "subarray2_custom_rot_angles_array", "Sub-array 2 Custom tracker rotation angles", "deg", "", "System Design", "subarray2_use_custom_rot_angles=1", "", "" }, - { SSC_INPUT, SSC_NUMBER, "subarray2_use_measured_temp", "Subarray 2 Use measured temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, - { SSC_INPUT, SSC_ARRAY, "subarray2_measured_temp_array", "Subarray 2 Measured module temperature", "C", "", "System Design", "subarray2_use_measured_temp=1", "", "" }, + { SSC_INPUT, SSC_NUMBER, "subarray2_use_custom_cell_temp", "Subarray 2 Use custom cell temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + { SSC_INPUT, SSC_ARRAY, "subarray2_custom_cell_temp_array", "Subarray 2 custom cell temperatures", "C", "", "System Design", "subarray2_use_custom_cell_temp=1", "", "" }, @@ -211,8 +211,8 @@ static var_info _cm_vtab_pvsamv1[] = { { SSC_INPUT, SSC_ARRAY, "subarray3_monthly_tilt", "Sub-array 3 Monthly tilt input", "degrees", "", "System Design", "subarray3_enable=1&subarray3_track_mode=4", "LENGTH=12", "" }, { SSC_INPUT, SSC_NUMBER, "subarray3_use_custom_rot_angles", "Sub-array 3 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, { SSC_INPUT, SSC_ARRAY, "subarray3_custom_rot_angles_array", "Sub-array 3 Custom tracker rotation angles", "deg", "", "System Design", "subarray3_use_custom_rot_angles=1", "", "" }, - { SSC_INPUT, SSC_NUMBER, "subarray3_use_measured_temp", "Subarray 3 Use measured temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, - { SSC_INPUT, SSC_ARRAY, "subarray3_measured_temp_array", "Subarray 3 Measured module temperature", "C", "", "System Design", "subarray3_use_measured_temp=1", "", "" }, + { SSC_INPUT, SSC_NUMBER, "subarray3_use_custom_cell_temp", "Subarray 3 Use custom cell temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + { SSC_INPUT, SSC_ARRAY, "subarray3_custom_cell_temp_array", "Subarray 3 custom cell temperatures", "C", "", "System Design", "subarray3_use_custom_cell_temp=1", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray3_shading_en_string_option", "Enable Sub-array 3 shading string option", "0/1", "0=false,1=true", "Shading", "?=0", "BOOLEAN", "" }, { SSC_INPUT, SSC_NUMBER, "subarray3_shading_string_option", "Sub-array 3 shading string option", "", "0=shadingdb,1=average,2=maximum,3=minimum", "Shading", "?=-1", "INTEGER,MIN=-1,MAX=4","" }, @@ -251,8 +251,8 @@ static var_info _cm_vtab_pvsamv1[] = { // { SSC_INPUT, SSC_TABLE, "subarray4_shading", "Sub-array 4 shading losses", "", "", "Shading", "?", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray4_use_custom_rot_angles", "Sub-array 4 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, { SSC_INPUT, SSC_ARRAY, "subarray4_custom_rot_angles_array", "Sub-array 4 Custom tracker rotation angles", "deg", "", "System Design", "subarray4_use_custom_rot_angles=1", "", "" }, - { SSC_INPUT, SSC_NUMBER, "subarray4_use_measured_temp", "Subarray 4 Use measured temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, - { SSC_INPUT, SSC_ARRAY, "subarray4_measured_temp_array", "Subarray 4 Measured module temperature", "C", "", "System Design", "subarray4_use_measured_temp=1", "", "" }, + { SSC_INPUT, SSC_NUMBER, "subarray4_use_custom_cell_temp", "Subarray 4 Use custom cell temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + { SSC_INPUT, SSC_ARRAY, "subarray4_custom_cell_temp_array", "Subarray 4 custom cell temperatures", "C", "", "System Design", "subarray4_use_custom_cell_temp=1", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray4_shading_en_string_option", "Enable Sub-array 4 shading string option", "0/1", "0=false,1=true", "Shading", "?=0", "BOOLEAN", "" }, { SSC_INPUT, SSC_NUMBER, "subarray4_shading_string_option", "Sub-array 4 shading string option", "", "0=shadingdb,1=average,2=maximum,3=minimum", "Shading", "?=-1", "INTEGER,MIN=-1,MAX=4","" }, @@ -1146,11 +1146,11 @@ void cm_pvsamv1::exec() } - size_t measured_temp_size; - if (Subarrays[nn]->useMeasuredTemp == 1) { - measured_temp_size = Subarrays[nn]->measuredTempArray.size(); - if (measured_temp_size != nrec) - throw exec_error("pvsamv1", "The measured temperature array must be the size of nrecords per year"); + size_t custom_cell_temp_size; + if (Subarrays[nn]->useCustomCellTemp == 1) { + custom_cell_temp_size = Subarrays[nn]->customCellTempArray.size(); + if (custom_cell_temp_size != nrec) + throw exec_error("pvsamv1", "The custom cell temperature array must be the size of nrecords per year"); } if (Subarrays[nn]->tiltEqualLatitude) @@ -1683,8 +1683,8 @@ void cm_pvsamv1::exec() ((double)wf.hour) + wf.minute / 60.0, radmode, Subarrays[nn]->poa.usePOAFromWF); // voltage set to -1 for max power - if (Subarrays[nn]->useMeasuredTemp == 1) - tcell = Subarrays[nn]->measuredTempArray[inrec]; + if (Subarrays[nn]->useCustomCellTemp == 1) + tcell = Subarrays[nn]->customCellTempArray[inrec]; else (*Subarrays[nn]->Module->cellTempModel)(in, *Subarrays[nn]->Module->moduleModel, -1.0, tcell); } @@ -2088,8 +2088,8 @@ void cm_pvsamv1::exec() { double tcell = wf.tdry; // calculate cell temperature using selected temperature model - if (Subarrays[nn]->useMeasuredTemp == 1) - tcell = Subarrays[nn]->measuredTempArray[inrec]; + if (Subarrays[nn]->useCustomCellTemp == 1) + tcell = Subarrays[nn]->customCellTempArray[inrec]; else (*Subarrays[nn]->Module->cellTempModel)(in, *Subarrays[nn]->Module->moduleModel, V, tcell); // calculate module power output using conversion model previously specified @@ -2147,8 +2147,8 @@ void cm_pvsamv1::exec() if (stringVoltage != -1) module_voltage = stringVoltage / (double)Subarrays[nn]->nModulesPerString; // calculate cell temperature using selected temperature model // calculate module power output using conversion model previously specified - if (Subarrays[nn]->useMeasuredTemp == 1) - tcell = Subarrays[nn]->measuredTempArray[inrec]; + if (Subarrays[nn]->useCustomCellTemp == 1) + tcell = Subarrays[nn]->customCellTempArray[inrec]; else (*Subarrays[nn]->Module->cellTempModel)(in[nn], *Subarrays[nn]->Module->moduleModel, module_voltage, tcell); @@ -2268,8 +2268,8 @@ void cm_pvsamv1::exec() //recalculate power at the correct voltage double module_voltage = avgVoltage / (double)Subarrays[nn]->nModulesPerString; - if (Subarrays[nn]->useMeasuredTemp == 1) - tcell = Subarrays[nn]->measuredTempArray[inrec]; + if (Subarrays[nn]->useCustomCellTemp == 1) + tcell = Subarrays[nn]->customCellTempArray[inrec]; else (*Subarrays[nn]->Module->cellTempModel)(in[nn], *Subarrays[nn]->Module->moduleModel, module_voltage, tcell); (*Subarrays[nn]->Module->moduleModel)(in[nn], tcell, module_voltage, out[nn]); @@ -2310,9 +2310,9 @@ void cm_pvsamv1::exec() Subarrays[nn]->Module->dcPowerW = out[nn].Power; Subarrays[nn]->Module->dcEfficiency = out[nn].Efficiency * 100; Subarrays[nn]->Module->dcVoltage = out[nn].Voltage; - if (Subarrays[nn]->useMeasuredTemp) { - Subarrays[nn]->Module->temperatureCellCelcius = Subarrays[nn]->measuredTempArray[inrec]; - Subarrays[nn]->Module->temperatureCellCelciusSS = Subarrays[nn]->measuredTempArray[inrec]; + if (Subarrays[nn]->useCustomCellTemp) { + Subarrays[nn]->Module->temperatureCellCelcius = Subarrays[nn]->customCellTempArray[inrec]; + Subarrays[nn]->Module->temperatureCellCelciusSS = Subarrays[nn]->customCellTempArray[inrec]; } else { Subarrays[nn]->Module->temperatureCellCelcius = out[nn].CellTemp; diff --git a/test/input_cases/pvsamv1_common_data.cpp b/test/input_cases/pvsamv1_common_data.cpp index 673f15a6d..9c1f99701 100644 --- a/test/input_cases/pvsamv1_common_data.cpp +++ b/test/input_cases/pvsamv1_common_data.cpp @@ -42,7 +42,7 @@ char subarray1_shading[256] = {}; char subarray2_shading[256] = {}; char temperature_path[256] = {}; char solar_resource_path_15min_fail[256] = {}; -char measured_temp_array_path[256] = {}; +char custom_cell_temp_array_path[256] = {}; char custom_rot_angle_array_path[256] = {}; int n1 = sprintf(solar_resource_path, "%s/test/input_cases/pvsamv1_data/USA AZ Phoenix (TMY2).csv", SSCDIR); @@ -54,7 +54,7 @@ int n6 = sprintf(subarray1_shading, "%s/test/input_cases/pvsamv1_data/subarray1_ int n7 = sprintf(subarray2_shading, "%s/test/input_cases/pvsamv1_data/subarray2_shading_timestep.csv", SSCDIR); int n8 = sprintf(temperature_path, "%s/test/input_cases/battery_data/batt_room_temperature_celsius_60min.csv", SSCDIR); int n9 = sprintf(solar_resource_path_15min_fail, "%s/test/input_cases/pvsamv1_data/LosAngeles_WeatherFile_15min_timestamp_fail.csv", SSCDIR); -int n10 = sprintf(measured_temp_array_path, "%s/test/input_cases/pvsamv1_data/measured_temp_array.csv", SSCDIR); +int n10 = sprintf(custom_cell_temp_array_path, "%s/test/input_cases/pvsamv1_data/custom_cell_temp_array.csv", SSCDIR); int n11 = sprintf(custom_rot_angle_array_path, "%s/test/input_cases/pvsamv1_data/custom_rot_angle_array.csv", SSCDIR); @@ -104,7 +104,7 @@ void pvsamv_nofinancial_default(ssc_data_t& data) ssc_data_set_number(data, "subarray1_dcwiring_loss", 2); ssc_data_set_number(data, "subarray1_tracking_loss", 0); ssc_data_set_number(data, "subarray1_nameplate_loss", 0); - set_array(data, "subarray1_measured_temp_array", measured_temp_array_path, 8760); + set_array(data, "subarray1_custom_cell_temp_array", custom_cell_temp_array_path, 8760); set_array(data, "subarray1_custom_rot_angles_array", custom_rot_angle_array_path, 8760); ssc_data_set_number(data, "subarray2_rear_soiling_loss", 0); ssc_data_set_number(data, "subarray2_rack_shading", 0); diff --git a/test/ssc_test/cmod_pvsamv1_test.cpp b/test/ssc_test/cmod_pvsamv1_test.cpp index 1ae87cec8..8042e8329 100644 --- a/test/ssc_test/cmod_pvsamv1_test.cpp +++ b/test/ssc_test/cmod_pvsamv1_test.cpp @@ -1109,11 +1109,11 @@ TEST_F(CMPvsamv1PowerIntegration_cmod_pvsamv1, SubhourlyClippingCorrectionModel) EXPECT_NEAR(subhourly_clipping_loss_percent, 0.74, m_error_tolerance_lo); } -TEST_F(CMPvsamv1PowerIntegration_cmod_pvsamv1, UseMeasuredTemp) { +TEST_F(CMPvsamv1PowerIntegration_cmod_pvsamv1, useCustomCellTemp) { std::map pairs; - pairs["subarray1_use_measured_temp"] = 1; + pairs["subarray1_use_custom_cell_temp"] = 1; int pvsam_errors = modify_ssc_data_and_run_module(data, "pvsamv1", pairs); EXPECT_FALSE(pvsam_errors); @@ -1124,7 +1124,7 @@ TEST_F(CMPvsamv1PowerIntegration_cmod_pvsamv1, UseMeasuredTemp) { ssc_data_get_number(data, "annual_energy", &annualEnergy); EXPECT_NEAR(annualEnergy, 8725, 1.0); - pairs["subarray1_use_measured_temp"] = 0; + pairs["subarray1_use_custom_cell_temp"] = 0; pvsam_errors = modify_ssc_data_and_run_module(data, "pvsamv1", pairs); EXPECT_FALSE(pvsam_errors); From b62aa4b6b64fe28cc0e7e0cde4a89efaacb6015f Mon Sep 17 00:00:00 2001 From: Matt Prilliman Date: Thu, 26 Oct 2023 17:23:07 -0500 Subject: [PATCH 13/15] Rename custom cell temp array csv file for ssc test --- .../{measured_temp_array.csv => custom_cell_temp_array.csv} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename test/input_cases/pvsamv1_data/{measured_temp_array.csv => custom_cell_temp_array.csv} (100%) diff --git a/test/input_cases/pvsamv1_data/measured_temp_array.csv b/test/input_cases/pvsamv1_data/custom_cell_temp_array.csv similarity index 100% rename from test/input_cases/pvsamv1_data/measured_temp_array.csv rename to test/input_cases/pvsamv1_data/custom_cell_temp_array.csv From e30bb35167c99a628fe3455950401a533290cff0 Mon Sep 17 00:00:00 2001 From: Paul Gilman Date: Thu, 26 Oct 2023 15:53:04 -0700 Subject: [PATCH 14/15] clean up tracker rotation labels --- shared/lib_pv_io_manager.cpp | 4 ++-- ssc/cmod_irradproc.cpp | 2 +- ssc/cmod_pvsamv1.cpp | 10 +++++----- 3 files changed, 8 insertions(+), 8 deletions(-) diff --git a/shared/lib_pv_io_manager.cpp b/shared/lib_pv_io_manager.cpp index d6872606c..fd12c99b2 100644 --- a/shared/lib_pv_io_manager.cpp +++ b/shared/lib_pv_io_manager.cpp @@ -384,7 +384,7 @@ Subarray_IO::Subarray_IO(compute_module* cm, const std::string& cmName, size_t s if (cm->is_assigned(prefix + "custom_rot_angles_array")) { customRotAngles = cm->as_vector_double(prefix + "custom_rot_angles_array"); for (int i = 0; i < customRotAngles.size(); i++) { - if (customRotAngles[i] > 90.0 || customRotAngles[i] < -90.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + "custom tracker rotation angles cannot be outside of 90deg."); + if (customRotAngles[i] > 90.0 || customRotAngles[i] < -90.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + " custom tracker rotation angles must be between -90 and 90 degrees."); } } else { @@ -399,7 +399,7 @@ Subarray_IO::Subarray_IO(compute_module* cm, const std::string& cmName, size_t s if (cm->is_assigned(prefix + "custom_cell_temp_array")) { customCellTempArray = cm->as_vector_double(prefix + "custom_cell_temp_array"); for (int i = 0; i < customCellTempArray.size(); i++) { - if (customCellTempArray[i] > 100.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + " custom cell temperatures cannot be greater than 100degC."); + if (customCellTempArray[i] > 100.0) throw exec_error(cmName, "Subarray " + util::to_string((int)subarrayNumber) + " custom cell temperature cannot be greater than 100 degrees Celsius."); } } else { diff --git a/ssc/cmod_irradproc.cpp b/ssc/cmod_irradproc.cpp index 5eaa321fd..4d3a7c2e0 100644 --- a/ssc/cmod_irradproc.cpp +++ b/ssc/cmod_irradproc.cpp @@ -89,7 +89,7 @@ static var_info _cm_vtab_irradproc[] = { { SSC_OUTPUT, SSC_ARRAY, "incidence", "Incidence angle to surface", "deg", "", "Irradiance Processor", "*", "LENGTH_EQUAL=beam", "" }, { SSC_OUTPUT, SSC_ARRAY, "surf_tilt", "Surface tilt angle", "deg", "", "Irradiance Processor", "*", "LENGTH_EQUAL=beam", "" }, { SSC_OUTPUT, SSC_ARRAY, "surf_azm", "Surface azimuth angle", "deg", "", "Irradiance Processor", "*", "LENGTH_EQUAL=beam", "" }, - { SSC_OUTPUT, SSC_ARRAY, "axis_rotation", "Tracking axis rotation angle", "deg", "", "Irradiance Processor", "*", "LENGTH_EQUAL=beam", "" }, + { SSC_OUTPUT, SSC_ARRAY, "axis_rotation", "Tracker rotation angle", "deg", "", "Irradiance Processor", "*", "LENGTH_EQUAL=beam", "" }, { SSC_OUTPUT, SSC_ARRAY, "bt_diff", "Backtracking difference from ideal rotation", "deg", "", "Irradiance Processor", "*", "LENGTH_EQUAL=beam", "" }, { SSC_OUTPUT, SSC_ARRAY, "sun_azm", "Solar azimuth", "deg", "", "Irradiance Processor", "*", "LENGTH_EQUAL=beam", "" }, diff --git a/ssc/cmod_pvsamv1.cpp b/ssc/cmod_pvsamv1.cpp index cb71d4ddc..79232baea 100644 --- a/ssc/cmod_pvsamv1.cpp +++ b/ssc/cmod_pvsamv1.cpp @@ -89,7 +89,7 @@ static var_info _cm_vtab_pvsamv1[] = { {SSC_INPUT, SSC_NUMBER, "subarray1_slope_tilt", "Sub-array 1 terrain tilt", "degrees", "", "System Design", "subarray1_track_mode=1", "MIN=0,MAX=90", "" }, {SSC_INPUT, SSC_NUMBER, "subarray1_slope_azm", "Sub-array 1 terrain azimuth", "degrees", "", "System Design", "subarray1_track_mode=1", "MIN=0,MAX=359.9", "" }, {SSC_INPUT, SSC_ARRAY, "subarray1_monthly_tilt", "Sub-array 1 monthly tilt input", "degrees", "", "System Design", "subarray1_track_mode=4", "LENGTH=12", "" }, - {SSC_INPUT, SSC_NUMBER, "subarray1_use_custom_rot_angles", "Sub-array 1 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + {SSC_INPUT, SSC_NUMBER, "subarray1_use_custom_rot_angles", "Sub-array 1 Use custom tracker rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, {SSC_INPUT, SSC_ARRAY, "subarray1_custom_rot_angles_array", "Sub-array 1 Custom tracker rotation angles", "deg", "", "System Design", "subarray1_use_custom_rot_angles=1", "", "" }, {SSC_INPUT, SSC_NUMBER, "subarray1_use_custom_cell_temp", "Subarray 1 Use custom cell temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, {SSC_INPUT, SSC_ARRAY, "subarray1_custom_cell_temp_array", "Subarray 1 custom cell temperature", "C", "", "System Design", "subarray1_use_custom_cell_temp=1", "", "" }, @@ -181,7 +181,7 @@ static var_info _cm_vtab_pvsamv1[] = { { SSC_INPUT, SSC_MATRIX, "subarray2_shading_azal", "Sub-array 2 Azimuth x altitude beam shading losses", "%", "", "Shading", "?", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray2_shading_en_diff", "Enable Sub-array 2 Diffuse shading loss", "0/1", "0=false,1=true", "Shading", "?=0", "BOOLEAN", "" }, { SSC_INPUT, SSC_NUMBER, "subarray2_shading_diff", "Sub-array 2 Diffuse shading loss", "%", "", "Shading", "?", "", "" }, - { SSC_INPUT, SSC_NUMBER, "subarray2_use_custom_rot_angles", "Sub-array 2 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + { SSC_INPUT, SSC_NUMBER, "subarray2_use_custom_rot_angles", "Sub-array 2 Use tracker custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, { SSC_INPUT, SSC_ARRAY, "subarray2_custom_rot_angles_array", "Sub-array 2 Custom tracker rotation angles", "deg", "", "System Design", "subarray2_use_custom_rot_angles=1", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray2_use_custom_cell_temp", "Subarray 2 Use custom cell temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, { SSC_INPUT, SSC_ARRAY, "subarray2_custom_cell_temp_array", "Subarray 2 custom cell temperatures", "C", "", "System Design", "subarray2_use_custom_cell_temp=1", "", "" }, @@ -209,7 +209,7 @@ static var_info _cm_vtab_pvsamv1[] = { { SSC_INPUT, SSC_NUMBER, "subarray3_slope_tilt", "Sub-array 3 terrain tilt", "degrees", "", "System Design", "subarray3_enable=1&subarray3_track_mode=1", "MIN=0,MAX=90", "" }, { SSC_INPUT, SSC_NUMBER, "subarray3_slope_azm", "Sub-array 3 terrain azimuth", "degrees", "", "System Design", "subarray3_enable=1&subarray3_track_mode=1", "MIN=0,MAX=359.9", "" }, { SSC_INPUT, SSC_ARRAY, "subarray3_monthly_tilt", "Sub-array 3 Monthly tilt input", "degrees", "", "System Design", "subarray3_enable=1&subarray3_track_mode=4", "LENGTH=12", "" }, - { SSC_INPUT, SSC_NUMBER, "subarray3_use_custom_rot_angles", "Sub-array 3 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + { SSC_INPUT, SSC_NUMBER, "subarray3_use_custom_rot_angles", "Sub-array 3 Use custom tracker rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, { SSC_INPUT, SSC_ARRAY, "subarray3_custom_rot_angles_array", "Sub-array 3 Custom tracker rotation angles", "deg", "", "System Design", "subarray3_use_custom_rot_angles=1", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray3_use_custom_cell_temp", "Subarray 3 Use custom cell temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, { SSC_INPUT, SSC_ARRAY, "subarray3_custom_cell_temp_array", "Subarray 3 custom cell temperatures", "C", "", "System Design", "subarray3_use_custom_cell_temp=1", "", "" }, @@ -249,7 +249,7 @@ static var_info _cm_vtab_pvsamv1[] = { { SSC_INPUT, SSC_NUMBER, "subarray4_slope_azm", "Sub-array 4 terrain azimuth", "degrees", "", "System Design", "subarray4_enable=1&subarray4_track_mode=1", "MIN=0,MAX=359.9", "" }, { SSC_INPUT, SSC_ARRAY, "subarray4_monthly_tilt", "Sub-array 4 Monthly tilt input", "degrees", "", "System Design", "subarray2_enable=1&subarray2_track_mode=4", "LENGTH=12", "" }, // { SSC_INPUT, SSC_TABLE, "subarray4_shading", "Sub-array 4 shading losses", "", "", "Shading", "?", "", "" }, - { SSC_INPUT, SSC_NUMBER, "subarray4_use_custom_rot_angles", "Sub-array 4 Use custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + { SSC_INPUT, SSC_NUMBER, "subarray4_use_custom_rot_angles", "Sub-array 4 Use custom tracker rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, { SSC_INPUT, SSC_ARRAY, "subarray4_custom_rot_angles_array", "Sub-array 4 Custom tracker rotation angles", "deg", "", "System Design", "subarray4_use_custom_rot_angles=1", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray4_use_custom_cell_temp", "Subarray 4 Use custom cell temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, { SSC_INPUT, SSC_ARRAY, "subarray4_custom_cell_temp_array", "Subarray 4 custom cell temperatures", "C", "", "System Design", "subarray4_use_custom_cell_temp=1", "", "" }, @@ -1139,7 +1139,7 @@ void cm_pvsamv1::exec() if (Subarrays[nn]->useCustomRotAngles == 1) { user_tilt_angles_size = Subarrays[nn]->customRotAngles.size(); if (user_tilt_angles_size != nrec) - throw exec_error("pvsamv1", "The custom rotation angle array must be the size of nrecords per year"); + throw exec_error("pvsamv1", "The custom tracker rotation angle array must be the size of nrecords per year"); Subarrays[nn]->trackMode = irrad::SINGLE_AXIS; //Subarrays[nn]->tiltDegrees = 0; //reset to 0 to then be replaced in loop? Subarrays[nn]->backtrackingEnabled = false; //account for backtracking in user-specified angles [deg] From 5018ac25bbadf5e0cc62264563b6686c851aef26 Mon Sep 17 00:00:00 2001 From: Matt Prilliman Date: Fri, 27 Oct 2023 09:53:03 -0500 Subject: [PATCH 15/15] Fix subarray 2 custom tracker rotation label --- ssc/cmod_pvsamv1.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ssc/cmod_pvsamv1.cpp b/ssc/cmod_pvsamv1.cpp index 79232baea..f620b0976 100644 --- a/ssc/cmod_pvsamv1.cpp +++ b/ssc/cmod_pvsamv1.cpp @@ -181,7 +181,7 @@ static var_info _cm_vtab_pvsamv1[] = { { SSC_INPUT, SSC_MATRIX, "subarray2_shading_azal", "Sub-array 2 Azimuth x altitude beam shading losses", "%", "", "Shading", "?", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray2_shading_en_diff", "Enable Sub-array 2 Diffuse shading loss", "0/1", "0=false,1=true", "Shading", "?=0", "BOOLEAN", "" }, { SSC_INPUT, SSC_NUMBER, "subarray2_shading_diff", "Sub-array 2 Diffuse shading loss", "%", "", "Shading", "?", "", "" }, - { SSC_INPUT, SSC_NUMBER, "subarray2_use_custom_rot_angles", "Sub-array 2 Use tracker custom rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, + { SSC_INPUT, SSC_NUMBER, "subarray2_use_custom_rot_angles", "Sub-array 2 Use custom tracker rotation angles", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, { SSC_INPUT, SSC_ARRAY, "subarray2_custom_rot_angles_array", "Sub-array 2 Custom tracker rotation angles", "deg", "", "System Design", "subarray2_use_custom_rot_angles=1", "", "" }, { SSC_INPUT, SSC_NUMBER, "subarray2_use_custom_cell_temp", "Subarray 2 Use custom cell temperatures", "0/1", "", "System Design", "?=0", "INTEGER,MIN=0,MAX=1", "" }, { SSC_INPUT, SSC_ARRAY, "subarray2_custom_cell_temp_array", "Subarray 2 custom cell temperatures", "C", "", "System Design", "subarray2_use_custom_cell_temp=1", "", "" },