Skip to content

Commit 8bce1ae

Browse files
author
Eloy Parra Barrero
committed
published on eLife
1 parent cadbae0 commit 8bce1ae

24 files changed

+746
-248
lines changed

analyze/batch_analyses.py

+4-4
Original file line numberDiff line numberDiff line change
@@ -12,10 +12,10 @@
1212

1313
def analyze(session, group_name):
1414

15-
if group_name == experimental_group_name:
16-
tracking = initialize((Tracking,), session, group_name)['Tracking']
17-
run_tracking(tracking)
18-
del tracking
15+
# if group_name == experimental_group_name:
16+
# tracking = initialize((Tracking,), session, group_name)['Tracking']
17+
# run_tracking(tracking)
18+
# del tracking
1919

2020
# place field sizes and skews
2121
firing_fields = initialize((FiringFields,), session, group_name)['FiringFields']

analyze/batch_config.py

+21-17
Original file line numberDiff line numberDiff line change
@@ -4,20 +4,20 @@
44

55
# select which sessions to analyze
66
sessions = [
7-
"ec013.156",
8-
"ec013.206",
9-
"ec013.374",
10-
"ec013.386",
11-
"ec013.388",
12-
"ec013.395",
13-
"ec013.412",
14-
"ec013.413",
15-
"ec013.440",
16-
"ec013.454",
17-
"ec013.466",
18-
"ec013.469",
19-
"ec013.502",
20-
"ec013.531",
7+
# "ec013.156",
8+
# "ec013.206",
9+
# "ec013.374",
10+
# "ec013.386",
11+
# "ec013.388",
12+
# "ec013.395",
13+
# "ec013.412",
14+
# "ec013.413",
15+
# "ec013.440",
16+
# "ec013.454",
17+
# "ec013.466",
18+
# "ec013.469",
19+
# "ec013.502",
20+
# "ec013.531",
2121
# only these three sessions were used in the models for ec013:
2222
"ec013.555",
2323
"ec013.556",
@@ -56,11 +56,15 @@
5656

5757
# select what to analyze: experimental data and/or models
5858
group_names = [
59-
experimental_group_name, # experimental data
59+
# experimental_group_name, # experimental data
6060
# 'Time', # temporal sweep model
6161
# 'Position', # spatial sweep model
62-
# 'SpeedDep57', # behavior-dependent sweep model
63-
# 'VariableNoise' # variable noise model
62+
# 'SpeedDepVanilla' # behavior-dependent sweep model
63+
64+
# 'VariableNoise' # variable noise model with extra variance
65+
'VariableNoiseVanilla' #
66+
67+
# 'SpeedDep57', # behavior-dependent sweep model with extra variance
6468
]
6569

6670
figures_path = f"{figures_path}/ALL"

analyze/batch_plots.py

+188-80
Large diffs are not rendered by default.

analyze/config.py

+1-1
Original file line numberDiff line numberDiff line change
@@ -58,7 +58,7 @@
5858
font_size = 7
5959
line_width = 1
6060

61-
thin_line_width = 0.5
61+
thin_line_width = 0.75 # 0.5
6262

6363
plt.rcParams.update({'font.family': 'sans-serif', 'font.sans-serif': 'Arial',
6464
'font.size': font_size, 'mathtext.default': 'regular', 'axes.linewidth': thin_line_width,

analyze/demo_BD_sweep.py

+32-12
Original file line numberDiff line numberDiff line change
@@ -44,10 +44,12 @@
4444
fig, ax = plt.subplots(1, 2, sharey='row', gridspec_kw={'width_ratios': [1, 0.2]}, figsize=(6.5*cm, 6*cm))
4545
ax[0].set_visible(False)
4646
# ax[1].invert_xaxis()
47-
ax[1].axis('off')
48-
ax[1].set_xlim([-0.25, 1.05])
49-
rect = plt.Rectangle((-0.2, bottom), 0.2, top - bottom, facecolor='whitesmoke')
50-
ax[1].add_patch(rect)
47+
# ax[1].axis('off')
48+
for spine in ['top', 'bottom', 'right']:
49+
ax[1].spines[spine].set_visible(False)
50+
ax[1].set_xlim([0, 1.2])
51+
# rect = plt.Rectangle((-0.2, bottom), 0.2, top - bottom, facecolor='whitesmoke')
52+
# ax[1].add_patch(rect)
5153
ax[1].set_ylim([bottom, top])
5254
ax[1].set_xlabel("Firing\nrate")
5355

@@ -122,8 +124,8 @@ def add_inset(left, bottom, width, height, x_label=None, y_label=None):
122124

123125
# FIRING FIELDS FROM THE MODEL
124126
super_group_name = "BDSweepDemo"
125-
group_name = "BDSweepDemo"
126-
t_sim = 300
127+
group_name = "BDSweepDemoRevision"
128+
t_sim = 1400
127129

128130
# LFP
129131
p = general_parameters['LFP']
@@ -158,9 +160,9 @@ def add_inset(left, bottom, width, height, x_label=None, y_label=None):
158160

159161
# Model Spikes
160162
p = general_parameters[f'SpeedSpikes|{group_name}']
161-
num_cells = 6
163+
num_cells = 2
162164
# field_centers = [c - bottom + 100 for c in [138, 150, 162, 238, 250, 262]]
163-
field_centers = [138, 150, 162, 238, 250, 262]
165+
field_centers = [150, 250]
164166

165167
model_spikes = SpeedSpikes(super_group_name, group_name, "Spikes", lfp, tracking, num_cells, p["ds"], p["dt"],
166168
p["phase_range"], p["phase_current"], p["firing_rate_0"], p["firing_rate_slope"],
@@ -173,13 +175,31 @@ def add_inset(left, bottom, width, height, x_label=None, y_label=None):
173175
p = general_parameters['FiringFields']
174176
firing_fields = FiringFields(super_group_name, group_name, "FiringFields", model_spikes.spikes, tracking,
175177
p['firing_rate_sigma'], p['consecutive_nans_max'], save_figures=False)
178+
firing_fields.find_fields_candidates(p['min_spikes'], p['min_peak_firing_rate'], p['firing_rate_threshold'],
179+
p['peak_prominence_threshold'])
180+
181+
path_arrow_color = "#D65F5F"
182+
field_arrow_color = "#D65F5F"
176183

177184
for field_num, firing_rates in enumerate(firing_fields.smooth_rate_maps):
178185
normalized_rates = firing_rates[0] / np.nanmax(firing_rates[0])
179-
ax[1].plot(normalized_rates, firing_fields.positions, color=colors[field_num])
180-
181-
ax[1].axvline(-0.2, color='gray')
182-
ax[1].axvline(0, color='gray')
186+
ax[1].plot(normalized_rates, firing_fields.positions, color='C0')
187+
field_bounds = firing_fields.cand_bounds[field_num*2]
188+
ax[1].axhline(field_bounds[0], color='C7', linestyle='dotted', zorder=0)
189+
ax[1].axhline(field_bounds[1], color='C7', linestyle='dotted', zorder=0)
190+
191+
arrow_x = 1.1
192+
ax[1].annotate('', (arrow_x, field_bounds[0]), xytext=(arrow_x, field_bounds[1]),
193+
arrowprops=dict(arrowstyle='<|-|>', shrinkA=0, shrinkB=0,
194+
facecolor=field_arrow_color, edgecolor=field_arrow_color))
195+
ax[1].annotate(f"{field_bounds[1] - field_bounds[0]:.0f}",
196+
(1.2, (field_bounds[0] + field_bounds[1]) / 2),
197+
color=field_arrow_color, verticalalignment='center')
198+
199+
# ax[1].axvline(-0.2, color='gray')
200+
# ax[1].axvline(0, color='gray')
201+
ax[1].set_xticks([])
202+
ax[1].set_yticks([125, 150, 175, 200, 225, 250, 275])
183203

184204
# fig.tight_layout(pad=2, w_pad=5)
185205
fig.savefig(f"figures/BD_sweep {datetime.now().strftime('%Y-%m-%d %H:%M:%S')}.pdf", bbox_inches='tight')

analyze/fields/Demo.Position.pkl

-791 Bytes
Binary file not shown.

analyze/fields/Demo.PositionDemo.pkl

-791 Bytes
Binary file not shown.

analyze/fields/Demo.Time.pkl

-791 Bytes
Binary file not shown.

analyze/fields/Demo.TimeDemo.pkl

-791 Bytes
Binary file not shown.
-12.5 KB
Binary file not shown.
1.59 KB
Binary file not shown.
2 KB
Binary file not shown.

analyze/parameters/paper.json

+59
Original file line numberDiff line numberDiff line change
@@ -200,6 +200,29 @@
200200
"exponential_factor": -0.025
201201
},
202202

203+
"VariableSpikes|VariableNoiseVanilla":
204+
{
205+
"num_cells": 20,
206+
"ds": 1.0,
207+
"dt": 0.002,
208+
"phase_range": [0, 360],
209+
"phase_current": 180,
210+
"firing_rate_0": 15,
211+
"firing_rate_slope": 0.2,
212+
"theta_modulation": 0.35,
213+
"fields_from": "characteristic_speed",
214+
"theta_d_slope": 0,
215+
"theta_d_offset": 30,
216+
"theta_d_min": 0,
217+
"theta_d_add_sigma": 0,
218+
"theta_d_mul_sigma": 0,
219+
"size_to_theta_d": 0.23,
220+
"size_min": 3,
221+
"size_add_sigma": 0,
222+
"phase_sigma_0": 120,
223+
"exponential_factor": -0.025
224+
},
225+
203226
"SpeedSpikes|SpeedDep57":
204227
{
205228
"num_cells": 20,
@@ -218,6 +241,24 @@
218241
"shift_sigma": 0
219242
},
220243

244+
"SpeedSpikes|SpeedDepVanilla":
245+
{
246+
"num_cells": 20,
247+
"ds": 1.0,
248+
"dt": 0.002,
249+
"phase_range": [0, 360],
250+
"phase_current": 180,
251+
"firing_rate_0": 15,
252+
"firing_rate_slope": 0.2,
253+
"theta_modulation": 0.35,
254+
"theta_time": 0.57,
255+
"multiplicative_sigma": 0.0,
256+
"additive_sigma": 0.0,
257+
"size_to_theta_d": 0.3,
258+
"size_min": 4,
259+
"shift_sigma": 0
260+
},
261+
221262
"SpeedSpikes|BDSweepDemo":
222263
{
223264
"num_cells": 6,
@@ -234,5 +275,23 @@
234275
"size_to_theta_d": 0.25,
235276
"size_min": 3,
236277
"shift_sigma": 0
278+
},
279+
280+
"SpeedSpikes|BDSweepDemoRevision":
281+
{
282+
"num_cells": 6,
283+
"ds": 1.0,
284+
"dt": 0.002,
285+
"phase_range": [0, 360],
286+
"phase_current": 180,
287+
"firing_rate_0": 15,
288+
"firing_rate_slope": 0.2,
289+
"theta_modulation": 0.35,
290+
"theta_time": 0.5,
291+
"multiplicative_sigma": 0,
292+
"additive_sigma": 0,
293+
"size_to_theta_d": 0,
294+
"size_min": 6,
295+
"shift_sigma": 0
237296
}
238297
}

analyze/run_cell_coordination.py

+1-1
Original file line numberDiff line numberDiff line change
@@ -7,7 +7,7 @@ def run_cell_coordination(cell_coordination):
77
print("Analyzing cell coordination...")
88
p = general_parameters['CellCoordination']
99

10-
cell_coordination.full_histograms()
10+
# cell_coordination.full_histograms()
1111
cell_coordination.coordination_by_speed(speed_groups, num_phase_bins=p['num_phase_bins'],
1212
sample_size=p['sample_size'])
1313

analyze/run_decoder.py

+2-3
Original file line numberDiff line numberDiff line change
@@ -31,9 +31,8 @@ def run_path_lengths(path_lengths):
3131

3232
path_lengths.single_cycles(min_peak_prob=p['min_peak_prob'], min_phase_coverage=p['min_phase_coverage'],
3333
min_phase_extent=p['min_phase_extent'], radon_fit_params=p['radon_fit_params'],
34-
max_cycles_to_plot=128,
35-
# max_cycles_to_plot=0,
36-
from_run_types=(1, 1), cycles_per_figure=(8, 8), cycles_fig_size=(9.7*cm, 9*cm))
34+
max_cycles_to_plot=128, from_run_types=(1, 1), cycles_per_figure=(8, 8),
35+
cycles_fig_size=(9.7*cm, 9*cm))
3736

3837
# if path_lengths.group_name == experimental_group_name:
3938
# # print("NO displacement compensation:")

analyze/run_firing_fields.py

+3-5
Original file line numberDiff line numberDiff line change
@@ -7,17 +7,15 @@ def run_firing_fields(firing_fields):
77
print("Calculating place fields...")
88
p = {**general_parameters['ALL'], **general_parameters['FiringFields']}
99

10-
# firing_fields.plot_traces(field_nums=(0, 1, 2))
10+
# # firing_fields.plot_traces(field_nums=(0, 1, 2))
1111
firing_fields.plot_heatmap()
1212

1313
firing_fields.field_sizes_by_speed(speed_groups=speed_groups, min_peak_firing_rate=p['min_peak_firing_rate'],
1414
threshold=p['firing_rate_threshold'],
1515
peak_prominence_threshold=p['peak_prominence_threshold'],
16-
min_occupancy=p['min_occupancy'],
17-
min_spread=p['min_spread'],
18-
plot_fields=False,
16+
min_occupancy=p['min_occupancy'], min_spread=p['min_spread'],
1917
# plot_fields=True, field_nums=(22, 9, 10), fields_per_plot=3,
20-
# fig_size=(6*cm, 10*cm), constrained_layout=True
18+
fig_size=(6.5*cm, 10*cm), constrained_layout=True
2119
)
2220

2321
firing_fields.field_sizes_vs_stuff(plot=True)

analyze/run_phase_vs_position.py

+4-6
Original file line numberDiff line numberDiff line change
@@ -22,11 +22,8 @@ def run_phase_vs_position(phase_vs_position):
2222
print(0)
2323
phase_vs_position.pool_all(full_speed_groups=speed_groups, fit_type=p['fit_type'], min_spikes=p['pooled_min_spikes'],
2424
pool_by_pass_speed=False, spike_speed_threshold=False, min_occupancy=p['min_occupancy'],
25-
min_spread=p['min_spread'], plot_fits=True, plot_occupancy=True,
26-
fig_size=(12, 9),
25+
min_spread=p['min_spread'], plot_fits=True, plot_occupancy=True, fig_size=(18*cm, 13*cm),
2726
# fields_per_plot=3, field_nums=(8, 20, 22), fig_size=(7.8*cm, 10.1*cm), constrained_layout=0
28-
# fields_per_plot=4, field_nums=(1, 6, 11, 16), fig_size=(8.5*cm, 10.1*cm), constrained_layout=0
29-
# fields_per_plot=4, field_nums=(5, 22, 24, 26), fig_size=(8.5 * cm, 10.1 * cm), constrained_layout=0
3027
)
3128

3229
# single passes for one field
@@ -50,7 +47,7 @@ def run_phase_vs_position(phase_vs_position):
5047

5148
if __name__ == '__main__':
5249
# session = "ec013.156"
53-
session = "ec013.454" # fields 4 and 16 nice for single passes
50+
session = "ec013.454" # fields 4 and 16 nice for single passes; also nice for comparing to variable noise model
5451
# session = "ec013.395"
5552
# session = "ec014.468" # fields 8, 20, 22 nice for pooled at different speed bins
5653
# session = "ec014.639"
@@ -60,10 +57,11 @@ def run_phase_vs_position(phase_vs_position):
6057
# session = "Buddy.06272013"
6158
# session = "Cicero.09172014"
6259

63-
group_name = experimental_group_name
60+
# group_name = experimental_group_name
6461
# group_name = "SpeedDepSharp"
6562
# group_name = "Time"
6663
# group_name = "VariableNoise3"
64+
group_name = "VariableNoiseVanilla"
6765

6866
# with open(f"fields/{session}.{group_name}.pkl", 'rb') as fields_file:
6967
# fields = pickle.load(fields_file)['complete_fields']

analyze/run_tracking.py

+2-1
Original file line numberDiff line numberDiff line change
@@ -20,14 +20,15 @@ def run_tracking(tracking):
2020

2121
if __name__ == '__main__':
2222

23+
session = "ec013.156"
2324
# session = "ec013.388"
2425
# session = "ec013.395"
2526
# session = "ec013.412"
2627
# session = "ec014.468"
2728
# session = "ec014.639"
2829
# session = "ec016.233"
2930

30-
session = "vvp01.1815"
31+
# session = "vvp01.1815"
3132
# session = "gor01.1216"
3233

3334
# session = "Achilles.10252013_alt"

analyze/test_lfp.py

+4-4
Original file line numberDiff line numberDiff line change
@@ -9,8 +9,8 @@
99
# session = "ec014.468"
1010
# session = "ec014.639"
1111
# session = "ec016.233"
12-
session = "Buddy.06272013"
13-
# session = "Achilles.10252013"
12+
# session = "Buddy.06272013"
13+
session = "Achilles.10252013"
1414
# session = "Gatsby.08022013"
1515

1616
p = general_parameters['LFP']
@@ -36,8 +36,8 @@
3636
lfp.calculate_phase_locking(data_path, s['dataset'], s['session_set'], s['session'], s['discarded_intervals'], plot=True)
3737
lfp.comp_instantaneous_frequency()
3838

39-
lfp.plot(time_interval=(0, 500), channels=[0])
39+
# lfp.plot(time_interval=(0, 500), channels=[0])
4040
# lfp.plot(time_interval=(17079.2, 17300), channels=[24]) # Gatsby
41-
# lfp.plot(time_interval=(18080, 182000), channels=[0]) # Achilles
41+
lfp.plot(time_interval=(18080, 182000), channels=[0]) # Achilles
4242

4343
plt.show()

0 commit comments

Comments
 (0)