本文整理匯總了Python中neo.core.analogsignal.AnalogSignal.copy方法的典型用法代碼示例。如果您正苦於以下問題:Python AnalogSignal.copy方法的具體用法?Python AnalogSignal.copy怎麽用?Python AnalogSignal.copy使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類neo.core.analogsignal.AnalogSignal
的用法示例。
在下文中一共展示了AnalogSignal.copy方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: TestAnalogSignalArrayMethods
# 需要導入模塊: from neo.core.analogsignal import AnalogSignal [as 別名]
# 或者: from neo.core.analogsignal.AnalogSignal import copy [as 別名]
class TestAnalogSignalArrayMethods(unittest.TestCase):
def setUp(self):
self.data1 = np.arange(10.0)
self.data1quant = self.data1 * pq.nA
self.signal1 = AnalogSignal(self.data1quant, sampling_rate=1*pq.kHz,
name='spam', description='eggs',
file_origin='testfile.txt', arg1='test')
self.signal1.segment = Segment()
self.signal1.channel_index = ChannelIndex(index=[0])
def test__compliant(self):
assert_neo_object_is_compliant(self.signal1)
def test__slice_should_return_AnalogSignalArray(self):
# slice
for index in (0, np.int64(0)):
result = self.signal1[3:8, index]
self.assertIsInstance(result, AnalogSignal)
assert_neo_object_is_compliant(result)
self.assertEqual(result.name, 'spam') # should slicing really preserve name and description?
self.assertEqual(result.description, 'eggs') # perhaps these should be modified to indicate the slice?
self.assertEqual(result.file_origin, 'testfile.txt')
self.assertEqual(result.annotations, {'arg1': 'test'})
self.assertEqual(result.size, 5)
self.assertEqual(result.sampling_period, self.signal1.sampling_period)
self.assertEqual(result.sampling_rate, self.signal1.sampling_rate)
self.assertEqual(result.t_start,
self.signal1.t_start+3*result.sampling_period)
self.assertEqual(result.t_stop,
result.t_start + 5*result.sampling_period)
assert_array_equal(result.magnitude, self.data1[3:8].reshape(-1, 1))
# Test other attributes were copied over (in this case, defaults)
self.assertEqual(result.file_origin, self.signal1.file_origin)
self.assertEqual(result.name, self.signal1.name)
self.assertEqual(result.description, self.signal1.description)
self.assertEqual(result.annotations, self.signal1.annotations)
def test__slice_should_let_access_to_parents_objects(self):
result = self.signal1.time_slice(1*pq.ms,3*pq.ms)
self.assertEqual(result.segment, self.signal1.segment)
self.assertEqual(result.channel_index, self.signal1.channel_index)
def test__slice_should_change_sampling_period(self):
result1 = self.signal1[:2, 0]
result2 = self.signal1[::2, 0]
result3 = self.signal1[1:7:2, 0]
self.assertIsInstance(result1, AnalogSignal)
assert_neo_object_is_compliant(result1)
self.assertEqual(result1.name, 'spam')
self.assertEqual(result1.description, 'eggs')
self.assertEqual(result1.file_origin, 'testfile.txt')
self.assertEqual(result1.annotations, {'arg1': 'test'})
self.assertIsInstance(result2, AnalogSignal)
assert_neo_object_is_compliant(result2)
self.assertEqual(result2.name, 'spam')
self.assertEqual(result2.description, 'eggs')
self.assertEqual(result2.file_origin, 'testfile.txt')
self.assertEqual(result2.annotations, {'arg1': 'test'})
self.assertIsInstance(result3, AnalogSignal)
assert_neo_object_is_compliant(result3)
self.assertEqual(result3.name, 'spam')
self.assertEqual(result3.description, 'eggs')
self.assertEqual(result3.file_origin, 'testfile.txt')
self.assertEqual(result3.annotations, {'arg1': 'test'})
self.assertEqual(result1.sampling_period, self.signal1.sampling_period)
self.assertEqual(result2.sampling_period,
self.signal1.sampling_period * 2)
self.assertEqual(result3.sampling_period,
self.signal1.sampling_period * 2)
assert_array_equal(result1.magnitude, self.data1[:2].reshape(-1, 1))
assert_array_equal(result2.magnitude, self.data1[::2].reshape(-1, 1))
assert_array_equal(result3.magnitude, self.data1[1:7:2].reshape(-1, 1))
def test__slice_should_modify_linked_channelindex(self):
n = 8 # number of channels
signal = AnalogSignal(np.arange(n * 100.0).reshape(100, n),
sampling_rate=1*pq.kHz,
units="mV",
name="test")
self.assertEqual(signal.shape, (100, n))
signal.channel_index = ChannelIndex(index=np.arange(n, dtype=int),
channel_names=["channel{0}".format(i) for i in range(n)])
signal.channel_index.analogsignals.append(signal)
odd_channels = signal[:, 1::2]
self.assertEqual(odd_channels.shape, (100, n//2))
assert_array_equal(odd_channels.channel_index.index, np.arange(n//2, dtype=int))
assert_array_equal(odd_channels.channel_index.channel_names, ["channel{0}".format(i) for i in range(1, n, 2)])
assert_array_equal(signal.channel_index.channel_names, ["channel{0}".format(i) for i in range(n)])
self.assertEqual(odd_channels.channel_index.analogsignals[0].name, signal.name)
def test__copy_should_let_access_to_parents_objects(self):
result = self.signal1.copy()
self.assertIs(result.segment, self.signal1.segment)
#.........這裏部分代碼省略.........
示例2: TestAnalogSignalArrayMethods
# 需要導入模塊: from neo.core.analogsignal import AnalogSignal [as 別名]
# 或者: from neo.core.analogsignal.AnalogSignal import copy [as 別名]
#.........這裏部分代碼省略.........
self.assertIsInstance(result1, AnalogSignal)
assert_neo_object_is_compliant(result1)
self.assertEqual(result1.name, 'spam')
self.assertEqual(result1.description, 'eggs')
self.assertEqual(result1.file_origin, 'testfile.txt')
self.assertEqual(result1.annotations, {'arg1': 'test'})
self.assertIsInstance(result2, AnalogSignal)
assert_neo_object_is_compliant(result2)
self.assertEqual(result2.name, 'spam')
self.assertEqual(result2.description, 'eggs')
self.assertEqual(result2.file_origin, 'testfile.txt')
self.assertEqual(result2.annotations, {'arg1': 'test'})
self.assertIsInstance(result3, AnalogSignal)
assert_neo_object_is_compliant(result3)
self.assertEqual(result3.name, 'spam')
self.assertEqual(result3.description, 'eggs')
self.assertEqual(result3.file_origin, 'testfile.txt')
self.assertEqual(result3.annotations, {'arg1': 'test'})
self.assertEqual(result1.sampling_period, self.signal1.sampling_period)
self.assertEqual(result2.sampling_period,
self.signal1.sampling_period * 2)
self.assertEqual(result3.sampling_period,
self.signal1.sampling_period * 2)
assert_arrays_equal(result1, self.data1[:2])
assert_arrays_equal(result2, self.data1[::2])
assert_arrays_equal(result3, self.data1[1:7:2])
def test__getitem_should_return_single_quantity(self):
result1 = self.signal1[0]
result2 = self.signal1[9]
self.assertIsInstance(result1, pq.Quantity)
self.assertFalse(hasattr(result1, 'name'))
self.assertFalse(hasattr(result1, 'description'))
self.assertFalse(hasattr(result1, 'file_origin'))
self.assertFalse(hasattr(result1, 'annotations'))
self.assertIsInstance(result2, pq.Quantity)
self.assertFalse(hasattr(result2, 'name'))
self.assertFalse(hasattr(result2, 'description'))
self.assertFalse(hasattr(result2, 'file_origin'))
self.assertFalse(hasattr(result2, 'annotations'))
self.assertEqual(result1, 0*pq.nA)
self.assertEqual(result2, 9*pq.nA)
def test__getitem_out_of_bounds_IndexError(self):
self.assertRaises(IndexError, self.signal1.__getitem__, 10)
def test_comparison_operators(self):
assert_arrays_equal(self.signal1 >= 5*pq.nA,
np.array([False, False, False, False, False,
True, True, True, True, True]))
assert_arrays_equal(self.signal1 >= 5*pq.pA,
np.array([False, True, True, True, True,
True, True, True, True, True]))
def test__comparison_with_inconsistent_units_should_raise_Exception(self):
self.assertRaises(ValueError, self.signal1.__gt__, 5*pq.mV)
def test__simple_statistics(self):
self.assertEqual(self.signal1.max(), 9*pq.nA)
self.assertEqual(self.signal1.min(), 0*pq.nA)
self.assertEqual(self.signal1.mean(), 4.5*pq.nA)
def test__rescale_same(self):
result = self.signal1.copy()
result = result.rescale(pq.nA)
self.assertIsInstance(result, AnalogSignal)
assert_neo_object_is_compliant(result)
self.assertEqual(result.name, 'spam')
self.assertEqual(result.description, 'eggs')
self.assertEqual(result.file_origin, 'testfile.txt')
self.assertEqual(result.annotations, {'arg1': 'test'})
self.assertEqual(result.units, 1*pq.nA)
assert_arrays_equal(result, self.data1)
assert_same_sub_schema(result, self.signal1)
def test__rescale_new(self):
result = self.signal1.copy()
result = result.rescale(pq.pA)
self.assertIsInstance(result, AnalogSignal)
assert_neo_object_is_compliant(result)
self.assertEqual(result.name, 'spam')
self.assertEqual(result.description, 'eggs')
self.assertEqual(result.file_origin, 'testfile.txt')
self.assertEqual(result.annotations, {'arg1': 'test'})
self.assertEqual(result.units, 1*pq.pA)
assert_arrays_almost_equal(np.array(result), self.data1*1000., 1e-10)
def test__rescale_new_incompatible_ValueError(self):
self.assertRaises(ValueError, self.signal1.rescale, pq.mV)
示例3: TestAnalogSignalArrayArrayMethods
# 需要導入模塊: from neo.core.analogsignal import AnalogSignal [as 別名]
# 或者: from neo.core.analogsignal.AnalogSignal import copy [as 別名]
#.........這裏部分代碼省略.........
self.assertEqual(result.t_start, self.signal1.t_start + 2 * self.signal1.sampling_period)
self.assertEqual(result.t_stop, self.signal1.t_start + 7 * self.signal1.sampling_period)
self.assertEqual(result.sampling_rate, self.signal1.sampling_rate)
assert_arrays_equal(result, self.data1[2:7])
def test__getitem_should_return_single_quantity(self):
# quantities drops the units in this case
self.assertEqual(self.signal1[9, 3], 48000 * pq.pA)
self.assertEqual(self.signal1[9][3], self.signal1[9, 3])
self.assertTrue(hasattr(self.signal1[9, 3], 'units'))
self.assertRaises(IndexError, self.signal1.__getitem__, (99, 73))
def test_comparison_operators(self):
assert_arrays_equal(self.signal1[0:3, 0:3] >= 5 * pq.nA, np.array(
[[False, False, False], [True, True, True], [True, True, True]]))
assert_arrays_equal(self.signal1[0:3, 0:3] >= 5 * pq.pA, np.array(
[[False, True, True], [True, True, True], [True, True, True]]))
assert_arrays_equal(self.signal1[0:3, 0:3] == 5 * pq.nA, np.array(
[[False, False, False], [True, False, False], [False, False, False]]))
assert_arrays_equal(self.signal1[0:3, 0:3] == self.signal1[0:3, 0:3],
np.array([[True, True, True], [True, True, True], [True, True, True]]))
def test__comparison_with_inconsistent_units_should_raise_Exception(self):
self.assertRaises(ValueError, self.signal1.__gt__, 5 * pq.mV)
def test__simple_statistics(self):
self.assertEqual(self.signal1.max(), 54000 * pq.pA)
self.assertEqual(self.signal1.min(), 0 * pq.nA)
self.assertEqual(self.signal1.mean(), 27 * pq.nA)
self.assertEqual(self.signal1.std(), self.signal1.magnitude.std() * pq.nA)
self.assertEqual(self.signal1.var(), self.signal1.magnitude.var() * pq.nA ** 2)
def test__rescale_same(self):
result = self.signal1.copy()
result = result.rescale(pq.nA)
self.assertIsInstance(result, AnalogSignal)
assert_neo_object_is_compliant(result)
self.assertEqual(result.name, 'spam')
self.assertEqual(result.description, 'eggs')
self.assertEqual(result.file_origin, 'testfile.txt')
self.assertEqual(result.annotations, {'arg1': 'test'})
assert_arrays_equal(result.array_annotations['anno1'], np.arange(5))
assert_arrays_equal(result.array_annotations['anno2'], np.array(['a', 'b', 'c', 'd', 'e']))
self.assertIsInstance(result.array_annotations, ArrayDict)
self.assertEqual(result.units, 1 * pq.nA)
assert_arrays_equal(result, self.data1)
assert_same_sub_schema(result, self.signal1)
def test__rescale_new(self):
result = self.signal1.copy()
result = result.rescale(pq.pA)
self.assertIsInstance(result, AnalogSignal)
assert_neo_object_is_compliant(result)
self.assertEqual(result.name, 'spam')
self.assertEqual(result.description, 'eggs')
self.assertEqual(result.file_origin, 'testfile.txt')
self.assertEqual(result.annotations, {'arg1': 'test'})
assert_arrays_equal(result.array_annotations['anno1'], np.arange(5))
assert_arrays_equal(result.array_annotations['anno2'], np.array(['a', 'b', 'c', 'd', 'e']))
self.assertIsInstance(result.array_annotations, ArrayDict)
self.assertEqual(result.units, 1 * pq.pA)
assert_arrays_almost_equal(np.array(result), self.data1 * 1000., 1e-10)
示例4: TestAnalogSignalArrayMethods
# 需要導入模塊: from neo.core.analogsignal import AnalogSignal [as 別名]
# 或者: from neo.core.analogsignal.AnalogSignal import copy [as 別名]
#.........這裏部分代碼省略.........
self.assertEqual(result3.name, 'spam')
self.assertEqual(result3.description, 'eggs')
self.assertEqual(result3.file_origin, 'testfile.txt')
self.assertEqual(result3.annotations, {'arg1': 'test'})
self.assertEqual(result3.array_annotations, {'anno1': [23], 'anno2': ['A']})
self.assertIsInstance(result3.array_annotations, ArrayDict)
self.assertEqual(result1.sampling_period, self.signal1.sampling_period)
self.assertEqual(result2.sampling_period, self.signal1.sampling_period * 2)
self.assertEqual(result3.sampling_period, self.signal1.sampling_period * 2)
assert_array_equal(result1.magnitude, self.data1[:2].reshape(-1, 1))
assert_array_equal(result2.magnitude, self.data1[::2].reshape(-1, 1))
assert_array_equal(result3.magnitude, self.data1[1:7:2].reshape(-1, 1))
def test__slice_should_modify_linked_channelindex(self):
n = 8 # number of channels
signal = AnalogSignal(np.arange(n * 100.0).reshape(100, n), sampling_rate=1 * pq.kHz,
units="mV", name="test")
self.assertEqual(signal.shape, (100, n))
signal.channel_index = ChannelIndex(index=np.arange(n, dtype=int),
channel_names=["channel{0}".format(i) for i in
range(n)])
signal.channel_index.analogsignals.append(signal)
odd_channels = signal[:, 1::2]
self.assertEqual(odd_channels.shape, (100, n // 2))
assert_array_equal(odd_channels.channel_index.index, np.arange(n // 2, dtype=int))
assert_array_equal(odd_channels.channel_index.channel_names,
["channel{0}".format(i) for i in range(1, n, 2)])
assert_array_equal(signal.channel_index.channel_names,
["channel{0}".format(i) for i in range(n)])
self.assertEqual(odd_channels.channel_index.analogsignals[0].name, signal.name)
def test__copy_should_let_access_to_parents_objects(self):
result = self.signal1.copy()
self.assertIs(result.segment, self.signal1.segment)
self.assertIs(result.channel_index, self.signal1.channel_index)
def test__deepcopy_should_let_access_to_parents_objects(self):
result = copy.deepcopy(self.signal1)
self.assertIsInstance(result.segment, Segment)
self.assertIsInstance(result.channel_index, ChannelIndex)
assert_same_sub_schema(result.segment, self.signal1.segment)
assert_same_sub_schema(result.channel_index, self.signal1.channel_index)
def test__getitem_should_return_single_quantity(self):
result1 = self.signal1[0, 0]
result2 = self.signal1[9, 0]
self.assertIsInstance(result1, pq.Quantity)
self.assertFalse(hasattr(result1, 'name'))
self.assertFalse(hasattr(result1, 'description'))
self.assertFalse(hasattr(result1, 'file_origin'))
self.assertFalse(hasattr(result1, 'annotations'))
self.assertFalse(hasattr(result1, 'array_annotations'))
self.assertIsInstance(result2, pq.Quantity)
self.assertFalse(hasattr(result2, 'name'))
self.assertFalse(hasattr(result2, 'description'))
self.assertFalse(hasattr(result2, 'file_origin'))
self.assertFalse(hasattr(result2, 'annotations'))
self.assertFalse(hasattr(result2, 'array_annotations'))
self.assertEqual(result1, 0 * pq.nA)
self.assertEqual(result2, 9 * pq.nA)
示例5: TestAnalogSignalArrayMethods
# 需要導入模塊: from neo.core.analogsignal import AnalogSignal [as 別名]
# 或者: from neo.core.analogsignal.AnalogSignal import copy [as 別名]
class TestAnalogSignalArrayMethods(unittest.TestCase):
def setUp(self):
self.data1 = np.arange(10.0)
self.data1quant = self.data1 * pq.nA
self.signal1 = AnalogSignal(self.data1quant, sampling_rate=1*pq.kHz,
name='spam', description='eggs',
file_origin='testfile.txt', arg1='test')
self.signal1.segment = 1
self.signal1.channel_index = ChannelIndex(index=[0])
def test__compliant(self):
assert_neo_object_is_compliant(self.signal1)
def test__slice_should_return_AnalogSignalArray(self):
# slice
result = self.signal1[3:8, 0]
self.assertIsInstance(result, AnalogSignal)
assert_neo_object_is_compliant(result)
self.assertEqual(result.name, 'spam') # should slicing really preserve name and description?
self.assertEqual(result.description, 'eggs') # perhaps these should be modified to indicate the slice?
self.assertEqual(result.file_origin, 'testfile.txt')
self.assertEqual(result.annotations, {'arg1': 'test'})
self.assertEqual(result.size, 5)
self.assertEqual(result.sampling_period, self.signal1.sampling_period)
self.assertEqual(result.sampling_rate, self.signal1.sampling_rate)
self.assertEqual(result.t_start,
self.signal1.t_start+3*result.sampling_period)
self.assertEqual(result.t_stop,
result.t_start + 5*result.sampling_period)
assert_array_equal(result.magnitude, self.data1[3:8].reshape(-1, 1))
# Test other attributes were copied over (in this case, defaults)
self.assertEqual(result.file_origin, self.signal1.file_origin)
self.assertEqual(result.name, self.signal1.name)
self.assertEqual(result.description, self.signal1.description)
self.assertEqual(result.annotations, self.signal1.annotations)
def test__slice_should_let_access_to_parents_objects(self):
result = self.signal1.time_slice(1*pq.ms,3*pq.ms)
self.assertEqual(result.segment, self.signal1.segment)
self.assertEqual(result.channel_index, self.signal1.channel_index)
def test__slice_should_change_sampling_period(self):
result1 = self.signal1[:2, 0]
result2 = self.signal1[::2, 0]
result3 = self.signal1[1:7:2, 0]
self.assertIsInstance(result1, AnalogSignal)
assert_neo_object_is_compliant(result1)
self.assertEqual(result1.name, 'spam')
self.assertEqual(result1.description, 'eggs')
self.assertEqual(result1.file_origin, 'testfile.txt')
self.assertEqual(result1.annotations, {'arg1': 'test'})
self.assertIsInstance(result2, AnalogSignal)
assert_neo_object_is_compliant(result2)
self.assertEqual(result2.name, 'spam')
self.assertEqual(result2.description, 'eggs')
self.assertEqual(result2.file_origin, 'testfile.txt')
self.assertEqual(result2.annotations, {'arg1': 'test'})
self.assertIsInstance(result3, AnalogSignal)
assert_neo_object_is_compliant(result3)
self.assertEqual(result3.name, 'spam')
self.assertEqual(result3.description, 'eggs')
self.assertEqual(result3.file_origin, 'testfile.txt')
self.assertEqual(result3.annotations, {'arg1': 'test'})
self.assertEqual(result1.sampling_period, self.signal1.sampling_period)
self.assertEqual(result2.sampling_period,
self.signal1.sampling_period * 2)
self.assertEqual(result3.sampling_period,
self.signal1.sampling_period * 2)
assert_array_equal(result1.magnitude, self.data1[:2].reshape(-1, 1))
assert_array_equal(result2.magnitude, self.data1[::2].reshape(-1, 1))
assert_array_equal(result3.magnitude, self.data1[1:7:2].reshape(-1, 1))
def test__slice_should_modify_linked_channelindex(self):
n = 8 # number of channels
signal = AnalogSignal(np.arange(n * 100.0).reshape(100, n),
sampling_rate=1*pq.kHz,
units="mV")
self.assertEqual(signal.shape, (100, n))
signal.channel_index = ChannelIndex(index=np.arange(n, dtype=int),
channel_names=["channel{0}".format(i) for i in range(n)])
odd_channels = signal[:, 1::2]
self.assertEqual(odd_channels.shape, (100, n//2))
assert_array_equal(odd_channels.channel_index.index, np.arange(n//2, dtype=int))
assert_array_equal(odd_channels.channel_index.channel_names, ["channel{0}".format(i) for i in range(1, n, 2)])
assert_array_equal(signal.channel_index.channel_names, ["channel{0}".format(i) for i in range(n)])
def test__copy_should_let_access_to_parents_objects(self):
##copy
result = self.signal1.copy()
self.assertEqual(result.segment, self.signal1.segment)
self.assertEqual(result.channel_index, self.signal1.channel_index)
## deep copy (not fixed yet)
#result = copy.deepcopy(self.signal1)
#.........這裏部分代碼省略.........