|
22 | 22 | import unittest |
23 | 23 | from datetime import datetime as dt |
24 | 24 |
|
| 25 | +import cftime |
25 | 26 | import geopandas as gpd |
26 | 27 | import numpy as np |
27 | 28 | import pandas as pd |
@@ -763,6 +764,116 @@ def test_subset(self): |
763 | 764 | tc_track = tc.TCTracks.from_ibtracs_netcdf(storm_id=storms) |
764 | 765 | self.assertEqual(tc_track.subset({"basin": "SP"}).size, 2) |
765 | 766 |
|
| 767 | + def test_subset_years(self): |
| 768 | + """Test that subset_years correctly select tracks between year min and year max.""" |
| 769 | + |
| 770 | + tc_test = tc.TCTracks.from_simulations_emanuel(TEST_TRACK_EMANUEL) |
| 771 | + for i in range(5): |
| 772 | + date = cftime.DatetimeProlepticGregorian( |
| 773 | + 2000 + i, 1 + i, 10 + i, 0, 0, 0, 0, has_year_zero=True |
| 774 | + ) |
| 775 | + tc_test.data[i]["time"] = np.full(tc_test.data[i].time.shape[0], date) |
| 776 | + |
| 777 | + # correct calling of the function |
| 778 | + tc_subset = tc_test.subset_year( |
| 779 | + start_date=(2000, False, False), end_date=(2003, False, False) |
| 780 | + ) |
| 781 | + self.assertEqual(len(tc_subset.data), 4) |
| 782 | + self.assertEqual(tc_subset.data[0].time[0].item().year, 2000) |
| 783 | + self.assertEqual(tc_subset.data[0].time[0].item().month, 1) |
| 784 | + self.assertEqual(tc_subset.data[1].time[0].item().year, 2001) |
| 785 | + self.assertEqual(tc_subset.data[1].time[0].item().month, 2) |
| 786 | + self.assertEqual(tc_subset.data[2].time[0].item().year, 2002) |
| 787 | + self.assertEqual(tc_subset.data[2].time[0].item().month, 3) |
| 788 | + self.assertEqual(tc_subset.data[3].time[0].item().year, 2003) |
| 789 | + self.assertEqual(tc_subset.data[3].time[0].item().month, 4) |
| 790 | + tc_subset = tc_test.subset_year( |
| 791 | + start_date=(2000, False, False), end_date=(2000, False, False) |
| 792 | + ) |
| 793 | + self.assertEqual(len(tc_subset.data), 1) |
| 794 | + self.assertEqual(tc_subset.data[0].time[0].item().month, 1) |
| 795 | + self.assertEqual(tc_subset.data[0].time[0].item().year, 2000) |
| 796 | + tc_subset = tc_test.subset_year( |
| 797 | + start_date=(False, 1, False), end_date=(False, 4, False) |
| 798 | + ) |
| 799 | + self.assertEqual(len(tc_subset.data), 4) |
| 800 | + self.assertEqual(tc_subset.data[0].time[0].item().year, 2000) |
| 801 | + self.assertEqual(tc_subset.data[0].time[0].item().month, 1) |
| 802 | + self.assertEqual(tc_subset.data[1].time[0].item().year, 2001) |
| 803 | + self.assertEqual(tc_subset.data[1].time[0].item().month, 2) |
| 804 | + self.assertEqual(tc_subset.data[2].time[0].item().year, 2002) |
| 805 | + self.assertEqual(tc_subset.data[2].time[0].item().month, 3) |
| 806 | + self.assertEqual(tc_subset.data[3].time[0].item().year, 2003) |
| 807 | + self.assertEqual(tc_subset.data[3].time[0].item().month, 4) |
| 808 | + tc_subset = tc_test.subset_year( |
| 809 | + start_date=(False, 3, False), end_date=(False, 3, False) |
| 810 | + ) |
| 811 | + self.assertEqual(len(tc_subset.data), 1) |
| 812 | + self.assertEqual(tc_subset.data[0].time[0].item().month, 3) |
| 813 | + self.assertEqual(tc_subset.data[0].time[0].item().year, 2002) |
| 814 | + tc_subset = tc_test.subset_year( |
| 815 | + start_date=(False, False, 11), end_date=(False, False, 14) |
| 816 | + ) |
| 817 | + self.assertEqual(len(tc_subset.data), 4) |
| 818 | + self.assertEqual(tc_subset.data[0].time[0].item().year, 2001) |
| 819 | + self.assertEqual(tc_subset.data[0].time[0].item().month, 2) |
| 820 | + self.assertEqual(tc_subset.data[1].time[0].item().year, 2002) |
| 821 | + self.assertEqual(tc_subset.data[1].time[0].item().month, 3) |
| 822 | + self.assertEqual(tc_subset.data[2].time[0].item().year, 2003) |
| 823 | + self.assertEqual(tc_subset.data[2].time[0].item().month, 4) |
| 824 | + self.assertEqual(tc_subset.data[3].time[0].item().year, 2004) |
| 825 | + self.assertEqual(tc_subset.data[3].time[0].item().month, 5) |
| 826 | + tc_subset = tc_test.subset_year( |
| 827 | + start_date=(False, False, 10), end_date=(False, False, 10) |
| 828 | + ) |
| 829 | + self.assertEqual(len(tc_subset.data), 1) |
| 830 | + self.assertEqual(tc_subset.data[0].time[0].item().month, 1) |
| 831 | + self.assertEqual(tc_subset.data[0].time[0].item().year, 2000) |
| 832 | + tc_subset = tc_test.subset_year( |
| 833 | + start_date=(2000, 1, 10), end_date=(2000, 1, 13) |
| 834 | + ) |
| 835 | + self.assertEqual(len(tc_subset.data), 1) |
| 836 | + self.assertEqual(tc_subset.data[0].time[0].item().month, 1) |
| 837 | + self.assertEqual(tc_subset.data[0].time[0].item().year, 2000) |
| 838 | + tc_subset = tc_test.subset_year( |
| 839 | + start_date=(2000, 1, 10), end_date=(2004, 9, 13) |
| 840 | + ) |
| 841 | + self.assertEqual(len(tc_subset.data), 4) |
| 842 | + self.assertEqual(tc_subset.data[0].time[0].item().year, 2000) |
| 843 | + self.assertEqual(tc_subset.data[0].time[0].item().month, 1) |
| 844 | + self.assertEqual(tc_subset.data[1].time[0].item().year, 2001) |
| 845 | + self.assertEqual(tc_subset.data[1].time[0].item().month, 2) |
| 846 | + self.assertEqual(tc_subset.data[2].time[0].item().year, 2002) |
| 847 | + self.assertEqual(tc_subset.data[2].time[0].item().month, 3) |
| 848 | + self.assertEqual(tc_subset.data[3].time[0].item().year, 2003) |
| 849 | + self.assertEqual(tc_subset.data[3].time[0].item().month, 4) |
| 850 | + |
| 851 | + # Invalid input: Mismatch between start_day and end_day |
| 852 | + with self.assertRaisesRegex( |
| 853 | + ValueError, |
| 854 | + "Mismatch between start_year and end_year: " |
| 855 | + "Both must be either True or False.", |
| 856 | + ): |
| 857 | + tc_test.subset_year((2000, False, False), (False, False, False)) |
| 858 | + with self.assertRaisesRegex( |
| 859 | + ValueError, |
| 860 | + "Mismatch between start_month and end_month: " |
| 861 | + "Both must be either True or False.", |
| 862 | + ): |
| 863 | + tc_test.subset_year((2000, False, False), (2000, 5, False)) |
| 864 | + with self.assertRaisesRegex( |
| 865 | + ValueError, |
| 866 | + "Mismatch between start_day and end_day: " |
| 867 | + "Both must be either True or False.", |
| 868 | + ): |
| 869 | + tc_test.subset_year((False, False, False), (False, False, 3)) |
| 870 | + with self.assertRaisesRegex(ValueError, "Start year is after end year."): |
| 871 | + tc_test.subset_year((2007, False, False), (2000, False, False)) |
| 872 | + with self.assertRaisesRegex( |
| 873 | + ValueError, "No tracks found for the specified date range" |
| 874 | + ): |
| 875 | + tc_test.subset_year((2100, False, False), (2150, False, False)) |
| 876 | + |
766 | 877 | def test_get_extent(self): |
767 | 878 | """Test extent/bounds attributes.""" |
768 | 879 | storms = ["1988169N14259", "2002073S16161", "2002143S07157"] |
|
0 commit comments