forked from perabrahamsen/daisy-model
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbdconv.C
executable file
·71 lines (63 loc) · 2.05 KB
/
bdconv.C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
// bdconv.C -- Bulk density convertion for select models.
//
// Copyright 2008 Per Abrahamsen and KVL.
//
// This file is part of Daisy.
//
// Daisy is free software; you can redistribute it and/or modify
// it under the terms of the GNU Lesser Public License as published by
// the Free Software Foundation; either version 2.1 of the License, or
// (at your option) any later version.
//
// Daisy is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Lesser Public License for more details.
//
// You should have received a copy of the GNU Lesser Public License
// along with Daisy; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#define BUILD_DLL
#include "bdconv.h"
#include "geometry.h"
#include "soil.h"
#include "volume.h"
#include "units.h"
#include "assertion.h"
#include "mathlib.h"
#include <sstream>
double
BD_convert::operator()(double value) const
{
#if 0
if (!std::isnormal (value))
return 0.0;
std::ostringstream tmp;
tmp << "value = " << value << ", bulk = " << bulk
<< ", in (value) = " << in (value) << ", in (value) / bulk = "
<< in (value) / bulk << ", result = " << out (in (value) / bulk);
Assertion::message (tmp.str ());
#endif
daisy_assert (bulk > 0.0);
return out (in (value) / bulk);
}
bool
BD_convert::valid (double value) const
{
daisy_assert (bulk > 0.0);
return in.valid (value) && out.valid (in (value) / bulk);
}
BD_convert::BD_convert (const Units& units, const symbol has, const symbol want,
const symbol bulk_unit)
: in (units.get_convertion (has, bulk_unit)),
out (units.get_convertion (Units::dry_soil_fraction (), want)),
bulk (-42.42e42)
{
#if 0
std::ostringstream tmp;
tmp << "has = " << has << ", bulk_unit = " << bulk_unit
<< ", dsf = " << Units::dry_soil_fraction () << ", want = " << want;
Assertion::message (tmp.str ());
#endif
}
// bdconv.C ends here.