CHANGELOG.md 5.11 KB
Newer Older
yanyan's avatar
yanyan committed
1
# Changelog
yan.yan's avatar
yan.yan committed
2
3
4
5
## [2.2.2] - 2022-9-25
### Fixed 
- Fix CI problem: main function too long and cause OOM in CI vm.

yan.yan's avatar
yan.yan committed
6
7
8
9
10
## [2.2.1] - 2022-9-25
### Fixed 
- Fix build problem
- Fix nvrtc problem

yan.yan's avatar
yan.yan committed
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
## [2.2.0] - 2022-9-24
### Added 
- Add Ampere support. faster fp16, faster tf32 and greatly faster int8 kernels in Ampere GPUs.
- Add pure c++ code generation (libspconv.so) for deploy (or train in another deeplearning framework)
- Add NVRTC support for all gemm kernels. if your GPU architecture isn't compiled in prebuilt, spconv will use slightly slower (10-20us overhead for every kernel launch) NVRTC kernels. 

### Fixed
- Fix launch fail in maxpool if too much voxels 

### Changed
- all weight layout will be KRSC, don't support old spconv 1.x weights anymore.
- previous gemm ops in ops.py now move to c++ by default (controlled by spconv.constants.SPCONV_CPP_GEMM)

### Removed
- drop python 3.6 support.
- pascal and kepler architecture is removed in CUDA 12 prebuilt.

yan.yan's avatar
yan.yan committed
28
29
30
## [2.1.22] - 2022-6-11
### Fixed
- Fix thrust problem by adding -fvisibility=hidden
yanyan's avatar
yanyan committed
31

yan.yan's avatar
sync  
yan.yan committed
32
33
34
35
36
## [2.1.22] - 2022-4-14
### Added
- add full nvrtc support
- add support for large spatial shape and batch size. if detect large shape, we use int64 instead of int32 when hashing.

yan.yan's avatar
yan.yan committed
37
38
39
40
## [2.1.21] - 2021-12-9
### Added
- add sm_37
- add fp16 kernels witl fp32 accumulator (run slower, but can avoid nan if channel size is too large)
yan.yan's avatar
yan.yan committed
41
- add SPCONV_BWD_SPLITK env to control splitk candidates.
yan.yan's avatar
yan.yan committed
42

43
44
45
46
## [2.1.20] - 2021-12-6
### Added
- Add fp16 conv simt kernels for mixed-training in pascal or older GPUS. WARNING: not optimized for TESLA P100 which has 2x throughput in half.

47
48
49
50
## [2.1.19] - 2021-12-3
### Fixed
- Fix wrong arch assert in all kernels for old GPUs to make spconv work in sm_50 GPUs

51
52
53
54
55
## [2.1.18] - 2021-11-29
### Fixed
- Fix a small bug of spatial_shape.
- Fix a bug in PointToVoxel, we must always return a clone instead of a view.

56
57
58
## [2.1.17] - 2021-11-29
### Fixed
- Fix a bug in sparse add.
yan.yan's avatar
yan.yan committed
59
- Fix a serious bug in conv weight init.
60
61
62
63
### Added
- Add more wrong usage check
- Add insert_exist_keys for hash table

yan.yan's avatar
yan.yan committed
64
65
66
67
## [2.1.16] - 2021-11-28
### Fixed
- Fix strange compile problem in windows

68
69
70
71
## [2.1.15] - 2021-11-28
### Fixed
- Fix missing pccm.Class in setup.py

72
73
74
75
76
77
78
79
## [2.1.14] - 2021-11-28
### Added 
- Add hash table
- update cumm version
- Add AddTableMisaligned for sptensors with same shape but different indices.
### Fixed
- Fix a bug already fixed in 2.1.10 but introduced in 2.1.12 again.

80
81
82
83
84
## [2.1.13] - 2021-?-?
### Added 
- Add some ops from spconv 1.x, see spconv.utils for more details.
- Add some debug tool for users to attach more info in issue.

85
86
87
88
89
90
## [2.1.12] - 2021-11-23
### Added 
- Add a method for voxel generator to get pc_voxel_id, which is usually used in semantic segmentation
### Fixed
- Fix a bug in cuda voxel generater when max_voxels is smaller than real number of voxels

91
92
93
94
95
96
## [2.1.11] - 2021-11-22
### Fixed
- Fixed a bug Volta kernels (TITAN V, Tesla V100), backward weight kernels use f16 as accumulator. we should use f32.
- Fixed a corner case when user use kernel size = 1x1 but stride != 1.
- Fixed a corner case when input feature is non-contiguous when maxpool.

yan.yan's avatar
yan.yan committed
97
98
99
100
101
102
103
104
## [2.1.10] - 2021-11-19
### Fixed
- Fixed a bug in utils.PointToVoxel, shouldn't get cuda stream in cpu code

## [2.1.9] - 2021-11-18
### Removed
- Remove a wrong assert

yan.yan's avatar
yan.yan committed
105
106
107
108
## [2.1.8] - 2021-11-15
### Added
- Add support for pytorch 1.5

109
110
111
112
## [2.1.7] - 2021-11-11
### Fixed
- Fix a bug when net have inverse and run inference in eval mode.

113
114
115
116
117
118
## [2.1.6] - 2021-11-10
### Fixed
- Fix missing -fopenmp in linker for CPU only
### Removed
- remove stale comment sending in CI

119
120
121
122
123
124
125
126
127
## [2.1.5] - 2021-11-10
### Added
- Add cuda profile tool
- Add python 36 support
### Changed
- Format all code
### Removed
- remove a unnecessary device sync and slightly improve performance.

128
129
130
131
132
133
134
135
136
137
138
139
## [2.1.4] - 2021-11-10
### Fixed
- Fix a bug of SparseInverseConv3d

## [2.1.3] - 2021-11-08
### Fixed
- Fix a bug of CPU only package

## [2.1.2] - 2021-11-06
### Fixed
- Fix a bug of python 3.7

yan.yan's avatar
v2.1  
yan.yan committed
140
## [2.1.0] - 2021-10-31
141
142
143
144
### Added
- add implicit gemm algorithm for all kind of convolution with kernel volume <= 32. this algorithm is very fast with float16.
- add pytorch wrapper for voxel generator
- add CPU support and CPU-only build.
yan.yan's avatar
v2.1  
yan.yan committed
145
146
147
148
149
150

## [2.0.2] - 2021-10-26
### Fixed
- Fix a serious bug that do nothing with non-spconv layers in SparseSequential
- Fix a bug of ProxyableClassMeta

yan.yan's avatar
yan.yan committed
151
152
153
154
155
156
## [2.0.0] - 2021-10-16
### Changed
- Change build system from cmake to pccm.
- Change pytorch python code to spconv.pytorch
- Rewrite All c++ code.

157
158
159
160
161
## [1.2.1] - 2020-06-04
### Changed
- The subm indice pair generation speed is greatly increased by two tricks: 1. most subm conv use only kernelsize=3, so we can unroll loops to get 100% performance increase. 2. subm indice pairs have a property: indicePairs[0, i] = indicePairs[1, kernelVolume - i - 1], so we can get another 100% performance increase. 


yanyan's avatar
yanyan committed
162
163
164
165
166
167
168
169
170
## [1.2.0] - 2020-05-28
### Added
- add batch gemm support. small performance increasement but more gpu memory usage. you can use algo=spconv.ConvAlgo.Batch to use it.

### Changed
- replace most of 'functor' with c++14 dispatch in c++ code.

### Fixed
- change gather/scatterAdd kernel parameter to support large points.