stdconvs.pp 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660
  1. {
  2. This file is part of the Free Pascal run time library.
  3. Copyright (c) 2004 by Marco van de Voort
  4. member of the Free Pascal development team.
  5. An implementation for unit stdconv,
  6. Based on list of function of delphibasics.co.uk and #7482.
  7. Quantities are mostly taken from my HP48g/gx or the unix units program
  8. This program is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY;without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  11. **********************************************************************}
  12. unit StdConvs;
  13. interface
  14. {$mode objfpc}
  15. {$H+}
  16. {$ifndef FPUNONE}
  17. Uses convutils;
  18. const
  19. // Powers of 10
  20. siYocto = 1E-24;
  21. siZepto = 1E-21;
  22. siAtto = 1E-18;
  23. siFemto = 1E-15;
  24. siPico = 1E-12;
  25. siNano = 1E-9;
  26. siMicro = 1E-6;
  27. siMilli = 1E-3;
  28. siCenti = 1E-2;
  29. siDeci = 1E-1;
  30. siDeca = 10;
  31. siHecto = siDeca*10;
  32. siKilo = siHecto*10;
  33. siMega = siKilo*1000;
  34. siGiga = siMega*1000;
  35. siTera = Int64(siGiga*1000);
  36. siPeta = Int64(siTera*1000);
  37. siExa = Int64(siPeta*1000);
  38. siZetta = 1E21;
  39. siYotta = 1E24;
  40. // Powers of 2
  41. iecKibi = 1024; // 10
  42. iecMebi = iecKibi*1024; // 20
  43. iecGibi = iecMebi*1024; // 30
  44. iecTebi = Int64(iecGibi*1024); // 40
  45. iecPebi = Int64(iecTebi*1024); // 50
  46. iecExbi = Int64(iecPebi*1024); // 60
  47. iecZebi = Double(iecExbi)*1024; // 70
  48. iecYobi = iecZebi*1024; // 80;
  49. var
  50. {cbArea family}
  51. auSquareMillimeters,
  52. auSquareCentimeters,
  53. auSquareDecimeters,
  54. auSquareMeters,
  55. auSquareDecameters,
  56. auSquareHectometers,
  57. auSquareKilometers,
  58. auSquareInches,
  59. auSquareFeet ,
  60. auSquareYards ,
  61. auSquareMiles,
  62. auAcres ,
  63. auCentares ,
  64. auAres ,
  65. auHectares ,
  66. auSquareRods ,
  67. {cbDistance family}
  68. duMicromicrons,
  69. duAngstroms ,
  70. duMillimicrons,
  71. duMicrons,
  72. duMillimeters,
  73. duCentimeters,
  74. duDecimeters,
  75. duMeters,
  76. duDecameters,
  77. duHectometers,
  78. duKilometers,
  79. duMegameters,
  80. duGigameters,
  81. duInches,
  82. duFeet,
  83. duYards,
  84. duMiles ,
  85. duNauticalMiles,
  86. duAstronomicalUnits,
  87. duLightYears,
  88. duParsecs,
  89. duCubits,
  90. duFathoms,
  91. duFurlongs,
  92. duHands,
  93. duPaces,
  94. duRods,
  95. duChains,
  96. duLinks,
  97. duPicas,
  98. duPoints,
  99. {cbMass family}
  100. muNanograms,
  101. muMicrograms,
  102. muMilligrams,
  103. muCentigrams,
  104. muDecigrams,
  105. muGrams,
  106. muDecagrams,
  107. muHectograms,
  108. muKilograms,
  109. muMetricTons,
  110. muDrams,
  111. muGrains,
  112. muLongTons,
  113. muTons,
  114. muOunces,
  115. muPounds,
  116. muStones,
  117. {cbTemperature family}
  118. tuCelsius,
  119. tuKelvin,
  120. tuFahrenheit,
  121. tuRankine,
  122. tuReamur,
  123. tuDelisle,
  124. tuNewton,
  125. tuRomer,
  126. tuReguloGasMark,
  127. {
  128. cbTime family
  129. }
  130. tuMilliSeconds,
  131. tuSeconds,
  132. tuMinutes,
  133. tuHours,
  134. tuDays,
  135. tuWeeks,
  136. tuFortnights,
  137. tuMonths,
  138. tuYears,
  139. tuDecades,
  140. tuCenturies,
  141. tuMillennia,
  142. tuDateTime,
  143. tuJulianDate,
  144. tuModifiedJulianDate,
  145. {
  146. cbVolume family
  147. }
  148. vuCubicMillimeters,
  149. vuCubicCentimeters,
  150. vuCubicDecimeters,
  151. vuCubicMeters,
  152. vuCubicDecameters,
  153. vuCubicHectometers,
  154. vuCubicKilometers,
  155. vuCubicInches,
  156. vuCubicFeet,
  157. vuCubicYards,
  158. vuCubicMiles,
  159. vuMilliLiters,
  160. vuCentiLiters,
  161. vuDeciLiters,
  162. vuLiters,
  163. vuDecaLiters,
  164. vuHectoLiters,
  165. vuKiloLiters,
  166. vuAcreFeet,
  167. vuAcreInches,
  168. vuCords,
  169. vuCordFeet,
  170. vuDecisteres,
  171. vuSteres,
  172. vuDecasteres,
  173. vuFluidGallons,
  174. vuFluidQuarts,
  175. vuFluidPints,
  176. vuFluidCups,
  177. vuFluidGills,
  178. vuFluidOunces,
  179. vuFluidTablespoons,
  180. vuFluidTeaspoons,
  181. vuDryGallons,
  182. vuDryQuarts,
  183. vuDryPints,
  184. vuDryPecks,
  185. vuDryBuckets,
  186. vuDryBushels,
  187. vuUKGallons,
  188. vuUKPottles,
  189. vuUKQuarts,
  190. vuUKPints,
  191. vuUKGills,
  192. vuUKOunces,
  193. vuUKPecks,
  194. vuUKBuckets,
  195. vuUKBushels : TConvType;
  196. var
  197. cbArea : TConvFamily;
  198. cbDistance : TConvFamily;
  199. cbMass : TConvFamily;
  200. cbTemperature : TConvFamily;
  201. cbTime : TConvFamily;
  202. cbVolume : TConvFamily;
  203. function CelsiusToFahrenheit(const AValue: Double): Double;
  204. function FahrenheitToCelsius(const AValue: Double): Double;
  205. function CelsiusToKelvin (const AValue: Double): Double;
  206. function KelvinToCelsius (const AValue: Double): Double;
  207. function RankineToCelsius (const AValue: Double): Double;
  208. function CelsiusToRankine (const AValue: Double): Double;
  209. function DelisleToCelsius (const AValue: Double): Double;
  210. function CelsiusToDelisle (const AValue: Double): Double;
  211. function NewtonToCelsius (const AValue: Double): Double;
  212. function CelsiusToNewton (const AValue: Double): Double;
  213. function RomerToCelsius (const AValue: Double): Double;
  214. function CelsiusToRomer (const AValue: Double): Double;
  215. function ReguloGasMarkToCelsius(const AValue: Double): Double;
  216. function CelsiusToReguloGasMark(const AValue: Double): Double;
  217. implementation
  218. function FahrenheitToCelsius(const AValue: Double): Double;
  219. begin
  220. result:= (double(5.0)/9.0) * (Avalue - 32.0);
  221. end;
  222. function CelsiusToFahrenheit(const AValue: Double): Double;
  223. begin
  224. result:= 32.0 + ((9.0 * AValue)/ 5.0);
  225. end;
  226. function CelsiusToKelvin (const AValue: Double): Double;
  227. begin
  228. result:=AValue+273.15;
  229. end;
  230. function KelvinToCelsius (const AValue: Double): Double;
  231. begin
  232. result:=AValue-273.15;
  233. end;
  234. function RankineToCelsius(const AValue: Double): Double;
  235. begin
  236. result:=(AValue*Double(5/9))-273.15;
  237. end;
  238. function CelsiusToRankine(const AValue: Double): Double;
  239. begin
  240. result:=(AValue+273.15)*1.8;
  241. end;
  242. function DelisleToCelsius(const AValue: Double): Double;
  243. begin
  244. result:=100-(Double(2/3)*AValue);
  245. end;
  246. function CelsiusToDelisle(const AValue: Double): Double;
  247. begin
  248. result:=1.5*(100-AValue);
  249. end;
  250. function NewtonToCelsius(const AValue: Double): Double;
  251. begin
  252. result:=Double(100/33)*AValue;
  253. end;
  254. function CelsiusToNewton(const AValue: Double): Double;
  255. begin
  256. result:=0.33*AValue;
  257. end;
  258. function RomerToCelsius(const AValue: Double): Double;
  259. begin
  260. result:=(AValue-7.5)*Double(40/21);
  261. end;
  262. function CelsiusToRomer(const AValue: Double): Double;
  263. begin
  264. result:=AValue*Double(21/40) + 7.5;
  265. end;
  266. function ReguloGasMarkToCelsius(const AValue: Double): Double;
  267. begin
  268. result:=AVAlue*Double(125/9) + 121.11;
  269. end;
  270. function CelsiusToReguloGasMark(const AValue: Double): Double;
  271. begin
  272. result:=Double(9/125)*(AValue-121.11);
  273. end;
  274. ResourceString // Note, designations for FFU's are guesses.
  275. txtauSquareMillimeters = 'Square millimeters (mm^2)';
  276. txtauSquareCentimeters = 'Square centimeters (cm^2)';
  277. txtauSquareDecimeters = 'Square decimeters (dm^2)';
  278. txtauSquareMeters = 'Square meters (m^2)';
  279. txtauSquareDecameters = 'Square decameters (dam^2)';
  280. txtauSquareHectometers = 'Square hectometers (hm^2)';
  281. txtauSquareKilometers = 'Square kilometers (km^2)';
  282. txtauSquareInches = 'Square inch (in^2)';
  283. txtauSquareFeet = 'Square feet (ft^2)';
  284. txtauSquareYards = 'Square yards (yd^2)';
  285. txtauSquareMiles = 'Square miles (mi^2)';
  286. txtauAcres = 'Square acres (acre^2)';
  287. txtauCentares = 'Centares (care^2)';
  288. txtauAres = 'Ares (are=dam^2)';
  289. txtauHectares = 'Hectares (ha=hm^2)';
  290. txtauSquareRods = 'Square Rods (sqr)';
  291. txtduMicromicrons = 'micro microms (mumum)';
  292. txtduAngstroms = 'Aengstroem (ang)';
  293. txtduMillimicrons = 'millimicroms (mmum)';
  294. txtduMicrons = 'microns (um)';
  295. txtduMillimeters = 'millimeters (mm)';
  296. txtduCentimeters = 'centimeters (cm)';
  297. txtduDecimeters = 'decimeters (dm)';
  298. txtduMeters = 'meters (m)';
  299. txtduDecameters = 'decameters (dam)';
  300. txtduHectometers = 'hectometers (hm)';
  301. txtduKilometers = 'kilometers (km)';
  302. txtduMegameters = 'megameters (Mm)';
  303. txtduGigameters = 'gigameters (Gm)';
  304. txtduInches = 'inches (in)';
  305. txtduFeet = 'feet (ft)';
  306. txtduYards = 'yards (yd)';
  307. txtduMiles = 'miles (mi)';
  308. txtduNauticalMiles = 'nautical miles (nmi)';
  309. txtduAstronomicalUnits = 'astronomical units (au)';
  310. txtduLightYears = 'light years (ly)';
  311. txtduParsecs = 'Parsec (Ps)';
  312. txtduCubits = 'Cubits (cb)';
  313. txtduFathoms = 'Fathom (Fth)';
  314. txtduFurlongs = 'Furlongs (furl)';
  315. txtduHands = 'Hands (hnd)';
  316. txtduPaces = 'Paces (pc)';
  317. txtduRods = 'Rods (rd)';
  318. txtduChains = 'Chains (ch)';
  319. txtduLinks = 'Links (lnk)';
  320. txtduPicas = 'Pica''s (pc)';
  321. txtduPoints = 'Points (pnts)'; // carat/Karaat 2E-6 gram ?
  322. txtmuNanograms = 'nanograms (ng)';
  323. txtmuMicrograms = 'micrograms (um)';
  324. txtmuMilligrams = 'milligrams (mg)';
  325. txtmuCentigrams = 'centigrams (cg)';
  326. txtmuDecigrams = 'decigrams (dg)';
  327. txtmuGrams = 'grams (g)';
  328. txtmuDecagrams = 'decagrams (dag)';
  329. txtmuHectograms = 'hectograms (hg)';
  330. txtmuKilograms = 'kilograms (kg)';
  331. txtmuMetricTons = 'metric ton (t)';
  332. txtmuDrams = 'dramgs (??)';
  333. txtmuGrains = 'grains (??)';
  334. txtmuLongTons = 'longton (??)';
  335. txtmuTons = 'imperial ton (??)'; // calling metric ton "ton" is normal in metric countries
  336. txtmuOunces = 'ounce (??)';
  337. txtmuPounds = 'pounds (??)'; // what kind? Metric pound =0.5
  338. txtmuStones = 'stones (??)';
  339. txttuCelsius = 'degrees Celsius (degC)';
  340. txttuKelvin = 'degrees Kelvin (K)';
  341. txttuFahrenheit = 'degrees Fahrenheit (degF)';
  342. txttuRankine = 'degrees Rankine (degR)';
  343. txttuReamur = 'degrees Reamur (degReam)';
  344. txttuDelisle = 'degrees Delisle(degDe)';
  345. txttuNewton = 'degrees Newton (degN)';
  346. txttuRomer = 'degrees Romer (degRo)';
  347. txttuReguloGasMark = 'degrees ReguloGasMark (degRM)';
  348. txttuMilliSeconds = 'milli seconds (ms)';
  349. txttuSeconds = 'seconds (s)';
  350. txttuMinutes = 'minutes (min)';
  351. txttuHours = 'hours (hr)';
  352. txttuDays = 'days (days)';
  353. txttuWeeks = 'weeks (weeks)';
  354. txttuFortnights = 'Fortnights (??)';
  355. txttuMonths = 'Months (months)';
  356. txttuYears = 'Years (years)';
  357. txttuDecades = 'Decades (decades)';
  358. txttuCenturies = 'Centuries (centuries)';
  359. txttuMillennia = 'Millennia (millennia)';
  360. txttuDateTime = 'DateTime (??)';
  361. txttuJulianDate = 'JulianDate (??)';
  362. txttuModifiedJulianDate = 'Modified JulianData (??)';
  363. txtvuCubicMillimeters = 'cubic millimeters (mm^3)';
  364. txtvuCubicCentimeters = 'cubic centimeters (cm^3)';
  365. txtvuCubicDecimeters = 'cubic decimeters (dm^3)';
  366. txtvuCubicMeters = 'cubic meters (m^3)';
  367. txtvuCubicDecameters = 'cubic decameters (dam^3)';
  368. txtvuCubicHectometers = 'cubic hectometers (hm^3)';
  369. txtvuCubicKilometers = 'cubic kilometers (km^3)';
  370. txtvuCubicInches = 'cubic inches (in^3)';
  371. txtvuCubicFeet = 'cubic feet (ft^3)';
  372. txtvuCubicYards = 'cubic yards (yd^3)';
  373. txtvuCubicMiles = 'cubic miles (mi^3)';
  374. txtvuMilliLiters = 'milliliters (ml)';
  375. txtvuCentiLiters = 'centiliters (cl)';
  376. txtvuDeciLiters = 'deciliters (dl)';
  377. txtvuLiters = 'liters (l)';
  378. txtvuDecaLiters = 'decaliters (dal)';
  379. txtvuHectoLiters = 'hectoliters (hl)';
  380. txtvuKiloLiters = 'kiloliters (kl)';
  381. txtvuAcreFeet = 'acrefeet (acre ft)';
  382. txtvuAcreInches = 'acreinches (acre in)';
  383. txtvuCords = 'cords (??)';
  384. txtvuCordFeet = 'cordfeet (??)';
  385. txtvuDecisteres = 'decisteres (??)';
  386. txtvuSteres = 'steres (??)';
  387. txtvuDecasteres = 'decasteres (??)';
  388. txtvuFluidGallons = 'US fluid gallons (fl gal)';
  389. txtvuFluidQuarts = 'US fluid Quarts (fl Quart)';
  390. txtvuFluidPints = 'US fluid Pints (fl pints)';
  391. txtvuFluidCups = 'US fluid Cups (fl Cups)';
  392. txtvuFluidGills = 'US fluid Gills (fl Quart)';
  393. txtvuFluidOunces = 'US fluid Ounces (fl Ounces)';
  394. txtvuFluidTablespoons = 'US fluid Tablespoons (fl Tablespoons)';
  395. txtvuFluidTeaspoons = 'US fluid teaspoons (fl teaspoon)';
  396. txtvuDryGallons = 'US dry gallons (dr gal)';
  397. txtvuDryQuarts = 'US dry Quarts (dr Quart)';
  398. txtvuDryPints = 'US dry Pints (dr pints)';
  399. txtvuDryPecks = 'US dry pecks (dr pecks)';
  400. txtvuDryBuckets = 'US dry buckets (dr buckets)';
  401. txtvuDryBushels = 'US dry bushels (dr bushels)';
  402. txtvuUKGallons = 'UK gallons (fl gal)';
  403. txtvuUKPottles = 'UK Pottles (fl pttle)';
  404. txtvuUKQuarts = 'UK Quarts (fl Quart)';
  405. txtvuUKPints = 'UK Pints (fl pints)';
  406. txtvuUKGills = 'UK Gills (fl Quart)';
  407. txtvuUKOunces = 'UK Ounces (fl Ounces)';
  408. txtvuUKPecks = 'UK pecks (dr pecks)';
  409. txtvuUKBuckets = 'UK buckets (dr buckets)';
  410. txtvuUKBushels = 'UK bushels (dr bushels)';
  411. // initial FFU factors from a HP48g calculator and BSD units program. However after
  412. // a while, the bushels/forthnight got boring, so please check.
  413. // undefined/uncertain factors get -1, and convert() functions
  414. // should check that and bomb on it.
  415. procedure RegisterArea;
  416. begin
  417. auSquareMillimeters := RegisterConversionType(cbArea,txtauSquareMillimeters,1E-6);
  418. auSquareCentimeters := RegisterConversionType(cbArea,txtauSquareCentimeters,1E-4);
  419. auSquareDecimeters := RegisterConversionType(cbArea,txtauSquareDecimeters,1E-2);
  420. auSquareMeters := RegisterConversionType(cbArea,txtauSquareMeters,1);
  421. auSquareDecameters := RegisterConversionType(cbArea,txtauSquareDecameters,1E2);
  422. auSquareHectometers := RegisterConversionType(cbArea,txtauSquareHectometers,1E4);
  423. auSquareKilometers := RegisterConversionType(cbArea,txtauSquareKilometers,1E6);
  424. auSquareInches := RegisterConversionType(cbArea,txtauSquareInches,0.00064516);
  425. auSquareFeet := RegisterConversionType(cbArea,txtauSquareFeet,0.092903040);
  426. auSquareYards := RegisterConversionType(cbArea,txtauSquareYards,0.83612736);
  427. auSquareMiles := RegisterConversionType(cbArea,txtauSquareMiles,2589988.11034);
  428. auAcres := RegisterConversionType(cbArea,txtauAcres,4046.87260987);
  429. auCentares := RegisterConversionType(cbArea,txtauCentares,-1);
  430. auAres := RegisterConversionType(cbArea,txtauAres,100);
  431. auHectares := RegisterConversionType(cbArea,txtauHectares,10000);
  432. auSquareRods := RegisterConversionType(cbArea,txtauSquareRods,25.2929538117);
  433. end;
  434. procedure RegisterLengths;
  435. begin
  436. duMicromicrons := RegisterConversionType(cbDistance,txtduMicromicrons,1E-12);
  437. duAngstroms := RegisterConversionType(cbDistance,txtduAngstroms,1E-10);
  438. duMillimicrons := RegisterConversionType(cbDistance,txtduMillimicrons,1E-9);
  439. duMicrons := RegisterConversionType(cbDistance,txtduMicrons,1E-6);
  440. duMillimeters := RegisterConversionType(cbDistance,txtduMillimeters,1E-3);
  441. duCentimeters := RegisterConversionType(cbDistance,txtduCentimeters,1E-2);
  442. duDecimeters := RegisterConversionType(cbDistance,txtduDecimeters,1E-1);
  443. duMeters := RegisterConversionType(cbDistance,txtduMeters,1);
  444. duDecameters := RegisterConversionType(cbDistance,txtduDecameters,10);
  445. duHectometers := RegisterConversionType(cbDistance,txtduHectometers,100);
  446. duKilometers := RegisterConversionType(cbDistance,txtduKilometers,1000);
  447. duMegameters := RegisterConversionType(cbDistance,txtduMegameters,1E6);
  448. duGigameters := RegisterConversionType(cbDistance,txtduGigameters,1E9);
  449. duInches := RegisterConversionType(cbDistance,txtduInches,0.0254);
  450. duFeet := RegisterConversionType(cbDistance,txtduFeet,0.3048);
  451. duYards := RegisterConversionType(cbDistance,txtduYards,0.9144);
  452. duMiles := RegisterConversionType(cbDistance,txtduMiles,1609.344);
  453. duNauticalMiles := RegisterConversionType(cbDistance,txtduNauticalMiles,1852);
  454. duAstronomicalUnits := RegisterConversionType(cbDistance,txtduAstronomicalUnits,149597900000.0);
  455. duLightYears := RegisterConversionType(cbDistance,txtduLightYears,9.46052840488E15);
  456. duParsecs := RegisterConversionType(cbDistance,txtduParsecs, 3.08567818585E16);
  457. duCubits := RegisterConversionType(cbDistance,txtduCubits,0.4572);
  458. duFathoms := RegisterConversionType(cbDistance,txtduFathoms,1.8288);
  459. duFurlongs := RegisterConversionType(cbDistance,txtduFurlongs,201.168);
  460. duHands := RegisterConversionType(cbDistance,txtduHands,0.1016);
  461. duPaces := RegisterConversionType(cbDistance,txtduPaces,0.9144);
  462. duRods := RegisterConversionType(cbDistance,txtduRods,5.0292);
  463. duChains := RegisterConversionType(cbDistance,txtduChains,20.1168);
  464. duLinks := RegisterConversionType(cbDistance,txtduLinks,0.201168);
  465. duPicas := RegisterConversionType(cbDistance,txtduPicas,0.0042333333);
  466. duPoints := RegisterConversionType(cbDistance,txtduPoints,0.00035277778);
  467. end;
  468. procedure Registermass; // weight? :)
  469. begin
  470. muNanograms := RegisterConversionType(cbMass,txtmuNanograms,1E-12);
  471. muMicrograms := RegisterConversionType(cbMass,txtmuMicrograms,1E-9);
  472. muMilligrams := RegisterConversionType(cbMass,txtmuMilligrams,1E-6);
  473. muCentigrams := RegisterConversionType(cbMass,txtmuCentigrams,1E-5);
  474. muDecigrams := RegisterConversionType(cbMass,txtmuDecigrams,1E-4);
  475. muGrams := RegisterConversionType(cbMass,txtmuGrams,1E-3);
  476. muDecagrams := RegisterConversionType(cbMass,txtmuDecagrams,1E-2);
  477. muHectograms := RegisterConversionType(cbMass,txtmuHectograms,1E-1);
  478. muKilograms := RegisterConversionType(cbMass,txtmuKilograms,1);
  479. muMetricTons := RegisterConversionType(cbMass,txtmuMetricTons,1000);
  480. muDrams := RegisterConversionType(cbMass,txtmuDrams,0.0017718452);
  481. muGrains := RegisterConversionType(cbMass,txtmuGrains,6.479891E-5);
  482. muLongTons := RegisterConversionType(cbMass,txtmuLongTons,1016.0469);
  483. muTons := RegisterConversionType(cbMass,txtmuTons,907.18474);
  484. muOunces := RegisterConversionType(cbMass,txtmuOunces,0.028349523);
  485. muPounds := RegisterConversionType(cbMass,txtmuPounds,0.45359237);
  486. muStones := RegisterConversionType(cbMass,txtmuStones,6.3502932);
  487. end;
  488. procedure RegisterTemperature;
  489. begin
  490. tuCelsius := RegisterConversionType(cbTemperature,txttuCelsius,1);
  491. tuKelvin := RegisterConversionType(cbTemperature,txttuKelvin,@KelvinToCelsius,@CelsiusToKelvin);
  492. tuFahrenheit := RegisterConversionType(cbTemperature,txttuFahrenheit,@FahrenheitToCelsius,@CelsiusToFahrenheit);
  493. tuRankine := RegisterConversionType(cbTemperature,txttuRankine,@RankineToCelsius,@CelsiusToRankine);
  494. tuReamur := RegisterConversionType(cbTemperature,txttuReamur,10/8); // Reaumur?
  495. tuDelisle := RegisterConversionType(cbTemperature,txttuDelisle,@DelisleToCelsius,@CelsiusToDelisle);
  496. tuNewton := RegisterConversionType(cbTemperature,txttuNewton,100/33);
  497. tuRomer := RegisterConversionType(cbTemperature,txttuRomer,@RomerToCelsius,@CelsiusToRomer);
  498. tuReguloGasMark := RegisterConversionType(cbTemperature,txttuReguloGasMark,@ReguloGasMarkToCelsius,@CelsiusToReguloGasMark);
  499. end;
  500. Const Yearsec=365.24219879*24*3600.0; // year in seconds;
  501. procedure RegisterTimes;
  502. begin
  503. tuMilliSeconds := RegisterConversionType(cbTime,txttuMilliSeconds,1E-3);
  504. tuSeconds := RegisterConversionType(cbTime,txttuSeconds,1);
  505. tuMinutes := RegisterConversionType(cbTime,txttuMinutes,60.0);
  506. tuHours := RegisterConversionType(cbTime,txttuHours,3600.0);
  507. tuDays := RegisterConversionType(cbTime,txttuDays,24*3600.0);
  508. tuWeeks := RegisterConversionType(cbTime,txttuWeeks,7*24*3600.0);
  509. tuFortnights := RegisterConversionType(cbTime,txttuFortnights,14*24*3600.0);
  510. tuMonths := RegisterConversionType(cbTime,txttuMonths,1/12*YearSec);
  511. tuYears := RegisterConversionType(cbTime,txttuYears,YearSec);
  512. tuDecades := RegisterConversionType(cbTime,txttuDecades,10*YearSec);
  513. tuCenturies := RegisterConversionType(cbTime,txttuCenturies,100*yearsec);
  514. tuMillennia := RegisterConversionType(cbTime,txttuMillennia,1000*yearsec);
  515. tuDateTime := RegisterConversionType(cbTime,txttuDateTime,-1);
  516. tuJulianDate := RegisterConversionType(cbTime,txttuJulianDate,-1);
  517. tuModifiedJulianDate := RegisterConversionType(cbTime,txttuModifiedJulianDate,-1);
  518. end;
  519. const flgal=0.0037854118;
  520. procedure RegisterVolumes;
  521. begin
  522. vuCubicMillimeters := RegisterConversionType(cbVolume,txtvuCubicMillimeters,1E-9);
  523. vuCubicCentimeters := RegisterConversionType(cbVolume,txtvuCubicCentimeters,1E-6);
  524. vuCubicDecimeters := RegisterConversionType(cbVolume,txtvuCubicDecimeters,1E-3);
  525. vuCubicMeters := RegisterConversionType(cbVolume,txtvuCubicMeters,1);
  526. vuCubicDecameters := RegisterConversionType(cbVolume,txtvuCubicDecameters,1E3);
  527. vuCubicHectometers := RegisterConversionType(cbVolume,txtvuCubicHectometers,1E6);
  528. vuCubicKilometers := RegisterConversionType(cbVolume,txtvuCubicKilometers,1E9);
  529. vuCubicInches := RegisterConversionType(cbVolume,txtvuCubicInches,1.6387064E-5);
  530. vuCubicFeet := RegisterConversionType(cbVolume,txtvuCubicFeet,0.028316847);
  531. vuCubicYards := RegisterConversionType(cbVolume,txtvuCubicYards,0.76455486);
  532. vuCubicMiles := RegisterConversionType(cbVolume,txtvuCubicMiles,4.1681818E9);
  533. vuMilliLiters := RegisterConversionType(cbVolume,txtvuMilliLiters,1E-6);
  534. vuCentiLiters := RegisterConversionType(cbVolume,txtvuCentiLiters,1E-5);
  535. vuDeciLiters := RegisterConversionType(cbVolume,txtvuDeciLiters,1E-4);
  536. vuLiters := RegisterConversionType(cbVolume,txtvuLiters,1E-3);
  537. vuDecaLiters := RegisterConversionType(cbVolume,txtvuDecaLiters,1E-2);
  538. vuHectoLiters := RegisterConversionType(cbVolume,txtvuHectoLiters,1E-1);
  539. vuKiloLiters := RegisterConversionType(cbVolume,txtvuKiloLiters,1);
  540. vuAcreFeet := RegisterConversionType(cbVolume,txtvuAcreFeet, -1);
  541. vuAcreInches := RegisterConversionType(cbVolume,txtvuAcreInches, -1);
  542. vuCords := RegisterConversionType(cbVolume,txtvuCords,128*0.028316847);
  543. vuCordFeet := RegisterConversionType(cbVolume,txtvuCordFeet,128*0.028316847);
  544. vuDecisteres := RegisterConversionType(cbVolume,txtvuDecisteres,0.1);
  545. vuSteres := RegisterConversionType(cbVolume,txtvuSteres,1);
  546. vuDecasteres := RegisterConversionType(cbVolume,txtvuDecasteres,10);
  547. vuFluidGallons := RegisterConversionType(cbVolume,txtvuFluidGallons,flgal);
  548. vuFluidQuarts := RegisterConversionType(cbVolume,txtvuFluidQuarts,0.25*flgal);
  549. vuFluidPints := RegisterConversionType(cbVolume,txtvuFluidPints,0.5*0.25*flgal);
  550. vuFluidCups := RegisterConversionType(cbVolume,txtvuFluidCups, -1);
  551. vuFluidGills := RegisterConversionType(cbVolume,txtvuFluidGills,-1);
  552. vuFluidOunces := RegisterConversionType(cbVolume,txtvuFluidOunces,1/16*0.5*0.25*flgal);
  553. vuFluidTablespoons := RegisterConversionType(cbVolume,txtvuFluidTablespoons,-1);
  554. vuFluidTeaspoons := RegisterConversionType(cbVolume,txtvuFluidTeaspoons,-1);
  555. vuDryGallons := RegisterConversionType(cbVolume,txtvuDryGallons,-1);
  556. vuDryQuarts := RegisterConversionType(cbVolume,txtvuDryQuarts,-1);
  557. vuDryPints := RegisterConversionType(cbVolume,txtvuDryPints,-1);
  558. vuDryPecks := RegisterConversionType(cbVolume,txtvuDryPecks, 0.0088097675);
  559. vuDryBuckets := RegisterConversionType(cbVolume,txtvuDryBuckets,-1);
  560. vuDryBushels := RegisterConversionType(cbVolume,txtvuDryBushels,0.03523907);
  561. vuUKGallons := RegisterConversionType(cbVolume,txtvuUKGallons,0.0045460993);
  562. vuUKPottles := RegisterConversionType(cbVolume,txtvuUKPottles,-1);
  563. vuUKQuarts := RegisterConversionType(cbVolume,txtvuUKQuarts,0.0011365248);
  564. vuUKPints := RegisterConversionType(cbVolume,txtvuUKPints,-1);
  565. vuUKGills := RegisterConversionType(cbVolume,txtvuUKGills,-1);
  566. vuUKOunces := RegisterConversionType(cbVolume,txtvuUKOunces,2.8413121E-5);
  567. vuUKPecks := RegisterConversionType(cbVolume,txtvuUKPecks,0.0090921986);
  568. vuUKBuckets := RegisterConversionType(cbVolume,txtvuUKBuckets,-1);
  569. vuUKBushels := RegisterConversionType(cbVolume,txtvuUKBushels,0.036368794);
  570. end;
  571. Procedure RegisterFamilies;
  572. Begin
  573. cbArea := RegisterConversionFamily('Area');
  574. cbDistance := RegisterConversionFamily('Distance');
  575. cbMass := RegisterConversionFamily('Mass');
  576. cbTemperature := RegisterConversionFamily('Temperature');
  577. cbTime := RegisterConversionFamily('Time');
  578. cbVolume := RegisterConversionFamily('Volume');
  579. End;
  580. Procedure RegisterAll;
  581. begin
  582. RegisterFamilies;
  583. RegisterVolumes;
  584. RegisterTimes;
  585. RegisterTemperature;
  586. Registermass;
  587. RegisterLengths;
  588. RegisterArea;
  589. end;
  590. initialization
  591. registerall;
  592. {$else}
  593. implementation
  594. {$endif}
  595. end.