Advertisement
pleasedontcode

Scanner rev_115

Nov 6th, 2023
89
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. /********* Pleasedontcode.com **********
  2.  
  3.     Pleasedontcode thanks you for automatic code generation! Enjoy your code!
  4.  
  5.     - Terms and Conditions:
  6.     You have a non-exclusive, revocable, worldwide, royalty-free license
  7.     for personal and commercial use. Attribution is optional; modifications
  8.     are allowed, but you're responsible for code maintenance. We're not
  9.     liable for any loss or damage. For full terms,
  10.     please visit pleasedontcode.com/termsandconditions.
  11.  
  12.     - Project: Scanner
  13.     - Source Code compiled for: Arduino Mega
  14.     - Source Code created on: 2023-11-07 00:03:50
  15.     - Source Code generated by: AlexWind
  16.  
  17. ********* Pleasedontcode.com **********/
  18. /****** DEFINITION OF LIBRARIES *****/
  19. #include <Arduino.h>
  20.  
  21. /****** SYSTEM REQUIREMENT 1 *****/
  22. /* if temperature is above 100°C so provide */
  23. /* information via serial monitor. */
  24.  
  25. /****** FUNCTION PROTOTYPES *****/
  26. void setup(void);
  27. void loop(void);
  28. void updateInputs(void);
  29. float lookup_phyData_from_voltage(float voltage, int segment_points, const float* voltage_phyData_lookup);
  30. float map_f(float x, float in_min, float in_max, float out_min, float out_max);
  31. void convertInputsFromRawToPhyData(void);
  32.  
  33. /***** DEFINITION OF ANALOG INPUT PINS *****/
  34. const uint8_t sensore_PIN_A0 = A0;
  35.  
  36. /****** DEFINITION OF ANALOG INPUTS CHARACTERISTIC CURVES *****/
  37. const uint8_t SEGMENT_POINTS_voltage_Temperature_PIN_A0 = 3;
  38. const float voltage_Temperature_PIN_A0_lookup[2][SEGMENT_POINTS_voltage_Temperature_PIN_A0] PROGMEM =
  39. {
  40.   {0.0, 2.0, 3.0}, //Voltage [V]
  41.   {20.0, 60.0, 100.0} //Temperature [°C]
  42. };
  43.  
  44.  
  45. /***** DEFINITION OF INPUT RAW VARIABLES *****/
  46. /***** used to store raw data *****/
  47. unsigned int sensore_PIN_A0_rawData = 0; // Analog Input
  48.  
  49. /***** DEFINITION OF INPUT PHYSICAL VARIABLES *****/
  50. /***** used to store data after characteristic curve transformation *****/
  51. float sensore_PIN_A0_phyData = 0.0; // Temperature [°C]
  52.  
  53. void setup(void)
  54. {
  55.   // put your setup code here, to run once:
  56.   pinMode(sensore_PIN_A0, INPUT);
  57.   Serial.begin(9600); // Initialize serial communication
  58. }
  59.  
  60. void loop(void)
  61. {
  62.   // put your main code here, to run repeatedly:
  63.   updateInputs(); // Refresh input data
  64.   convertInputsFromRawToPhyData(); // after that updateInput function is called, so raw data are transformed in physical data in according to characteristic curve
  65.  
  66.   // Check if temperature is above 100°C
  67.   if (sensore_PIN_A0_phyData > 100.0)
  68.   {
  69.     Serial.println("Temperature is above 100°C");
  70.   }
  71.  
  72.   delay(1000); // Wait for 1 second before next iteration
  73. }
  74.  
  75. void updateInputs()
  76. {
  77.   sensore_PIN_A0_rawData = analogRead(sensore_PIN_A0);
  78. }
  79.  
  80. /* BLOCK lookup_phyData_from_voltage */
  81. float lookup_phyData_from_voltage(float voltage, int segment_points, const float* voltage_phyData_lookup)
  82. {
  83.     // Search table for appropriate value.
  84.     uint8_t index = 0;
  85.  
  86.     const float *voltagePointer = &voltage_phyData_lookup[0];
  87.     const float *phyDataPointer = &voltage_phyData_lookup[segment_points];
  88.  
  89.     // Perform minimum and maximum voltage saturation based on characteristic curve
  90.     voltage = min(voltage, voltagePointer[segment_points-1]);
  91.     voltage = max(voltage, voltagePointer[0]);
  92.  
  93.     while( pgm_read_float(voltagePointer[index]) <= voltage && index < segment_points )
  94.         index++;
  95.  
  96.     // If index is zero, physical value is smaller than our table range
  97.     if( index==0 )
  98.     {
  99.         return map_f( voltage,
  100.             pgm_read_float(voltagePointer[0]),   // X1
  101.             pgm_read_float(voltagePointer[1]),   // X2
  102.             pgm_read_float(phyDataPointer[0]),   // Y1
  103.             pgm_read_float(phyDataPointer[1]) ); // Y2
  104.     }
  105.     // If index is maxed out, phyisical value is larger than our range.
  106.     else if( index==segment_points )
  107.     {
  108.         return map_f( voltage,
  109.             pgm_read_float(voltagePointer[segment_points-2]),   // X1
  110.             pgm_read_float(voltagePointer[segment_points-1]),   // X2
  111.             pgm_read_float(phyDataPointer[segment_points-2]),   // Y1
  112.             pgm_read_float(phyDataPointer[segment_points-1]) ); // Y2
  113.     }
  114.     // index is between 0 and max, just right
  115.     else
  116.     {
  117.         return map_f( voltage,
  118.             pgm_read_float(voltagePointer[index-1]), // X1
  119.             pgm_read_float(voltagePointer[index]),    // X2
  120.             pgm_read_float(phyDataPointer[index-1]), // Y1
  121.             pgm_read_float(phyDataPointer[index]) );  // Y2
  122.     }
  123. }
  124. /* END BLOCK lookup_phyData_from_voltage */
  125.  
  126. /* BLOCK map_f */
  127. float map_f(float x, float in_min, float in_max, float out_min, float out_max)
  128. {
  129.     return (x - in_min) * (out_max - out_min) / (in_max - in_min) + out_min;
  130. }
  131. /* END BLOCK map_f */
  132.  
  133. /* BLOCK convertInputsFromRawToPhyData */
  134. void convertInputsFromRawToPhyData()
  135. {
  136.     float voltage = 0.0;
  137.  
  138.     voltage = sensore_PIN_A0_rawData * (5.0 / 1023.0);
  139.     sensore_PIN_A0_phyData = lookup_phyData_from_voltage(voltage, SEGMENT_POINTS_voltage_Temperature_PIN_A0, &(voltage_Temperature_PIN_A0_lookup[0][0]));
  140.  
  141. }
  142. /* END BLOCK convertInputsFromRawToPhyData */
  143.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement