本文整理汇总了C++中InvalidArgument函数的典型用法代码示例。如果您正苦于以下问题:C++ InvalidArgument函数的具体用法?C++ InvalidArgument怎么用?C++ InvalidArgument使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了InvalidArgument函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: checkSupported
FXImage *
MFXImageHelper::loadImage(FXApp *a, const std::string& file) {
FXString ext=FXPath::extension(file.c_str());
checkSupported(ext);
FXImage *img=NULL;
if (comparecase(ext,"gif")==0) {
img=new FXGIFImage(a,NULL,IMAGE_KEEP|IMAGE_SHMI|IMAGE_SHMP);
} else if (comparecase(ext,"bmp")==0) {
img=new FXBMPImage(a,NULL,IMAGE_KEEP|IMAGE_SHMI|IMAGE_SHMP);
} else if (comparecase(ext,"xpm")==0) {
img=new FXXPMImage(a,NULL,IMAGE_KEEP|IMAGE_SHMI|IMAGE_SHMP);
} else if (comparecase(ext,"pcx")==0) {
img=new FXPCXImage(a,NULL,IMAGE_KEEP|IMAGE_SHMI|IMAGE_SHMP);
} else if (comparecase(ext,"ico")==0 || comparecase(ext,"cur")==0) {
img=new FXICOImage(a,NULL,IMAGE_KEEP|IMAGE_SHMI|IMAGE_SHMP);
} else if (comparecase(ext,"tga")==0) {
img=new FXTGAImage(a,NULL,IMAGE_KEEP|IMAGE_SHMI|IMAGE_SHMP);
} else if (comparecase(ext,"rgb")==0) {
img=new FXRGBImage(a,NULL,IMAGE_KEEP|IMAGE_SHMI|IMAGE_SHMP);
} else if (comparecase(ext,"xbm")==0) {
img=new FXXBMImage(a,NULL,NULL,IMAGE_KEEP|IMAGE_SHMI|IMAGE_SHMP);
} else if (comparecase(ext,"png")==0) {
img=new FXPNGImage(a,NULL,IMAGE_KEEP|IMAGE_SHMI|IMAGE_SHMP);
} else if (comparecase(ext,"jpg")==0 || comparecase(ext,"jpeg")==0) {
img=new FXJPGImage(a,NULL,IMAGE_KEEP|IMAGE_SHMI|IMAGE_SHMP);
} else if (comparecase(ext,"tif")==0 || comparecase(ext,"tiff")==0) {
img=new FXTIFImage(a,NULL,IMAGE_KEEP|IMAGE_SHMI|IMAGE_SHMP);
} else {
throw InvalidArgument("Unknown file extension for image '" + file + "'!");
}
FXFileStream stream;
if (img != NULL && stream.open(file.c_str(), FXStreamLoad)) {
a->beginWaitCursor();
img->loadPixels(stream);
stream.close();
img->create();
a->endWaitCursor();
} else {
throw InvalidArgument("Loading failed!");
}
return img;
}
示例2: switch
bool
GNEDetectorE2::isValid(SumoXMLAttr key, const std::string& value) {
switch (key) {
case SUMO_ATTR_ID:
return isValidDetectorID(value);
case SUMO_ATTR_LANE:
if (value.empty()) {
return false;
} else {
return canParse<std::vector<GNELane*> >(myViewNet->getNet(), value, false);
}
case SUMO_ATTR_LANES:
if (value.empty()) {
return false;
} else if (canParse<std::vector<GNELane*> >(myViewNet->getNet(), value, false)) {
// check if lanes are consecutives
return lanesConsecutives(parse<std::vector<GNELane*> >(myViewNet->getNet(), value));
} else {
return false;
}
case SUMO_ATTR_POSITION:
return canParse<double>(value);
case SUMO_ATTR_ENDPOS:
return canParse<double>(value);
case SUMO_ATTR_FREQUENCY:
return (canParse<double>(value) && (parse<double>(value) >= 0));
case SUMO_ATTR_LENGTH:
return (canParse<double>(value) && (parse<double>(value) >= 0));
case SUMO_ATTR_NAME:
return SUMOXMLDefinitions::isValidAttribute(value);
case SUMO_ATTR_FILE:
return SUMOXMLDefinitions::isValidFilename(value);
case SUMO_ATTR_VTYPES:
if (value.empty()) {
return true;
} else {
return SUMOXMLDefinitions::isValidListOfTypeID(value);
}
case SUMO_ATTR_HALTING_TIME_THRESHOLD:
return (canParse<double>(value) && (parse<double>(value) >= 0));
case SUMO_ATTR_HALTING_SPEED_THRESHOLD:
return (canParse<double>(value) && (parse<double>(value) >= 0));
case SUMO_ATTR_JAM_DIST_THRESHOLD:
return (canParse<double>(value) && (parse<double>(value) >= 0));
case SUMO_ATTR_FRIENDLY_POS:
return canParse<bool>(value);
case GNE_ATTR_BLOCK_MOVEMENT:
return canParse<bool>(value);
case GNE_ATTR_SELECTED:
return canParse<bool>(value);
case GNE_ATTR_GENERIC:
return isGenericParametersValid(value);
default:
throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
}
}
示例3: InvalidArgument
void Dictionary::Add(const Dictionary& other)
{
for (auto& kv : *(other.m_dictionaryData))
{
if (Contains(kv.first))
InvalidArgument("Dictionary::Add: This dictionary already contains an entry with key %S that is being attempted to add from the 'other' dictionary", kv.first.c_str());
(*this)[kv.first] = kv.second;
}
}
示例4: throw
MSLane *
NLDetectorBuilder::getLaneChecking(const std::string &id,
const std::string &detid) throw(InvalidArgument) {
// get and check the lane
MSLane *clane = MSLane::dictionary(id);
if (clane==0) {
throw InvalidArgument("The lane with the id '" + id + "' is not known (while building detector '" + detid + "').");
}
return clane;
}
示例5: InvalidArgument
std::pair<SUMOReal, SUMOReal>
GeomHelper::getNormal90D_CW(const Position& beg,
const Position& end,
SUMOReal length, SUMOReal wanted_offset) {
if (beg == end) {
throw InvalidArgument("same points at " + toString(beg));
}
return std::pair<SUMOReal, SUMOReal>
((beg.y() - end.y()) * wanted_offset / length, (end.x() - beg.x()) * wanted_offset / length);
}
示例6: MSBusStop
void
NLTriggerBuilder::buildBusStop(MSNet& net, const std::string& id,
const std::vector<std::string>& lines,
MSLane* lane, SUMOReal frompos, SUMOReal topos) {
MSBusStop* stop = new MSBusStop(id, lines, *lane, frompos, topos);
if (!net.addBusStop(stop)) {
delete stop;
throw InvalidArgument("Could not build bus stop '" + id + "'; probably declared twice.");
}
}
示例7: InvalidArgument
void
NLDetectorBuilder::createEdgeLaneMeanData(const std::string& id, SUMOTime frequency,
SUMOTime begin, SUMOTime end, const std::string& type,
const bool useLanes, const bool withEmpty, const bool printDefaults,
const bool withInternal, const bool trackVehicles,
const double maxTravelTime, const double minSamples,
const double haltSpeed, const std::string& vTypes,
const std::string& device) {
if (begin < 0) {
throw InvalidArgument("Negative begin time for meandata dump '" + id + "'.");
}
if (end < 0) {
end = SUMOTime_MAX;
}
if (end <= begin) {
throw InvalidArgument("End before or at begin for meandata dump '" + id + "'.");
}
MSMeanData* det = 0;
if (type == "" || type == "performance" || type == "traffic") {
det = new MSMeanData_Net(id, begin, end, useLanes, withEmpty,
printDefaults, withInternal, trackVehicles, maxTravelTime, minSamples, haltSpeed, vTypes);
} else if (type == "emissions" || type == "hbefa") {
if (type == "hbefa") {
WRITE_WARNING("The netstate type 'hbefa' is deprecated. Please use the type 'emissions' instead.");
}
det = new MSMeanData_Emissions(id, begin, end, useLanes, withEmpty,
printDefaults, withInternal, trackVehicles, maxTravelTime, minSamples, vTypes);
} else if (type == "harmonoise") {
det = new MSMeanData_Harmonoise(id, begin, end, useLanes, withEmpty,
printDefaults, withInternal, trackVehicles, maxTravelTime, minSamples, vTypes);
} else if (type == "amitran") {
det = new MSMeanData_Amitran(id, begin, end, useLanes, withEmpty,
printDefaults, withInternal, trackVehicles, maxTravelTime, minSamples, haltSpeed, vTypes);
} else {
throw InvalidArgument("Invalid type '" + type + "' for meandata dump '" + id + "'.");
}
if (det != 0) {
if (frequency < 0) {
frequency = end - begin;
}
MSNet::getInstance()->getDetectorControl().add(det, device, frequency, begin);
}
}
示例8: throw
bool
Option_Float::set(const std::string &v) throw(InvalidArgument) {
try {
myValue = TplConvert<char>::_2SUMOReal(v.c_str());
return markSet();
} catch (...) {
std::string s = "'" + v + "' is not a valid float (should be).";
throw InvalidArgument(s);
}
}
示例9: buildEdge
void
NLEdgeControlBuilder::beginEdgeParsing(
const std::string& id, const MSEdge::EdgeBasicFunction function,
const std::string& streetName) {
myActiveEdge = buildEdge(id, function, streetName);
if (MSEdge::dictionary(id) != 0) {
throw InvalidArgument("Another edge with the id '" + id + "' exists.");
}
myEdges.push_back(myActiveEdge);
}
示例10: NDArrayView
NDArrayView::NDArrayView(const NDShape& viewShape, const SparseIndexType* colStarts, const SparseIndexType* rowIndices, const ElementType* nonZeroValues, size_t numNonZeroValues, const DeviceDescriptor& device, bool readOnly/* = false*/)
: NDArrayView(AsDataType<ElementType>(), device, StorageFormat::SparseCSC, viewShape, false, AllocateTensorView<ElementType>(viewShape, StorageFormat::SparseCSC, device))
{
if ((colStarts == nullptr) || (rowIndices == nullptr) || (nonZeroValues == nullptr) || (numNonZeroValues == 0) || (numNonZeroValues > viewShape.TotalSize()))
InvalidArgument("Invalid sparse CSC format initial data specified for NDArrayView construction");
auto sparseMatrix = GetWritableMatrix<ElementType>(1);
sparseMatrix->SetMatrixFromCSCFormat(colStarts, rowIndices, nonZeroValues, numNonZeroValues, sparseMatrix->GetNumRows(), sparseMatrix->GetNumCols());
m_isReadOnly = readOnly;
}
示例11: InvalidArgument
/*virtual*/ void ScatterPackedNode<ElemType>::ForwardPropNonLooping() /*override*/
{
if (*Input(INDEXDATA)->GetMBLayout() != *Input(SOURCEDATA)->GetMBLayout())
InvalidArgument("%ls %ls operation requires the minibatch layout of index and source data to be the same.", NodeName().c_str(), OperationName().c_str());
Input(INDEXDATA)->MaskMissingValueColumnsTo(FrameRange(Input(INDEXDATA)->GetMBLayout()), -1); // indicates an invalid column to Gather/Scatter
let& index = Input(INDEXDATA)->Value(); // column indices to copy from
let& source = Input(SOURCEDATA)->Value(); // source data to copy
auto& output = Value(); // output goes here
output.DoScatterColumnsOf(/*beta=*/0, index, source, /*alpha=*/1);
}
示例12: InvalidArgument
void InvertibleRSAFunction::Initialize(const Integer &n, const Integer &e, const Integer &d)
{
if (n.IsEven() || e.IsEven() | d.IsEven())
throw InvalidArgument("InvertibleRSAFunction: input is not a valid RSA private key");
m_n = n;
m_e = e;
m_d = d;
Integer r = --(d*e);
unsigned int s = 0;
while (r.IsEven())
{
r >>= 1;
s++;
}
ModularArithmetic modn(n);
for (Integer i = 2; ; ++i)
{
Integer a = modn.Exponentiate(i, r);
if (a == 1)
continue;
Integer b;
unsigned int j = 0;
while (a != n-1)
{
b = modn.Square(a);
if (b == 1)
{
m_p = GCD(a-1, n);
m_q = n/m_p;
m_dp = m_d % (m_p-1);
m_dq = m_d % (m_q-1);
m_u = m_q.InverseMod(m_p);
return;
}
if (++j == s)
throw InvalidArgument("InvertibleRSAFunction: input is not a valid RSA private key");
a = b;
}
}
}
示例13: InvalidArgument
double Trainer::PreviousMinibatchEvaluationAverage() const
{
if (!m_evaluationFunction)
InvalidArgument("Trainer::PreviousMinibatchEvaluationAverage: Cannot get evaluation criterion value when no evaluation function was specified during 'this' trainer's construction");
if (m_prevMinibatchNumSamples == 0)
RuntimeError("There was no preceeding call to TrainMinibatch or the minibatch was empty.");
return m_prevMinibatchAggregateEvalCriterionValue->AsScalar<double>() / m_prevMinibatchNumSamples;
}
示例14: switch
bool
GNEPOI::isValid(SumoXMLAttr key, const std::string& value) {
switch (key) {
case SUMO_ATTR_ID:
return SUMOXMLDefinitions::isValidNetID(value) && (myNet->retrievePOI(value, false) == nullptr);
case SUMO_ATTR_COLOR:
return canParse<RGBColor>(value);
case SUMO_ATTR_LANE:
return (myNet->retrieveLane(value, false) != nullptr);
case SUMO_ATTR_POSITION:
if (getLaneParents().size() > 0) {
return canParse<double>(value);
} else {
return canParse<Position>(value);
}
case SUMO_ATTR_POSITION_LAT:
return canParse<double>(value);
case SUMO_ATTR_GEOPOSITION: {
return canParse<Position>(value);
}
case SUMO_ATTR_GEO:
return canParse<bool>(value);
case SUMO_ATTR_TYPE:
return true;
case SUMO_ATTR_LAYER:
if (value == "default") {
return true;
} else {
return canParse<double>(value);
}
case SUMO_ATTR_IMGFILE:
if (value == "") {
return true;
} else {
// check that image can be loaded
return GUITexturesHelper::getTextureID(value) != -1;
}
case SUMO_ATTR_RELATIVEPATH:
return canParse<bool>(value);
case SUMO_ATTR_WIDTH:
return canParse<double>(value) && (parse<double>(value) >= 0);
case SUMO_ATTR_HEIGHT:
return canParse<double>(value) && (parse<double>(value) >= 0);
case SUMO_ATTR_ANGLE:
return canParse<double>(value);
case GNE_ATTR_BLOCK_MOVEMENT:
return canParse<bool>(value);
case GNE_ATTR_SELECTED:
return canParse<bool>(value);
case GNE_ATTR_GENERIC:
return isGenericParametersValid(value);
default:
throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
}
}
示例15: throw
void
NLEdgeControlBuilder::beginEdgeParsing(const std::string &id,
MSEdge::EdgeBasicFunction function) throw(InvalidArgument) {
myActiveEdge = buildEdge(id);
if (!MSEdge::dictionary(id, myActiveEdge)) {
throw InvalidArgument("Another edge with the id '" + id + "' exists.");
}
myEdges.push_back(myActiveEdge);
m_pDepartLane = (MSLane*) 0;
m_Function = function;
}