stdconvs.pp 26 KB

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