summaryrefslogtreecommitdiff
path: root/gr-fec/include/gnuradio/fec/ccsds_encoder.h
diff options
context:
space:
mode:
Diffstat (limited to 'gr-fec/include/gnuradio/fec/ccsds_encoder.h')
-rw-r--r--gr-fec/include/gnuradio/fec/ccsds_encoder.h154
1 files changed, 76 insertions, 78 deletions
diff --git a/gr-fec/include/gnuradio/fec/ccsds_encoder.h b/gr-fec/include/gnuradio/fec/ccsds_encoder.h
index f482ad90f7..4eca78084e 100644
--- a/gr-fec/include/gnuradio/fec/ccsds_encoder.h
+++ b/gr-fec/include/gnuradio/fec/ccsds_encoder.h
@@ -30,88 +30,86 @@
#include <string>
namespace gr {
- namespace fec {
- namespace code {
+namespace fec {
+namespace code {
- /*!
- * \brief CCSDS Encoding class for convolutional encoding with
- * rate 1/2, K=7, and polynomials [109, 79].
- * \ingroup error_coding_blk
- *
- * \details
- *
- * Uses Phil Karn's (KA9Q) implementation of the CCSDS encoder
- * for rate 1/2, K=7, and CC polynomial [109, 79]. These are
- * non-adjustable in this encoder. For an adjustable CC encoder
- * where we can set the rate, constraint length, and polynomial,
- * see gr::fec::code::cc_encoder.
- *
- * The encoder is set up with a number of bits per frame in the
- * constructor. When not being used in a tagged stream mode,
- * this encoder will only process frames of the length provided
- * here. If used in a tagged stream block, this setting becomes
- * the maximum allowable frame size that the block may process.
- *
- * The \p mode is a cc_mode_t that specifies how the convolutional
- * encoder will behave and under what conditions.
- *
- * \li 'CC_STREAMING': mode expects an uninterrupted flow of
- * samples into the encoder, and the output stream is
- * continually encoded.
- *
- * \li 'CC_TERMINATED': is a mode designed for packet-based
- * systems. This mode adds rate*(k-1) bits to the output as a
- * way to help flush the decoder.
- *
- * \li 'CC_TAILBITING': is another packet-based method. Instead of
- * adding bits onto the end of the packet, this mode will
- * continue the code between the payloads of packets by
- * pre-initializing the state of the new packet based on the
- * state of the last packet for (k-1) bits.
- *
- * \li 'CC_TRUNCATED': a truncated code always resets the registers
- * to the \p start_state between frames.
- *
- * A common convolutional encoder uses K=7, Rate=1/2,
- * Polynomials=[109, 79]. This is the Voyager code from NASA:
- * \li 109: b(1101101) --> 1 + x + x^3 + x^4 + x^6
- * \li 79: b(1001111) --> 1 + x^3 + x^4 + x^5 + x^6
- */
- class FEC_API ccsds_encoder : virtual public generic_encoder
- {
- public:
-
- /*!
- * Build the CCSDS (rate=1/2, K=7, polys=[109,79]
- * convolutional code FECAPI object.
- *
- * \param frame_size Number of bits per frame. If using in the
- * tagged stream style, this is the maximum allowable
- * number of bits per frame.
- * \param start_state Initialization state of the shift register.
- * \param mode cc_mode_t mode of the encoding.
- */
- static generic_encoder::sptr make
- (int frame_size, int start_state = 0,
- cc_mode_t mode=CC_STREAMING);
+/*!
+ * \brief CCSDS Encoding class for convolutional encoding with
+ * rate 1/2, K=7, and polynomials [109, 79].
+ * \ingroup error_coding_blk
+ *
+ * \details
+ *
+ * Uses Phil Karn's (KA9Q) implementation of the CCSDS encoder
+ * for rate 1/2, K=7, and CC polynomial [109, 79]. These are
+ * non-adjustable in this encoder. For an adjustable CC encoder
+ * where we can set the rate, constraint length, and polynomial,
+ * see gr::fec::code::cc_encoder.
+ *
+ * The encoder is set up with a number of bits per frame in the
+ * constructor. When not being used in a tagged stream mode,
+ * this encoder will only process frames of the length provided
+ * here. If used in a tagged stream block, this setting becomes
+ * the maximum allowable frame size that the block may process.
+ *
+ * The \p mode is a cc_mode_t that specifies how the convolutional
+ * encoder will behave and under what conditions.
+ *
+ * \li 'CC_STREAMING': mode expects an uninterrupted flow of
+ * samples into the encoder, and the output stream is
+ * continually encoded.
+ *
+ * \li 'CC_TERMINATED': is a mode designed for packet-based
+ * systems. This mode adds rate*(k-1) bits to the output as a
+ * way to help flush the decoder.
+ *
+ * \li 'CC_TAILBITING': is another packet-based method. Instead of
+ * adding bits onto the end of the packet, this mode will
+ * continue the code between the payloads of packets by
+ * pre-initializing the state of the new packet based on the
+ * state of the last packet for (k-1) bits.
+ *
+ * \li 'CC_TRUNCATED': a truncated code always resets the registers
+ * to the \p start_state between frames.
+ *
+ * A common convolutional encoder uses K=7, Rate=1/2,
+ * Polynomials=[109, 79]. This is the Voyager code from NASA:
+ * \li 109: b(1101101) --> 1 + x + x^3 + x^4 + x^6
+ * \li 79: b(1001111) --> 1 + x^3 + x^4 + x^5 + x^6
+ */
+class FEC_API ccsds_encoder : virtual public generic_encoder
+{
+public:
+ /*!
+ * Build the CCSDS (rate=1/2, K=7, polys=[109,79]
+ * convolutional code FECAPI object.
+ *
+ * \param frame_size Number of bits per frame. If using in the
+ * tagged stream style, this is the maximum allowable
+ * number of bits per frame.
+ * \param start_state Initialization state of the shift register.
+ * \param mode cc_mode_t mode of the encoding.
+ */
+ static generic_encoder::sptr
+ make(int frame_size, int start_state = 0, cc_mode_t mode = CC_STREAMING);
- /*!
- * Sets the uncoded frame size to \p frame_size. If \p
- * frame_size is greater than the value given to the
- * constructor, the frame size will be capped by that initial
- * value and this function will return false. Otherwise, it
- * returns true.
- */
- virtual bool set_frame_size(unsigned int frame_size) = 0;
+ /*!
+ * Sets the uncoded frame size to \p frame_size. If \p
+ * frame_size is greater than the value given to the
+ * constructor, the frame size will be capped by that initial
+ * value and this function will return false. Otherwise, it
+ * returns true.
+ */
+ virtual bool set_frame_size(unsigned int frame_size) = 0;
- /*!
- * Returns the coding rate of this encoder.
- */
- virtual double rate() = 0;
- };
+ /*!
+ * Returns the coding rate of this encoder.
+ */
+ virtual double rate() = 0;
+};
- } /* namespace code */
- } /* namespace fec */
+} /* namespace code */
+} /* namespace fec */
} /* namespace gr */
#endif /* INCLUDED_FEC_CCSDS_ENCODER_H */