Web server based weather station using Sparkfun Weather Meters.

Dependencies:   FatFileSystem mbed WeatherMeters SDFileSystem

Committer:
AdamGreen
Date:
Thu Feb 23 21:38:39 2012 +0000
Revision:
0:616601bde9fb

        

Who changed what in which revision?

UserRevisionLine numberNew contents of line
AdamGreen 0:616601bde9fb 1 /* Copyright 2012 Adam Green (http://mbed.org/users/AdamGreen/)
AdamGreen 0:616601bde9fb 2
AdamGreen 0:616601bde9fb 3 Licensed under the Apache License, Version 2.0 (the "License");
AdamGreen 0:616601bde9fb 4 you may not use this file except in compliance with the License.
AdamGreen 0:616601bde9fb 5 You may obtain a copy of the License at
AdamGreen 0:616601bde9fb 6
AdamGreen 0:616601bde9fb 7 http://www.apache.org/licenses/LICENSE-2.0
AdamGreen 0:616601bde9fb 8
AdamGreen 0:616601bde9fb 9 Unless required by applicable law or agreed to in writing, software
AdamGreen 0:616601bde9fb 10 distributed under the License is distributed on an "AS IS" BASIS,
AdamGreen 0:616601bde9fb 11 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
AdamGreen 0:616601bde9fb 12 See the License for the specific language governing permissions and
AdamGreen 0:616601bde9fb 13 limitations under the License.
AdamGreen 0:616601bde9fb 14 */
AdamGreen 0:616601bde9fb 15 /* Declaration of class to interface with wind vane sensor Sparkfun Weather Meters:
AdamGreen 0:616601bde9fb 16 http://www.sparkfun.com/products/8942
AdamGreen 0:616601bde9fb 17 */
AdamGreen 0:616601bde9fb 18 #include <mbed.h>
AdamGreen 0:616601bde9fb 19 #include "WindVane.h"
AdamGreen 0:616601bde9fb 20
AdamGreen 0:616601bde9fb 21
AdamGreen 0:616601bde9fb 22 #define REV_PER_SECOND_TO_KMPH 2.4f
AdamGreen 0:616601bde9fb 23 #define PARALLEL_R(R1, R2) (((R1) * (R2)) / ((R1) + (R2)))
AdamGreen 0:616601bde9fb 24 #define ARRAY_SIZE(X) (sizeof(X)/sizeof(X[0]))
AdamGreen 0:616601bde9fb 25
AdamGreen 0:616601bde9fb 26 struct SDescription
AdamGreen 0:616601bde9fb 27 {
AdamGreen 0:616601bde9fb 28 const char* DirectionString;
AdamGreen 0:616601bde9fb 29 float DirectionAngle;
AdamGreen 0:616601bde9fb 30 float SensorResistance;
AdamGreen 0:616601bde9fb 31 };
AdamGreen 0:616601bde9fb 32
AdamGreen 0:616601bde9fb 33
AdamGreen 0:616601bde9fb 34 static SDescription g_WindVaneDescriptionTable[16] = {
AdamGreen 0:616601bde9fb 35 { "North", 0.0f, 33.0f * 1000.0f },
AdamGreen 0:616601bde9fb 36 { "North North East", 22.5f, PARALLEL_R(33.0f * 1000.0f, 8.2f * 1000.0f) },
AdamGreen 0:616601bde9fb 37 { "North East", 45.0f, 8.2f * 1000.0f },
AdamGreen 0:616601bde9fb 38 { "East North East", 67.5f, PARALLEL_R(8.2f * 1000.0f, 1000.0f) },
AdamGreen 0:616601bde9fb 39 { "East", 90.0f, 1000.0f },
AdamGreen 0:616601bde9fb 40 { "East South East", 112.5f, PARALLEL_R(1000.0f, 2.2f * 1000.0f) },
AdamGreen 0:616601bde9fb 41 { "South East", 135.0f, 2.2f * 1000.0f },
AdamGreen 0:616601bde9fb 42 { "South South East", 157.5f, PARALLEL_R(2.2f * 1000.0f, 3.9f * 1000.0f) },
AdamGreen 0:616601bde9fb 43 { "South", 180.0f, 3.9f * 1000.0f },
AdamGreen 0:616601bde9fb 44 { "South South West", 202.5f, PARALLEL_R(3.9f * 1000.0f, 16.0f * 1000.0f) },
AdamGreen 0:616601bde9fb 45 { "South West", 225.0f, 16.0f * 1000.0f },
AdamGreen 0:616601bde9fb 46 { "West South West", 247.5f, PARALLEL_R(16.0f * 1000.0f, 120.0f * 1000.0f) },
AdamGreen 0:616601bde9fb 47 { "West", 270.0f, 120.0f * 1000.0f },
AdamGreen 0:616601bde9fb 48 { "West North West", 292.5f, PARALLEL_R(120.0f * 1000.0f, 64.9f * 1000.0f) },
AdamGreen 0:616601bde9fb 49 { "North West", 315.0f, 64.9f * 1000.0f },
AdamGreen 0:616601bde9fb 50 { "North North West", 337.5f, PARALLEL_R(64.9f * 1000.0f, 33.0f * 1000.0f) }
AdamGreen 0:616601bde9fb 51 };
AdamGreen 0:616601bde9fb 52
AdamGreen 0:616601bde9fb 53
AdamGreen 0:616601bde9fb 54 CWindVane::CWindVane(PinName WindVanePin, float WindVaneSeriesResistance)
AdamGreen 0:616601bde9fb 55 : m_WindVaneAnalogIn(WindVanePin)
AdamGreen 0:616601bde9fb 56 {
AdamGreen 0:616601bde9fb 57 for (size_t i = 0 ; i < ARRAY_SIZE(g_WindVaneDescriptionTable) ; i++)
AdamGreen 0:616601bde9fb 58 {
AdamGreen 0:616601bde9fb 59 SDescription* pDescription = &g_WindVaneDescriptionTable[i];
AdamGreen 0:616601bde9fb 60
AdamGreen 0:616601bde9fb 61 m_WindVaneVoltageTable[i] = pDescription->SensorResistance /
AdamGreen 0:616601bde9fb 62 (pDescription->SensorResistance + WindVaneSeriesResistance);
AdamGreen 0:616601bde9fb 63 }
AdamGreen 0:616601bde9fb 64 }
AdamGreen 0:616601bde9fb 65
AdamGreen 0:616601bde9fb 66 const char* CWindVane::GetWindDirectionAsString()
AdamGreen 0:616601bde9fb 67 {
AdamGreen 0:616601bde9fb 68 return g_WindVaneDescriptionTable[DetermineWindDirectionIndex()].DirectionString;
AdamGreen 0:616601bde9fb 69 }
AdamGreen 0:616601bde9fb 70
AdamGreen 0:616601bde9fb 71 float CWindVane::GetWindDirectionAsAngle()
AdamGreen 0:616601bde9fb 72 {
AdamGreen 0:616601bde9fb 73 return g_WindVaneDescriptionTable[DetermineWindDirectionIndex()].DirectionAngle;
AdamGreen 0:616601bde9fb 74 }
AdamGreen 0:616601bde9fb 75
AdamGreen 0:616601bde9fb 76 size_t CWindVane::DetermineWindDirectionIndex()
AdamGreen 0:616601bde9fb 77 {
AdamGreen 0:616601bde9fb 78 float WindVaneSensorVoltage = m_WindVaneAnalogIn.read();
AdamGreen 0:616601bde9fb 79
AdamGreen 0:616601bde9fb 80 // Default to the first entry being closest.
AdamGreen 0:616601bde9fb 81 size_t ClosestIndex = 0;
AdamGreen 0:616601bde9fb 82 float ClosestDelta = fabs(m_WindVaneVoltageTable[0] - WindVaneSensorVoltage);
AdamGreen 0:616601bde9fb 83
AdamGreen 0:616601bde9fb 84 // Walk the rest of the entries to see if there is another which is closer.
AdamGreen 0:616601bde9fb 85 for (size_t i = 1 ; i < ARRAY_SIZE(m_WindVaneVoltageTable) ; i++)
AdamGreen 0:616601bde9fb 86 {
AdamGreen 0:616601bde9fb 87 float Delta = fabs(m_WindVaneVoltageTable[i] - WindVaneSensorVoltage);
AdamGreen 0:616601bde9fb 88 if (Delta < ClosestDelta)
AdamGreen 0:616601bde9fb 89 {
AdamGreen 0:616601bde9fb 90 ClosestDelta = Delta;
AdamGreen 0:616601bde9fb 91 ClosestIndex = i;
AdamGreen 0:616601bde9fb 92 }
AdamGreen 0:616601bde9fb 93 }
AdamGreen 0:616601bde9fb 94
AdamGreen 0:616601bde9fb 95 return ClosestIndex;
AdamGreen 0:616601bde9fb 96 }