本文整理匯總了Python中dipplanner.dive.Dive.do_surface_interval方法的典型用法代碼示例。如果您正苦於以下問題:Python Dive.do_surface_interval方法的具體用法?Python Dive.do_surface_interval怎麽用?Python Dive.do_surface_interval使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類dipplanner.dive.Dive
的用法示例。
在下文中一共展示了Dive.do_surface_interval方法的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: TestRepetitiveDive1
# 需要導入模塊: from dipplanner.dive import Dive [as 別名]
# 或者: from dipplanner.dive.Dive import do_surface_interval [as 別名]
class TestRepetitiveDive1(TestDive):
def setUp(self):
TestDive.setUp(self)
diveseg1 = SegmentDive(40, 20 * 60, self.airtank12, 0)
self.profile0 = Dive([diveseg1], [self.airtank12])
self.profile0.do_dive()
diveseg2 = SegmentDive(40, 20 * 60, self.airtank, 0)
self.profile1 = Dive([diveseg2], [self.airtank], self.profile0)
self.profile1.do_surface_interval(20 * 60)
self.profile1.do_dive()
def test_rt(self):
assert seconds_to_mmss(self.profile1.run_time) == ' 68:09', \
'bad dive runtime ? (%s)' \
% seconds_to_mmss(self.profile1.run_time)
def test_otu(self):
self.assertAlmostEqual(self.profile1.model.ox_tox.otu,
40.0702502936, 7, 'bad dive OTU ? (%s)'
% self.profile1.model.ox_tox.otu)
def test_cns(self):
self.assertAlmostEqual(self.profile1.model.ox_tox.cns * 100,
14.3091665925, 7, 'bad dive CNS ? (%s)'
% (self.profile1.model.ox_tox.cns * 100))
def test_tank_cons(self):
self.assertAlmostEqual(self.airtank12.used_gas, 2115.5196384,
7, 'bad used gas (%s)'
% self.airtank12.used_gas)
def test_tank_cons_rule(self):
self.assertEqual(self.profile1.tanks[0].check_rule(), True,
'Wrong tank status : it should pass the remaining '
'gas rule test (result:%s)'
% self.profile1.tanks[0].check_rule())
def test_no_flight(self):
no_flight_time = self.profile1.no_flight_time()
self.assertEqual(no_flight_time, 5460, 'Bad no flight time: %s'
% no_flight_time)
def test_no_flight_wo_exc(self):
no_flight_time = self.profile1.no_flight_time_wo_exception()
self.assertEqual(no_flight_time, 5460, 'Bad no flight time: %s'
% no_flight_time)
def test_surfaceint(self):
self.assertEqual(self.profile1.get_surface_interval(),
' 20:00',
'wrong surface interval:%s'
% self.profile1.get_surface_interval())
示例2: TestRepetitiveTxDive2
# 需要導入模塊: from dipplanner.dive import Dive [as 別名]
# 或者: from dipplanner.dive.Dive import do_surface_interval [as 別名]
class TestRepetitiveTxDive2(TestDive):
def setUp(self):
TestDive.setUp(self)
diveseg1 = SegmentDive(55, 20 * 60, self.txtank1, 0)
self.profile0 = Dive([diveseg1], [self.txtank1])
self.profile0.do_dive()
diveseg2 = SegmentDive(50, 20 * 60, self.txtank1, 0)
self.profile1 = Dive([diveseg2], [self.txtank1], self.profile0)
self.profile1.do_surface_interval(30 * 60)
self.profile1.do_dive()
diveseg3 = SegmentDive(35, 35 * 60, self.txtank1, 0)
self.profile2 = Dive([diveseg3], [self.txtank1], self.profile1)
self.profile2.do_surface_interval(60 * 60)
# self.profile2.refill_tanks()
self.profile2.do_dive()
def test_rt(self):
assert seconds_to_mmss(self.profile2.run_time) == '166:21', \
'bad dive runtime ? (%s)' \
% seconds_to_mmss(self.profile2.run_time)
def test_otu(self):
self.assertAlmostEqual(self.profile2.model.ox_tox.otu,
86.5037540773, 7, 'bad dive OTU ? (%s)'
% self.profile2.model.ox_tox.otu)
def test_cns(self):
self.assertAlmostEqual(self.profile2.model.ox_tox.cns * 100,
24.2843630006, 7, 'bad dive CNS ? (%s)'
% (self.profile2.model.ox_tox.cns * 100))
def test_tank_cons(self):
self.assertAlmostEqual(self.txtank1.used_gas, 4979.54636588, 7,
'bad used gas (%s)'
% self.txtank1.used_gas)
def test_tank_cons_rule(self):
self.assertEqual(self.profile2.tanks[0].check_rule(), True,
'Wrong tank status : it should pass the remaining '
'gas rule test (result:%s)'
% self.profile2.tanks[0].check_rule())
def test_no_flight(self):
no_flight_time = self.profile2.no_flight_time()
self.assertEqual(no_flight_time, 18960, 'Bad no flight time: %s'
% no_flight_time)
示例3: TestRepetitiveTxDive1
# 需要導入模塊: from dipplanner.dive import Dive [as 別名]
# 或者: from dipplanner.dive.Dive import do_surface_interval [as 別名]
class TestRepetitiveTxDive1(TestDive):
def setUp(self):
TestDive.setUp(self)
diveseg1 = SegmentDive(55, 20 * 60, self.txtank1, 0)
self.profile0 = Dive([diveseg1], [self.txtank1])
self.profile0.do_dive()
diveseg2 = SegmentDive(50, 20 * 60, self.txtank1, 0)
self.profile1 = Dive([diveseg2], [self.txtank1], self.profile0)
self.profile1.do_surface_interval(20 * 60)
# self.profile1.refill_tanks()
self.profile1.do_dive()
def test_rt(self):
assert seconds_to_mmss(self.profile1.run_time) == '124:44', \
'bad dive runtime ? (%s)' \
% seconds_to_mmss(self.profile1.run_time)
def test_otu(self):
self.assertAlmostEqual(self.profile1.model.ox_tox.otu,
55.5549635111, 7, 'bad dive OTU ? (%s)'
% self.profile1.model.ox_tox.otu)
def test_cns(self):
self.assertAlmostEqual(self.profile1.model.ox_tox.cns * 100,
21.1631708375, 7, 'bad dive CNS ? (%s)'
% (self.profile1.model.ox_tox.cns * 100))
def test_tank_cons(self):
self.assertAlmostEqual(self.txtank1.used_gas, 4006.7619273, 7,
'bad used gas (%s)'
% self.txtank1.used_gas)
def test_tank_cons_rule(self):
self.assertEqual(self.profile1.tanks[0].check_rule(), True,
'Wrong tank status : it should pass the remaining '
'gas rule test (result:%s)'
% self.profile1.tanks[0].check_rule())
def test_no_flight(self):
no_flight_time = self.profile1.no_flight_time()
self.assertEqual(no_flight_time, 12660, 'Bad no flight time: %s'
% no_flight_time)
示例4: TestRepetitiveTxDive3
# 需要導入模塊: from dipplanner.dive import Dive [as 別名]
# 或者: from dipplanner.dive.Dive import do_surface_interval [as 別名]
class TestRepetitiveTxDive3(TestDive):
def setUp(self):
TestDive.setUp(self)
diveseg1 = SegmentDive(55, 20 * 60, self.txtank1, 0)
self.profile0 = Dive([diveseg1], [self.txtank1])
self.profile0.do_dive()
diveseg2 = SegmentDive(50, 20 * 60, self.txtank1, 0)
self.profile1 = Dive([diveseg2], [self.txtank1], self.profile0)
self.profile1.do_surface_interval(30 * 60)
self.profile1.do_dive()
diveseg3 = SegmentDive(35, 35 * 60, self.txtank1, 0)
self.profile2 = Dive([diveseg3], [self.txtank1], self.profile1)
self.profile2.do_surface_interval(60 * 60)
# self.profile2.refill_tanks()
self.profile2.do_dive()
diveseg4 = SegmentDive(55, 20 * 60, self.txtank1, 0)
self.profile3 = Dive([diveseg4], [self.txtank1], self.profile2)
self.profile3.do_surface_interval(12 * 60 * 60)
# self.profile3.refill_tanks()
self.profile3.do_dive()
def test_rt(self):
assert seconds_to_mmss(self.profile3.run_time) == ' 72:40', \
'bad dive runtime ? (%s)' \
% seconds_to_mmss(self.profile3.run_time)
def test_otu(self):
self.assertAlmostEqual(self.profile3.model.ox_tox.otu,
115.825853006, 7, 'bad dive OTU ? (%s)'
% self.profile3.model.ox_tox.otu)
def test_cns(self):
self.assertAlmostEqual(self.profile3.model.ox_tox.cns * 100,
12.6208702934, 7, 'bad dive CNS ? (%s)'
% (self.profile3.model.ox_tox.cns * 100))
def test_tank_cons(self):
self.assertAlmostEqual(self.txtank1.used_gas, 3350.41341833, 7,
'bad used gas (%s)'
% self.txtank1.used_gas)
def test_tank_cons_rule(self):
self.assertEqual(self.profile3.tanks[0].check_rule(), True,
'Wrong tank status : it should pass the remaining '
'gas rule test (result:%s)'
% self.profile2.tanks[0].check_rule())
def test_no_flight(self):
no_flight_time = self.profile3.no_flight_time()
self.assertEqual(no_flight_time, 7380, 'Bad no flight time: %s'
% no_flight_time)
示例5: main
# 需要導入模塊: from dipplanner.dive import Dive [as 別名]
# 或者: from dipplanner.dive.Dive import do_surface_interval [as 別名]
def main(cli_arguments=None):
"""Main entry point.
main uses the parameters, tanks and dives given in config file(s)
and/or command line, calculates the dives and return the output in stdout.
:param list cli_arguments: list of arguments, like sys.argv
"""
if sys.version_info < (3, 4):
raise SystemExit("ERROR: This programm needs python 3.4 or greater")
if cli_arguments is None:
cli_arguments = sys.argv
activate_debug()
# get the version
try:
version_file = open("RELEASE-VERSION", "r")
try:
version = version_file.readlines()[0]
settings.__VERSION__ = version.strip()
finally:
version_file.close()
except IOError:
settings.__VERSION__ = "unknown"
dipplanner_arguments = DipplannerCliArguments(cli_arguments)
dives = dipplanner_arguments.dives
profiles = []
current_dive = None
previous_dive = None
for dive in dives:
if previous_dive is None:
current_dive = Dive(
dives[dive]['segments'].values(),
dives[dive]['tanks'].values())
else:
current_dive = Dive(
dives[dive]['segments'].values(),
dives[dive]['tanks'].values(),
previous_dive
)
if dives[dive]['surface_interval']:
current_dive.do_surface_interval(dives[dive]['surface_interval'])
current_dive.do_dive_without_exceptions()
profiles.append(current_dive)
previous_dive = current_dive
# now, dive exceptins do not stop the program anymore, but can be
# displayed in the output template instead. The used MUST take care of
# the result.
# now calculate no flight time based on the last dive
######current_dive.no_flight_time_wo_exception()
# now Prepare the output
env = Environment(loader=PackageLoader('dipplanner', 'templates'))
tpl = env.get_template(settings.TEMPLATE)
# pylint: disable=no-member
text = tpl.render(settings=settings, dives=profiles)
# pylint: enable=no-member
print(text)
示例6: TestRepetitiveDive3
# 需要導入模塊: from dipplanner.dive import Dive [as 別名]
# 或者: from dipplanner.dive.Dive import do_surface_interval [as 別名]
class TestRepetitiveDive3(TestDive):
def setUp(self):
TestDive.setUp(self)
diveseg1 = SegmentDive(40, 20 * 60, self.airtank12, 0)
self.profile0 = Dive([diveseg1], [self.airtank12])
self.profile0.do_dive()
diveseg2 = SegmentDive(30, 40 * 60, self.airtank, 0)
self.profile1 = Dive([diveseg2], [self.airtank], self.profile0)
self.profile1.do_surface_interval(30 * 60)
self.profile1.do_dive()
diveseg3 = SegmentDive(25, 35 * 60, self.airtank, 0)
self.profile2 = Dive([diveseg3], [self.airtank], self.profile1)
self.profile2.do_surface_interval(60 * 60)
# self.profile2.refill_tanks()
self.profile2.do_dive()
diveseg4 = SegmentDive(40, 20 * 60, self.airtank, 0)
self.profile3 = Dive([diveseg4], [self.airtank], self.profile2)
self.profile3.do_surface_interval(12 * 60 * 60)
# self.profile3.refill_tanks()
self.profile3.do_dive()
def test_rt(self):
assert seconds_to_mmss(self.profile3.run_time) == ' 38:36', \
'bad dive runtime ? (%s)' \
% seconds_to_mmss(self.profile3.run_time)
def test_otu(self):
self.assertAlmostEqual(self.profile3.model.ox_tox.otu,
86.8657204829, 7, 'bad dive OTU ? (%s)'
% self.profile3.model.ox_tox.otu)
def test_cns(self):
self.assertAlmostEqual(self.profile3.model.ox_tox.cns * 100,
7.75546902304, 7, 'bad dive CNS ? (%s)'
% (self.profile3.model.ox_tox.cns * 100))
def test_tank_cons(self):
self.assertAlmostEqual(self.airtank.used_gas, 2115.5196384, 7,
'bad used gas (%s)'
% self.airtank.used_gas)
def test_tank_cons_rule(self):
self.assertEqual(self.profile3.tanks[0].check_rule(), True,
'Wrong tank status : it should pass the remaining '
'gas rule test (result:%s)'
% self.profile2.tanks[0].check_rule())
def test_no_flight(self):
no_flight_time = self.profile3.no_flight_time()
self.assertEqual(no_flight_time, 1620, 'Bad no flight time: %s'
% no_flight_time)
def test_no_flight_wo_exc(self):
no_flight_time = self.profile3.no_flight_time_wo_exception()
self.assertEqual(no_flight_time, 1620, 'Bad no flight time: %s'
% no_flight_time)
def test_surfaceint(self):
self.assertEqual(self.profile3.get_surface_interval(),
'720:00',
'wrong surface interval:%s'
% self.profile3.get_surface_interval())
示例7: TestRepetitiveDive2
# 需要導入模塊: from dipplanner.dive import Dive [as 別名]
# 或者: from dipplanner.dive.Dive import do_surface_interval [as 別名]
class TestRepetitiveDive2(TestDive):
def setUp(self):
TestDive.setUp(self)
diveseg1 = SegmentDive(40, 20 * 60, self.airtank12, 0)
self.profile0 = Dive([diveseg1], [self.airtank12])
self.profile0.do_dive()
diveseg2 = SegmentDive(30, 40 * 60, self.airtank, 0)
self.profile1 = Dive([diveseg2], [self.airtank], self.profile0)
self.profile1.do_surface_interval(30 * 60)
self.profile1.do_dive()
diveseg3 = SegmentDive(25, 35 * 60, self.airtank, 0)
self.profile2 = Dive([diveseg3], [self.airtank], self.profile1)
self.profile2.do_surface_interval(60 * 60)
# self.profile2.refill_tanks()
self.profile2.do_dive()
def test_rt(self):
assert seconds_to_mmss(self.profile2.run_time) == ' 70:18', \
'bad dive runtime ? (%s)' \
% seconds_to_mmss(self.profile2.run_time)
def test_otu(self):
self.assertAlmostEqual(self.profile2.model.ox_tox.otu,
66.8427163401, 7, 'bad dive OTU ? (%s)'
% self.profile2.model.ox_tox.otu)
def test_cns(self):
self.assertAlmostEqual(self.profile2.model.ox_tox.cns * 100,
18.1490350581, 7, 'bad dive CNS ? (%s)'
% (self.profile2.model.ox_tox.cns * 100))
def test_tank_cons(self):
self.assertAlmostEqual(self.airtank.used_gas, 2701.73162947, 7,
'bad used gas (%s)'
% self.airtank.used_gas)
def test_tank_cons_rule(self):
self.assertEqual(self.profile2.tanks[0].check_rule(), True,
'Wrong tank status : it should pass the remaining '
'gas rule test (result:%s)'
% self.profile2.tanks[0].check_rule())
def test_no_flight(self):
no_flight_time = self.profile2.no_flight_time()
self.assertEqual(no_flight_time, 18360, 'Bad no flight time: %s'
% no_flight_time)
def test_no_flight_wo_exc(self):
no_flight_time = self.profile2.no_flight_time_wo_exception()
self.assertEqual(no_flight_time, 18360, 'Bad no flight time: %s'
% no_flight_time)
def test_surfaceint(self):
self.assertEqual(self.profile2.get_surface_interval(),
' 60:00',
'wrong surface interval:%s'
% self.profile2.get_surface_interval())