LSSTApplications  16.0-1-gce273f5+12,16.0-1-gf77f410+3,16.0-10-g230e10e+5,16.0-10-g90ce0e4+3,16.0-10-gc1446dd+3,16.0-12-g726f8f3+1,16.0-13-g4c33ca5+3,16.0-13-g5f6c0b1+3,16.0-13-gd9b1b71+3,16.0-13-gde155d7+11,16.0-16-g925333c+3,16.0-17-g6a7bfb3b+3,16.0-17-gd75be2c9,16.0-2-g0febb12+11,16.0-2-g839ba83+41,16.0-2-g9d5294e+30,16.0-3-g404ea43+3,16.0-3-gbc759ec+1,16.0-3-gcfd6c53+28,16.0-4-g03cf288+19,16.0-4-g13a27c5+5,16.0-4-g2cc461c+2,16.0-4-g5f3a788+10,16.0-4-g8a0f11a+25,16.0-4-ga3eb747,16.0-42-gaa8aebfeb+1,16.0-5-g1991253+3,16.0-5-g865efd9+3,16.0-5-gb3f8a4b+35,16.0-5-gd0f1235,16.0-6-g0a6c279+4,16.0-6-g316b399+3,16.0-6-gf0acd13+22,16.0-6-gf9cb114+4,16.0-7-g88875c5,16.0-7-gc370964+2,16.0-8-g4dec96c+16,16.0-8-gb99f628,16.0-9-gcc4efb7+15,w.2018.38
LSSTDataManagementBasePackage
RaDecStr.cc
Go to the documentation of this file.
1 /*
2  * LSST Data Management System
3  * Copyright 2008, 2009, 2010 LSST Corporation.
4  *
5  * This product includes software developed by the
6  * LSST Project (http://www.lsst.org/).
7  *
8  * This program is free software: you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation, either version 3 of the License, or
11  * (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the LSST License Statement and
19  * the GNU General Public License along with this program. If not,
20  * see <http://www.lsstcorp.org/LegalNotices/>.
21  */
22 
23 #include <string>
24 
25 #include "lsst/utils/RaDecStr.h"
26 
27 namespace except = lsst::pex::exceptions;
28 
58 namespace ut = lsst::utils;
59 
60 double radToDeg(long double angleInRadians) {
61  const long double pi = 3.141592653589793115997963468544;
62  return angleInRadians * 180./pi;
63 }
64 
65 
66 double degToRad(long double angleInDegrees) {
67  const long double pi = 3.141592653589793115997963468544;
68  return angleInDegrees * pi / 180.;
69 }
70 
71 
74 std::string ut::raRadToStr(double raRad ) {
75  return raDegToStr( radToDeg(raRad) );
76 }
77 
79 
80  double ra = raDeg; //Shorthand
81 
82  //Convert to seconds of arc
83  ra = round(ra*1e6)/1e6;
84  ra *= 86400/360;
85 
86  int hr = (int) floor(ra/3600.);
87  ra -= hr*3600;
88 
89  int mn = (int) floor(ra/60.);
90  ra -= mn*60; //Only seconds remain
91 
92  return boost::str( boost::format("%02i:%02i:%05.2f") % hr % mn % ra);
93 }
94 
95 
96 std::string ut::decRadToStr(double decRad) {
97  return decDegToStr( radToDeg(decRad) );
98 }
99 
100 
101 std::string ut::decDegToStr(double decDeg) {
102 
103  double dec = decDeg; //Shorthand
104 
105  std::string sgn = (dec<0) ? "-" : "+";
106 
107  //Rounding the declination prevents 14.999999999 being represented
108  //as 14.:59:60.00
109  dec = fabs(round(dec*1e6)/1e6);
110 
111  int degrees = (int) floor(dec);
112  dec -= degrees;
113 
114  int min = (int) floor(dec*60);
115  dec -= min/60.;
116 
117  double sec = dec*3600;
118  sec = floor(sec*100)/100.;
119 
120  std::string str = sgn;
121  return boost::str(boost::format("%s%02i:%02i:%05.2f") % sgn % degrees % min % sec);
122 
123 }
124 
125 
126 std::string ut::raDecRadToStr(double raRad, double decRad) {
127  std::string val = raRadToStr(raRad);
128  val = val + " "+decRadToStr(decRad);
129  return val;
130 }
131 
132 
133 std::string ut::raDecDegToStr(double raDeg, double decDeg) {
134  std::string val = raDegToStr(raDeg);
135  val = val + " "+decDegToStr(decDeg);
136  return val;
137 }
138 
139 
140 
141 
142 
143 // ////////////////////////////////////////////////////////////////
144 
145 //
146 // Converting strings to numbers
147 //
148 
157  std::string inStr,
159 ) {
160  // Regex the hh:mm:ss or dd:mm:ss with delimiter.
161  std::string regexStr = "(\\d+)";
162  regexStr.append(delimiter);
163  regexStr.append("(\\d+)");
164  regexStr.append(delimiter);
165  regexStr.append("([\\d\\.]+)");
166 
167  const boost::regex re(regexStr);
168  boost::cmatch what;
169  //This throws an exception of failure. I could catch it,
170  //but I'd only throw it again
171  if(! boost::regex_search(inStr.c_str(), what, re)) {
173  "Failed to parse %s as a right ascension or declination with regex %s")
174  % inStr % regexStr);
175  throw LSST_EXCEPT(except::RuntimeError, msg);
176  }
177 
178  //Convert strings to doubles. Again, errors thrown on failure
179  double hh_or_dd = std::stod(std::string(what[1].first, what[1].second));
180  double mm = std::stod(std::string(what[2].first, what[2].second));
181  double ss = std::stod(std::string(what[3].first, what[3].second));
182 
183  hh_or_dd += (mm + ss/60.0)/60.0;
184 
185  //Search for leading - sign.
186  std::string pmStr = "^-";
187  static const boost::regex pm(pmStr);
188  if(boost::regex_search(inStr, pm))
189  hh_or_dd *= -1;
190  return hh_or_dd;
191 }
192 
193 
195  return degToRad( raStrToDeg(raStr, delimiter) );
196 }
197 
198 
200  double ra_hours = sexagesimalStrToDecimal(raStr, delimiter);
201  if (ra_hours < 0) {
202  std::string msg= boost::str(boost::format("Right ascension %s is negative!") % raStr);
203  throw LSST_EXCEPT(except::RuntimeError, msg);
204  }
205 
206  return ra_hours * (360.0/24.0); // hours to degrees
207 }
208 
209 
211  return degToRad( decStrToDeg(decStr, delimiter) );
212 }
213 
214 
216  return sexagesimalStrToDecimal(decStr, delimiter);
217 }
218 
double decStrToDeg(std::string decStr, std::string delimiter=":")
Definition: RaDecStr.cc:215
std::string raDecDegToStr(double raDeg, double decDeg)
Definition: RaDecStr.cc:133
std::string decRadToStr(double decRad)
Definition: RaDecStr.cc:96
std::string raDecRadToStr(double raRad, double decRad)
Definition: RaDecStr.cc:126
T stod(T... args)
int min
Definition: Coord.cc:82
double sexagesimalStrToDecimal(std::string inStr, std::string delimiter)
Convert a sexagesimal string to a decimal double.
Definition: RaDecStr.cc:156
ImageT val
Definition: CR.cc:146
double decStrToRad(std::string decStr, std::string delimiter=":")
Definition: RaDecStr.cc:210
double raStrToDeg(std::string raStr, std::string delimiter=":")
Definition: RaDecStr.cc:199
double dec
Definition: Match.cc:41
double raStrToRad(std::string raStr, std::string delimiter=":")
Definition: RaDecStr.cc:194
STL class.
double radToDeg(long double angleInRadians)
Definition: RaDecStr.cc:60
AngleUnit constexpr degrees
constant with units of degrees
Definition: Angle.h:106
T append(T... args)
double sec
Definition: Coord.cc:83
def format(config, name=None, writeSourceLine=True, prefix="", verbose=False)
Definition: history.py:129
double degToRad(long double angleInDegrees)
Definition: RaDecStr.cc:66
#define LSST_EXCEPT(type,...)
Create an exception with a given type.
Definition: Exception.h:48
T c_str(T... args)
std::string raRadToStr(double raRad)
Convert a right ascension in radians to a string format.
Definition: RaDecStr.cc:74
char delimiter
Definition: Schema.cc:192
Extent< int, N > floor(Extent< double, N > const &input) noexcept
Return the component-wise floor (round towards more negative).
Definition: Extent.cc:108
std::string raDegToStr(double raDeg)
Definition: RaDecStr.cc:78
std::string decDegToStr(double decDeg)
Definition: RaDecStr.cc:101
Reports errors that are due to events beyond the control of the program.
Definition: Runtime.h:104