diff options
author | Josh Blum <josh@joshknows.com> | 2010-01-12 14:43:43 -0800 |
---|---|---|
committer | Josh Blum <josh@joshknows.com> | 2010-01-12 14:43:43 -0800 |
commit | cbb8e474bb5592753a340ba31d3afbab7226f7c6 (patch) | |
tree | 6dd14d37d8d46f3a506a309f57d82ed1ed05f781 /test | |
parent | 4e94574aeaa46c671bba0a6fc83cb967d228c880 (diff) | |
download | uhd-cbb8e474bb5592753a340ba31d3afbab7226f7c6.tar.gz uhd-cbb8e474bb5592753a340ba31d3afbab7226f7c6.tar.bz2 uhd-cbb8e474bb5592753a340ba31d3afbab7226f7c6.zip |
Reorganized structure into include, lib, test, firmware, fpga.
The fpga and firmware are empty placeholders for now.
Diffstat (limited to 'test')
-rw-r--r-- | test/.gitignore | 3 | ||||
-rw-r--r-- | test/Makefile.am | 20 | ||||
-rw-r--r-- | test/wax_test.cpp | 81 |
3 files changed, 104 insertions, 0 deletions
diff --git a/test/.gitignore b/test/.gitignore new file mode 100644 index 000000000..3d6649c66 --- /dev/null +++ b/test/.gitignore @@ -0,0 +1,3 @@ +/Makefile +/Makefile.in +/wax_test diff --git a/test/Makefile.am b/test/Makefile.am new file mode 100644 index 000000000..3373d838c --- /dev/null +++ b/test/Makefile.am @@ -0,0 +1,20 @@ +# +# Copyright 2010 Ettus Research LLC +# + +include $(top_srcdir)/Makefile.common + +SUBDIRS = + +AM_CPPFLAGS = $(GENERAL_CPPFLAGS) + +LDADD = \ + $(GENERAL_LDDFLAGS) + $(USRP_UHD_LA) + +noinst_PROGRAMS = \ + wax_test + +wax_test_SOURCES = wax_test.cpp + +TESTS = $(noinst_PROGRAMS) diff --git a/test/wax_test.cpp b/test/wax_test.cpp new file mode 100644 index 000000000..88c9e0f32 --- /dev/null +++ b/test/wax_test.cpp @@ -0,0 +1,81 @@ +// +// Copyright 2010 Ettus Research LLC +// + +#include <usrp_uhd/wax.hpp> +#include <iostream> +#include <stdexcept> +#include <vector> +#include <boost/assert.hpp> + +class wax_demo : public wax::obj{ +private: + std::vector<float> d_nums; + std::vector<wax_demo> d_subs; +public: + wax_demo(size_t sub_demos, size_t len){ + d_nums = std::vector<float>(len); + if (sub_demos != 0){ + for (size_t i = 0; i < len; i++){ + d_subs.push_back(wax_demo(sub_demos-1, len)); + } + } + } + ~wax_demo(void){ + /* NOP */ + } + void get(const wax::type &key, wax::type &value){ + if (d_subs.size() == 0){ + value = d_nums[wax::cast<size_t>(key)]; + }else{ + value = obj::cast(&d_subs[wax::cast<size_t>(key)]); + } + } + void set(const wax::type &key, const wax::type &value){ + if (d_subs.size() == 0){ + d_nums[wax::cast<size_t>(key)] = wax::cast<float>(value); + }else{ + throw std::runtime_error("cant set to a wax demo with sub demos"); + } + } +}; + +#define transform(i, j, k) float(i * j * k + i + j + k); + +int main(void){ + try{ + wax_demo wd(2, 10); + //test chained access + std::cout << "chain 1" << std::endl; + wd[size_t(0)]; + std::cout << "chain 2" << std::endl; + wd[size_t(0)][size_t(0)]; + std::cout << "chain 3" << std::endl; + wd[size_t(0)][size_t(0)][size_t(0)]; + //set a bunch of values + std::cout << "set and get all" << std::endl; + for (size_t i = 0; i < 10; i++){ + for (size_t j = 0; j < 10; j++){ + for (size_t k = 0; k < 10; k++){ + float val = transform(i, j, k); + //std::cout << i << " " << j << " " << k << std::endl; + wd[i][j][k] = val; + BOOST_ASSERT(wax::cast<float>(wd[i][j][k]) == val); + } + } + } + //test storing a proxy + std::cout << "store proxy" << std::endl; + wax::proxy p = wd[size_t(0)][size_t(0)]; + p[size_t(0)] = float(5); + //test printing a type + std::cout << "print type" << std::endl; + wax::type test_type = float(3.33); + std::cout << test_type << std::endl; + std::cout << "done" << std::endl; + }catch(std::exception const& e){ + std::cout << "Exception: " << e.what() << std::endl; + return ~0; + } + return 0; +} |